Compare commits
No commits in common. "main" and "1.0.0" have entirely different histories.
2 changed files with 37 additions and 63 deletions
|
|
@ -4,11 +4,11 @@
|
||||||
"description": "Adds a browser to easily find and copy Active Effect data paths in Daggerheart.",
|
"description": "Adds a browser to easily find and copy Active Effect data paths in Daggerheart.",
|
||||||
"url": "https://git.geeks.gay/cosmo/dh-path-browser",
|
"url": "https://git.geeks.gay/cosmo/dh-path-browser",
|
||||||
"manifest": "https://git.geeks.gay/cosmo/dh-path-browser/raw/branch/main/module.json",
|
"manifest": "https://git.geeks.gay/cosmo/dh-path-browser/raw/branch/main/module.json",
|
||||||
"download": "https://git.geeks.gay/cosmo/dh-path-browser/releases/download/1.1.1/dh-path-browser.zip",
|
"download": "https://git.geeks.gay/cosmo/dh-path-browser/releases/download/1.0.0/dh-path-browser.zip",
|
||||||
"version": "1.1.1",
|
"version": "1.0.0",
|
||||||
"compatibility": {
|
"compatibility": {
|
||||||
"minimum": "13",
|
"minimum": "13",
|
||||||
"verified": "14"
|
"verified": "13"
|
||||||
},
|
},
|
||||||
"authors": [
|
"authors": [
|
||||||
{
|
{
|
||||||
|
|
@ -31,7 +31,7 @@
|
||||||
"id": "daggerheart",
|
"id": "daggerheart",
|
||||||
"type": "system",
|
"type": "system",
|
||||||
"compatibility": {
|
"compatibility": {
|
||||||
"minimum": "1.9.9"
|
"minimum": "1.9.4"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
|
||||||
|
|
@ -97,17 +97,37 @@ export class DhPathBrowserApp extends HandlebarsApplicationMixin(ApplicationV2)
|
||||||
static getChangeChoices() {
|
static getChangeChoices() {
|
||||||
const ignoredActorKeys = ['config', 'DhEnvironment', 'DhParty'];
|
const ignoredActorKeys = ['config', 'DhEnvironment', 'DhParty'];
|
||||||
|
|
||||||
const getTranslations = (model, path) => {
|
const getAllLeaves = (root, group, parentPath = '') => {
|
||||||
|
const leaves = [];
|
||||||
|
const rootKey = `${parentPath ? `${parentPath}.` : ''}${root.name}`;
|
||||||
|
for (const field of Object.values(root.fields)) {
|
||||||
|
if (field instanceof foundry.data.fields.SchemaField)
|
||||||
|
leaves.push(...getAllLeaves(field, group, rootKey));
|
||||||
|
else
|
||||||
|
leaves.push({
|
||||||
|
value: `${rootKey}.${field.name}`,
|
||||||
|
label: game.i18n.localize(field.label),
|
||||||
|
hint: game.i18n.localize(field.hint),
|
||||||
|
group
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return leaves;
|
||||||
|
};
|
||||||
|
|
||||||
|
return Object.keys(game.system.api.models.actors).reduce((acc, key) => {
|
||||||
|
if (ignoredActorKeys.includes(key)) return acc;
|
||||||
|
|
||||||
|
const model = game.system.api.models.actors[key];
|
||||||
|
const group = game.i18n.localize(model.metadata.label);
|
||||||
|
const attributes = CONFIG.Token.documentClass.getTrackedAttributes(model.metadata.type);
|
||||||
|
|
||||||
|
const getTranslations = path => {
|
||||||
if (path === 'resources.hope.max')
|
if (path === 'resources.hope.max')
|
||||||
return {
|
return {
|
||||||
label: game.i18n.localize('DAGGERHEART.SETTINGS.Homebrew.FIELDS.maxHope.label'),
|
label: game.i18n.localize('DAGGERHEART.SETTINGS.Homebrew.FIELDS.maxHope.label'),
|
||||||
hint: ''
|
hint: ''
|
||||||
};
|
};
|
||||||
|
|
||||||
// Armor overrides
|
|
||||||
if (path.endsWith('armor.max')) return { label: game.i18n.localize('DAGGERHEART.ArmorScoreMax'), hint: '' };
|
|
||||||
if (path.endsWith('armor.current')) return { label: game.i18n.localize('DAGGERHEART.ArmorScoreCurrent'), hint: '' };
|
|
||||||
|
|
||||||
const field = model.schema.getField(path);
|
const field = model.schema.getField(path);
|
||||||
return {
|
return {
|
||||||
label: field ? game.i18n.localize(field.label) : path,
|
label: field ? game.i18n.localize(field.label) : path,
|
||||||
|
|
@ -115,69 +135,23 @@ export class DhPathBrowserApp extends HandlebarsApplicationMixin(ApplicationV2)
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
const getAllLeaves = (model, root, group, parentPath = '') => {
|
|
||||||
if (!root) return [];
|
|
||||||
const leaves = [];
|
|
||||||
const rootKey = `${parentPath ? `${parentPath}.` : ''}${root.name}`;
|
|
||||||
|
|
||||||
const fields = root.fields || root;
|
|
||||||
|
|
||||||
for (const [name, field] of Object.entries(fields)) {
|
|
||||||
const currentPath = `${rootKey}.${name}`;
|
|
||||||
if (field instanceof foundry.data.fields.SchemaField) {
|
|
||||||
leaves.push(...getAllLeaves(model, field, group, rootKey));
|
|
||||||
} else {
|
|
||||||
const trans = getTranslations(model, currentPath);
|
|
||||||
leaves.push({
|
|
||||||
value: currentPath,
|
|
||||||
label: trans.label || name,
|
|
||||||
hint: trans.hint || '',
|
|
||||||
group
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return leaves;
|
|
||||||
};
|
|
||||||
|
|
||||||
const choices = [];
|
|
||||||
|
|
||||||
// Process Actors
|
|
||||||
for (const [key, model] of Object.entries(game.system.api.models.actors)) {
|
|
||||||
if (ignoredActorKeys.includes(key) || !model?.metadata) continue;
|
|
||||||
|
|
||||||
const group = game.i18n.localize(model.metadata.label);
|
|
||||||
const attributes = CONFIG.Token.documentClass.getTrackedAttributes(model.metadata.type);
|
|
||||||
|
|
||||||
const bars = attributes.bar.flatMap(x => {
|
const bars = attributes.bar.flatMap(x => {
|
||||||
const baseJoined = x.join('.');
|
const baseJoined = x.join('.');
|
||||||
return [
|
return [
|
||||||
{ value: `${baseJoined}.max`, ...getTranslations(model, `${baseJoined}.max`), group },
|
{ value: `${baseJoined}.max`, ...getTranslations(`${baseJoined}.max`), group },
|
||||||
{ value: `${baseJoined}.value`, ...getTranslations(model, `${baseJoined}.value`), group }
|
{ value: `${baseJoined}.value`, ...getTranslations(`${baseJoined}.value`), group }
|
||||||
];
|
];
|
||||||
});
|
});
|
||||||
const values = attributes.value.flatMap(x => {
|
const values = attributes.value.flatMap(x => {
|
||||||
const joined = x.join('.');
|
const joined = x.join('.');
|
||||||
return { value: joined, ...getTranslations(model, joined), group };
|
return { value: joined, ...getTranslations(joined), group };
|
||||||
});
|
});
|
||||||
|
|
||||||
const bonuses = getAllLeaves(model, model.schema.fields.bonuses, group);
|
const bonuses = getAllLeaves(model.schema.fields.bonuses, group);
|
||||||
const rules = getAllLeaves(model, model.schema.fields.rules, group);
|
const rules = getAllLeaves(model.schema.fields.rules, group);
|
||||||
const armor = getAllLeaves(model, model.schema.fields.armor, group);
|
|
||||||
|
|
||||||
choices.push(...bars, ...values, ...rules, ...bonuses, ...armor);
|
acc.push(...bars, ...values, ...rules, ...bonuses);
|
||||||
}
|
return acc;
|
||||||
|
}, []);
|
||||||
// Process Items
|
|
||||||
for (const [key, model] of Object.entries(game.system.api.models.items)) {
|
|
||||||
if (!model?.metadata) continue;
|
|
||||||
const group = `${game.i18n.localize('DOCUMENT.Item')} (${game.i18n.localize(model.metadata.label)})`;
|
|
||||||
|
|
||||||
const bonuses = getAllLeaves(model, model.schema.fields.bonuses, group);
|
|
||||||
const armor = getAllLeaves(model, model.schema.fields.armor, group);
|
|
||||||
|
|
||||||
choices.push(...bonuses, ...armor);
|
|
||||||
}
|
|
||||||
|
|
||||||
return choices;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue