bc-deeplib 2.0.0 → 2.1.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,10 @@ 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
329
332
  };
330
333
  constructor(module) {
331
334
  if (module) this.module = module;
@@ -394,15 +397,14 @@ var BaseSubscreen = class _BaseSubscreen {
394
397
  */
395
398
  managePageElementsVisibility() {
396
399
  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
- }
400
+ item.forEach((setting) => {
401
+ const element = ElementWrap(`${setting.id}-container`) ?? ElementWrap(`${setting.id}`);
402
+ if (ix != _BaseSubscreen.currentPage - 1) {
403
+ if (element) domUtil.hide(element);
404
+ } else {
405
+ if (element) domUtil.unhide(element);
406
+ }
407
+ });
406
408
  });
407
409
  }
408
410
  /**
@@ -462,12 +464,14 @@ var BaseSubscreen = class _BaseSubscreen {
462
464
  });
463
465
  ElementMenu.AppendButton(menu, helpButton);
464
466
  }
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") {
467
+ if (this.options.doShowTitle) {
468
+ const subscreenTitle = advElement.createLabel({
469
+ id: "deeplib-subscreen-title",
470
+ label: getText(`${this.options.name}.title`).replace("$ModVersion", ModSdkManager.ModInfo.version)
471
+ });
472
+ layout.appendToSubscreen(subscreenTitle);
473
+ }
474
+ if (this.options.doShowExitButton) {
471
475
  const exitButton = advElement.createButton({
472
476
  id: "deeplib-exit",
473
477
  size: [90, 90],
@@ -504,6 +508,9 @@ var BaseSubscreen = class _BaseSubscreen {
504
508
  case "custom":
505
509
  element = advElement.createCustom(item);
506
510
  break;
511
+ case "dropdown":
512
+ element = advElement.createDropdown(item);
513
+ break;
507
514
  }
508
515
  layout.appendToSettingsDiv(element);
509
516
  })
@@ -551,16 +558,11 @@ var BaseSubscreen = class _BaseSubscreen {
551
558
  const offset = this.options.drawCharacter ? 0 : 380;
552
559
  const subscreen = layout.getSubscreen();
553
560
  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
- }
561
+ ElementSetPosition(subscreen, 0, 0);
562
+ ElementSetSize(subscreen, 2e3, 1e3);
563
+ ElementSetFontSize(subscreen, "auto");
564
+ ElementSetPosition(settingsDiv, 530 - offset, 170);
565
+ ElementSetSize(settingsDiv, this.options.settingsWidth ?? 1e3 + offset, 660);
564
566
  ElementSetPosition("deeplib-subscreen-title", 530 - offset, 75);
565
567
  ElementSetSize("deeplib-subscreen-title", 800, 60);
566
568
  ElementSetPosition("deeplib-nav-menu", 1905, 75, "top-right");
@@ -770,6 +772,9 @@ var styles_default = `.deeplib-subscreen,
770
772
  .deeplib-checkbox-container input.deeplib-input {
771
773
  width: min(5vh, 2.5vw);
772
774
  height: min(5vh, 2.5vw);
775
+ width: min(5dvh, 2.5dvw);
776
+ height: min(5dvh, 2.5dvw);
777
+ border-radius: min(1vh, 0.5vw);
773
778
  border-radius: min(1dvh, 0.5dvw);
774
779
  }
775
780
 
@@ -787,16 +792,18 @@ var styles_default = `.deeplib-subscreen,
787
792
 
788
793
  .deeplib-input-container:has(label.deeplib-text) {
789
794
  margin-top: min(1vh, 0.5vw);
795
+ margin-top: min(1dvh, 0.5dvw);
790
796
  }
791
797
 
792
798
  .deeplib-input-container input.deeplib-input {
793
799
  font-size: 0.6em;
794
- padding: 5px 0;
800
+ padding: min(1vh, 0.5vw);
801
+ padding: min(1dvh, 0.5dvw);
795
802
  background-color: transparent;
796
803
  outline: none;
797
- padding-left: min(1vh, 0.5vw);
798
- padding-right: min(1vh, 0.5vw);
804
+ min-height: min(5vh, 2.5vw);
799
805
  min-height: min(5dvh, 2.5dvw);
806
+ border-radius: min(1vh, 0.5vw);
800
807
  border-radius: min(1dvh, 0.5dvw);
801
808
  }
802
809
 
@@ -804,6 +811,8 @@ var styles_default = `.deeplib-subscreen,
804
811
  padding: 0px;
805
812
  width: min(5vh, 2.5vw);
806
813
  height: min(5vh, 2.5vw);
814
+ width: min(5dvh, 2.5dvw);
815
+ height: min(5dvh, 2.5dvw);
807
816
  border-radius: 0px;
808
817
  }
809
818
 
@@ -812,15 +821,19 @@ var styles_default = `.deeplib-subscreen,
812
821
  cursor: not-allowed;
813
822
  }
814
823
 
815
- input::-webkit-outer-spin-button,
816
- input::-webkit-inner-spin-button {
817
- -webkit-appearance: none;
818
- margin: 0;
824
+ .deeplib-dropdown-container {
825
+ display: flex;
826
+ flex-direction: row;
827
+ align-items: center;
828
+ gap: min(2vh, 1vw);
829
+ gap: min(2dvh, 1dvw);
830
+ color: var(--deeplib-text-color);
819
831
  }
820
-
821
- input[type=number] {
822
- appearance: textfield;
823
- -moz-appearance: textfield;
832
+ .deeplib-dropdown-container select {
833
+ padding: 0 min(1vh, 0.5vw);
834
+ padding: 0 min(1dvh, 0.5dvw);
835
+ border-radius: min(1vh, 0.5vw);
836
+ border-radius: min(1dvh, 0.5dvw);
824
837
  }
825
838
 
826
839
  .deeplib-highlight-text {
@@ -915,7 +928,7 @@ input[type=number] {
915
928
  height: 100dvh;
916
929
  background-color: rgba(0, 0, 0, 0.5);
917
930
  }
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"]} */`;
931
+ /*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sourceRoot":"/media/NVME/Stuff/Code/bc/BC-DeepLib/src/styles","sources":["vars.scss","buttons.scss","elements.scss","inputs.scss","messages.scss","modal.scss"],"names":[],"mappings":"AAAA;AAAA;EAEE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;ACdF;EACE;EACA;EACA;;;AAGF;AAAA;EAEE;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EAEA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;;;AAGF;EACE;;;AC3CF;EACE;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAGE;EACE;EACA;;AAHJ;EAME;EACA;;AAGF;EACE;;;AAIJ;EACE;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;;;ACzGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;;ACvEJ;EACE;EACA;;;AAGF;AAAA;EAEE;EACA;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA;;;AAGF;AAAA;EAEE;;;AAGF;EACE;EACA;EACA;;;AC7BF;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAGF;EACE;;AAGF;EACE;EACA;EACA;EACA;EACA;;AAEA;EACE;EACA;EACA;EACA;;AAEA;EACE;;AAKN;EACE;EACA;EACA;EACA;;;AAIJ;EACE;EACA;EACA;EACA;EACA;EACA;EACA","sourcesContent":[".deeplib-subscreen,\n.deeplib-modal {\n  --deeplib-background-color: var(--tmd-main, white);\n  --deeplib-element-color: var(--tmd-element, white);\n  --deeplib-element-hover-color: var(--tmd-element-hover, cyan);\n  --deeplib-accent-color: var(--tmd-accent, #FFFF88);\n  --deeplib-blocked-color: var(--tmd-blocked, red);\n  --deeplib-text-color: var(--tmd-text, black);\n  --deeplib-icon-color: var(--tmd-accent, black);\n  --deeplib-icon-hover-color: var(--tmd-accent-hover, black);\n  --deeplib-border-color: var(--tmd-accent, black);\n  --deeplib-border-width: min(0.2vh, 0.1vw);\n  --deeplib-border-width: min(0.2dvh, 0.1dvw);\n  --deeplib-border-radius: min(1vh, 0.5vw);\n  --deeplib-border-radius: min(1dvh, 0.5dvw);\n}\n",".deeplib-button {\n  color: var(--deeplib-text-color);\n  width: 100%;\n  height: 100%;\n}\n\n.deeplib-button.button-styling,\n.deeplib-button.button-styling::before {\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n\n.deeplib-button img {\n  position: absolute;\n  top: 0%;\n  left: 0%;\n  width: 100%;\n  height: 100%;\n  background-position: left;\n  background-color: var(--deeplib-icon-color);\n  background-blend-mode: multiply;\n  background-size: contain;\n  mask-position: left;\n  mask-size: contain;\n  background-repeat: no-repeat;\n  mask-repeat: no-repeat;\n  color: transparent;\n\n  background-image: var(--image);\n  mask-image: var(--image);\n  pointer-events: none;\n}\n\n.deeplib-button:hover img {\n  background-color: var(--deeplib-icon-hover-color);\n}\n\n.deeplib-button .button-label {\n  background-color: transparent !important;\n  color: var(--deeplib-text-color);\n  font-size: min(3.6dvh, 1.8dvw);\n}\n\n.deeplib-button .button-tooltip {\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n","#deeplib-page-label {\n  display: flex;\n  align-items: center;\n  justify-content: center;\n}\n\n#deeplib-subscreen-title {\n  text-align: left;\n  color: var(--deeplib-text-color);\n}\n\n.deeplib-text {\n  color: var(--deeplib-text-color);\n}\n\n.deeplib-subscreen {\n  padding: 0;\n  margin: 0;\n  pointer-events: none;\n}\n\n.deeplib-subscreen * {\n  box-sizing: border-box;\n  pointer-events: all;\n}\n\n.deeplib-settings {\n  display: grid;\n  grid-auto-rows: min-content;\n  padding: min(1.0dvh, 0.5dvw);\n  gap: 0.3em;\n}\n\n.deeplib-misc {\n  display: flex;\n  align-items: center;\n  flex-direction: column-reverse;\n  gap: min(1vh, 0.5vw);\n}\n\n.deeplib-tooltip {\n  background-color: var(--deeplib-element-color);\n  color: var(--deeplib-text-color);\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  border-radius: min(1.0dvh, 0.5dvw);\n  padding: min(1vh, 0.5vw);\n  font-size: 0.8em;\n  border: min(0.2vh, 0.1vw) solid var(--deeplib-border-color);\n  z-index: 1;\n}\n\n.deeplib-overflow-box {\n  border: var(--deeplib-border-color) solid var(--deeplib-border-width);\n}\n\n.deeplib-prev-next {\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  flex-direction: row;\n  gap: min(2dvh, 1dvw);\n  background-color: var(--deeplib-element-color);\n  color: var(--deeplib-text-color);\n  border-radius: min(1.0dvh, 0.5dvw);\n  border: min(0.2vh, 0.1vw) solid var(--deeplib-border-color);\n\n  .deeplib-prev-next-button {\n    &:hover {\n      background-color: var(--deeplib-element-hover-color);\n      border-radius: var(--deeplib-border-radius);\n    }\n    \n    height: 100%;\n    aspect-ratio: 1;\n  }\n\n  .deeplib-prev-next-label {\n    white-space: nowrap;\n  }\n}\n\n#deeplib-nav-menu {\n  display: flex;\n  flex-direction: row;\n  gap: min(2dvh, 1dvw);\n}\n\n#deeplib-storage-meter {\n  position: absolute;\n  top: 0px;\n  left: 0px;\n  width: 100%;\n  height: 100%;\n  overflow: hidden;\n  background-color: var(--deeplib-element-color);\n  border: var(--deeplib-border-width) solid var(--deeplib-border-color);\n  border-radius: var(--deeplib-border-radius);\n  z-index: -1;\n}\n\n#deeplib-storage-bar {\n  height: 100%;\n  width: 0%;\n  background: var(--deeplib-accent-color);\n}\n",".deeplib-checkbox-container {\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: 0.3em;\n}\n\n.deeplib-checkbox-container input.deeplib-input {\n  width: min(5vh, 2.5vw);\n  height: min(5vh, 2.5vw);\n  width: min(5dvh, 2.5dvw);\n  height: min(5dvh, 2.5dvw);\n  border-radius: min(1.0vh, 0.5vw);\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n\n.deeplib-checkbox-container input.deeplib-input[type=\"checkbox\"]:checked::before {\n  width: 80%;\n  height: 80%;\n}\n\n.deeplib-input-container {\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: 0.3em;\n}\n\n.deeplib-input-container:has(label.deeplib-text) {\n  margin-top: min(1vh, 0.5vw);\n  margin-top: min(1dvh, 0.5dvw);\n}\n\n.deeplib-input-container input.deeplib-input {\n  font-size: 0.6em;\n  padding: min(1vh, 0.5vw);\n  padding: min(1dvh, 0.5dvw);\n  background-color: transparent;\n  outline: none;\n  min-height: min(5vh, 2.5vw);\n  min-height: min(5dvh, 2.5dvw);\n  border-radius: min(1.0vh, 0.5vw);\n  border-radius: min(1.0dvh, 0.5dvw);\n}\n\n.deeplib-input-container input.deeplib-input[type=\"color\"] {\n  padding: 0px;\n  width: min(5vh, 2.5vw);\n  height: min(5vh, 2.5vw);\n  width: min(5dvh, 2.5dvw);\n  height: min(5dvh, 2.5dvw);\n  border-radius: 0px;\n}\n\n.deeplib-input-container input.deeplib-input[type=\"color\"]:disabled {\n  border: var(--deeplib-blocked-color) solid var(--deeplib-border-width);\n  cursor: not-allowed;\n}\n\n.deeplib-dropdown-container {\n  display: flex;\n  flex-direction: row;\n  align-items: center;\n  gap: min(2vh, 1vw);\n  gap: min(2dvh, 1dvw);\n  color: var(--deeplib-text-color);\n\n  select {\n    padding: 0 min(1vh, 0.5vw);\n    padding: 0 min(1dvh, 0.5dvw);\n    border-radius: min(1vh, 0.5vw);\n    border-radius: min(1dvh, 0.5dvw);\n  }\n}",".deeplib-highlight-text {\n  font-weight: bold;\n  color: rgb(203, 185, 23);\n}\n\n#TextAreaChatLog[data-colortheme='dark'] div.ChatMessage.deeplib-message,\n#TextAreaChatLog[data-colortheme='dark2'] div.ChatMessage.deeplib-message {\n  background-color: var(--deeplib-element-color);\n  border: min(0.2dvh, 0.1dvw) solid var(--deeplib-border-color);\n  color: var(--deeplib-text-color);\n}\n\n#TextAreaChatLog div.ChatMessage.deeplib-message {\n  background-color: #eee;\n  border: min(0.2dvh, 0.1dvw) solid #440171;\n  color: #111;\n  padding-left: min(0.6dvh, 0.3dvw);\n  display: block;\n  white-space: normal;\n}\n\n#TextAreaChatLog[data-colortheme='dark'] div.ChatMessage.deeplib-message a,\n#TextAreaChatLog[data-colortheme='dark2'] div.ChatMessage.deeplib-message a {\n  color: var(--deeplib-text-color);\n}\n\n#TextAreaChatLog div.ChatMessage.deeplib-message a {\n  cursor: pointer;\n  font-weight: bold;\n  color: #111;\n}\n",".deeplib-modal {\n  position: fixed;\n  top: 10%;\n  left: 50%;\n  transform: translateX(-50%);\n  z-index: 1001;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  gap: 0.5em;\n  width: max(50dvw, 25dvh);\n  font-size: min(4dvh, 2dvw);\n  padding: min(2dvh, 1dvw);\n  background-color: var(--deeplib-element-color);\n  border-radius: min(1.2dvh, 0.6dvw);\n  border: min(0.2dvh, 0.1dvw) solid var(--deeplib-border-color);\n  color: var(--deeplib-text-color);\n\n  .deeplib-modal-input {\n    width: 100%;\n    font-size: min(2.6dvh, 1.8dvw);\n    border-radius: min(1.0dvh, 0.5dvw);\n    padding: min(1dvh, 0.5dvw);\n  }\n\n  input.deeplib-modal-input {\n    max-width: max(50dvh, 25dvw);\n  }\n\n  .deeplib-modal-button-container {\n    display: flex;\n    flex-direction: row;\n    justify-content: flex-end;\n    gap: 0.5em;\n    width: 100%;\n\n    .deeplib-button {\n      font-size: 0.8em;\n      display: flex;\n      width: auto;\n      padding: min(0.4vh, 0.2vw) min(2vh, 1vw);\n\n      .button-label {\n        display: contents;\n      }\n    }\n  }\n\n  .deeplib-modal-prompt-container {\n    display: flex;\n    flex-direction: column;\n    justify-content: center;\n    align-items: center;\n  }\n}\n\n.deeplib-modal-blocker {\n  z-index: 1000;\n  position: fixed;\n  top: 0;\n  left: 0;\n  width: 100dvw;\n  height: 100dvh;\n  background-color: rgba(0, 0, 0, 0.5);\n}\n"]} */`;
919
932
 
