bc-deeplib 2.1.0 → 2.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/deeplib.d.ts +26 -22
- package/dist/deeplib.js +50 -55
- package/dist/deeplib.js.map +3 -3
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -2
package/dist/deeplib.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
declare module 'bc-deeplib/base/base_module' {
|
|
2
|
-
import { BaseSettingsModel, Subscreen } from 'bc-deeplib/deeplib';
|
|
2
|
+
import { BaseSettingsModel, SettingsModel, Subscreen } from 'bc-deeplib/deeplib';
|
|
3
3
|
/**
|
|
4
4
|
* An abstract foundation for modular systems that require:
|
|
5
5
|
* - Optional settings screens
|
|
@@ -57,7 +57,7 @@ declare module 'bc-deeplib/base/base_module' {
|
|
|
57
57
|
* If some settings already exist, they will be merged with defaults.
|
|
58
58
|
* Existing values will NOT be overwritten.
|
|
59
59
|
*/
|
|
60
|
-
registerDefaultSettings(): void;
|
|
60
|
+
registerDefaultSettings(target: SettingsModel): void;
|
|
61
61
|
/**
|
|
62
62
|
* Provides default settings for this module.
|
|
63
63
|
* Subclasses should override this getter to return their defaults.
|
|
@@ -140,6 +140,10 @@ declare module 'bc-deeplib/base/base_subscreen' {
|
|
|
140
140
|
* Defaults to 1000.
|
|
141
141
|
*/
|
|
142
142
|
settingsWidth?: number;
|
|
143
|
+
/**
|
|
144
|
+
* If `true`, the character will be forced to the top of the screen.
|
|
145
|
+
*/
|
|
146
|
+
forceUpCharacter?: boolean;
|
|
143
147
|
};
|
|
144
148
|
/**
|
|
145
149
|
* Represents a constructor type for a subscreen.
|
|
@@ -148,7 +152,7 @@ declare module 'bc-deeplib/base/base_subscreen' {
|
|
|
148
152
|
*/
|
|
149
153
|
export type Subscreen = new (module?: BaseModule) => BaseSubscreen;
|
|
150
154
|
/** Switches the active subscreen in the global `GUI` instance. */
|
|
151
|
-
export function setSubscreen(subscreen: BaseSubscreen | string
|
|
155
|
+
export function setSubscreen(subscreen: BaseSubscreen | string): Promise<void>;
|
|
152
156
|
/**
|
|
153
157
|
* Abstract base class for creating settings/configuration subscreens in a module.
|
|
154
158
|
*
|
|
@@ -180,7 +184,7 @@ declare module 'bc-deeplib/base/base_subscreen' {
|
|
|
180
184
|
protected static readonly subscreenOptions: SubscreenOptions;
|
|
181
185
|
constructor(module?: BaseModule);
|
|
182
186
|
/** Changes the currently active subscreen. */
|
|
183
|
-
setSubscreen(screen: BaseSubscreen | string
|
|
187
|
+
setSubscreen(screen: BaseSubscreen | string): Promise<void>;
|
|
184
188
|
/** Gets this subscreen's settings object from its parent module. */
|
|
185
189
|
get settings(): BaseSettingsModel;
|
|
186
190
|
/** Updates this subscreen's settings in its parent module. */
|
|
@@ -306,7 +310,7 @@ declare module 'bc-deeplib/base/elements_typings' {
|
|
|
306
310
|
|
|
307
311
|
}
|
|
308
312
|
declare module 'bc-deeplib/base/initialization' {
|
|
309
|
-
import { BaseModule, ModSdkManager,
|
|
313
|
+
import { BaseModule, ModSdkManager, ModStorage, MainMenuOptions, TranslationOptions, Logger } from 'bc-deeplib/deeplib';
|
|
310
314
|
/** Configuration object for initializing a mod via `initMod`. */
|
|
311
315
|
interface InitOptions {
|
|
312
316
|
/**
|
|
@@ -323,11 +327,6 @@ declare module 'bc-deeplib/base/initialization' {
|
|
|
323
327
|
* Modules are initialized, loaded, and run in order.
|
|
324
328
|
*/
|
|
325
329
|
modules?: BaseModule[];
|
|
326
|
-
/**
|
|
327
|
-
* List of data migration handlers to register with the `VersionModule`.
|
|
328
|
-
* Each `BaseMigrator` handles upgrading data from one version to another.
|
|
329
|
-
*/
|
|
330
|
-
migrators?: BaseMigrator[];
|
|
331
330
|
/** Configuration for customizing the main menu when the mod is active. */
|
|
332
331
|
mainMenuOptions?: MainMenuOptions;
|
|
333
332
|
/**
|
|
@@ -353,6 +352,11 @@ declare module 'bc-deeplib/base/initialization' {
|
|
|
353
352
|
* Initialized by `initMod()`.
|
|
354
353
|
*/
|
|
355
354
|
export let sdk: ModSdkManager;
|
|
355
|
+
/**
|
|
356
|
+
* Mod specific logger instance.
|
|
357
|
+
* Initialized by `initMod()`.
|
|
358
|
+
*/
|
|
359
|
+
export let logger: Logger;
|
|
356
360
|
/**
|
|
357
361
|
* Entry point for initializing a mod. Handles:
|
|
358
362
|
* - Setting up the Mod SDK
|
|
@@ -580,10 +584,20 @@ declare module 'bc-deeplib/modules/gui' {
|
|
|
580
584
|
declare module 'bc-deeplib/modules/version' {
|
|
581
585
|
import { BaseMigrator, BaseModule } from 'bc-deeplib/deeplib';
|
|
582
586
|
export type VersionModuleOptions = {
|
|
587
|
+
/**
|
|
588
|
+
* List of data migration handlers to register with the `VersionModule`.
|
|
589
|
+
* Each `BaseMigrator` handles upgrading data from one version to another.
|
|
590
|
+
*/
|
|
591
|
+
migrators?: BaseMigrator[];
|
|
592
|
+
/** Message to display when a new version is detected */
|
|
583
593
|
newVersionMessage?: string;
|
|
594
|
+
/** Optional lifecycle hook. Runs before each migration */
|
|
584
595
|
beforeEach?: () => void;
|
|
596
|
+
/** Optional lifecycle hook. Runs after each migration */
|
|
585
597
|
afterEach?: () => void;
|
|
598
|
+
/** Optional lifecycle hook. Runs before all migrations */
|
|
586
599
|
beforeAll?: () => void;
|
|
600
|
+
/** Optional lifecycle hook. Runs after all migrations */
|
|
587
601
|
afterAll?: () => void;
|
|
588
602
|
};
|
|
589
603
|
/**
|
|
@@ -602,17 +616,12 @@ declare module 'bc-deeplib/modules/version' {
|
|
|
602
616
|
private static isItNewVersion;
|
|
603
617
|
/** The current mod version (retrieved from `ModSdkManager.ModInfo.version`) */
|
|
604
618
|
private static version;
|
|
605
|
-
/** Message to display when a new version is detected */
|
|
606
619
|
private static newVersionMessage?;
|
|
607
620
|
/** List of registered migration handlers, sorted by version */
|
|
608
621
|
private static migrators;
|
|
609
|
-
/** Optional lifecycle hook. Runs before each migration */
|
|
610
622
|
private static beforeEach?;
|
|
611
|
-
/** Optional lifecycle hook. Runs after each migration */
|
|
612
623
|
private static afterEach?;
|
|
613
|
-
/** Optional lifecycle hook. Runs before all migrations */
|
|
614
624
|
private static beforeAll?;
|
|
615
|
-
/** Optional lifecycle hook. Runs after all migrations */
|
|
616
625
|
private static afterAll?;
|
|
617
626
|
constructor(options: VersionModuleOptions);
|
|
618
627
|
/**
|
|
@@ -635,11 +644,6 @@ declare module 'bc-deeplib/modules/version' {
|
|
|
635
644
|
* is newer than the previously stored version.
|
|
636
645
|
*/
|
|
637
646
|
private static checkVersionMigration;
|
|
638
|
-
/**
|
|
639
|
-
* Registers a new migrator for handling version-specific changes.
|
|
640
|
-
* Migrators are sorted by their `MigrationVersion` in ascending order.
|
|
641
|
-
*/
|
|
642
|
-
static registerMigrator(migrator: BaseMigrator): void;
|
|
643
647
|
/** Sends the currently configured "new version" message to the local player. */
|
|
644
648
|
static sendNewVersionMessage(): void;
|
|
645
649
|
/**
|
|
@@ -701,7 +705,7 @@ declare module 'bc-deeplib/screens/import_export' {
|
|
|
701
705
|
/** Imports mod data using the specified method. */
|
|
702
706
|
dataImport(transferMethod: DataTransferMethod): Promise<void>;
|
|
703
707
|
/** Saves data to a file using the browser's save dialog. */
|
|
704
|
-
exportToFile(data: string, defaultFileName: string): Promise<
|
|
708
|
+
exportToFile(data: string, defaultFileName: string): Promise<boolean>;
|
|
705
709
|
/** Opens a file picker and reads the selected file's contents, importing the data. */
|
|
706
710
|
importFromFile(): Promise<string | null>;
|
|
707
711
|
/** Copies the given data to the clipboard. */
|
|
@@ -846,7 +850,7 @@ declare module 'bc-deeplib/utilities/elements/elements' {
|
|
|
846
850
|
};
|
|
847
851
|
function elementCreateButton(options: Omit<Button, 'type'>): HTMLButtonElement;
|
|
848
852
|
function elementCreateCheckbox(options: Omit<Checkbox, 'type'>): HTMLElement;
|
|
849
|
-
function elementCreateCustom(options: Omit<Custom, 'type'>):
|
|
853
|
+
function elementCreateCustom(options: Omit<Custom, 'type'>): HTMLHeadElement;
|
|
850
854
|
function elementCreateInput(options: Input): HTMLElement;
|
|
851
855
|
function elementCreateLabel(options: Omit<Label, 'type'>): HTMLElement;
|
|
852
856
|
function elementCreateDropdown(options: Omit<Dropdown, 'type'>): HTMLDivElement;
|
package/dist/deeplib.js
CHANGED
|
@@ -230,8 +230,10 @@ var BaseModule = class {
|
|
|
230
230
|
if (!this.settingsStorage) return {};
|
|
231
231
|
if (!modStorage.playerStorage) {
|
|
232
232
|
Player[modName] = {};
|
|
233
|
-
this.registerDefaultSettings();
|
|
234
|
-
} else if (!modStorage.playerStorage[this.settingsStorage])
|
|
233
|
+
this.registerDefaultSettings(modStorage.playerStorage);
|
|
234
|
+
} else if (!modStorage.playerStorage[this.settingsStorage]) {
|
|
235
|
+
this.registerDefaultSettings(modStorage.playerStorage);
|
|
236
|
+
}
|
|
235
237
|
return modStorage.playerStorage[this.settingsStorage];
|
|
236
238
|
}
|
|
237
239
|
/**
|
|
@@ -244,8 +246,10 @@ var BaseModule = class {
|
|
|
244
246
|
if (!this.settingsStorage) return;
|
|
245
247
|
if (!storage.playerStorage) {
|
|
246
248
|
Player[modName] = {};
|
|
247
|
-
this.registerDefaultSettings();
|
|
248
|
-
} else if (!storage.playerStorage[this.settingsStorage])
|
|
249
|
+
this.registerDefaultSettings(modStorage.playerStorage);
|
|
250
|
+
} else if (!storage.playerStorage[this.settingsStorage]) {
|
|
251
|
+
this.registerDefaultSettings(modStorage.playerStorage);
|
|
252
|
+
}
|
|
249
253
|
storage.playerStorage[this.settingsStorage] = value;
|
|
250
254
|
}
|
|
251
255
|
/**
|
|
@@ -254,7 +258,7 @@ var BaseModule = class {
|
|
|
254
258
|
* Subclasses can override to perform additional setup.
|
|
255
259
|
*/
|
|
256
260
|
init() {
|
|
257
|
-
this.registerDefaultSettings();
|
|
261
|
+
this.registerDefaultSettings(modStorage.playerStorage);
|
|
258
262
|
}
|
|
259
263
|
/**
|
|
260
264
|
* Registers default settings for this module in persistent storage.
|
|
@@ -263,11 +267,11 @@ var BaseModule = class {
|
|
|
263
267
|
* If some settings already exist, they will be merged with defaults.
|
|
264
268
|
* Existing values will NOT be overwritten.
|
|
265
269
|
*/
|
|
266
|
-
registerDefaultSettings() {
|
|
270
|
+
registerDefaultSettings(target) {
|
|
267
271
|
const storage = this.settingsStorage;
|
|
268
272
|
const defaults = this.defaultSettings;
|
|
269
273
|
if (!storage || !defaults) return;
|
|
270
|
-
|
|
274
|
+
target[storage] = Object.assign(defaults, target[storage] ?? {});
|
|
271
275
|
}
|
|
272
276
|
/**
|
|
273
277
|
* Provides default settings for this module.
|
|
@@ -328,7 +332,8 @@ var BaseSubscreen = class _BaseSubscreen {
|
|
|
328
332
|
background: "Sheet",
|
|
329
333
|
doShowExitButton: true,
|
|
330
334
|
doShowTitle: true,
|
|
331
|
-
settingsWidth: 1e3
|
|
335
|
+
settingsWidth: 1e3,
|
|
336
|
+
forceUpCharacter: false
|
|
332
337
|
};
|
|
333
338
|
constructor(module) {
|
|
334
339
|
if (module) this.module = module;
|
|
@@ -421,7 +426,7 @@ var BaseSubscreen = class _BaseSubscreen {
|
|
|
421
426
|
load() {
|
|
422
427
|
for (const module of modules()) {
|
|
423
428
|
if (!module.settingsScreen) continue;
|
|
424
|
-
if (!module.settings || !Object.keys(module.settings).length) module.registerDefaultSettings();
|
|
429
|
+
if (!module.settings || !Object.keys(module.settings).length) module.registerDefaultSettings(modStorage.playerStorage);
|
|
425
430
|
}
|
|
426
431
|
_BaseSubscreen.currentPage = 1;
|
|
427
432
|
layout.getSubscreen();
|
|
@@ -516,7 +521,11 @@ var BaseSubscreen = class _BaseSubscreen {
|
|
|
516
521
|
})
|
|
517
522
|
);
|
|
518
523
|
this.managePageElementsVisibility();
|
|
519
|
-
|
|
524
|
+
if (this.options.drawCharacter && this.options.forceUpCharacter) {
|
|
525
|
+
CharacterAppearanceForceUpCharacter = Player.MemberNumber;
|
|
526
|
+
} else {
|
|
527
|
+
CharacterAppearanceForceUpCharacter = -1;
|
|
528
|
+
}
|
|
520
529
|
}
|
|
521
530
|
/**
|
|
522
531
|
* Called each frame while this subscreen is active.
|
|
@@ -563,8 +572,10 @@ var BaseSubscreen = class _BaseSubscreen {
|
|
|
563
572
|
ElementSetFontSize(subscreen, "auto");
|
|
564
573
|
ElementSetPosition(settingsDiv, 530 - offset, 170);
|
|
565
574
|
ElementSetSize(settingsDiv, this.options.settingsWidth ?? 1e3 + offset, 660);
|
|
566
|
-
|
|
567
|
-
|
|
575
|
+
if (this.options.doShowTitle) {
|
|
576
|
+
ElementSetPosition("deeplib-subscreen-title", 530 - offset, 75);
|
|
577
|
+
ElementSetSize("deeplib-subscreen-title", 800, 60);
|
|
578
|
+
}
|
|
568
579
|
ElementSetPosition("deeplib-nav-menu", 1905, 75, "top-right");
|
|
569
580
|
ElementSetSize("deeplib-nav-menu", null, 90);
|
|
570
581
|
ElementSetPosition(advElement.getTooltip() || "", 250, 850);
|
|
@@ -928,21 +939,23 @@ var styles_default = `.deeplib-subscreen,
|
|
|
928
939
|
height: 100dvh;
|
|
929
940
|
background-color: rgba(0, 0, 0, 0.5);
|
|
930
941
|
}
|
|
931
|
-
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/media/NVME/Stuff/Code/bc/BC-DeepLib/src/styles","sources":["vars.scss","buttons.scss","elements.scss","inputs.scss","messages.scss","modal.scss"],"names":[],"mappings":"AAAA;AAAA;EAEE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;ACdF;EACE;EACA;EACA;;;AAGF;AAAA;EAEE;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EAEA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;;;AAGF;EACE;;;AC3CF;EACE;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;EACA;;AAHJ;EAME;EACA;;AAGF;EACE;;;AAIJ;EACE;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;;;ACzGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;;ACvEJ;EACE;EACA;;;AAGF;AAAA;EAEE;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;AAAA;EAEE;;;AAGF;EACE;EACA;EACA;;;AC7BF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAGF;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAEA;EACE;;AAKN;EACE;EACA;EACA;EACA;;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA","sourcesContent":[".deeplib-subscreen,\n.deeplib-modal {\n  --deeplib-background-color: var(--tmd-main, white);\n  --deeplib-element-color: var(--tmd-element, white);\n  --deeplib-element-hover-color: var(--tmd-element-hover, cyan);\n  --deeplib-accent-color: var(--tmd-accent, #FFFF88);\n  --deeplib-blocked-color: var(--tmd-blocked, red);\n  --deeplib-text-color: var(--tmd-text, black);\n  --deeplib-icon-color: var(--tmd-accent, black);\n  --deeplib-icon-hover-color: var(--tmd-accent-hover, black);\n  --deeplib-border-color: var(--tmd-accent, black);\n  --deeplib-border-width: min(0.2vh, 0.1vw);\n  --deeplib-border-width: min(0.2dvh, 0.1dvw);\n  --deeplib-border-radius: min(1vh, 0.5vw);\n  --deeplib-border-radius: min(1dvh, 0.5dvw);\n}\n",".deeplib-button {\n  color: var(--deeplib-text-color);\n  width: 100%;\n  height: 100%;\n}\n\n.deeplib-button.button-styling,\n.deeplib-button.button-styling::before {\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n\n.deeplib-button img {\n  position: absolute;\n  top: 0%;\n  left: 0%;\n  width: 100%;\n  height: 100%;\n  background-position: left;\n  background-color: var(--deeplib-icon-color);\n  background-blend-mode: multiply;\n  background-size: contain;\n  mask-position: left;\n  mask-size: contain;\n  background-repeat: no-repeat;\n  mask-repeat: no-repeat;\n  color: transparent;\n\n  background-image: var(--image);\n  mask-image: var(--image);\n  pointer-events: none;\n}\n\n.deeplib-button:hover img {\n  background-color: var(--deeplib-icon-hover-color);\n}\n\n.deeplib-button .button-label {\n  background-color: transparent !important;\n  color: var(--deeplib-text-color);\n  font-size: min(3.6dvh, 1.8dvw);\n}\n\n.deeplib-button .button-tooltip {\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n","#deeplib-page-label {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n}\n\n#deeplib-subscreen-title {\n  text-align: left;\n  color: var(--deeplib-text-color);\n}\n\n.deeplib-text {\n  color: var(--deeplib-text-color);\n}\n\n.deeplib-subscreen {\n  padding: 0;\n  margin: 0;\n  pointer-events: none;\n}\n\n.deeplib-subscreen * {\n  box-sizing: border-box;\n  pointer-events: all;\n}\n\n.deeplib-settings {\n  display: grid;\n  grid-auto-rows: min-content;\n  padding: min(1.0dvh, 0.5dvw);\n  gap: 0.3em;\n}\n\n.deeplib-misc {\n  display: flex;\n  align-items: center;\n  flex-direction: column-reverse;\n  gap: min(1vh, 0.5vw);\n}\n\n.deeplib-tooltip {\n  background-color: var(--deeplib-element-color);\n  color: var(--deeplib-text-color);\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: min(1.0dvh, 0.5dvw);\n  padding: min(1vh, 0.5vw);\n  font-size: 0.8em;\n  border: min(0.2vh, 0.1vw) solid var(--deeplib-border-color);\n  z-index: 1;\n}\n\n.deeplib-overflow-box {\n  border: var(--deeplib-border-color) solid var(--deeplib-border-width);\n}\n\n.deeplib-prev-next {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  flex-direction: row;\n  gap: min(2dvh, 1dvw);\n  background-color: var(--deeplib-element-color);\n  color: var(--deeplib-text-color);\n  border-radius: min(1.0dvh, 0.5dvw);\n  border: min(0.2vh, 0.1vw) solid var(--deeplib-border-color);\n\n  .deeplib-prev-next-button {\n    &:hover {\n      background-color: var(--deeplib-element-hover-color);\n      border-radius: var(--deeplib-border-radius);\n    }\n    \n    height: 100%;\n    aspect-ratio: 1;\n  }\n\n  .deeplib-prev-next-label {\n    white-space: nowrap;\n  }\n}\n\n#deeplib-nav-menu {\n  display: flex;\n  flex-direction: row;\n  gap: min(2dvh, 1dvw);\n}\n\n#deeplib-storage-meter {\n  position: absolute;\n  top: 0px;\n  left: 0px;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  background-color: var(--deeplib-element-color);\n  border: var(--deeplib-border-width) solid var(--deeplib-border-color);\n  border-radius: var(--deeplib-border-radius);\n  z-index: -1;\n}\n\n#deeplib-storage-bar {\n  height: 100%;\n  width: 0%;\n  background: var(--deeplib-accent-color);\n}\n",".deeplib-checkbox-container {\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: 0.3em;\n}\n\n.deeplib-checkbox-container input.deeplib-input {\n  width: min(5vh, 2.5vw);\n  height: min(5vh, 2.5vw);\n  width: min(5dvh, 2.5dvw);\n  height: min(5dvh, 2.5dvw);\n  border-radius: min(1.0vh, 0.5vw);\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n\n.deeplib-checkbox-container input.deeplib-input[type=\"checkbox\"]:checked::before {\n  width: 80%;\n  height: 80%;\n}\n\n.deeplib-input-container {\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: 0.3em;\n}\n\n.deeplib-input-container:has(label.deeplib-text) {\n  margin-top: min(1vh, 0.5vw);\n  margin-top: min(1dvh, 0.5dvw);\n}\n\n.deeplib-input-container input.deeplib-input {\n  font-size: 0.6em;\n  padding: min(1vh, 0.5vw);\n  padding: min(1dvh, 0.5dvw);\n  background-color: transparent;\n  outline: none;\n  min-height: min(5vh, 2.5vw);\n  min-height: min(5dvh, 2.5dvw);\n  border-radius: min(1.0vh, 0.5vw);\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n\n.deeplib-input-container input.deeplib-input[type=\"color\"] {\n  padding: 0px;\n  width: min(5vh, 2.5vw);\n  height: min(5vh, 2.5vw);\n  width: min(5dvh, 2.5dvw);\n  height: min(5dvh, 2.5dvw);\n  border-radius: 0px;\n}\n\n.deeplib-input-container input.deeplib-input[type=\"color\"]:disabled {\n  border: var(--deeplib-blocked-color) solid var(--deeplib-border-width);\n  cursor: not-allowed;\n}\n\n.deeplib-dropdown-container {\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: min(2vh, 1vw);\n  gap: min(2dvh, 1dvw);\n  color: var(--deeplib-text-color);\n\n  select {\n    padding: 0 min(1vh, 0.5vw);\n    padding: 0 min(1dvh, 0.5dvw);\n    border-radius: min(1vh, 0.5vw);\n    border-radius: min(1dvh, 0.5dvw);\n  }\n}",".deeplib-highlight-text {\n  font-weight: bold;\n  color: rgb(203, 185, 23);\n}\n\n#TextAreaChatLog[data-colortheme='dark'] div.ChatMessage.deeplib-message,\n#TextAreaChatLog[data-colortheme='dark2'] div.ChatMessage.deeplib-message {\n  background-color: var(--deeplib-element-color);\n  border: min(0.2dvh, 0.1dvw) solid var(--deeplib-border-color);\n  color: var(--deeplib-text-color);\n}\n\n#TextAreaChatLog div.ChatMessage.deeplib-message {\n  background-color: #eee;\n  border: min(0.2dvh, 0.1dvw) solid #440171;\n  color: #111;\n  padding-left: min(0.6dvh, 0.3dvw);\n  display: block;\n  white-space: normal;\n}\n\n#TextAreaChatLog[data-colortheme='dark'] div.ChatMessage.deeplib-message a,\n#TextAreaChatLog[data-colortheme='dark2'] div.ChatMessage.deeplib-message a {\n  color: var(--deeplib-text-color);\n}\n\n#TextAreaChatLog div.ChatMessage.deeplib-message a {\n  cursor: pointer;\n  font-weight: bold;\n  color: #111;\n}\n",".deeplib-modal {\n  position: fixed;\n  top: 10%;\n  left: 50%;\n  transform: translateX(-50%);\n  z-index: 1001;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  gap: 0.5em;\n  width: max(50dvw, 25dvh);\n  font-size: min(4dvh, 2dvw);\n  padding: min(2dvh, 1dvw);\n  background-color: var(--deeplib-element-color);\n  border-radius: min(1.2dvh, 0.6dvw);\n  border: min(0.2dvh, 0.1dvw) solid var(--deeplib-border-color);\n  color: var(--deeplib-text-color);\n\n  .deeplib-modal-input {\n    width: 100%;\n    font-size: min(2.6dvh, 1.8dvw);\n    border-radius: min(1.0dvh, 0.5dvw);\n    padding: min(1dvh, 0.5dvw);\n  }\n\n  input.deeplib-modal-input {\n    max-width: max(50dvh, 25dvw);\n  }\n\n  .deeplib-modal-button-container {\n    display: flex;\n    flex-direction: row;\n    justify-content: flex-end;\n    gap: 0.5em;\n    width: 100%;\n\n    .deeplib-button {\n      font-size: 0.8em;\n      display: flex;\n      width: auto;\n      padding: min(0.4vh, 0.2vw) min(2vh, 1vw);\n\n      .button-label {\n        display: contents;\n      }\n    }\n  }\n\n  .deeplib-modal-prompt-container {\n    display: flex;\n    flex-direction: column;\n    justify-content: center;\n    align-items: center;\n  }\n}\n\n.deeplib-modal-blocker {\n  z-index: 1000;\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100dvw;\n  height: 100dvh;\n  background-color: rgba(0, 0, 0, 0.5);\n}\n"]} */`;
|
|
942
|
+
/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/mnt/shindows/Stuff/Code/bc/BC-DeepLib/src/styles","sources":["vars.scss","buttons.scss","elements.scss","inputs.scss","messages.scss","modal.scss"],"names":[],"mappings":"AAAA;AAAA;EAEE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;ACdF;EACE;EACA;EACA;;;AAGF;AAAA;EAEE;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EAEA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;;;AAGF;EACE;;;AC3CF;EACE;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;EACA;;AAHJ;EAME;EACA;;AAGF;EACE;;;AAIJ;EACE;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;;;ACzGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;;ACvEJ;EACE;EACA;;;AAGF;AAAA;EAEE;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;AAAA;EAEE;;;AAGF;EACE;EACA;EACA;;;AC7BF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAGF;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAEA;EACE;;AAKN;EACE;EACA;EACA;EACA;;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA","sourcesContent":[".deeplib-subscreen,\n.deeplib-modal {\n  --deeplib-background-color: var(--tmd-main, white);\n  --deeplib-element-color: var(--tmd-element, white);\n  --deeplib-element-hover-color: var(--tmd-element-hover, cyan);\n  --deeplib-accent-color: var(--tmd-accent, #FFFF88);\n  --deeplib-blocked-color: var(--tmd-blocked, red);\n  --deeplib-text-color: var(--tmd-text, black);\n  --deeplib-icon-color: var(--tmd-accent, black);\n  --deeplib-icon-hover-color: var(--tmd-accent-hover, black);\n  --deeplib-border-color: var(--tmd-accent, black);\n  --deeplib-border-width: min(0.2vh, 0.1vw);\n  --deeplib-border-width: min(0.2dvh, 0.1dvw);\n  --deeplib-border-radius: min(1vh, 0.5vw);\n  --deeplib-border-radius: min(1dvh, 0.5dvw);\n}\n",".deeplib-button {\n  color: var(--deeplib-text-color);\n  width: 100%;\n  height: 100%;\n}\n\n.deeplib-button.button-styling,\n.deeplib-button.button-styling::before {\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n\n.deeplib-button img {\n  position: absolute;\n  top: 0%;\n  left: 0%;\n  width: 100%;\n  height: 100%;\n  background-position: left;\n  background-color: var(--deeplib-icon-color);\n  background-blend-mode: multiply;\n  background-size: contain;\n  mask-position: left;\n  mask-size: contain;\n  background-repeat: no-repeat;\n  mask-repeat: no-repeat;\n  color: transparent;\n\n  background-image: var(--image);\n  mask-image: var(--image);\n  pointer-events: none;\n}\n\n.deeplib-button:hover img {\n  background-color: var(--deeplib-icon-hover-color);\n}\n\n.deeplib-button .button-label {\n  background-color: transparent !important;\n  color: var(--deeplib-text-color);\n  font-size: min(3.6dvh, 1.8dvw);\n}\n\n.deeplib-button .button-tooltip {\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n","#deeplib-page-label {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n}\n\n#deeplib-subscreen-title {\n  text-align: left;\n  color: var(--deeplib-text-color);\n}\n\n.deeplib-text {\n  color: var(--deeplib-text-color);\n}\n\n.deeplib-subscreen {\n  padding: 0;\n  margin: 0;\n  pointer-events: none;\n}\n\n.deeplib-subscreen * {\n  box-sizing: border-box;\n  pointer-events: all;\n}\n\n.deeplib-settings {\n  display: grid;\n  grid-auto-rows: min-content;\n  padding: min(1.0dvh, 0.5dvw);\n  gap: 0.3em;\n}\n\n.deeplib-misc {\n  display: flex;\n  align-items: center;\n  flex-direction: column-reverse;\n  gap: min(1vh, 0.5vw);\n}\n\n.deeplib-tooltip {\n  background-color: var(--deeplib-element-color);\n  color: var(--deeplib-text-color);\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: min(1.0dvh, 0.5dvw);\n  padding: min(1vh, 0.5vw);\n  font-size: 0.8em;\n  border: min(0.2vh, 0.1vw) solid var(--deeplib-border-color);\n  z-index: 1;\n}\n\n.deeplib-overflow-box {\n  border: var(--deeplib-border-color) solid var(--deeplib-border-width);\n}\n\n.deeplib-prev-next {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  flex-direction: row;\n  gap: min(2dvh, 1dvw);\n  background-color: var(--deeplib-element-color);\n  color: var(--deeplib-text-color);\n  border-radius: min(1.0dvh, 0.5dvw);\n  border: min(0.2vh, 0.1vw) solid var(--deeplib-border-color);\n\n  .deeplib-prev-next-button {\n    &:hover {\n      background-color: var(--deeplib-element-hover-color);\n      border-radius: var(--deeplib-border-radius);\n    }\n    \n    height: 100%;\n    aspect-ratio: 1;\n  }\n\n  .deeplib-prev-next-label {\n    white-space: nowrap;\n  }\n}\n\n#deeplib-nav-menu {\n  display: flex;\n  flex-direction: row;\n  gap: min(2dvh, 1dvw);\n}\n\n#deeplib-storage-meter {\n  position: absolute;\n  top: 0px;\n  left: 0px;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  background-color: var(--deeplib-element-color);\n  border: var(--deeplib-border-width) solid var(--deeplib-border-color);\n  border-radius: var(--deeplib-border-radius);\n  z-index: -1;\n}\n\n#deeplib-storage-bar {\n  height: 100%;\n  width: 0%;\n  background: var(--deeplib-accent-color);\n}\n",".deeplib-checkbox-container {\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: 0.3em;\n}\n\n.deeplib-checkbox-container input.deeplib-input {\n  width: min(5vh, 2.5vw);\n  height: min(5vh, 2.5vw);\n  width: min(5dvh, 2.5dvw);\n  height: min(5dvh, 2.5dvw);\n  border-radius: min(1.0vh, 0.5vw);\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n\n.deeplib-checkbox-container input.deeplib-input[type=\"checkbox\"]:checked::before {\n  width: 80%;\n  height: 80%;\n}\n\n.deeplib-input-container {\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: 0.3em;\n}\n\n.deeplib-input-container:has(label.deeplib-text) {\n  margin-top: min(1vh, 0.5vw);\n  margin-top: min(1dvh, 0.5dvw);\n}\n\n.deeplib-input-container input.deeplib-input {\n  font-size: 0.6em;\n  padding: min(1vh, 0.5vw);\n  padding: min(1dvh, 0.5dvw);\n  background-color: transparent;\n  outline: none;\n  min-height: min(5vh, 2.5vw);\n  min-height: min(5dvh, 2.5dvw);\n  border-radius: min(1.0vh, 0.5vw);\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n\n.deeplib-input-container input.deeplib-input[type=\"color\"] {\n  padding: 0px;\n  width: min(5vh, 2.5vw);\n  height: min(5vh, 2.5vw);\n  width: min(5dvh, 2.5dvw);\n  height: min(5dvh, 2.5dvw);\n  border-radius: 0px;\n}\n\n.deeplib-input-container input.deeplib-input[type=\"color\"]:disabled {\n  border: var(--deeplib-blocked-color) solid var(--deeplib-border-width);\n  cursor: not-allowed;\n}\n\n.deeplib-dropdown-container {\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: min(2vh, 1vw);\n  gap: min(2dvh, 1dvw);\n  color: var(--deeplib-text-color);\n\n  select {\n    padding: 0 min(1vh, 0.5vw);\n    padding: 0 min(1dvh, 0.5dvw);\n    border-radius: min(1vh, 0.5vw);\n    border-radius: min(1dvh, 0.5dvw);\n  }\n}",".deeplib-highlight-text {\n  font-weight: bold;\n  color: rgb(203, 185, 23);\n}\n\n#TextAreaChatLog[data-colortheme='dark'] div.ChatMessage.deeplib-message,\n#TextAreaChatLog[data-colortheme='dark2'] div.ChatMessage.deeplib-message {\n  background-color: var(--deeplib-element-color);\n  border: min(0.2dvh, 0.1dvw) solid var(--deeplib-border-color);\n  color: var(--deeplib-text-color);\n}\n\n#TextAreaChatLog div.ChatMessage.deeplib-message {\n  background-color: #eee;\n  border: min(0.2dvh, 0.1dvw) solid #440171;\n  color: #111;\n  padding-left: min(0.6dvh, 0.3dvw);\n  display: block;\n  white-space: normal;\n}\n\n#TextAreaChatLog[data-colortheme='dark'] div.ChatMessage.deeplib-message a,\n#TextAreaChatLog[data-colortheme='dark2'] div.ChatMessage.deeplib-message a {\n  color: var(--deeplib-text-color);\n}\n\n#TextAreaChatLog div.ChatMessage.deeplib-message a {\n  cursor: pointer;\n  font-weight: bold;\n  color: #111;\n}\n",".deeplib-modal {\n  position: fixed;\n  top: 10%;\n  left: 50%;\n  transform: translateX(-50%);\n  z-index: 1001;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  gap: 0.5em;\n  width: max(50dvw, 25dvh);\n  font-size: min(4dvh, 2dvw);\n  padding: min(2dvh, 1dvw);\n  background-color: var(--deeplib-element-color);\n  border-radius: min(1.2dvh, 0.6dvw);\n  border: min(0.2dvh, 0.1dvw) solid var(--deeplib-border-color);\n  color: var(--deeplib-text-color);\n\n  .deeplib-modal-input {\n    width: 100%;\n    font-size: min(2.6dvh, 1.8dvw);\n    border-radius: min(1.0dvh, 0.5dvw);\n    padding: min(1dvh, 0.5dvw);\n  }\n\n  input.deeplib-modal-input {\n    max-width: max(50dvh, 25dvw);\n  }\n\n  .deeplib-modal-button-container {\n    display: flex;\n    flex-direction: row;\n    justify-content: flex-end;\n    gap: 0.5em;\n    width: 100%;\n\n    .deeplib-button {\n      font-size: 0.8em;\n      display: flex;\n      width: auto;\n      padding: min(0.4vh, 0.2vw) min(2vh, 1vw);\n\n      .button-label {\n        display: contents;\n      }\n    }\n  }\n\n  .deeplib-modal-prompt-container {\n    display: flex;\n    flex-direction: column;\n    justify-content: center;\n    align-items: center;\n  }\n}\n\n.deeplib-modal-blocker {\n  z-index: 1000;\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100dvw;\n  height: 100dvh;\n  background-color: rgba(0, 0, 0, 0.5);\n}\n"]} */`;
|
|
932
943
|
|
|
933
944
|
// src/base/initialization.ts
|
|
934
945
|
var modStorage;
|
|
935
946
|
var sdk;
|
|
947
|
+
var logger;
|
|
936
948
|
function initMod(options) {
|
|
937
949
|
sdk = new ModSdkManager(options.modInfo.info, options.modInfo.options);
|
|
938
950
|
const MOD_NAME = ModSdkManager.ModInfo.name;
|
|
939
951
|
modStorage = new ModStorage(ModSdkManager.ModInfo.name);
|
|
952
|
+
logger = new Logger(MOD_NAME);
|
|
940
953
|
Style.injectInline("deeplib-style", styles_default);
|
|
941
|
-
|
|
954
|
+
logger.debug("Init wait");
|
|
942
955
|
if (CurrentScreen == null || CurrentScreen === "Login") {
|
|
943
956
|
options.beforeLogin?.();
|
|
944
957
|
const removeHook = sdk.hookFunction("LoginResponse", 0, (args, next) => {
|
|
945
|
-
|
|
958
|
+
logger.debug("Init! LoginResponse caught: ", args);
|
|
946
959
|
next(args);
|
|
947
960
|
const response = args[0];
|
|
948
961
|
if (response === "InvalidNamePassword") return next(args);
|
|
@@ -952,7 +965,7 @@ function initMod(options) {
|
|
|
952
965
|
}
|
|
953
966
|
});
|
|
954
967
|
} else {
|
|
955
|
-
|
|
968
|
+
logger.debug(`Already logged in, initing ${MOD_NAME}`);
|
|
956
969
|
init(options);
|
|
957
970
|
}
|
|
958
971
|
}
|
|
@@ -967,11 +980,6 @@ async function init(options) {
|
|
|
967
980
|
unloadMod();
|
|
968
981
|
return;
|
|
969
982
|
}
|
|
970
|
-
if (options.migrators) {
|
|
971
|
-
for (const m of options.migrators) {
|
|
972
|
-
VersionModule.registerMigrator(m);
|
|
973
|
-
}
|
|
974
|
-
}
|
|
975
983
|
await options.initFunction?.();
|
|
976
984
|
if (options.mainMenuOptions)
|
|
977
985
|
MainMenu.setOptions(options.mainMenuOptions);
|
|
@@ -982,11 +990,10 @@ async function init(options) {
|
|
|
982
990
|
}
|
|
983
991
|
}
|
|
984
992
|
window[MOD_NAME + "Loaded"] = true;
|
|
985
|
-
|
|
993
|
+
logger.log(`Loaded! Version: ${MOD_VERSION}`);
|
|
986
994
|
}
|
|
987
995
|
__name(init, "init");
|
|
988
996
|
function initModules(modulesToRegister) {
|
|
989
|
-
const MOD_NAME = ModSdkManager.ModInfo.name;
|
|
990
997
|
for (const module of modulesToRegister) {
|
|
991
998
|
registerModule(module);
|
|
992
999
|
}
|
|
@@ -999,7 +1006,7 @@ function initModules(modulesToRegister) {
|
|
|
999
1006
|
for (const module of modules()) {
|
|
1000
1007
|
module.run();
|
|
1001
1008
|
}
|
|
1002
|
-
|
|
1009
|
+
logger.debug("Modules Loaded.");
|
|
1003
1010
|
return true;
|
|
1004
1011
|
}
|
|
1005
1012
|
__name(initModules, "initModules");
|
|
@@ -1007,7 +1014,7 @@ function unloadMod() {
|
|
|
1007
1014
|
const MOD_NAME = ModSdkManager.ModInfo.name;
|
|
1008
1015
|
unloadModules();
|
|
1009
1016
|
delete window[MOD_NAME + "Loaded"];
|
|
1010
|
-
|
|
1017
|
+
logger.debug("Unloaded.");
|
|
1011
1018
|
return true;
|
|
1012
1019
|
}
|
|
1013
1020
|
__name(unloadMod, "unloadMod");
|
|
@@ -1035,7 +1042,7 @@ function getModule(moduleType) {
|
|
|
1035
1042
|
__name(getModule, "getModule");
|
|
1036
1043
|
|
|
1037
1044
|
// src/migrators/base_migrator.ts
|
|
1038
|
-
var
|
|
1045
|
+
var BaseMigrator = class {
|
|
1039
1046
|
static {
|
|
1040
1047
|
__name(this, "BaseMigrator");
|
|
1041
1048
|
}
|
|
@@ -1120,21 +1127,20 @@ var VersionModule = class _VersionModule extends BaseModule {
|
|
|
1120
1127
|
static isItNewVersion = false;
|
|
1121
1128
|
/** The current mod version (retrieved from `ModSdkManager.ModInfo.version`) */
|
|
1122
1129
|
static version;
|
|
1123
|
-
/** Message to display when a new version is detected */
|
|
1124
1130
|
static newVersionMessage = "";
|
|
1125
1131
|
/** List of registered migration handlers, sorted by version */
|
|
1126
1132
|
static migrators = [];
|
|
1127
|
-
/** Optional lifecycle hook. Runs before each migration */
|
|
1128
1133
|
static beforeEach;
|
|
1129
|
-
/** Optional lifecycle hook. Runs after each migration */
|
|
1130
1134
|
static afterEach;
|
|
1131
|
-
/** Optional lifecycle hook. Runs before all migrations */
|
|
1132
1135
|
static beforeAll;
|
|
1133
|
-
/** Optional lifecycle hook. Runs after all migrations */
|
|
1134
1136
|
static afterAll;
|
|
1135
1137
|
constructor(options) {
|
|
1136
1138
|
super();
|
|
1137
1139
|
_VersionModule.newVersionMessage = options.newVersionMessage;
|
|
1140
|
+
if (options.migrators) {
|
|
1141
|
+
_VersionModule.migrators = options.migrators;
|
|
1142
|
+
_VersionModule.migrators.sort((a, b) => a.migrationVersion.localeCompare(b.migrationVersion));
|
|
1143
|
+
}
|
|
1138
1144
|
_VersionModule.beforeEach = options.beforeEach;
|
|
1139
1145
|
_VersionModule.afterEach = options.afterEach;
|
|
1140
1146
|
_VersionModule.beforeAll = options.beforeAll;
|
|
@@ -1191,14 +1197,6 @@ var VersionModule = class _VersionModule extends BaseModule {
|
|
|
1191
1197
|
}
|
|
1192
1198
|
_VersionModule.afterAll?.();
|
|
1193
1199
|
}
|
|
1194
|
-
/**
|
|
1195
|
-
* Registers a new migrator for handling version-specific changes.
|
|
1196
|
-
* Migrators are sorted by their `MigrationVersion` in ascending order.
|
|
1197
|
-
*/
|
|
1198
|
-
static registerMigrator(migrator) {
|
|
1199
|
-
_VersionModule.migrators.push(migrator);
|
|
1200
|
-
_VersionModule.migrators.sort((a, b) => a.migrationVersion.localeCompare(b.migrationVersion));
|
|
1201
|
-
}
|
|
1202
1200
|
/** Sends the currently configured "new version" message to the local player. */
|
|
1203
1201
|
static sendNewVersionMessage() {
|
|
1204
1202
|
if (!_VersionModule.newVersionMessage) return;
|
|
@@ -2245,7 +2243,7 @@ var MainMenu = class _MainMenu extends BaseSubscreen {
|
|
|
2245
2243
|
PreferenceSubscreenExtensionsClear();
|
|
2246
2244
|
});
|
|
2247
2245
|
} else if (returnScreen instanceof BaseSubscreen) {
|
|
2248
|
-
setSubscreen(returnScreen
|
|
2246
|
+
setSubscreen(returnScreen).then(() => {
|
|
2249
2247
|
});
|
|
2250
2248
|
} else if (Array.isArray(returnScreen)) {
|
|
2251
2249
|
CommonSetScreen(...returnScreen);
|
|
@@ -2260,18 +2258,6 @@ var MainMenu = class _MainMenu extends BaseSubscreen {
|
|
|
2260
2258
|
_MainMenu.options = mainMenuOptions;
|
|
2261
2259
|
}
|
|
2262
2260
|
};
|
|
2263
|
-
async function PreferenceOpenSubscreen(subscreen, page = 1) {
|
|
2264
|
-
if (CurrentModule !== "Character" || CurrentScreen !== "Preference") {
|
|
2265
|
-
await CommonSetScreen("Character", "Preference");
|
|
2266
|
-
}
|
|
2267
|
-
PreferenceSubscreen?.unload?.();
|
|
2268
|
-
PreferenceSubscreen = PreferenceSubscreens.find((s) => s.name === subscreen) ?? null;
|
|
2269
|
-
if (!CommonIsNonNegativeInteger(page)) page = 1;
|
|
2270
|
-
PreferencePageCurrent = page;
|
|
2271
|
-
PreferenceMessage = "";
|
|
2272
|
-
PreferenceSubscreen?.load?.();
|
|
2273
|
-
}
|
|
2274
|
-
__name(PreferenceOpenSubscreen, "PreferenceOpenSubscreen");
|
|
2275
2261
|
|
|
2276
2262
|
// src/screens/import_export.ts
|
|
2277
2263
|
var GuiImportExport = class extends BaseSubscreen {
|
|
@@ -2347,7 +2333,10 @@ var GuiImportExport = class extends BaseSubscreen {
|
|
|
2347
2333
|
if (transferMethod === "clipboard") {
|
|
2348
2334
|
await this.exportToClipboard(data);
|
|
2349
2335
|
} else if (transferMethod === "file") {
|
|
2350
|
-
await this.exportToFile(data, "
|
|
2336
|
+
if (!await this.exportToFile(data, "settings")) {
|
|
2337
|
+
return;
|
|
2338
|
+
}
|
|
2339
|
+
;
|
|
2351
2340
|
}
|
|
2352
2341
|
this.importExportOptions.onExport?.();
|
|
2353
2342
|
ToastManager.success("Data exported successfully.");
|
|
@@ -2372,6 +2361,9 @@ var GuiImportExport = class extends BaseSubscreen {
|
|
|
2372
2361
|
if (!data) {
|
|
2373
2362
|
throw new Error("Invalid data.");
|
|
2374
2363
|
}
|
|
2364
|
+
for (const module of modules()) {
|
|
2365
|
+
module.registerDefaultSettings(data);
|
|
2366
|
+
}
|
|
2375
2367
|
modStorage.playerStorage = data;
|
|
2376
2368
|
this.importExportOptions.onImport?.();
|
|
2377
2369
|
ToastManager.success("Data imported successfully.");
|
|
@@ -2398,13 +2390,14 @@ var GuiImportExport = class extends BaseSubscreen {
|
|
|
2398
2390
|
const writable = await handle.createWritable();
|
|
2399
2391
|
await writable.write(data);
|
|
2400
2392
|
await writable.close();
|
|
2393
|
+
return true;
|
|
2401
2394
|
} catch (error) {
|
|
2402
2395
|
throw new Error("File save cancelled or failed: " + error.message);
|
|
2403
2396
|
}
|
|
2404
2397
|
} else {
|
|
2405
2398
|
const fileName = await Modal.prompt("Enter file name", suggestedName);
|
|
2406
2399
|
if (fileName === null) {
|
|
2407
|
-
return;
|
|
2400
|
+
return false;
|
|
2408
2401
|
} else if (fileName === "") {
|
|
2409
2402
|
throw new Error("File name cannot be empty.");
|
|
2410
2403
|
}
|
|
@@ -2418,6 +2411,7 @@ var GuiImportExport = class extends BaseSubscreen {
|
|
|
2418
2411
|
});
|
|
2419
2412
|
link.click();
|
|
2420
2413
|
URL.revokeObjectURL(link.href);
|
|
2414
|
+
return true;
|
|
2421
2415
|
}
|
|
2422
2416
|
}
|
|
2423
2417
|
/** Opens a file picker and reads the selected file's contents, importing the data. */
|
|
@@ -3139,7 +3133,7 @@ var EventChannel = class {
|
|
|
3139
3133
|
}
|
|
3140
3134
|
};
|
|
3141
3135
|
export {
|
|
3142
|
-
|
|
3136
|
+
BaseMigrator,
|
|
3143
3137
|
BaseModule,
|
|
3144
3138
|
BaseSubscreen,
|
|
3145
3139
|
EventChannel,
|
|
@@ -3168,6 +3162,7 @@ export {
|
|
|
3168
3162
|
hasSetter,
|
|
3169
3163
|
initMod,
|
|
3170
3164
|
layout,
|
|
3165
|
+
logger,
|
|
3171
3166
|
modStorage,
|
|
3172
3167
|
modules,
|
|
3173
3168
|
modulesMap,
|