UNPKG

@kitten-science/kitten-scientists

Version:

Add-on for the wonderful incremental browser game: https://kittensgame.com/web/

75 lines 3.97 kB
import { isNil } from "@oliversalzburg/js-utils/data/nil.js"; import { redirectErrorsToConsole } from "@oliversalzburg/js-utils/errors/console.js"; import { Icons } from "../images/Icons.js"; import stylesButton from "./components/Button.module.css"; import { Container } from "./components/Container.js"; import { Dialog } from "./components/Dialog.js"; import { HeaderListItem } from "./components/HeaderListItem.js"; import { IconSettingsPanel } from "./components/IconSettingsPanel.js"; import stylesLabelListItem from "./components/LabelListItem.module.css"; import { SettingTriggerListItem } from "./components/SettingTriggerListItem.js"; import { SettingsList } from "./components/SettingsList.js"; export class ResetTimeSettingsUi extends IconSettingsPanel { constructor(host, settings, locale) { const label = host.engine.i18n("ui.time"); super(host, label, settings, { childrenHead: [new Container(host, { classes: [stylesLabelListItem.fillSpace] })], icon: Icons.Time, }); this.addChild(new SettingsList(host, { children: [ new HeaderListItem(host, host.engine.i18n("$workshop.chronoforge.label")), ...host.game.time.chronoforgeUpgrades .filter(item => !isNil(this.setting.buildings[item.name])) .map(building => this._getResetOption(host, this.setting.buildings[building.name], locale, settings, building.label, building.name === host.game.time.chronoforgeUpgrades.at(-1)?.name)), new HeaderListItem(host, host.engine.i18n("$science.voidSpace.label")), ...host.game.time.voidspaceUpgrades .filter(item => !isNil(this.setting.buildings[item.name])) .map(building => this._getResetOption(host, this.setting.buildings[building.name], locale, settings, building.label)), ], })); } _getResetOption(host, option, locale, sectionSetting, label, delimiter = false, upgradeIndicator = false) { const element = new SettingTriggerListItem(host, option, locale, label, { delimiter, onCheck: () => { host.engine.imessage("status.reset.check.enable", [label]); }, onUnCheck: () => { host.engine.imessage("status.reset.check.disable", [label]); }, onRefresh: () => { element.triggerButton.inactive = !option.enabled || option.trigger === -1; element.triggerButton.ineffective = sectionSetting.enabled && option.enabled && option.trigger === -1; }, onSetTrigger: () => { Dialog.prompt(host, host.engine.i18n("ui.trigger.prompt.absolute"), host.engine.i18n("ui.trigger.build.prompt", [ label, option.trigger !== -1 ? host.renderAbsolute(option.trigger, locale.selected) : host.engine.i18n("ui.trigger.inactive"), ]), option.trigger !== -1 ? host.renderAbsolute(option.trigger) : "", host.engine.i18n("ui.trigger.reset.promptExplainer")) .then(value => { if (value === undefined) { return; } if (value === "" || value.startsWith("-")) { option.trigger = -1; option.enabled = false; return; } option.trigger = Number(value); }) .then(() => { element.refreshUi(); }) .catch(redirectErrorsToConsole(console)); }, upgradeIndicator, }); element.triggerButton.element.addClass(stylesButton.lastHeadAction); return element; } } //# sourceMappingURL=ResetTimeSettingsUi.js.map