920
933
  // src/base/initialization.ts
921
934
  var modStorage;
@@ -1188,6 +1201,7 @@ var VersionModule = class _VersionModule extends BaseModule {
1188
1201
  }
1189
1202
  /** Sends the currently configured "new version" message to the local player. */
1190
1203
  static sendNewVersionMessage() {
1204
+ if (!_VersionModule.newVersionMessage) return;
1191
1205
  const beepLogLength = FriendListBeepLog.push({
1192
1206
  MemberNumber: Player.MemberNumber,
1193
1207
  MemberName: ModSdkManager.ModInfo.name,
@@ -1261,10 +1275,12 @@ var GuiDebug = class extends BaseSubscreen {
1261
1275
  {
1262
1276
  type: "button",
1263
1277
  id: "test-deeplib-big-button",
1278
+ options: {
1279
+ label: "Big Button",
1280
+ tooltip: "This is a big button",
1281
+ image: "Icons/Exit.png"
1282
+ },
1264
1283
  size: [405, 80],
1265
- label: "Big Button",
1266
- tooltip: "This is a big button",
1267
- image: "Icons/Exit.png",
1268
1284
  onClick() {
1269
1285
  deepLibLogger.info("Big Button Clicked");
1270
1286
  }
@@ -1272,9 +1288,11 @@ var GuiDebug = class extends BaseSubscreen {
1272
1288
  {
1273
1289
  type: "button",
1274
1290
  id: "test-deeplib-small-button",
1291
+ options: {
1292
+ tooltip: "This is a small button",
1293
+ image: "Icons/Exit.png"
1294
+ },
1275
1295
  size: [90, 90],
1276
- tooltip: "This is a small button",
1277
- image: "Icons/Exit.png",
1278
1296
  onClick() {
1279
1297
  deepLibLogger.info("Small Button Clicked");
1280
1298
  }
@@ -1326,10 +1344,12 @@ var GuiDebug = class extends BaseSubscreen {
1326
1344
  {
1327
1345
  type: "button",
1328
1346
  id: "test-deeplib-big-button2",
1347
+ options: {
1348
+ label: "Big Button",
1349
+ tooltip: "This is a big button",
1350
+ image: "Icons/Exit.png"
1351
+ },
1329
1352
  size: [405, 80],
1330
- label: "Big Button",
1331
- tooltip: "This is a big button",
1332
- image: "Icons/Prev.png",
1333
1353
  onClick() {
1334
1354
  deepLibLogger.info("Big Button Clicked");
1335
1355
  }
@@ -1337,9 +1357,11 @@ var GuiDebug = class extends BaseSubscreen {
1337
1357
  {
1338
1358
  type: "button",
1339
1359
  id: "test-deeplib-small-button2",
1360
+ options: {
1361
+ tooltip: "This is a small button",
1362
+ image: "Icons/Next.png"
1363
+ },
1340
1364
  size: [90, 90],
1341
- tooltip: "This is a small button",
1342
- image: "Icons/Next.png",
1343
1365
  onClick() {
1344
1366
  deepLibLogger.info("Small Button Clicked");
1345
1367
  }
@@ -1385,6 +1407,22 @@ var GuiDebug = class extends BaseSubscreen {
1385
1407
  id: "test-deeplib-label2",
1386
1408
  label: "Label",
1387
1409
  description: "This is a label"
1410
+ },
1411
+ {
1412
+ type: "dropdown",
1413
+ id: "test-deeplib-dropdown",
1414
+ label: "Dropdown",
1415
+ description: "This is a dropdown",
1416
+ optionsList: ["Option 1", "Option 2", "Option 3"],
1417
+ setElementValue() {
1418
+ return "Option 2";
1419
+ },
1420
+ setSettingValue(val) {
1421
+ deepLibLogger.info("Dropdown value:", val);
1422
+ },
1423
+ options: {
1424
+ width: 200
1425
+ }
1388
1426
  }
1389
1427
  ]
1390
1428
  ];
@@ -1392,22 +1430,27 @@ var GuiDebug = class extends BaseSubscreen {
1392
1430
  };
1393
1431
 
1394
1432
  // src/utilities/common.ts
1433
+ function isPlainObject(value) {
1434
+ return value !== null && typeof value === "object" && Object.getPrototypeOf(value) === Object.prototype;
1435
+ }
1436
+ __name(isPlainObject, "isPlainObject");
1395
1437
  function deepMerge(target, source) {
1396
1438
  if (target === void 0) return source;
1397
1439
  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];
1440
+ if (Array.isArray(target) && Array.isArray(source)) {
1441
+ return [...target, ...source];
1442
+ }
1443
+ if (isPlainObject(target) && isPlainObject(source)) {
1444
+ const result = { ...target };
1445
+ for (const key of Object.keys(source)) {
1446
+ if (key === "__proto__" || key === "constructor" || key === "prototype") {
1447
+ continue;
1448
+ }
1449
+ result[key] = key in target ? deepMerge(target[key], source[key]) : source[key];
1408
1450
  }
1451
+ return result;
1409
1452
  }
1410
- return target;
1453
+ return source;
1411
1454
  }
1412
1455
  __name(deepMerge, "deepMerge");
1413
1456
  function shuffleArray(array) {
@@ -1472,6 +1515,7 @@ var advElement = {
1472
1515
  createInput: elementCreateInput,
1473
1516
  createLabel: elementCreateLabel,
1474
1517
  createCustom: elementCreateCustom,
1518
+ createDropdown: elementCreateDropdown,
1475
1519
  createTooltip: elementCreateTooltip,
1476
1520
  getTooltip: elementGetTooltip,
1477
1521
  setTooltip: elementSetTooltip,
@@ -1502,7 +1546,7 @@ function elementCreateButton(options) {
1502
1546
  disabled
1503
1547
  },
1504
1548
  children: [
1505
- image ? {
1549
+ image ? deepMerge({
1506
1550
  tag: "img",
1507
1551
  attributes: {
1508
1552
  id: `${options.id}-image`,
@@ -1515,7 +1559,7 @@ function elementCreateButton(options) {
1515
1559
  style: {
1516
1560
  "--image": `url("${image}")`
1517
1561
  }
1518
- } : void 0
1562
+ }, options.htmlOptions?.img) : void 0
1519
1563
  ]
1520
1564
  }
1521
1565
  }, options.htmlOptions ?? {})
@@ -1529,7 +1573,7 @@ function elementCreateCheckbox(options) {
1529
1573
  if (elem) return elem;
1530
1574
  options.type = "checkbox";
1531
1575
  const disabled = typeof options?.disabled === "function" ? options?.disabled() : options?.disabled;
1532
- const retElem = ElementCreate({
1576
+ const retElem = ElementCreate(deepMerge({
1533
1577
  tag: "div",
1534
1578
  classList: ["deeplib-checkbox-container"],
1535
1579
  attributes: {
@@ -1544,23 +1588,23 @@ function elementCreateCheckbox(options) {
1544
1588
  id: options.id,
1545
1589
  disabled,
1546
1590
  checked: options?.setElementValue?.() || void 0
1591
+ },
1592
+ eventListeners: {
1593
+ change: /* @__PURE__ */ __name(function() {
1594
+ options?.setSettingValue?.(this.checked);
1595
+ }, "change")
1547
1596
  }
1548
- }, options.htmlOptions),
1549
- {
1597
+ }, options.htmlOptions?.checkbox),
1598
+ deepMerge({
1550
1599
  tag: "label",
1551
1600
  classList: ["deeplib-text"],
1552
1601
  attributes: {
1553
1602
  for: options.id
1554
1603
  },
1555
1604
  children: [options.label]
1556
- }
1557
- ],
1558
- eventListeners: {
1559
- change: /* @__PURE__ */ __name(() => {
1560
- options?.setSettingValue?.(document.getElementById(options.id)?.checked);
1561
- }, "change")
1562
- }
1563
- });
1605
+ }, options.htmlOptions?.label)
1606
+ ]
1607
+ }, options.htmlOptions?.container));
1564
1608
  if (options.description) {
1565
1609
  retElem.addEventListener("mouseover", () => {
1566
1610
  elementSetTooltip(options.description || "");
@@ -1574,7 +1618,10 @@ function elementCreateCheckbox(options) {
1574
1618
  }
1575
1619
  __name(elementCreateCheckbox, "elementCreateCheckbox");
1576
1620
  function elementCreateCustom(options) {
1577
- const elem = document.getElementById(options.id);
1621
+ options.id ??= ElementGenerateID();
1622
+ options.htmlOptions.attributes ??= {};
1623
+ options.htmlOptions.attributes.id ??= options.id;
1624
+ const elem = document.getElementById(options.htmlOptions.attributes.id);
1578
1625
  if (elem) return elem;
1579
1626
  options.type = "custom";
1580
1627
  const retElem = ElementCreate(options.htmlOptions);
@@ -1586,7 +1633,7 @@ function elementCreateInput(options) {
1586
1633
  const elem = document.getElementById(options.id);
1587
1634
  if (elem) return elem;
1588
1635
  const disabled = typeof options?.disabled === "function" ? options?.disabled() : options?.disabled;
1589
- const retElem = ElementCreate({
1636
+ const retElem = ElementCreate(deepMerge({
1590
1637
  tag: "div",
1591
1638
  classList: ["deeplib-input-container"],
1592
1639
  attributes: {
@@ -1602,23 +1649,23 @@ function elementCreateInput(options) {
1602
1649
  placeholder: " ",
1603
1650
  disabled,
1604
1651
  value: options?.setElementValue?.() || void 0
1652
+ },
1653
+ eventListeners: {
1654
+ input: /* @__PURE__ */ __name(function() {
1655
+ options?.setSettingValue?.(this.value);
1656
+ }, "input")
1605
1657
  }
1606
- }, options.htmlOptions),
1607
- options.label ? {
1658
+ }, options.htmlOptions?.input),
1659
+ options.label ? deepMerge({
1608
1660
  tag: "label",
1609
1661
  classList: ["deeplib-text"],
1610
1662
  attributes: {
1611
1663
  for: options.id
1612
1664
  },
1613
1665
  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
- });
1666
+ }, options.htmlOptions?.label) : void 0
1667
+ ]
1668
+ }, options.htmlOptions?.container));
1622
1669
  if (options.description) {
1623
1670
  retElem.addEventListener("mouseover", () => {
1624
1671
  elementSetTooltip(options.description || "");
@@ -1657,6 +1704,49 @@ function elementCreateLabel(options) {
1657
1704
  return retElem;
1658
1705
  }
1659
1706
  __name(elementCreateLabel, "elementCreateLabel");
1707
+ function elementCreateDropdown(options) {
1708
+ options.id ??= ElementGenerateID();
1709
+ const elem = document.getElementById(`${options.id}-container`);
1710
+ if (elem) return elem;
1711
+ options.type = "dropdown";
1712
+ const retElem = ElementCreate(deepMerge({
1713
+ tag: "div",
1714
+ classList: ["deeplib-dropdown-container"],
1715
+ attributes: {
1716
+ id: `${options.id}-container`
1717
+ },
1718
+ children: [
1719
+ options.label ? deepMerge({
1720
+ tag: "label",
1721
+ classList: ["deeplib-text"],
1722
+ attributes: {
1723
+ for: options.id
1724
+ },
1725
+ children: [options.label]
1726
+ }, options.htmlOptions?.label) : void 0,
1727
+ ElementCreateDropdown(
1728
+ options.id,
1729
+ options.optionsList,
1730
+ function() {
1731
+ return options.setSettingValue?.(this.value);
1732
+ },
1733
+ options.options,
1734
+ options.htmlOptions?.select
1735
+ )
1736
+ ],
1737
+ eventListeners: {
1738
+ mouseover: /* @__PURE__ */ __name(function() {
1739
+ elementSetTooltip(options.description ?? "");
1740
+ }, "mouseover"),
1741
+ mouseout: /* @__PURE__ */ __name(function() {
1742
+ elementSetTooltip("");
1743
+ }, "mouseout")
1744
+ }
1745
+ }, options.htmlOptions?.container));
1746
+ BaseSubscreen.currentElements.push([retElem, options]);
1747
+ return retElem;
1748
+ }
1749
+ __name(elementCreateDropdown, "elementCreateDropdown");
1660
1750
  function elementCreateTooltip() {
1661
1751
  const element = ElementCreate({
1662
1752
  tag: "div",
@@ -1985,7 +2075,9 @@ var MainMenu = class _MainMenu extends BaseSubscreen {
1985
2075
  subscreens = [];
1986
2076
  static options = {};
1987
2077
  static subscreenOptions = {
1988
- name: "mainmenu"
2078
+ name: "mainmenu",
2079
+ doShowExitButton: false,
2080
+ settingsWidth: 600
1989
2081
  };
1990
2082
  constructor(module) {
1991
2083
  super(module);
@@ -2436,7 +2528,9 @@ var ModStorage = class _ModStorage {
2436
2528
  if (this.extensionStorage) {
2437
2529
  const parsed = _ModStorage.dataDecompress(this.extensionStorage || "");
2438
2530
  if (parsed === null || !Object.hasOwn(parsed, "Version")) {
2439
- this.playerStorage = {};
2531
+ this.playerStorage = {
2532
+ Version: ModSdkManager.ModInfo.version
2533
+ };
2440
2534
  } else {
2441
2535
  this.playerStorage = parsed;
2442
2536
  }
@@ -3072,7 +3166,6 @@ export {
3072
3166
  getText,
3073
3167
  hasGetter,
3074
3168
  hasSetter,
3075
- init,
3076
3169
  initMod,
3077
3170
  layout,
3078
3171
  modStorage,