bc-deeplib 2.3.0 → 2.4.1
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 +8 -9
- package/dist/deeplib.js +69 -72
- package/dist/deeplib.js.map +3 -3
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +1 -1
package/dist/deeplib.d.ts
CHANGED
|
@@ -182,6 +182,8 @@ declare module 'bc-deeplib/base/base_subscreen' {
|
|
|
182
182
|
static readonly id: string;
|
|
183
183
|
/** Optional configuration flags for a BaseSubscreen instance. */
|
|
184
184
|
protected static readonly subscreenOptions: SubscreenOptions;
|
|
185
|
+
/** The menu at the top of the subscreen */
|
|
186
|
+
protected static menu: HTMLDivElement | null;
|
|
185
187
|
constructor(module?: BaseModule);
|
|
186
188
|
/** Changes the currently active subscreen. */
|
|
187
189
|
setSubscreen(screen: BaseSubscreen | string): Promise<void>;
|
|
@@ -764,13 +766,16 @@ declare module 'bc-deeplib/screens/main_menu' {
|
|
|
764
766
|
|
|
765
767
|
}
|
|
766
768
|
declare module 'bc-deeplib/utilities/common' {
|
|
769
|
+
export type DeepMergeOptions = {
|
|
770
|
+
concatArrays?: boolean;
|
|
771
|
+
};
|
|
767
772
|
/**
|
|
768
773
|
* Deeply merges two values into a new value.
|
|
769
774
|
* - Arrays are concatenated.
|
|
770
775
|
* - Plain objects are merged recursively.
|
|
771
776
|
* - Other values are replaced by `source`.
|
|
772
777
|
*/
|
|
773
|
-
export function deepMerge<T, U>(target: T, source: U): T & U;
|
|
778
|
+
export function deepMerge<T, U>(target: T, source: U, options?: DeepMergeOptions): T & U;
|
|
774
779
|
/**
|
|
775
780
|
* Returns a new array with elements of the input array shuffled.
|
|
776
781
|
* Uses something-something shuffle algorithm by splicing from a cloned array.
|
|
@@ -783,12 +788,6 @@ declare module 'bc-deeplib/utilities/common' {
|
|
|
783
788
|
* Example: `exportToGlobal('MyMod.Utils', value)` creates `globalThis.MyMod.Utils = value`.
|
|
784
789
|
*/
|
|
785
790
|
export function exportToGlobal(name: string, value: any): void;
|
|
786
|
-
/**
|
|
787
|
-
* Deeply merges only matching properties from `mergeFrom` into `mergeTo`.
|
|
788
|
-
* Properties not present in `mergeTo` are ignored.
|
|
789
|
-
* Objects are recursively merged, primitive properties overwritten.
|
|
790
|
-
*/
|
|
791
|
-
export function deepMergeMatchingProperties<T extends object>(mergeTo: T, mergeFrom: T): T;
|
|
792
791
|
/** Checks if the given property has a getter defined on the object or its prototype chain. */
|
|
793
792
|
export function hasGetter<T extends object>(obj: T, prop: keyof T | string): boolean;
|
|
794
793
|
/** Checks if the given property has a setter defined on the object or its prototype chain. */
|
|
@@ -850,10 +849,10 @@ declare module 'bc-deeplib/utilities/elements/elements' {
|
|
|
850
849
|
};
|
|
851
850
|
function elementCreateButton(options: Omit<Button, 'type'>): HTMLButtonElement;
|
|
852
851
|
function elementCreateCheckbox(options: Omit<Checkbox, 'type'>): HTMLElement;
|
|
853
|
-
function elementCreateCustom(options: Omit<Custom, 'type'>):
|
|
852
|
+
function elementCreateCustom(options: Omit<Custom, 'type'>): HTMLElement;
|
|
854
853
|
function elementCreateInput(options: Input): HTMLElement;
|
|
855
854
|
function elementCreateLabel(options: Omit<Label, 'type'>): HTMLElement;
|
|
856
|
-
function elementCreateDropdown(options: Omit<Dropdown, 'type'>): HTMLDivElement;
|
|
855
|
+
function elementCreateDropdown(options: Omit<Dropdown, 'type'>): HTMLDivElement | HTMLLabelElement;
|
|
857
856
|
function elementCreateTooltip(): HTMLDivElement;
|
|
858
857
|
function elementGetTooltip(): HTMLElement | undefined;
|
|
859
858
|
function elementSetTooltip(text: string): boolean;
|
package/dist/deeplib.js
CHANGED
|
@@ -258,7 +258,6 @@ var BaseModule = class {
|
|
|
258
258
|
* Subclasses can override to perform additional setup.
|
|
259
259
|
*/
|
|
260
260
|
init() {
|
|
261
|
-
this.registerDefaultSettings(modStorage.playerStorage);
|
|
262
261
|
}
|
|
263
262
|
/**
|
|
264
263
|
* Registers default settings for this module in persistent storage.
|
|
@@ -271,7 +270,8 @@ var BaseModule = class {
|
|
|
271
270
|
const storage = this.settingsStorage;
|
|
272
271
|
const defaults = this.defaultSettings;
|
|
273
272
|
if (!storage || !defaults) return;
|
|
274
|
-
|
|
273
|
+
if (Object.entries(this.defaultSettings).length === 0) return;
|
|
274
|
+
target[storage] = deepMerge(this.defaultSettings, target[storage], { concatArrays: false });
|
|
275
275
|
}
|
|
276
276
|
/**
|
|
277
277
|
* Provides default settings for this module.
|
|
@@ -335,6 +335,8 @@ var BaseSubscreen = class _BaseSubscreen {
|
|
|
335
335
|
settingsWidth: 1e3,
|
|
336
336
|
forceUpCharacter: false
|
|
337
337
|
};
|
|
338
|
+
/** The menu at the top of the subscreen */
|
|
339
|
+
static menu = null;
|
|
338
340
|
constructor(module) {
|
|
339
341
|
if (module) this.module = module;
|
|
340
342
|
const ctor = this.constructor;
|
|
@@ -432,8 +434,8 @@ var BaseSubscreen = class _BaseSubscreen {
|
|
|
432
434
|
layout.getSubscreen();
|
|
433
435
|
const settingsElement = layout.getSettingsDiv();
|
|
434
436
|
layout.appendToSubscreen(settingsElement);
|
|
435
|
-
|
|
436
|
-
layout.appendToSubscreen(menu);
|
|
437
|
+
_BaseSubscreen.menu = ElementMenu.Create("deeplib-nav-menu", []);
|
|
438
|
+
layout.appendToSubscreen(_BaseSubscreen.menu);
|
|
437
439
|
if (this.pageStructure.length > 1) {
|
|
438
440
|
const backNext = advElement.createBackNext({
|
|
439
441
|
id: "deeplib-page-back-next",
|
|
@@ -443,7 +445,7 @@ var BaseSubscreen = class _BaseSubscreen {
|
|
|
443
445
|
initialPrevTooltip: getText("settings.button.prev_button_hint"),
|
|
444
446
|
initialLabel: this.getPageLabel()
|
|
445
447
|
});
|
|
446
|
-
|
|
448
|
+
_BaseSubscreen.menu.prepend(backNext);
|
|
447
449
|
}
|
|
448
450
|
if (this.options.help) {
|
|
449
451
|
const onClick = this.options.help.onClick;
|
|
@@ -467,7 +469,7 @@ var BaseSubscreen = class _BaseSubscreen {
|
|
|
467
469
|
tooltip: this.options.help.tooltip
|
|
468
470
|
}
|
|
469
471
|
});
|
|
470
|
-
|
|
472
|
+
_BaseSubscreen.menu.append(helpButton);
|
|
471
473
|
}
|
|
472
474
|
if (this.options.doShowTitle) {
|
|
473
475
|
const subscreenTitle = advElement.createLabel({
|
|
@@ -488,7 +490,7 @@ var BaseSubscreen = class _BaseSubscreen {
|
|
|
488
490
|
tooltip: getText("settings.button.back_button_hint")
|
|
489
491
|
}
|
|
490
492
|
});
|
|
491
|
-
|
|
493
|
+
_BaseSubscreen.menu.append(exitButton);
|
|
492
494
|
}
|
|
493
495
|
const tooltip = advElement.createTooltip();
|
|
494
496
|
layout.appendToSubscreen(tooltip);
|
|
@@ -628,12 +630,9 @@ var styles_default = `.deeplib-subscreen,
|
|
|
628
630
|
width: 100%;
|
|
629
631
|
height: 100%;
|
|
630
632
|
}
|
|
631
|
-
|
|
632
|
-
.deeplib-button.button-styling,
|
|
633
|
-
.deeplib-button.button-styling::before {
|
|
633
|
+
.deeplib-button.button-styling, .deeplib-button.button-styling::before {
|
|
634
634
|
border-radius: min(1dvh, 0.5dvw);
|
|
635
635
|
}
|
|
636
|
-
|
|
637
636
|
.deeplib-button img {
|
|
638
637
|
position: absolute;
|
|
639
638
|
top: 0%;
|
|
@@ -653,17 +652,15 @@ var styles_default = `.deeplib-subscreen,
|
|
|
653
652
|
mask-image: var(--image);
|
|
654
653
|
pointer-events: none;
|
|
655
654
|
}
|
|
656
|
-
|
|
657
655
|
.deeplib-button:hover img {
|
|
658
656
|
background-color: var(--deeplib-icon-hover-color);
|
|
659
657
|
}
|
|
660
|
-
|
|
661
658
|
.deeplib-button .button-label {
|
|
662
659
|
background-color: transparent !important;
|
|
663
660
|
color: var(--deeplib-text-color);
|
|
664
661
|
font-size: min(3.6dvh, 1.8dvw);
|
|
662
|
+
display: contents;
|
|
665
663
|
}
|
|
666
|
-
|
|
667
664
|
.deeplib-button .button-tooltip {
|
|
668
665
|
border-radius: min(1dvh, 0.5dvw);
|
|
669
666
|
}
|
|
@@ -672,11 +669,14 @@ var styles_default = `.deeplib-subscreen,
|
|
|
672
669
|
display: flex;
|
|
673
670
|
align-items: center;
|
|
674
671
|
justify-content: center;
|
|
672
|
+
pointer-events: none;
|
|
675
673
|
}
|
|
676
674
|
|
|
677
675
|
#deeplib-subscreen-title {
|
|
678
676
|
text-align: left;
|
|
679
677
|
color: var(--deeplib-text-color);
|
|
678
|
+
user-select: none;
|
|
679
|
+
pointer-events: none;
|
|
680
680
|
}
|
|
681
681
|
|
|
682
682
|
.deeplib-text {
|
|
@@ -746,12 +746,17 @@ var styles_default = `.deeplib-subscreen,
|
|
|
746
746
|
}
|
|
747
747
|
.deeplib-prev-next .deeplib-prev-next-label {
|
|
748
748
|
white-space: nowrap;
|
|
749
|
+
user-select: none;
|
|
749
750
|
}
|
|
750
751
|
|
|
751
752
|
#deeplib-nav-menu {
|
|
752
753
|
display: flex;
|
|
753
754
|
flex-direction: row;
|
|
754
755
|
gap: min(2dvh, 1dvw);
|
|
756
|
+
z-index: 1;
|
|
757
|
+
}
|
|
758
|
+
#deeplib-nav-menu > .deeplib-button {
|
|
759
|
+
flex: 1 0 auto;
|
|
755
760
|
}
|
|
756
761
|
|
|
757
762
|
#deeplib-storage-meter {
|
|
@@ -766,8 +771,7 @@ var styles_default = `.deeplib-subscreen,
|
|
|
766
771
|
border-radius: var(--deeplib-border-radius);
|
|
767
772
|
z-index: -1;
|
|
768
773
|
}
|
|
769
|
-
|
|
770
|
-
#deeplib-storage-bar {
|
|
774
|
+
#deeplib-storage-meter #deeplib-storage-bar {
|
|
771
775
|
height: 100%;
|
|
772
776
|
width: 0%;
|
|
773
777
|
background: var(--deeplib-accent-color);
|
|
@@ -778,9 +782,12 @@ var styles_default = `.deeplib-subscreen,
|
|
|
778
782
|
flex-direction: row;
|
|
779
783
|
align-items: center;
|
|
780
784
|
gap: 0.3em;
|
|
785
|
+
width: fit-content;
|
|
781
786
|
}
|
|
782
|
-
|
|
783
|
-
|
|
787
|
+
.deeplib-checkbox-container span {
|
|
788
|
+
user-select: none;
|
|
789
|
+
}
|
|
790
|
+
.deeplib-checkbox-container .deeplib-input {
|
|
784
791
|
width: min(5vh, 2.5vw);
|
|
785
792
|
height: min(5vh, 2.5vw);
|
|
786
793
|
width: min(5dvh, 2.5dvw);
|
|
@@ -788,8 +795,7 @@ var styles_default = `.deeplib-subscreen,
|
|
|
788
795
|
border-radius: min(1vh, 0.5vw);
|
|
789
796
|
border-radius: min(1dvh, 0.5dvw);
|
|
790
797
|
}
|
|
791
|
-
|
|
792
|
-
.deeplib-checkbox-container input.deeplib-input[type=checkbox]:checked::before {
|
|
798
|
+
.deeplib-checkbox-container .deeplib-input[type=checkbox]:checked::before {
|
|
793
799
|
width: 80%;
|
|
794
800
|
height: 80%;
|
|
795
801
|
}
|
|
@@ -799,14 +805,16 @@ var styles_default = `.deeplib-subscreen,
|
|
|
799
805
|
flex-direction: row;
|
|
800
806
|
align-items: center;
|
|
801
807
|
gap: 0.3em;
|
|
808
|
+
width: fit-content;
|
|
802
809
|
}
|
|
803
|
-
|
|
804
|
-
|
|
810
|
+
.deeplib-input-container span {
|
|
811
|
+
user-select: none;
|
|
812
|
+
}
|
|
813
|
+
.deeplib-input-container:has(.deeplib-text) {
|
|
805
814
|
margin-top: min(1vh, 0.5vw);
|
|
806
815
|
margin-top: min(1dvh, 0.5dvw);
|
|
807
816
|
}
|
|
808
|
-
|
|
809
|
-
.deeplib-input-container input.deeplib-input {
|
|
817
|
+
.deeplib-input-container .deeplib-input {
|
|
810
818
|
font-size: 0.6em;
|
|
811
819
|
padding: min(1vh, 0.5vw);
|
|
812
820
|
padding: min(1dvh, 0.5dvw);
|
|
@@ -817,8 +825,7 @@ var styles_default = `.deeplib-subscreen,
|
|
|
817
825
|
border-radius: min(1vh, 0.5vw);
|
|
818
826
|
border-radius: min(1dvh, 0.5dvw);
|
|
819
827
|
}
|
|
820
|
-
|
|
821
|
-
.deeplib-input-container input.deeplib-input[type=color] {
|
|
828
|
+
.deeplib-input-container .deeplib-input[type=color] {
|
|
822
829
|
padding: 0px;
|
|
823
830
|
width: min(5vh, 2.5vw);
|
|
824
831
|
height: min(5vh, 2.5vw);
|
|
@@ -826,8 +833,7 @@ var styles_default = `.deeplib-subscreen,
|
|
|
826
833
|
height: min(5dvh, 2.5dvw);
|
|
827
834
|
border-radius: 0px;
|
|
828
835
|
}
|
|
829
|
-
|
|
830
|
-
.deeplib-input-container input.deeplib-input[type=color]:disabled {
|
|
836
|
+
.deeplib-input-container .deeplib-input[type=color]:disabled {
|
|
831
837
|
border: var(--deeplib-blocked-color) solid var(--deeplib-border-width);
|
|
832
838
|
cursor: not-allowed;
|
|
833
839
|
}
|
|
@@ -839,6 +845,7 @@ var styles_default = `.deeplib-subscreen,
|
|
|
839
845
|
gap: min(2vh, 1vw);
|
|
840
846
|
gap: min(2dvh, 1dvw);
|
|
841
847
|
color: var(--deeplib-text-color);
|
|
848
|
+
width: fit-content;
|
|
842
849
|
}
|
|
843
850
|
.deeplib-dropdown-container select {
|
|
844
851
|
padding: 0 min(1vh, 0.5vw);
|
|
@@ -846,6 +853,9 @@ var styles_default = `.deeplib-subscreen,
|
|
|
846
853
|
border-radius: min(1vh, 0.5vw);
|
|
847
854
|
border-radius: min(1dvh, 0.5dvw);
|
|
848
855
|
}
|
|
856
|
+
.deeplib-dropdown-container span {
|
|
857
|
+
user-select: none;
|
|
858
|
+
}
|
|
849
859
|
|
|
850
860
|
.deeplib-highlight-text {
|
|
851
861
|
font-weight: bold;
|
|
@@ -939,7 +949,7 @@ var styles_default = `.deeplib-subscreen,
|
|
|
939
949
|
height: 100dvh;
|
|
940
950
|
background-color: rgba(0, 0, 0, 0.5);
|
|
941
951
|
}
|
|
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"]} */`;
|
|
952
|
+
/*# 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;;AAEA;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;EACA;;AAGF;EACE;;;AC3CJ;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;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;EACA;;;AAIJ;EACE;EACA;EACA;EACA;;AAEA;EACE;;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;;;ACjHJ;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;;AAKN;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;;AAGF;EACE;EACA;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;;;AAOR;EACE;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAGF;EACE;;;ACvFJ;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  &.button-styling,\n  &.button-styling::before {\n    border-radius: min(1.0dvh, 0.5dvw);\n  }\n\n  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  &:hover img {\n    background-color: var(--deeplib-icon-hover-color);\n  }\n\n  .button-label {\n    background-color: transparent !important;\n    color: var(--deeplib-text-color);\n    font-size: min(3.6dvh, 1.8dvw);\n    display: contents;\n  }\n\n  .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  pointer-events: none;\n}\n\n#deeplib-subscreen-title {\n  text-align: left;\n  color: var(--deeplib-text-color);\n  user-select: none;\n  pointer-events: none;\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    user-select: none;\n  }\n}\n\n#deeplib-nav-menu {\n  display: flex;\n  flex-direction: row;\n  gap: min(2dvh, 1dvw);\n  z-index: 1;\n\n  &>.deeplib-button {\n    flex: 1 0 auto;\n  }\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  #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  width: fit-content;\n\n  span {\n    user-select: none;\n  }\n\n  .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    &[type=\"checkbox\"]:checked::before {\n      width: 80%;\n      height: 80%;\n    }\n  }\n}\n\n.deeplib-input-container {\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: 0.3em;\n  width: fit-content;\n\n  span {\n    user-select: none;\n  }\n\n  &:has(.deeplib-text) {\n    margin-top: min(1vh, 0.5vw);\n    margin-top: min(1dvh, 0.5dvw);\n  }\n\n  .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    &[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      &:disabled {\n        border: var(--deeplib-blocked-color) solid var(--deeplib-border-width);\n        cursor: not-allowed;\n      }\n    }\n  }\n}\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  width: fit-content;\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\n  span {\n    user-select: none;\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"]} */`;
|
|
943
953
|
|
|
944
954
|
// src/base/initialization.ts
|
|
945
955
|
var modStorage;
|
|
@@ -983,12 +993,6 @@ async function init(options) {
|
|
|
983
993
|
await options.initFunction?.();
|
|
984
994
|
if (options.mainMenuOptions)
|
|
985
995
|
MainMenu.setOptions(options.mainMenuOptions);
|
|
986
|
-
for (const m of modules()) {
|
|
987
|
-
if (m.defaultSettings && hasGetter(m, "defaultSettings") && m.settings && hasSetter(m, "settings")) {
|
|
988
|
-
if (Object.entries(m.defaultSettings).length === 0) continue;
|
|
989
|
-
m.settings = deepMergeMatchingProperties(m.defaultSettings, m.settings);
|
|
990
|
-
}
|
|
991
|
-
}
|
|
992
996
|
window[MOD_NAME + "Loaded"] = true;
|
|
993
997
|
logger.log(`Loaded! Version: ${MOD_VERSION}`);
|
|
994
998
|
}
|
|
@@ -1006,6 +1010,9 @@ function initModules(modulesToRegister) {
|
|
|
1006
1010
|
for (const module of modules()) {
|
|
1007
1011
|
module.run();
|
|
1008
1012
|
}
|
|
1013
|
+
for (const module of modules()) {
|
|
1014
|
+
module.registerDefaultSettings(modStorage.playerStorage);
|
|
1015
|
+
}
|
|
1009
1016
|
logger.debug("Modules Loaded.");
|
|
1010
1017
|
return true;
|
|
1011
1018
|
}
|
|
@@ -1429,13 +1436,13 @@ var GuiDebug = class extends BaseSubscreen {
|
|
|
1429
1436
|
|
|
1430
1437
|
// src/utilities/common.ts
|
|
1431
1438
|
function isPlainObject(value) {
|
|
1432
|
-
return value !== null && typeof value === "object" && Object.getPrototypeOf(value) === Object.prototype;
|
|
1439
|
+
return value !== null && typeof value === "object" && Object.getPrototypeOf(value) === Object.prototype && !Array.isArray(value);
|
|
1433
1440
|
}
|
|
1434
1441
|
__name(isPlainObject, "isPlainObject");
|
|
1435
|
-
function deepMerge(target, source) {
|
|
1442
|
+
function deepMerge(target, source, options = { concatArrays: true }) {
|
|
1436
1443
|
if (target === void 0) return source;
|
|
1437
1444
|
if (source === void 0) return target;
|
|
1438
|
-
if (Array.isArray(target) && Array.isArray(source)) {
|
|
1445
|
+
if (Array.isArray(target) && Array.isArray(source) && options.concatArrays) {
|
|
1439
1446
|
return [...target, ...source];
|
|
1440
1447
|
}
|
|
1441
1448
|
if (isPlainObject(target) && isPlainObject(source)) {
|
|
@@ -1444,7 +1451,7 @@ function deepMerge(target, source) {
|
|
|
1444
1451
|
if (key === "__proto__" || key === "constructor" || key === "prototype") {
|
|
1445
1452
|
continue;
|
|
1446
1453
|
}
|
|
1447
|
-
result[key] = key in target ? deepMerge(target[key], source[key]) : source[key];
|
|
1454
|
+
result[key] = key in target ? deepMerge(target[key], source[key], options) : source[key];
|
|
1448
1455
|
}
|
|
1449
1456
|
return result;
|
|
1450
1457
|
}
|
|
@@ -1474,19 +1481,7 @@ function exportToGlobal(name, value) {
|
|
|
1474
1481
|
current[keys[keys.length - 1]] = value;
|
|
1475
1482
|
}
|
|
1476
1483
|
__name(exportToGlobal, "exportToGlobal");
|
|
1477
|
-
function
|
|
1478
|
-
const mergedObject = { ...mergeTo };
|
|
1479
|
-
for (const key in mergeFrom) {
|
|
1480
|
-
if (mergeFrom[key] !== null && typeof mergeFrom[key] === "object") {
|
|
1481
|
-
mergedObject[key] = deepMergeMatchingProperties(mergedObject[key] || {}, mergeFrom[key]);
|
|
1482
|
-
} else if (key in mergedObject) {
|
|
1483
|
-
mergedObject[key] = mergeFrom[key];
|
|
1484
|
-
}
|
|
1485
|
-
}
|
|
1486
|
-
return mergedObject;
|
|
1487
|
-
}
|
|
1488
|
-
__name(deepMergeMatchingProperties, "deepMergeMatchingProperties");
|
|
1489
|
-
function hasGetter(obj, prop) {
|
|
1484
|
+
function hasGetter3(obj, prop) {
|
|
1490
1485
|
while (obj && obj !== Object.prototype) {
|
|
1491
1486
|
const descriptor = Object.getOwnPropertyDescriptor(obj, prop);
|
|
1492
1487
|
if (descriptor?.get) return true;
|
|
@@ -1494,8 +1489,8 @@ function hasGetter(obj, prop) {
|
|
|
1494
1489
|
}
|
|
1495
1490
|
return false;
|
|
1496
1491
|
}
|
|
1497
|
-
__name(
|
|
1498
|
-
function
|
|
1492
|
+
__name(hasGetter3, "hasGetter");
|
|
1493
|
+
function hasSetter3(obj, prop) {
|
|
1499
1494
|
while (obj && obj !== Object.prototype) {
|
|
1500
1495
|
const descriptor = Object.getOwnPropertyDescriptor(obj, prop);
|
|
1501
1496
|
if (descriptor?.set) return true;
|
|
@@ -1503,7 +1498,7 @@ function hasSetter(obj, prop) {
|
|
|
1503
1498
|
}
|
|
1504
1499
|
return false;
|
|
1505
1500
|
}
|
|
1506
|
-
__name(
|
|
1501
|
+
__name(hasSetter3, "hasSetter");
|
|
1507
1502
|
var byteToKB = /* @__PURE__ */ __name((nByte) => Math.round(nByte / 100) / 10, "byteToKB");
|
|
1508
1503
|
|
|
1509
1504
|
// src/utilities/elements/elements.ts
|
|
@@ -1572,10 +1567,11 @@ function elementCreateCheckbox(options) {
|
|
|
1572
1567
|
options.type = "checkbox";
|
|
1573
1568
|
const disabled = typeof options?.disabled === "function" ? options?.disabled() : options?.disabled;
|
|
1574
1569
|
const retElem = ElementCreate(deepMerge({
|
|
1575
|
-
tag: "
|
|
1570
|
+
tag: "label",
|
|
1576
1571
|
classList: ["deeplib-checkbox-container"],
|
|
1577
1572
|
attributes: {
|
|
1578
|
-
id: `${options.id}-container
|
|
1573
|
+
id: `${options.id}-container`,
|
|
1574
|
+
for: options.id
|
|
1579
1575
|
},
|
|
1580
1576
|
children: [
|
|
1581
1577
|
deepMerge({
|
|
@@ -1594,10 +1590,10 @@ function elementCreateCheckbox(options) {
|
|
|
1594
1590
|
}
|
|
1595
1591
|
}, options.htmlOptions?.checkbox),
|
|
1596
1592
|
deepMerge({
|
|
1597
|
-
tag: "
|
|
1593
|
+
tag: "span",
|
|
1598
1594
|
classList: ["deeplib-text"],
|
|
1599
1595
|
attributes: {
|
|
1600
|
-
|
|
1596
|
+
id: `${options.id}-label`
|
|
1601
1597
|
},
|
|
1602
1598
|
children: [options.label]
|
|
1603
1599
|
}, options.htmlOptions?.label)
|
|
@@ -1632,10 +1628,11 @@ function elementCreateInput(options) {
|
|
|
1632
1628
|
if (elem) return elem;
|
|
1633
1629
|
const disabled = typeof options?.disabled === "function" ? options?.disabled() : options?.disabled;
|
|
1634
1630
|
const retElem = ElementCreate(deepMerge({
|
|
1635
|
-
tag: "
|
|
1631
|
+
tag: "label",
|
|
1636
1632
|
classList: ["deeplib-input-container"],
|
|
1637
1633
|
attributes: {
|
|
1638
|
-
id: `${options.id}-container
|
|
1634
|
+
id: `${options.id}-container`,
|
|
1635
|
+
for: options.id
|
|
1639
1636
|
},
|
|
1640
1637
|
children: [
|
|
1641
1638
|
deepMerge({
|
|
@@ -1655,10 +1652,10 @@ function elementCreateInput(options) {
|
|
|
1655
1652
|
}
|
|
1656
1653
|
}, options.htmlOptions?.input),
|
|
1657
1654
|
options.label ? deepMerge({
|
|
1658
|
-
tag: "
|
|
1655
|
+
tag: "span",
|
|
1659
1656
|
classList: ["deeplib-text"],
|
|
1660
1657
|
attributes: {
|
|
1661
|
-
|
|
1658
|
+
id: `${options.id}-label`
|
|
1662
1659
|
},
|
|
1663
1660
|
children: [options.label]
|
|
1664
1661
|
}, options.htmlOptions?.label) : void 0
|
|
@@ -1681,7 +1678,7 @@ function elementCreateLabel(options) {
|
|
|
1681
1678
|
if (elem) return elem;
|
|
1682
1679
|
options.type = "label";
|
|
1683
1680
|
const retElem = ElementCreate(deepMerge({
|
|
1684
|
-
tag: "
|
|
1681
|
+
tag: "label",
|
|
1685
1682
|
classList: ["deeplib-label", "deeplib-text"],
|
|
1686
1683
|
attributes: {
|
|
1687
1684
|
id: options.id
|
|
@@ -1708,17 +1705,18 @@ function elementCreateDropdown(options) {
|
|
|
1708
1705
|
if (elem) return elem;
|
|
1709
1706
|
options.type = "dropdown";
|
|
1710
1707
|
const retElem = ElementCreate(deepMerge({
|
|
1711
|
-
tag: "
|
|
1708
|
+
tag: "label",
|
|
1712
1709
|
classList: ["deeplib-dropdown-container"],
|
|
1713
1710
|
attributes: {
|
|
1714
|
-
id: `${options.id}-container
|
|
1711
|
+
id: `${options.id}-container`,
|
|
1712
|
+
for: options.id
|
|
1715
1713
|
},
|
|
1716
1714
|
children: [
|
|
1717
1715
|
options.label ? deepMerge({
|
|
1718
|
-
tag: "
|
|
1716
|
+
tag: "span",
|
|
1719
1717
|
classList: ["deeplib-text"],
|
|
1720
1718
|
attributes: {
|
|
1721
|
-
|
|
1719
|
+
id: `${options.id}-label`
|
|
1722
1720
|
},
|
|
1723
1721
|
children: [options.label]
|
|
1724
1722
|
}, options.htmlOptions?.label) : void 0,
|
|
@@ -2177,7 +2175,7 @@ var MainMenu = class _MainMenu extends BaseSubscreen {
|
|
|
2177
2175
|
}
|
|
2178
2176
|
if (_MainMenu.options.storageFullnessIndicator) {
|
|
2179
2177
|
const maxStorageCapacityKB = 180;
|
|
2180
|
-
const currentStorageCapacityKB = byteToKB(ModStorage.measureSize(
|
|
2178
|
+
const currentStorageCapacityKB = byteToKB(ModStorage.measureSize(modStorage.extensionStorage));
|
|
2181
2179
|
const fullness = (currentStorageCapacityKB / maxStorageCapacityKB * 100).toFixed(1);
|
|
2182
2180
|
const storageFullnessWrapper = advElement.createButton({
|
|
2183
2181
|
id: CommonGenerateUniqueID(),
|
|
@@ -3153,13 +3151,12 @@ export {
|
|
|
3153
3151
|
byteToKB,
|
|
3154
3152
|
deepLibLogger,
|
|
3155
3153
|
deepMerge,
|
|
3156
|
-
deepMergeMatchingProperties,
|
|
3157
3154
|
domUtil,
|
|
3158
3155
|
exportToGlobal,
|
|
3159
3156
|
getModule,
|
|
3160
3157
|
getText,
|
|
3161
|
-
hasGetter,
|
|
3162
|
-
hasSetter,
|
|
3158
|
+
hasGetter3 as hasGetter,
|
|
3159
|
+
hasSetter3 as hasSetter,
|
|
3163
3160
|
initMod,
|
|
3164
3161
|
layout,
|
|
3165
3162
|
logger,
|