From 02066d64750bdb787d8ef19846c917bda45e70db Mon Sep 17 00:00:00 2001 From: Werner Date: Tue, 31 Jan 2023 21:30:53 +0100 Subject: [PATCH] add setting to fail button that allows you to hide or display it --- lang/en.json | 4 +++- src/lmrtfy.js | 32 +++++++++++++++++++++++--------- 2 files changed, 26 insertions(+), 10 deletions(-) diff --git a/lang/en.json b/lang/en.json index 04bdabf..8891086 100644 --- a/lang/en.json +++ b/lang/en.json @@ -63,5 +63,7 @@ "LMRTFY.SavingThrowFail": "FAIL Saving Throw: ", "LMRTFY.AbilityCheckFail": "FAIL Ability Check: ", "LMRTFY.SkillCheckFail": "FAIL Skill Check: ", - "LMRTFY.EnableChooseFail": "Enable Fail Button" + "LMRTFY.EnableChooseFail": "Enable Fail Button", + "LMRTFY.ShowFailButtons": "Show Fail Button", + "LMRTFY.ShowFailButtonsHint": "Show fail buttons for ability checks, ability saves and skill the requested roll form" } diff --git a/src/lmrtfy.js b/src/lmrtfy.js index 379d6f1..6a1afcc 100644 --- a/src/lmrtfy.js +++ b/src/lmrtfy.js @@ -28,6 +28,20 @@ class LMRTFY { onChange: () => window.location.reload() }); + var showFailButtonSetting = false; + if (game.system.id === 'dnd5e') { + showFailButtonSetting = true; + } + game.settings.register('lmrtfy', 'showFailButtons', { + name: game.i18n.localize('LMRTFY.ShowFailButtons'), + hint: game.i18n.localize('LMRTFY.ShowFailButtonsHint'), + scope: 'world', + config: showFailButtonSetting, + type: Boolean, + default: showFailButtonSetting, // if it's DnD 5e default to true + onChange: () => window.location.reload() + }); + Handlebars.registerHelper('lmrtfy-controlledToken', function (actor) { const actorsControlledToken = canvas.tokens?.controlled.find(t => t.actor.id === actor.id); if (actorsControlledToken) { @@ -66,7 +80,7 @@ class LMRTFY { LMRTFY.abilityAbbreviations = CONFIG.DND5E.abilityAbbreviations; LMRTFY.modIdentifier = 'mod'; LMRTFY.abilityModifiers = LMRTFY.parseAbilityModifiers(); - LMRTFY.canFailChecks = true; + LMRTFY.canFailChecks = game.settings.get('lmrtfy', 'showFailButtons'); break; case 'pf1': @@ -83,7 +97,7 @@ class LMRTFY { LMRTFY.abilityAbbreviations = CONFIG.PF1.abilitiesShort; LMRTFY.modIdentifier = 'mod'; LMRTFY.abilityModifiers = LMRTFY.parseAbilityModifiers(); - LMRTFY.canFailChecks = false; // unsure if how and if system could handle this + LMRTFY.canFailChecks = game.settings.get('lmrtfy', 'showFailButtons'); // defaulted to false due to system break; case 'pf2e': @@ -100,7 +114,7 @@ class LMRTFY { LMRTFY.abilityAbbreviations = CONFIG.PF2E.abilities; LMRTFY.modIdentifier = 'mod'; LMRTFY.abilityModifiers = LMRTFY.parseAbilityModifiers(); - LMRTFY.canFailChecks = false; // unsure if how and if system could handle this + LMRTFY.canFailChecks = game.settings.get('lmrtfy', 'showFailButtons'); // defaulted to false due to system break; case 'D35E': @@ -117,7 +131,7 @@ class LMRTFY { LMRTFY.abilityAbbreviations = CONFIG.D35E.abilityAbbreviations; LMRTFY.modIdentifier = 'mod'; LMRTFY.abilityModifiers = LMRTFY.parseAbilityModifiers(); - LMRTFY.canFailChecks = false; // unsure if how and if system could handle this + LMRTFY.canFailChecks = game.settings.get('lmrtfy', 'showFailButtons'); // defaulted to false due to system break; case 'cof': @@ -133,7 +147,7 @@ class LMRTFY { LMRTFY.abilityAbbreviations = CONFIG.COF.statAbbreviations; LMRTFY.modIdentifier = 'mod'; LMRTFY.abilityModifiers = LMRTFY.parseAbilityModifiers(); - LMRTFY.canFailChecks = false; // unsure if how and if system could handle this + LMRTFY.canFailChecks = game.settings.get('lmrtfy', 'showFailButtons'); // defaulted to false due to system break; case 'coc': @@ -149,7 +163,7 @@ class LMRTFY { LMRTFY.abilityAbbreviations = CONFIG.COC.statAbbreviations; LMRTFY.modIdentifier = 'mod'; LMRTFY.abilityModifiers = LMRTFY.parseAbilityModifiers(); - LMRTFY.canFailChecks = false; // unsure if how and if system could handle this + LMRTFY.canFailChecks = game.settings.get('lmrtfy', 'showFailButtons'); // defaulted to false due to system break; case 'demonlord': @@ -168,7 +182,7 @@ class LMRTFY { LMRTFY.abilityAbbreviations = abilities; LMRTFY.modIdentifier = 'modifier'; LMRTFY.abilityModifiers = {}; - LMRTFY.canFailChecks = false; // unsure if how and if system could handle this + LMRTFY.canFailChecks = game.settings.get('lmrtfy', 'showFailButtons'); // defaulted to false due to system break; case 'ose': @@ -187,7 +201,7 @@ class LMRTFY { LMRTFY.specialRolls = {}; LMRTFY.modIdentifier = 'modifier'; LMRTFY.abilityModifiers = {}; - LMRTFY.canFailChecks = false; // unsure if how and if system could handle this + LMRTFY.canFailChecks = game.settings.get('lmrtfy', 'showFailButtons'); // defaulted to false due to system break; case 'foundry-chromatic-dungeons': @@ -199,7 +213,7 @@ class LMRTFY { LMRTFY.skills = {}; LMRTFY.saves = CONFIG.CHROMATIC.saves; LMRTFY.specialRolls = {}; - LMRTFY.canFailChecks = false; // unsure if how and if system could handle this + LMRTFY.canFailChecks = game.settings.get('lmrtfy', 'showFailButtons'); // defaulted to false due to system break; default: