UNPKG

@kitten-science/kitten-scientists

Version:

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

70 lines 3.81 kB
import { cl } from "../tools/Log.js"; import stylesButton from "./components/Button.module.css"; import { Container } from "./components/Container.js"; import { Dialog } from "./components/Dialog.js"; import stylesLabelListItem from "./components/LabelListItem.module.css"; import { SettingListItem } from "./components/SettingListItem.js"; import { SettingsList } from "./components/SettingsList.js"; import { SettingsPanel } from "./components/SettingsPanel.js"; import { SettingTriggerListItem } from "./components/SettingTriggerListItem.js"; import { ResetSettingsUi } from "./ResetSettingsUi.js"; import { TimeSkipSettingsUi } from "./TimeSkipSettingsUi.js"; export class TimeControlSettingsUi extends SettingsPanel { _items; _accelerateTime; _timeSkipUi; _resetUi; constructor(parent, settings, locale) { console.debug(...cl(`Constructing ${TimeControlSettingsUi.name}`)); const label = parent.host.engine.i18n("ui.timeCtrl"); super(parent, settings, new SettingListItem(parent, settings, label, { onCheck: (_isBatchProcess) => { parent.host.engine.imessage("status.auto.enable", [label]); }, onUnCheck: (_isBatchProcess) => { parent.host.engine.imessage("status.auto.disable", [label]); }, }).addChildrenHead([new Container(parent, { classes: [stylesLabelListItem.fillSpace] })]), { onRefreshRequest: () => { this.expando.ineffective = settings.enabled && [this._timeSkipUi, this._resetUi].some(_ => _.expando.ineffective); }, }); const list = new SettingsList(this, { hasDisableAll: false, hasEnableAll: false, }); const accelerateLabel = this.host.engine.i18n("option.accelerate"); this._accelerateTime = new SettingTriggerListItem(this, this.setting.accelerateTime, locale, accelerateLabel, { onCheck: () => { this.host.engine.imessage("status.sub.enable", [accelerateLabel]); }, onRefresh: () => { this._accelerateTime.triggerButton.inactive = !this.setting.accelerateTime.enabled; this._accelerateTime.triggerButton.ineffective = this.setting.enabled && this.setting.accelerateTime.enabled && this.setting.accelerateTime.trigger === -1; }, onSetTrigger: async () => { const value = await Dialog.prompt(this, this.host.engine.i18n("ui.trigger.accelerateTime.prompt"), this.host.engine.i18n("ui.trigger.accelerateTime.promptTitle", [ this.host.renderPercentage(this.setting.accelerateTime.trigger, locale.selected, true), ]), this.host.renderPercentage(this.setting.accelerateTime.trigger), this.host.engine.i18n("ui.trigger.accelerateTime.promptExplainer")); if (value === undefined || value === "" || value.startsWith("-")) { return; } this.setting.accelerateTime.trigger = this.host.parsePercentage(value); }, onUnCheck: () => { this.host.engine.imessage("status.sub.disable", [accelerateLabel]); }, }); this._accelerateTime.triggerButton.element.addClass(stylesButton.lastHeadAction); this._timeSkipUi = new TimeSkipSettingsUi(this, this.setting.timeSkip, locale, settings); this._resetUi = new ResetSettingsUi(this, this.setting.reset, locale); this._items = [this._accelerateTime, this._timeSkipUi, this._resetUi]; list.addChildren(this._items); this.addChildContent(list); } } //# sourceMappingURL=TimeControlSettingsUi.js.map