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 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'>): HTMLHeadElement;
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
- target[storage] = Object.assign(defaults, target[storage] ?? {});
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
- const menu = ElementMenu.Create("deeplib-nav-menu", []);
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
- ElementMenu.PrependItem(menu, backNext);
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
- ElementMenu.AppendButton(menu, helpButton);
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
- ElementMenu.AppendButton(menu, exitButton);
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
- .deeplib-checkbox-container input.deeplib-input {
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
- .deeplib-input-container:has(label.deeplib-text) {
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 deepMergeMatchingProperties(mergeTo, mergeFrom) {
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(hasGetter, "hasGetter");
1498
- function hasSetter(obj, prop) {
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(hasSetter, "hasSetter");
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: "div",
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: "label",
1593
+ tag: "span",
1598
1594
  classList: ["deeplib-text"],
1599
1595
  attributes: {
1600
- for: options.id
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: "div",
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: "label",
1655
+ tag: "span",
1659
1656
  classList: ["deeplib-text"],
1660
1657
  attributes: {
1661
- for: options.id
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: "span",
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: "div",
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: "label",
1716
+ tag: "span",
1719
1717
  classList: ["deeplib-text"],
1720
1718
  attributes: {
1721
- for: options.id
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(Player.OnlineSettings));
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,