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.d.ts +58 -35
- package/dist/deeplib.js +186 -100
- 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 +2 -2
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
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
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
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
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
|
-
|
|
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
|
|
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
|
-
}
|
|
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:
|
|
805
|
+
padding: min(1vh, 0.5vw);
|
|
806
|
+
padding: min(1dvh, 0.5dvw);
|
|
795
807
|
background-color: transparent;
|
|
796
808
|
outline: none;
|
|
797
|
-
|
|
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
|
-
|
|
816
|
-
|
|
817
|
-
-
|
|
818
|
-
|
|
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
|
-
|
|
822
|
-
|
|
823
|
-
-
|
|
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 (
|
|
1399
|
-
return source;
|
|
1400
|
-
}
|
|
1401
|
-
|
|
1402
|
-
|
|
1403
|
-
|
|
1404
|
-
|
|
1405
|
-
|
|
1406
|
-
|
|
1407
|
-
|
|
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
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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,
|