bc-deeplib 2.0.0 → 2.2.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.js CHANGED
@@ -325,7 +325,11 @@ var BaseSubscreen = class _BaseSubscreen {
325
325
  drawCharacter: true,
326
326
  name: "UNKNOWN",
327
327
  icon: "",
328
- background: "Sheet"
328
+ background: "Sheet",
329
+ doShowExitButton: true,
330
+ doShowTitle: true,
331
+ settingsWidth: 1e3,
332
+ forceUpCharacter: false
329
333
  };
330
334
  constructor(module) {
331
335
  if (module) this.module = module;
@@ -394,15 +398,14 @@ var BaseSubscreen = class _BaseSubscreen {
394
398
  */
395
399
  managePageElementsVisibility() {
396
400
  this.pageStructure.forEach((item, ix) => {
397
- if (ix != _BaseSubscreen.currentPage - 1) {
398
- item.forEach((setting) => {
399
- domUtil.hide(`${setting.id}-container`);
400
- });
401
- } else {
402
- item.forEach((setting) => {
403
- domUtil.unhide(`${setting.id}-container`);
404
- });
405
- }
401
+ item.forEach((setting) => {
402
+ const element = ElementWrap(`${setting.id}-container`) ?? ElementWrap(`${setting.id}`);
403
+ if (ix != _BaseSubscreen.currentPage - 1) {
404
+ if (element) domUtil.hide(element);
405
+ } else {
406
+ if (element) domUtil.unhide(element);
407
+ }
408
+ });
406
409
  });
407
410
  }
408
411
  /**
@@ -462,12 +465,14 @@ var BaseSubscreen = class _BaseSubscreen {
462
465
  });
463
466
  ElementMenu.AppendButton(menu, helpButton);
464
467
  }
465
- const subscreenTitle = advElement.createLabel({
466
- id: "deeplib-subscreen-title",
467
- label: getText(`${this.options.name}.title`).replace("$ModVersion", ModSdkManager.ModInfo.version)
468
- });
469
- layout.appendToSubscreen(subscreenTitle);
470
- if (this.options.name !== "mainmenu") {
468
+ if (this.options.doShowTitle) {
469
+ const subscreenTitle = advElement.createLabel({
470
+ id: "deeplib-subscreen-title",
471
+ label: getText(`${this.options.name}.title`).replace("$ModVersion", ModSdkManager.ModInfo.version)
472
+ });
473
+ layout.appendToSubscreen(subscreenTitle);
474
+ }
475
+ if (this.options.doShowExitButton) {
471
476
  const exitButton = advElement.createButton({
472
477
  id: "deeplib-exit",
473
478
  size: [90, 90],
@@ -504,12 +509,19 @@ var BaseSubscreen = class _BaseSubscreen {
504
509
  case "custom":
505
510
  element = advElement.createCustom(item);
506
511
  break;
512
+ case "dropdown":
513
+ element = advElement.createDropdown(item);
514
+ break;
507
515
  }
508
516
  layout.appendToSettingsDiv(element);
509
517
  })
510
518
  );
511
519
  this.managePageElementsVisibility();
512
- CharacterAppearanceForceUpCharacter = Player.MemberNumber ?? -1;
520
+ if (this.options.drawCharacter && this.options.forceUpCharacter) {
521
+ CharacterAppearanceForceUpCharacter = Player.MemberNumber;
522
+ } else {
523
+ CharacterAppearanceForceUpCharacter = -1;
524
+ }
513
525
  }
514
526
  /**
515
527
  * Called each frame while this subscreen is active.
@@ -551,16 +563,11 @@ var BaseSubscreen = class _BaseSubscreen {
551
563
  const offset = this.options.drawCharacter ? 0 : 380;
552
564
  const subscreen = layout.getSubscreen();
553
565
  const settingsDiv = layout.getSettingsDiv();
554
- ElementSetPosition(subscreen || "", 0, 0);
555
- ElementSetSize(subscreen || "", 2e3, 1e3);
556
- ElementSetFontSize(subscreen || "", "auto");
557
- if (this.options.name === "mainmenu") {
558
- ElementSetPosition(settingsDiv || "", 530 - offset, 170);
559
- ElementSetSize(settingsDiv || "", 600 + offset, 660);
560
- } else {
561
- ElementSetPosition(settingsDiv || "", 530 - offset, 170);
562
- ElementSetSize(settingsDiv || "", 1e3 + offset, 660);
563
- }
566
+ ElementSetPosition(subscreen, 0, 0);
567
+ ElementSetSize(subscreen, 2e3, 1e3);
568
+ ElementSetFontSize(subscreen, "auto");
569
+ ElementSetPosition(settingsDiv, 530 - offset, 170);
570
+ ElementSetSize(settingsDiv, this.options.settingsWidth ?? 1e3 + offset, 660);
564
571
  ElementSetPosition("deeplib-subscreen-title", 530 - offset, 75);
565
572
  ElementSetSize("deeplib-subscreen-title", 800, 60);
566
573
  ElementSetPosition("deeplib-nav-menu", 1905, 75, "top-right");
@@ -770,6 +777,9 @@ var styles_default = `.deeplib-subscreen,
770
777
  .deeplib-checkbox-container input.deeplib-input {
771
778
  width: min(5vh, 2.5vw);
772
779
  height: min(5vh, 2.5vw);
780
+ width: min(5dvh, 2.5dvw);
781
+ height: min(5dvh, 2.5dvw);
782
+ border-radius: min(1vh, 0.5vw);
773
783
  border-radius: min(1dvh, 0.5dvw);
774
784
  }
775
785
 
@@ -787,16 +797,18 @@ var styles_default = `.deeplib-subscreen,
787
797
 
788
798
  .deeplib-input-container:has(label.deeplib-text) {
789
799
  margin-top: min(1vh, 0.5vw);
800
+ margin-top: min(1dvh, 0.5dvw);
790
801
  }
791
802
 
792
803
  .deeplib-input-container input.deeplib-input {
793
804
  font-size: 0.6em;
794
- padding: 5px 0;
805
+ padding: min(1vh, 0.5vw);
806
+ padding: min(1dvh, 0.5dvw);
795
807
  background-color: transparent;
796
808
  outline: none;
797
- padding-left: min(1vh, 0.5vw);
798
- padding-right: min(1vh, 0.5vw);
809
+ min-height: min(5vh, 2.5vw);
799
810
  min-height: min(5dvh, 2.5dvw);
811
+ border-radius: min(1vh, 0.5vw);
800
812
  border-radius: min(1dvh, 0.5dvw);
801
813
  }
802
814
 
@@ -804,6 +816,8 @@ var styles_default = `.deeplib-subscreen,
804
816
  padding: 0px;
805
817
  width: min(5vh, 2.5vw);
806
818
  height: min(5vh, 2.5vw);
819
+ width: min(5dvh, 2.5dvw);
820
+ height: min(5dvh, 2.5dvw);
807
821
  border-radius: 0px;
808
822
  }
809
823
 
@@ -812,15 +826,19 @@ var styles_default = `.deeplib-subscreen,
812
826
  cursor: not-allowed;
813
827
  }
814
828
 
815
- input::-webkit-outer-spin-button,
816
- input::-webkit-inner-spin-button {
817
- -webkit-appearance: none;
818
- margin: 0;
829
+ .deeplib-dropdown-container {
830
+ display: flex;
831
+ flex-direction: row;
832
+ align-items: center;
833
+ gap: min(2vh, 1vw);
834
+ gap: min(2dvh, 1dvw);
835
+ color: var(--deeplib-text-color);
819
836
  }
820
-
821
- input[type=number] {
822
- appearance: textfield;
823
- -moz-appearance: textfield;
837
+ .deeplib-dropdown-container select {
838
+ padding: 0 min(1vh, 0.5vw);
839
+ padding: 0 min(1dvh, 0.5dvw);
840
+ border-radius: min(1vh, 0.5vw);
841
+ border-radius: min(1dvh, 0.5dvw);
824
842
  }
825
843
 
826
844
  .deeplib-highlight-text {
@@ -915,7 +933,7 @@ input[type=number] {
915
933
  height: 100dvh;
916
934
  background-color: rgba(0, 0, 0, 0.5);
917
935
  }
918
- /*# 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;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAIF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;AAAA;EAEE;EACA;;;AAGF;EACE;EACA;;;AC7DF;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  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}\n\n.deeplib-input-container input.deeplib-input {\n  font-size: 0.6em;\n  padding: 5px 0;\n  background-color: transparent;\n  outline: none;\n  padding-left: min(1vh, 0.5vw);\n  padding-right: min(1vh, 0.5vw);\n  min-height: min(5dvh, 2.5dvw);\n  border-radius: min(1.0dvh, 0.5dvw);\n}\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  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\ninput::-webkit-outer-spin-button,\ninput::-webkit-inner-spin-button {\n  -webkit-appearance: none;\n  margin: 0;\n}\n\ninput[type=number] {\n  appearance: textfield;\n  -moz-appearance: textfield;\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"]} */`;
936
+ /*# 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"]} */`;
919
937
 
920
938
  // src/base/initialization.ts
921
939
  var modStorage;
@@ -1188,6 +1206,7 @@ var VersionModule = class _VersionModule extends BaseModule {
1188
1206
  }
1189
1207
  /** Sends the currently configured "new version" message to the local player. */
1190
1208
  static sendNewVersionMessage() {
1209
+ if (!_VersionModule.newVersionMessage) return;
1191
1210
  const beepLogLength = FriendListBeepLog.push({
1192
1211
  MemberNumber: Player.MemberNumber,
1193
1212
  MemberName: ModSdkManager.ModInfo.name,
@@ -1261,10 +1280,12 @@ var GuiDebug = class extends BaseSubscreen {
1261
1280
  {
1262
1281
  type: "button",
1263
1282
  id: "test-deeplib-big-button",
1283
+ options: {
1284
+ label: "Big Button",
1285
+ tooltip: "This is a big button",
1286
+ image: "Icons/Exit.png"
1287
+ },
1264
1288
  size: [405, 80],
1265
- label: "Big Button",
1266
- tooltip: "This is a big button",
1267
- image: "Icons/Exit.png",
1268
1289
  onClick() {
1269
1290
  deepLibLogger.info("Big Button Clicked");
1270
1291
  }
@@ -1272,9 +1293,11 @@ var GuiDebug = class extends BaseSubscreen {
1272
1293
  {
1273
1294
  type: "button",
1274
1295
  id: "test-deeplib-small-button",
1296
+ options: {
1297
+ tooltip: "This is a small button",
1298
+ image: "Icons/Exit.png"
1299
+ },
1275
1300
  size: [90, 90],
1276
- tooltip: "This is a small button",
1277
- image: "Icons/Exit.png",
1278
1301
  onClick() {
1279
1302
  deepLibLogger.info("Small Button Clicked");
1280
1303
  }
@@ -1326,10 +1349,12 @@ var GuiDebug = class extends BaseSubscreen {
1326
1349
  {
1327
1350
  type: "button",
1328
1351
  id: "test-deeplib-big-button2",
1352
+ options: {
1353
+ label: "Big Button",
1354
+ tooltip: "This is a big button",
1355
+ image: "Icons/Exit.png"
1356
+ },
1329
1357
  size: [405, 80],
1330
- label: "Big Button",
1331
- tooltip: "This is a big button",
1332
- image: "Icons/Prev.png",
1333
1358
  onClick() {
1334
1359
  deepLibLogger.info("Big Button Clicked");
1335
1360
  }
@@ -1337,9 +1362,11 @@ var GuiDebug = class extends BaseSubscreen {
1337
1362
  {
1338
1363
  type: "button",
1339
1364
  id: "test-deeplib-small-button2",
1365
+ options: {
1366
+ tooltip: "This is a small button",
1367
+ image: "Icons/Next.png"
1368
+ },
1340
1369
  size: [90, 90],
1341
- tooltip: "This is a small button",
1342
- image: "Icons/Next.png",
1343
1370
  onClick() {
1344
1371
  deepLibLogger.info("Small Button Clicked");
1345
1372
  }
@@ -1385,6 +1412,22 @@ var GuiDebug = class extends BaseSubscreen {
1385
1412
  id: "test-deeplib-label2",
1386
1413
  label: "Label",
1387
1414
  description: "This is a label"
1415
+ },
1416
+ {
1417
+ type: "dropdown",
1418
+ id: "test-deeplib-dropdown",
1419
+ label: "Dropdown",
1420
+ description: "This is a dropdown",
1421
+ optionsList: ["Option 1", "Option 2", "Option 3"],
1422
+ setElementValue() {
1423
+ return "Option 2";
1424
+ },
1425
+ setSettingValue(val) {
1426
+ deepLibLogger.info("Dropdown value:", val);
1427
+ },
1428
+ options: {
1429
+ width: 200
1430
+ }
1388
1431
  }
1389
1432
  ]
1390
1433
  ];
@@ -1392,22 +1435,27 @@ var GuiDebug = class extends BaseSubscreen {
1392
1435
  };
1393
1436
 
1394
1437
  // src/utilities/common.ts
1438
+ function isPlainObject(value) {
1439
+ return value !== null && typeof value === "object" && Object.getPrototypeOf(value) === Object.prototype;
1440
+ }
1441
+ __name(isPlainObject, "isPlainObject");
1395
1442
  function deepMerge(target, source) {
1396
1443
  if (target === void 0) return source;
1397
1444
  if (source === void 0) return target;
1398
- if (typeof target !== "object" || typeof source !== "object") {
1399
- return source;
1400
- }
1401
- for (const key of Object.keys(source)) {
1402
- if (Array.isArray(source[key]) && Array.isArray(target[key])) {
1403
- target[key] = [...target[key], ...source[key]];
1404
- } else if (typeof source[key] === "object" && source[key] !== null) {
1405
- target[key] = deepMerge(target[key] || {}, source[key]);
1406
- } else {
1407
- target[key] = source[key];
1445
+ if (Array.isArray(target) && Array.isArray(source)) {
1446
+ return [...target, ...source];
1447
+ }
1448
+ if (isPlainObject(target) && isPlainObject(source)) {
1449
+ const result = { ...target };
1450
+ for (const key of Object.keys(source)) {
1451
+ if (key === "__proto__" || key === "constructor" || key === "prototype") {
1452
+ continue;
1453
+ }
1454
+ result[key] = key in target ? deepMerge(target[key], source[key]) : source[key];
1408
1455
  }
1456
+ return result;
1409
1457
  }
1410
- return target;
1458
+ return source;
1411
1459
  }
1412
1460
  __name(deepMerge, "deepMerge");
1413
1461
  function shuffleArray(array) {
@@ -1472,6 +1520,7 @@ var advElement = {
1472
1520
  createInput: elementCreateInput,
1473
1521
  createLabel: elementCreateLabel,
1474
1522
  createCustom: elementCreateCustom,
1523
+ createDropdown: elementCreateDropdown,
1475
1524
  createTooltip: elementCreateTooltip,
1476
1525
  getTooltip: elementGetTooltip,
1477
1526
  setTooltip: elementSetTooltip,
@@ -1502,7 +1551,7 @@ function elementCreateButton(options) {
1502
1551
  disabled
1503
1552
  },
1504
1553
  children: [
1505
- image ? {
1554
+ image ? deepMerge({
1506
1555
  tag: "img",
1507
1556
  attributes: {
1508
1557
  id: `${options.id}-image`,
@@ -1515,7 +1564,7 @@ function elementCreateButton(options) {
1515
1564
  style: {
1516
1565
  "--image": `url("${image}")`
1517
1566
  }
1518
- } : void 0
1567
+ }, options.htmlOptions?.img) : void 0
1519
1568
  ]
1520
1569
  }
1521
1570
  }, options.htmlOptions ?? {})
@@ -1529,7 +1578,7 @@ function elementCreateCheckbox(options) {
1529
1578
  if (elem) return elem;
1530
1579
  options.type = "checkbox";
1531
1580
  const disabled = typeof options?.disabled === "function" ? options?.disabled() : options?.disabled;
1532
- const retElem = ElementCreate({
1581
+ const retElem = ElementCreate(deepMerge({
1533
1582
  tag: "div",
1534
1583
  classList: ["deeplib-checkbox-container"],
1535
1584
  attributes: {
@@ -1544,23 +1593,23 @@ function elementCreateCheckbox(options) {
1544
1593
  id: options.id,
1545
1594
  disabled,
1546
1595
  checked: options?.setElementValue?.() || void 0
1596
+ },
1597
+ eventListeners: {
1598
+ change: /* @__PURE__ */ __name(function() {
1599
+ options?.setSettingValue?.(this.checked);
1600
+ }, "change")
1547
1601
  }
1548
- }, options.htmlOptions),
1549
- {
1602
+ }, options.htmlOptions?.checkbox),
1603
+ deepMerge({
1550
1604
  tag: "label",
1551
1605
  classList: ["deeplib-text"],
1552
1606
  attributes: {
1553
1607
  for: options.id
1554
1608
  },
1555
1609
  children: [options.label]
1556
- }
1557
- ],
1558
- eventListeners: {
1559
- change: /* @__PURE__ */ __name(() => {
1560
- options?.setSettingValue?.(document.getElementById(options.id)?.checked);
1561
- }, "change")
1562
- }
1563
- });
1610
+ }, options.htmlOptions?.label)
1611
+ ]
1612
+ }, options.htmlOptions?.container));
1564
1613
  if (options.description) {
1565
1614
  retElem.addEventListener("mouseover", () => {
1566
1615
  elementSetTooltip(options.description || "");
@@ -1574,7 +1623,10 @@ function elementCreateCheckbox(options) {
1574
1623
  }
1575
1624
  __name(elementCreateCheckbox, "elementCreateCheckbox");
1576
1625
  function elementCreateCustom(options) {
1577
- const elem = document.getElementById(options.id);
1626
+ options.id ??= ElementGenerateID();
1627
+ options.htmlOptions.attributes ??= {};
1628
+ options.htmlOptions.attributes.id ??= options.id;
1629
+ const elem = document.getElementById(options.htmlOptions.attributes.id);
1578
1630
  if (elem) return elem;
1579
1631
  options.type = "custom";
1580
1632
  const retElem = ElementCreate(options.htmlOptions);
@@ -1586,7 +1638,7 @@ function elementCreateInput(options) {
1586
1638
  const elem = document.getElementById(options.id);
1587
1639
  if (elem) return elem;
1588
1640
  const disabled = typeof options?.disabled === "function" ? options?.disabled() : options?.disabled;
1589
- const retElem = ElementCreate({
1641
+ const retElem = ElementCreate(deepMerge({
1590
1642
  tag: "div",
1591
1643
  classList: ["deeplib-input-container"],
1592
1644
  attributes: {
@@ -1602,23 +1654,23 @@ function elementCreateInput(options) {
1602
1654
  placeholder: " ",
1603
1655
  disabled,
1604
1656
  value: options?.setElementValue?.() || void 0
1657
+ },
1658
+ eventListeners: {
1659
+ input: /* @__PURE__ */ __name(function() {
1660
+ options?.setSettingValue?.(this.value);
1661
+ }, "input")
1605
1662
  }
1606
- }, options.htmlOptions),
1607
- options.label ? {
1663
+ }, options.htmlOptions?.input),
1664
+ options.label ? deepMerge({
1608
1665
  tag: "label",
1609
1666
  classList: ["deeplib-text"],
1610
1667
  attributes: {
1611
1668
  for: options.id
1612
1669
  },
1613
1670
  children: [options.label]
1614
- } : void 0
1615
- ],
1616
- eventListeners: {
1617
- input: /* @__PURE__ */ __name(() => {
1618
- options?.setSettingValue?.(document.getElementById(options.id)?.value);
1619
- }, "input")
1620
- }
1621
- });
1671
+ }, options.htmlOptions?.label) : void 0
1672
+ ]
1673
+ }, options.htmlOptions?.container));
1622
1674
  if (options.description) {
1623
1675
  retElem.addEventListener("mouseover", () => {
1624
1676
  elementSetTooltip(options.description || "");
@@ -1657,6 +1709,49 @@ function elementCreateLabel(options) {
1657
1709
  return retElem;
1658
1710
  }
1659
1711
  __name(elementCreateLabel, "elementCreateLabel");
1712
+ function elementCreateDropdown(options) {
1713
+ options.id ??= ElementGenerateID();
1714
+ const elem = document.getElementById(`${options.id}-container`);
1715
+ if (elem) return elem;
1716
+ options.type = "dropdown";
1717
+ const retElem = ElementCreate(deepMerge({
1718
+ tag: "div",
1719
+ classList: ["deeplib-dropdown-container"],
1720
+ attributes: {
1721
+ id: `${options.id}-container`
1722
+ },
1723
+ children: [
1724
+ options.label ? deepMerge({
1725
+ tag: "label",
1726
+ classList: ["deeplib-text"],
1727
+ attributes: {
1728
+ for: options.id
1729
+ },
1730
+ children: [options.label]
1731
+ }, options.htmlOptions?.label) : void 0,
1732
+ ElementCreateDropdown(
1733
+ options.id,
1734
+ options.optionsList,
1735
+ function() {
1736
+ return options.setSettingValue?.(this.value);
1737
+ },
1738
+ options.options,
1739
+ options.htmlOptions?.select
1740
+ )
1741
+ ],
1742
+ eventListeners: {
1743
+ mouseover: /* @__PURE__ */ __name(function() {
1744
+ elementSetTooltip(options.description ?? "");
1745
+ }, "mouseover"),
1746
+ mouseout: /* @__PURE__ */ __name(function() {
1747
+ elementSetTooltip("");
1748
+ }, "mouseout")
1749
+ }
1750
+ }, options.htmlOptions?.container));
1751
+ BaseSubscreen.currentElements.push([retElem, options]);
1752
+ return retElem;
1753
+ }
1754
+ __name(elementCreateDropdown, "elementCreateDropdown");
1660
1755
  function elementCreateTooltip() {
1661
1756
  const element = ElementCreate({
1662
1757
  tag: "div",
@@ -1985,7 +2080,9 @@ var MainMenu = class _MainMenu extends BaseSubscreen {
1985
2080
  subscreens = [];
1986
2081
  static options = {};
1987
2082
  static subscreenOptions = {
1988
- name: "mainmenu"
2083
+ name: "mainmenu",
2084
+ doShowExitButton: false,
2085
+ settingsWidth: 600
1989
2086
  };
1990
2087
  constructor(module) {
1991
2088
  super(module);
@@ -2168,18 +2265,6 @@ var MainMenu = class _MainMenu extends BaseSubscreen {
2168
2265
  _MainMenu.options = mainMenuOptions;
2169
2266
  }
2170
2267
  };
2171
- async function PreferenceOpenSubscreen(subscreen, page = 1) {
2172
- if (CurrentModule !== "Character" || CurrentScreen !== "Preference") {
2173
- await CommonSetScreen("Character", "Preference");
2174
- }
2175
- PreferenceSubscreen?.unload?.();
2176
- PreferenceSubscreen = PreferenceSubscreens.find((s) => s.name === subscreen) ?? null;
2177
- if (!CommonIsNonNegativeInteger(page)) page = 1;
2178
- PreferencePageCurrent = page;
2179
- PreferenceMessage = "";
2180
- PreferenceSubscreen?.load?.();
2181
- }
2182
- __name(PreferenceOpenSubscreen, "PreferenceOpenSubscreen");
2183
2268
 
2184
2269
  // src/screens/import_export.ts
2185
2270
  var GuiImportExport = class extends BaseSubscreen {
@@ -2436,7 +2521,9 @@ var ModStorage = class _ModStorage {
2436
2521
  if (this.extensionStorage) {
2437
2522
  const parsed = _ModStorage.dataDecompress(this.extensionStorage || "");
2438
2523
  if (parsed === null || !Object.hasOwn(parsed, "Version")) {
2439
- this.playerStorage = {};
2524
+ this.playerStorage = {
2525
+ Version: ModSdkManager.ModInfo.version
2526
+ };
2440
2527
  } else {
2441
2528
  this.playerStorage = parsed;
2442
2529
  }
@@ -3072,7 +3159,6 @@ export {
3072
3159
  getText,
3073
3160
  hasGetter,
3074
3161
  hasSetter,
3075
- init,
3076
3162
  initMod,
3077
3163
  layout,
3078
3164
  modStorage,