Add optional toggle for Relationship Status Fields (v2.1.2)

- Added relationships.enabled toggle in tracker configuration
- Relationship fields and emoji badges can now be disabled/enabled
- UI toggle added in Edit Trackers > Present Characters tab
- Updated prompt generation to respect the toggle
- Maintains backward compatibility with existing configs
- Added i18n translations (en, zh-tw)
This commit is contained in:
Spicy_Marinara
2026-01-03 00:55:29 +01:00
parent d44bb1cff9
commit c6b71ec1aa
8 changed files with 121 additions and 20 deletions
+8 -4
View File
@@ -325,8 +325,11 @@ export function renderThoughts() {
const enabledFields = config?.customFields?.filter(f => f && f.enabled && f.name) || [];
const characterStatsConfig = config?.characterStats;
const enabledCharStats = characterStatsConfig?.enabled && characterStatsConfig?.customStats?.filter(s => s && s.enabled && s.name) || [];
const relationshipFields = config?.relationshipFields || [];
const hasRelationshipEnabled = relationshipFields.length > 0;
// Check if relationships are enabled (new structure with fallback to legacy)
const relationshipsEnabled = config?.relationships?.enabled !== false; // Default to true if not set
const relationshipFields = relationshipsEnabled ? (config?.relationshipFields || []) : [];
const hasRelationshipEnabled = relationshipFields.length > 0 && relationshipsEnabled;
// Use committedTrackerData as fallback if lastGeneratedData is empty (e.g., after page refresh)
const characterThoughtsData = lastGeneratedData.characterThoughts || committedTrackerData.characterThoughts || '';
@@ -442,7 +445,8 @@ export function renderThoughts() {
}
// Get relationship emojis from config (with fallback defaults)
const relationshipEmojis = config?.relationshipEmojis || {
// Support both new and legacy structure
const relationshipEmojis = config?.relationships?.relationshipEmojis || config?.relationshipEmojis || {
'Enemy': '⚔️',
'Neutral': '⚖️',
'Friend': '⭐',
@@ -876,7 +880,7 @@ export function updateCharacterField(characterName, field, value) {
}
newCharacterLines.push(`Details: ${detailsParts.join(' | ')}`);
if (presentCharsConfig?.relationshipFields?.length > 0) {
if (presentCharsConfig?.relationships?.enabled !== false && presentCharsConfig?.relationshipFields?.length > 0) {
const emojiToRelationship = { '⚔️': 'Enemy', '⚖️': 'Neutral', '⭐': 'Friend', '❤️': 'Lover' };
const relationshipValue = field === 'Relationship' ? (emojiToRelationship[value] || value) : 'Neutral';
newCharacterLines.push(`Relationship: ${relationshipValue}`);