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.d.ts +54 -35
- package/dist/deeplib.js +180 -87
- package/dist/deeplib.js.map +2 -2
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/dist/vendored_types/utility.d.ts +3 -0
- package/package.json +1 -1
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
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
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
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
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
|
|
555
|
-
ElementSetSize(subscreen
|
|
556
|
-
ElementSetFontSize(subscreen
|
|
557
|
-
|
|
558
|
-
|
|
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:
|
|
800
|
+
padding: min(1vh, 0.5vw);
|
|
801
|
+
padding: min(1dvh, 0.5dvw);
|
|
795
802
|
background-color: transparent;
|
|
796
803
|
outline: none;
|
|
797
|
-
|
|
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
|
-
|
|
816
|
-
|
|
817
|
-
-
|
|
818
|
-
|
|
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
|
-
|
|
822
|
-
|
|
823
|
-
-
|
|
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 (
|
|
1399
|
-
return source;
|
|
1400
|
-
}
|
|
1401
|
-
|
|
1402
|
-
|
|
1403
|
-
|
|
1404
|
-
|
|
1405
|
-
|
|
1406
|
-
|
|
1407
|
-
|
|
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
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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,
|