@kitten-science/kitten-scientists
Version:
Add-on for the wonderful incremental browser game: https://kittensgame.com/web/
73 lines • 3.79 kB
JavaScript
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 ResetSpaceSettingsUi extends IconSettingsPanel {
constructor(host, settings, locale) {
const label = host.engine.i18n("ui.space");
super(host, label, settings, {
childrenHead: [new Container(host, { classes: [stylesLabelListItem.fillSpace] })],
icon: Icons.Space,
});
this.addChild(new SettingsList(host, {
children: host.game.space.planets
.filter(plant => 0 < plant.buildings.length)
.flatMap((planet, indexPlanet, arrayPlant) => [
new HeaderListItem(host, host.engine.labelForPlanet(planet.name)),
...planet.buildings
.filter(item => !isNil(this.setting.buildings[item.name]))
.map((building, indexBuilding, arrayBuilding) => this._getResetOption(host, this.setting.buildings[building.name], locale, settings, building.label, indexPlanet < arrayPlant.length - 1 && indexBuilding === arrayBuilding.length - 1)),
]),
}));
}
_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=ResetSpaceSettingsUi.js.map