dcl-npc-toolkit 1.1.4-20230619185824.commit-afe7da0 → 1.1.4-20230620173040.commit-0c1ebfe
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/ui.d.ts +1 -0
- package/dist/ui.js +56 -35
- package/package.json +2 -2
package/dist/ui.d.ts
CHANGED
|
@@ -74,4 +74,5 @@ export declare let redButtonSection: {
|
|
|
74
74
|
sourceLeft: number;
|
|
75
75
|
sourceTop: number;
|
|
76
76
|
};
|
|
77
|
+
export declare function setupNPCUiScaling(inModalScale: number, inFontSize: number, inModalTextWrapScale: number): void;
|
|
77
78
|
export declare const NpcUtilsUi: () => ReactEcs.JSX.Element;
|
package/dist/ui.js
CHANGED
|
@@ -50,9 +50,27 @@ export let redButtonSection = {
|
|
|
50
50
|
atlasHeight: sourcesComponentsCoordinates.atlasHeight,
|
|
51
51
|
atlasWidth: sourcesComponentsCoordinates.atlasWidth
|
|
52
52
|
};
|
|
53
|
+
let modalScale = 1;
|
|
54
|
+
let modelFontSizeScale = 1;
|
|
55
|
+
let modalTextWrapScale = 1;
|
|
56
|
+
export function setupNPCUiScaling(inModalScale, inFontSize, inModalTextWrapScale) {
|
|
57
|
+
modalScale = inModalScale;
|
|
58
|
+
modelFontSizeScale = inFontSize;
|
|
59
|
+
modalTextWrapScale = inModalTextWrapScale;
|
|
60
|
+
console.log('NPC-TOOLKIT', 'Scale UI:', modalScale, 'TextFontSize:', modelFontSizeScale, 'TextWrapScaling:', modalTextWrapScale);
|
|
61
|
+
}
|
|
62
|
+
function getScaledSize(size) {
|
|
63
|
+
return size * modalScale;
|
|
64
|
+
}
|
|
65
|
+
function getScaledFontSize(size) {
|
|
66
|
+
return size * modelFontSizeScale;
|
|
67
|
+
}
|
|
68
|
+
function getScaledTextWrap(size) {
|
|
69
|
+
return size * modalTextWrapScale;
|
|
70
|
+
}
|
|
53
71
|
export const NpcUtilsUi = () => {
|
|
54
|
-
const width = realWidth(700);
|
|
55
|
-
const height = realHeight(225);
|
|
72
|
+
const width = getScaledSize(realWidth(700));
|
|
73
|
+
const height = getScaledSize(realHeight(225));
|
|
56
74
|
return (ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
57
75
|
display: displayDialog() ? 'flex' : 'none',
|
|
58
76
|
flexDirection: 'column',
|
|
@@ -80,10 +98,13 @@ export const NpcUtilsUi = () => {
|
|
|
80
98
|
} }),
|
|
81
99
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
82
100
|
display: displayPortrait() ? 'flex' : 'none',
|
|
83
|
-
width: portraitWidth(),
|
|
84
|
-
height: portraitHeight(),
|
|
101
|
+
width: getScaledSize(portraitWidth()),
|
|
102
|
+
height: getScaledSize(portraitHeight()),
|
|
85
103
|
positionType: 'absolute',
|
|
86
|
-
position: {
|
|
104
|
+
position: {
|
|
105
|
+
bottom: getScaledSize(positionPortaitY()),
|
|
106
|
+
left: getScaledSize(positionPortaitX())
|
|
107
|
+
}
|
|
87
108
|
}, uiBackground: {
|
|
88
109
|
textureMode: 'stretch',
|
|
89
110
|
texture: {
|
|
@@ -92,8 +113,8 @@ export const NpcUtilsUi = () => {
|
|
|
92
113
|
} }),
|
|
93
114
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
94
115
|
display: displayImage() ? 'flex' : 'none',
|
|
95
|
-
width: imageWidth(),
|
|
96
|
-
height: imageHeight(),
|
|
116
|
+
width: getScaledSize(imageWidth()),
|
|
117
|
+
height: getScaledSize(imageHeight()),
|
|
97
118
|
positionType: 'absolute',
|
|
98
119
|
position: { bottom: positionImageY(), right: positionImageX() }
|
|
99
120
|
}, uiBackground: {
|
|
@@ -104,8 +125,8 @@ export const NpcUtilsUi = () => {
|
|
|
104
125
|
} }),
|
|
105
126
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
106
127
|
display: displaySkipable() ? 'flex' : 'none',
|
|
107
|
-
width: 15,
|
|
108
|
-
height: 15,
|
|
128
|
+
width: getScaledSize(15),
|
|
129
|
+
height: getScaledSize(15),
|
|
109
130
|
positionType: 'absolute',
|
|
110
131
|
position: { bottom: '7%', left: '25%' }
|
|
111
132
|
}, uiBackground: {
|
|
@@ -124,12 +145,12 @@ export const NpcUtilsUi = () => {
|
|
|
124
145
|
}, uiText: {
|
|
125
146
|
value: 'Skip',
|
|
126
147
|
color: getTextColor(),
|
|
127
|
-
fontSize: 12
|
|
148
|
+
fontSize: getScaledFontSize(12)
|
|
128
149
|
} })),
|
|
129
150
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
130
151
|
display: 'flex',
|
|
131
|
-
width: 24,
|
|
132
|
-
height: 36,
|
|
152
|
+
width: getScaledSize(24),
|
|
153
|
+
height: getScaledSize(36),
|
|
133
154
|
positionType: 'absolute',
|
|
134
155
|
position: { bottom: '5%', right: '2%' }
|
|
135
156
|
}, uiBackground: {
|
|
@@ -148,11 +169,11 @@ export const NpcUtilsUi = () => {
|
|
|
148
169
|
}, uiText: {
|
|
149
170
|
value: getText(),
|
|
150
171
|
color: getTextColor(),
|
|
151
|
-
fontSize: getFontSize(),
|
|
172
|
+
fontSize: getScaledFontSize(getFontSize()),
|
|
152
173
|
textAlign: 'middle-left'
|
|
153
174
|
} }),
|
|
154
175
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
155
|
-
width:
|
|
176
|
+
width: getScaledSize(300),
|
|
156
177
|
alignItems: 'center',
|
|
157
178
|
flexDirection: 'row',
|
|
158
179
|
justifyContent: 'space-between',
|
|
@@ -160,8 +181,8 @@ export const NpcUtilsUi = () => {
|
|
|
160
181
|
position: { top: '20%' }
|
|
161
182
|
} },
|
|
162
183
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
163
|
-
width:
|
|
164
|
-
height:
|
|
184
|
+
width: getScaledSize(150),
|
|
185
|
+
height: getScaledSize(45),
|
|
165
186
|
margin: { right: '5%' },
|
|
166
187
|
flexDirection: 'row',
|
|
167
188
|
alignItems: 'center',
|
|
@@ -174,13 +195,13 @@ export const NpcUtilsUi = () => {
|
|
|
174
195
|
src: getTheme()
|
|
175
196
|
},
|
|
176
197
|
uvs: getImageAtlasMapping(darkButtonSection)
|
|
177
|
-
}, uiText: { value: getButtonText(0), fontSize: 16 }, onMouseDown: () => {
|
|
198
|
+
}, uiText: { value: getButtonText(0), fontSize: getScaledFontSize(16) }, onMouseDown: () => {
|
|
178
199
|
buttonClick(0);
|
|
179
200
|
} },
|
|
180
201
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
181
|
-
width:
|
|
182
|
-
height:
|
|
183
|
-
position: { left: 5 }
|
|
202
|
+
width: getScaledSize(25),
|
|
203
|
+
height: getScaledSize(25),
|
|
204
|
+
position: { left: getScaledSize(5) }
|
|
184
205
|
}, uiBackground: {
|
|
185
206
|
textureMode: 'stretch',
|
|
186
207
|
texture: {
|
|
@@ -189,8 +210,8 @@ export const NpcUtilsUi = () => {
|
|
|
189
210
|
uvs: getImageAtlasMapping(secondaryButtonSection)
|
|
190
211
|
} })),
|
|
191
212
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
192
|
-
width:
|
|
193
|
-
height:
|
|
213
|
+
width: getScaledSize(150),
|
|
214
|
+
height: getScaledSize(45),
|
|
194
215
|
flexDirection: 'row',
|
|
195
216
|
alignItems: 'center',
|
|
196
217
|
justifyContent: 'flex-start',
|
|
@@ -202,13 +223,13 @@ export const NpcUtilsUi = () => {
|
|
|
202
223
|
src: getTheme()
|
|
203
224
|
},
|
|
204
225
|
uvs: getImageAtlasMapping(redButtonSection)
|
|
205
|
-
}, uiText: { value: getButtonText(1), fontSize: 16 }, onMouseDown: () => {
|
|
226
|
+
}, uiText: { value: getButtonText(1), fontSize: getScaledFontSize(16) }, onMouseDown: () => {
|
|
206
227
|
buttonClick(1);
|
|
207
228
|
} },
|
|
208
229
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
209
|
-
width:
|
|
210
|
-
height:
|
|
211
|
-
position: { left: 5 }
|
|
230
|
+
width: getScaledSize(25),
|
|
231
|
+
height: getScaledSize(25),
|
|
232
|
+
position: { left: getScaledSize(5) }
|
|
212
233
|
}, uiBackground: {
|
|
213
234
|
textureMode: 'stretch',
|
|
214
235
|
texture: {
|
|
@@ -217,17 +238,17 @@ export const NpcUtilsUi = () => {
|
|
|
217
238
|
uvs: getImageAtlasMapping(primaryButtonSection)
|
|
218
239
|
} }))),
|
|
219
240
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
220
|
-
width:
|
|
241
|
+
width: getScaledSize(300),
|
|
221
242
|
alignItems: 'center',
|
|
222
243
|
flexDirection: 'row',
|
|
223
244
|
justifyContent: 'space-between',
|
|
224
|
-
margin: { top: 20 },
|
|
245
|
+
margin: { top: getScaledSize(20) },
|
|
225
246
|
display: displaySecondButtonContainer() ? 'flex' : 'none',
|
|
226
247
|
position: { top: '15%' }
|
|
227
248
|
} },
|
|
228
249
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
229
|
-
width:
|
|
230
|
-
height:
|
|
250
|
+
width: getScaledSize(150),
|
|
251
|
+
height: getScaledSize(45),
|
|
231
252
|
margin: { right: '5%' },
|
|
232
253
|
alignItems: 'center',
|
|
233
254
|
justifyContent: 'center',
|
|
@@ -239,12 +260,12 @@ export const NpcUtilsUi = () => {
|
|
|
239
260
|
src: getTheme()
|
|
240
261
|
},
|
|
241
262
|
uvs: getImageAtlasMapping(darkButtonSection)
|
|
242
|
-
}, uiText: { value: getButtonText(2), fontSize: 16 }, onMouseDown: () => {
|
|
263
|
+
}, uiText: { value: getButtonText(2), fontSize: getScaledFontSize(16) }, onMouseDown: () => {
|
|
243
264
|
buttonClick(3);
|
|
244
265
|
} }),
|
|
245
266
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
246
|
-
width:
|
|
247
|
-
height:
|
|
267
|
+
width: getScaledSize(150),
|
|
268
|
+
height: getScaledSize(45),
|
|
248
269
|
alignItems: 'center',
|
|
249
270
|
justifyContent: 'center',
|
|
250
271
|
alignContent: 'flex-start',
|
|
@@ -255,8 +276,8 @@ export const NpcUtilsUi = () => {
|
|
|
255
276
|
src: getTheme()
|
|
256
277
|
},
|
|
257
278
|
uvs: getImageAtlasMapping(darkButtonSection)
|
|
258
|
-
}, uiText: { value: getButtonText(3), fontSize: 16 }, onMouseDown: () => {
|
|
279
|
+
}, uiText: { value: getButtonText(3), fontSize: getScaledFontSize(16) }, onMouseDown: () => {
|
|
259
280
|
buttonClick(4);
|
|
260
281
|
} }))));
|
|
261
282
|
};
|
|
262
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui.js","sourceRoot":"","sources":["../src/ui.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math'\nimport ReactEcs, { Button, Label, ReactEcsRenderer, UiEntity } from '@dcl/sdk/react-ecs'\nimport { Entity } from '@dcl/sdk/ecs'\nimport {\n  buttonClick,\n  confirmText,\n  displayButton,\n  displayDialog,\n  displayFirstButtonContainer,\n  displayImage,\n  displayPortrait,\n  displaySecondButtonContainer,\n  displaySkipable,\n  getButtonText,\n  getFontSize,\n  getImage,\n  getImageAtlasMapping,\n  getLeftClickTheme,\n  getPortrait,\n  getSkipableTheme,\n  getText,\n  getTextColor,\n  getTextPosition,\n  getTheme,\n  handleDialogClick,\n  imageHeight,\n  imageWidth,\n  portraitHeight,\n  portraitWidth,\n  positionImageX,\n  positionImageY,\n  positionPortaitX,\n  positionPortaitY,\n  positionTextX,\n  positionTextY,\n  realHeight,\n  realWidth,\n  skipDialogs\n} from './dialog'\nimport { sourcesComponentsCoordinates } from './uiResources'\nimport { activeNPC } from './npc'\n\nexport let lightTheme = 'https://decentraland.org/images/ui/light-atlas-v3.png'\nexport let darkTheme = 'https://decentraland.org/images/ui/dark-atlas-v3.png'\n\nexport let bubblesTexture = 'https://decentraland.org/images/ui/dialog-bubbles.png'\n\nexport let section = {\n  ...sourcesComponentsCoordinates.backgrounds.NPCDialog,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let skipButtonSection = {\n  ...sourcesComponentsCoordinates.buttons.F,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let skipButtonSectionBlack = {\n  ...sourcesComponentsCoordinates.buttons.FBlack,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let leftClickSection = {\n  ...sourcesComponentsCoordinates.icons.ClickWhite,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let leftClickSectionbBlack = {\n  ...sourcesComponentsCoordinates.icons.ClickDark,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let primaryButtonSection = {\n  ...sourcesComponentsCoordinates.buttons.E,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let secondaryButtonSection = {\n  ...sourcesComponentsCoordinates.buttons.F,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let darkButtonSection = {\n  ...sourcesComponentsCoordinates.buttons.buttonF,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let redButtonSection = {\n  ...sourcesComponentsCoordinates.buttons.buttonE,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport const NpcUtilsUi = () => {\n  const width = realWidth(700)\n  const height = realHeight(225)\n\n  return (\n    <UiEntity\n      uiTransform={{\n        display: displayDialog() ? 'flex' : 'none',\n        flexDirection: 'column',\n        alignItems: 'center',\n        justifyContent: 'center',\n        positionType: 'absolute',\n        position: { bottom: '15%', left: '50%' },\n        margin: { top: -height / 2, left: -width / 2 },\n        width,\n        height\n      }}\n    >\n      <UiEntity\n        uiTransform={{\n          positionType: 'absolute',\n          position: { top: 0, left: 0 },\n          width: '100%',\n          height: '100%'\n        }}\n        uiBackground={{\n          textureMode: 'stretch',\n          texture: {\n            src: getTheme()\n          },\n          uvs: getImageAtlasMapping(section)\n        }}\n        onMouseDown={() => {\n          handleDialogClick()\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          display: displayPortrait() ? 'flex' : 'none',\n          width: portraitWidth(),\n          height: portraitHeight(),\n          positionType: 'absolute',\n          position: { bottom: positionPortaitY(), left: positionPortaitX() }\n        }}\n        uiBackground={{\n          textureMode: 'stretch',\n          texture: {\n            src: getPortrait()\n          }\n          // uvs: getImageAtlasMapping(skipButtonSection),\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          display: displayImage() ? 'flex' : 'none',\n          width: imageWidth(),\n          height: imageHeight(),\n          positionType: 'absolute',\n          position: { bottom: positionImageY(), right: positionImageX() }\n        }}\n        uiBackground={{\n          textureMode: 'stretch',\n          texture: {\n            src: getImage()\n          }\n          // uvs: getImageAtlasMapping(skipButtonSection),\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          display: displaySkipable() ? 'flex' : 'none',\n          width: 15,\n          height: 15,\n          positionType: 'absolute',\n          position: { bottom: '7%', left: '25%' }\n        }}\n        uiBackground={{\n          textureMode: 'stretch',\n          texture: {\n            src: getTheme()\n          },\n          uvs: getImageAtlasMapping(getSkipableTheme())\n        }}\n        onMouseDown={() => {\n          skipDialogs(activeNPC)\n        }}\n      >\n        <UiEntity\n          uiTransform={{\n            display: 'flex',\n            positionType: 'absolute',\n            position: { left: '215%' }\n          }}\n          uiText={{\n            value: 'Skip',\n            color: getTextColor(),\n            fontSize: 12\n          }}\n        />\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          display: 'flex',\n          width: 24,\n          height: 36,\n          positionType: 'absolute',\n          position: { bottom: '5%', right: '2%' }\n        }}\n        uiBackground={{\n          textureMode: 'stretch',\n          texture: {\n            src: getTheme()\n          },\n          uvs: getImageAtlasMapping(getLeftClickTheme())\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          alignSelf: 'flex-start',\n          alignItems: 'flex-start',\n          justifyContent: 'flex-start',\n          flexDirection: 'row',\n          position: getTextPosition()\n        }}\n        uiText={{\n          value: getText(),\n          color: getTextColor(),\n          fontSize: getFontSize(),\n          textAlign: 'middle-left'\n        }}\n      ></UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          width: '300px',\n          alignItems: 'center',\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          display: displayFirstButtonContainer() ? 'flex' : 'none',\n          position: { top: '20%' }\n        }}\n      >\n        {/* Button1 (Top-Left) */}\n        <UiEntity\n          uiTransform={{\n            width: '150px',\n            height: '45px',\n            margin: { right: '5%' },\n            flexDirection: 'row',\n            alignItems: 'center',\n            justifyContent: 'flex-start',\n            alignContent: 'flex-start',\n            display: displayButton(1) ? 'flex' : 'none'\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: getTheme()\n            },\n            uvs: getImageAtlasMapping(darkButtonSection)\n          }}\n          uiText={{ value: getButtonText(0), fontSize: 16 }}\n          onMouseDown={() => {\n            buttonClick(0)\n          }}\n        >\n          <UiEntity\n            uiTransform={{\n              width: '25px',\n              height: '25px',\n              position: { left: 5 }\n            }}\n            uiBackground={{\n              textureMode: 'stretch',\n              texture: {\n                src: getTheme()\n              },\n              uvs: getImageAtlasMapping(secondaryButtonSection)\n            }}\n          ></UiEntity>\n        </UiEntity>\n\n        {/* Button2 (Top-Right) */}\n        <UiEntity\n          uiTransform={{\n            width: '150px',\n            height: '45px',\n            flexDirection: 'row',\n            alignItems: 'center',\n            justifyContent: 'flex-start',\n            alignContent: 'flex-start',\n            display: displayButton(2) ? 'flex' : 'none'\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: getTheme()\n            },\n            uvs: getImageAtlasMapping(redButtonSection)\n          }}\n          uiText={{ value: getButtonText(1), fontSize: 16 }}\n          onMouseDown={() => {\n            buttonClick(1)\n          }}\n        >\n          <UiEntity\n            uiTransform={{\n              width: '25px',\n              height: '25px',\n              position: { left: 5 }\n            }}\n            uiBackground={{\n              textureMode: 'stretch',\n              texture: {\n                src: getTheme()\n              },\n              uvs: getImageAtlasMapping(primaryButtonSection)\n            }}\n          ></UiEntity>\n        </UiEntity>\n      </UiEntity>\n\n      {/* Second row of buttons */}\n      <UiEntity\n        uiTransform={{\n          width: '300px',\n          alignItems: 'center',\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          margin: { top: 20 },\n          display: displaySecondButtonContainer() ? 'flex' : 'none',\n          position: { top: '15%' }\n        }}\n      >\n        {/* Button3 */}\n        <UiEntity\n          uiTransform={{\n            width: '150px',\n            height: '45px',\n            margin: { right: '5%' },\n            alignItems: 'center',\n            justifyContent: 'center',\n            alignContent: 'flex-start',\n            display: displayButton(3) ? 'flex' : 'none'\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: getTheme()\n            },\n            uvs: getImageAtlasMapping(darkButtonSection)\n          }}\n          uiText={{ value: getButtonText(2), fontSize: 16 }}\n          onMouseDown={() => {\n            buttonClick(3)\n          }}\n        ></UiEntity>\n\n        {/* Button4 */}\n        <UiEntity\n          uiTransform={{\n            width: '150px',\n            height: '45px',\n            alignItems: 'center',\n            justifyContent: 'center',\n            alignContent: 'flex-start',\n            display: displayButton(4) ? 'flex' : 'none'\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: getTheme()\n            },\n            uvs: getImageAtlasMapping(darkButtonSection)\n          }}\n          uiText={{ value: getButtonText(3), fontSize: 16 }}\n          onMouseDown={() => {\n            buttonClick(4)\n          }}\n        ></UiEntity>\n      </UiEntity>\n    </UiEntity>\n  )\n}\n"]}
|
|
283
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui.js","sourceRoot":"","sources":["../src/ui.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math'\nimport ReactEcs, { Button, Label, ReactEcsRenderer, UiEntity } from '@dcl/sdk/react-ecs'\nimport { Entity } from '@dcl/sdk/ecs'\nimport {\n  buttonClick,\n  confirmText,\n  displayButton,\n  displayDialog,\n  displayFirstButtonContainer,\n  displayImage,\n  displayPortrait,\n  displaySecondButtonContainer,\n  displaySkipable,\n  getButtonText,\n  getFontSize,\n  getImage,\n  getImageAtlasMapping,\n  getLeftClickTheme,\n  getPortrait,\n  getSkipableTheme,\n  getText,\n  getTextColor,\n  getTextPosition,\n  getTheme,\n  handleDialogClick,\n  imageHeight,\n  imageWidth,\n  portraitHeight,\n  portraitWidth,\n  positionImageX,\n  positionImageY,\n  positionPortaitX,\n  positionPortaitY,\n  positionTextX,\n  positionTextY,\n  realHeight,\n  realWidth,\n  skipDialogs\n} from './dialog'\nimport { sourcesComponentsCoordinates } from './uiResources'\nimport { activeNPC } from './npc'\n\nexport let lightTheme = 'https://decentraland.org/images/ui/light-atlas-v3.png'\nexport let darkTheme = 'https://decentraland.org/images/ui/dark-atlas-v3.png'\n\nexport let bubblesTexture = 'https://decentraland.org/images/ui/dialog-bubbles.png'\n\nexport let section = {\n  ...sourcesComponentsCoordinates.backgrounds.NPCDialog,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let skipButtonSection = {\n  ...sourcesComponentsCoordinates.buttons.F,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let skipButtonSectionBlack = {\n  ...sourcesComponentsCoordinates.buttons.FBlack,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let leftClickSection = {\n  ...sourcesComponentsCoordinates.icons.ClickWhite,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let leftClickSectionbBlack = {\n  ...sourcesComponentsCoordinates.icons.ClickDark,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let primaryButtonSection = {\n  ...sourcesComponentsCoordinates.buttons.E,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let secondaryButtonSection = {\n  ...sourcesComponentsCoordinates.buttons.F,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let darkButtonSection = {\n  ...sourcesComponentsCoordinates.buttons.buttonF,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nexport let redButtonSection = {\n  ...sourcesComponentsCoordinates.buttons.buttonE,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth\n}\n\nlet modalScale = 1\nlet modelFontSizeScale = 1\nlet modalTextWrapScale = 1\n\nexport function setupNPCUiScaling(inModalScale: number, inFontSize: number, inModalTextWrapScale: number) {\n  modalScale = inModalScale\n  modelFontSizeScale = inFontSize\n  modalTextWrapScale = inModalTextWrapScale\n  console.log(\n    'NPC-TOOLKIT',\n    'Scale UI:',\n    modalScale,\n    'TextFontSize:',\n    modelFontSizeScale,\n    'TextWrapScaling:',\n    modalTextWrapScale\n  )\n}\n\nfunction getScaledSize(size: number): number {\n  return size * modalScale\n}\nfunction getScaledFontSize(size: number): number {\n  return size * modelFontSizeScale\n}\nfunction getScaledTextWrap(size: number): number {\n  return size * modalTextWrapScale\n}\n\nexport const NpcUtilsUi = () => {\n  const width = getScaledSize(realWidth(700))\n  const height = getScaledSize(realHeight(225))\n\n  return (\n    <UiEntity\n      uiTransform={{\n        display: displayDialog() ? 'flex' : 'none',\n        flexDirection: 'column',\n        alignItems: 'center',\n        justifyContent: 'center',\n        positionType: 'absolute',\n        position: { bottom: '15%', left: '50%' },\n        margin: { top: -height / 2, left: -width / 2 },\n        width,\n        height\n      }}\n    >\n      <UiEntity\n        uiTransform={{\n          positionType: 'absolute',\n          position: { top: 0, left: 0 },\n          width: '100%',\n          height: '100%'\n        }}\n        uiBackground={{\n          textureMode: 'stretch',\n          texture: {\n            src: getTheme()\n          },\n          uvs: getImageAtlasMapping(section)\n        }}\n        onMouseDown={() => {\n          handleDialogClick()\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          display: displayPortrait() ? 'flex' : 'none',\n          width: getScaledSize(portraitWidth()),\n          height: getScaledSize(portraitHeight()),\n          positionType: 'absolute',\n          position: {\n            bottom: getScaledSize(positionPortaitY()),\n            left: getScaledSize(positionPortaitX())\n          }\n        }}\n        uiBackground={{\n          textureMode: 'stretch',\n          texture: {\n            src: getPortrait()\n          }\n          // uvs: getImageAtlasMapping(skipButtonSection),\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          display: displayImage() ? 'flex' : 'none',\n          width: getScaledSize(imageWidth()),\n          height: getScaledSize(imageHeight()),\n          positionType: 'absolute',\n          position: { bottom: positionImageY(), right: positionImageX() }\n        }}\n        uiBackground={{\n          textureMode: 'stretch',\n          texture: {\n            src: getImage()\n          }\n          // uvs: getImageAtlasMapping(skipButtonSection),\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          display: displaySkipable() ? 'flex' : 'none',\n          width: getScaledSize(15),\n          height: getScaledSize(15),\n          positionType: 'absolute',\n          position: { bottom: '7%', left: '25%' }\n        }}\n        uiBackground={{\n          textureMode: 'stretch',\n          texture: {\n            src: getTheme()\n          },\n          uvs: getImageAtlasMapping(getSkipableTheme())\n        }}\n        onMouseDown={() => {\n          skipDialogs(activeNPC)\n        }}\n      >\n        <UiEntity\n          uiTransform={{\n            display: 'flex',\n            positionType: 'absolute',\n            position: { left: '215%' }\n          }}\n          uiText={{\n            value: 'Skip',\n            color: getTextColor(),\n            fontSize: getScaledFontSize(12)\n          }}\n        />\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          display: 'flex',\n          width: getScaledSize(24),\n          height: getScaledSize(36),\n          positionType: 'absolute',\n          position: { bottom: '5%', right: '2%' }\n        }}\n        uiBackground={{\n          textureMode: 'stretch',\n          texture: {\n            src: getTheme()\n          },\n          uvs: getImageAtlasMapping(getLeftClickTheme())\n        }}\n      />\n\n      <UiEntity\n        uiTransform={{\n          alignSelf: 'flex-start',\n          alignItems: 'flex-start',\n          justifyContent: 'flex-start',\n          flexDirection: 'row',\n          position: getTextPosition()\n        }}\n        uiText={{\n          value: getText(),\n          color: getTextColor(),\n          fontSize: getScaledFontSize(getFontSize()),\n          textAlign: 'middle-left'\n        }}\n      ></UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          width: getScaledSize(300),\n          alignItems: 'center',\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          display: displayFirstButtonContainer() ? 'flex' : 'none',\n          position: { top: '20%' }\n        }}\n      >\n        {/* Button1 (Top-Left) */}\n        <UiEntity\n          uiTransform={{\n            width: getScaledSize(150),\n            height: getScaledSize(45),\n            margin: { right: '5%' },\n            flexDirection: 'row',\n            alignItems: 'center',\n            justifyContent: 'flex-start',\n            alignContent: 'flex-start',\n            display: displayButton(1) ? 'flex' : 'none'\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: getTheme()\n            },\n            uvs: getImageAtlasMapping(darkButtonSection)\n          }}\n          uiText={{ value: getButtonText(0), fontSize: getScaledFontSize(16) }}\n          onMouseDown={() => {\n            buttonClick(0)\n          }}\n        >\n          <UiEntity\n            uiTransform={{\n              width: getScaledSize(25),\n              height: getScaledSize(25),\n              position: { left: getScaledSize(5) }\n            }}\n            uiBackground={{\n              textureMode: 'stretch',\n              texture: {\n                src: getTheme()\n              },\n              uvs: getImageAtlasMapping(secondaryButtonSection)\n            }}\n          ></UiEntity>\n        </UiEntity>\n\n        {/* Button2 (Top-Right) */}\n        <UiEntity\n          uiTransform={{\n            width: getScaledSize(150),\n            height: getScaledSize(45),\n            flexDirection: 'row',\n            alignItems: 'center',\n            justifyContent: 'flex-start',\n            alignContent: 'flex-start',\n            display: displayButton(2) ? 'flex' : 'none'\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: getTheme()\n            },\n            uvs: getImageAtlasMapping(redButtonSection)\n          }}\n          uiText={{ value: getButtonText(1), fontSize: getScaledFontSize(16) }}\n          onMouseDown={() => {\n            buttonClick(1)\n          }}\n        >\n          <UiEntity\n            uiTransform={{\n              width: getScaledSize(25),\n              height: getScaledSize(25),\n              position: { left: getScaledSize(5) }\n            }}\n            uiBackground={{\n              textureMode: 'stretch',\n              texture: {\n                src: getTheme()\n              },\n              uvs: getImageAtlasMapping(primaryButtonSection)\n            }}\n          ></UiEntity>\n        </UiEntity>\n      </UiEntity>\n\n      {/* Second row of buttons */}\n      <UiEntity\n        uiTransform={{\n          width: getScaledSize(300),\n          alignItems: 'center',\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          margin: { top: getScaledSize(20) },\n          display: displaySecondButtonContainer() ? 'flex' : 'none',\n          position: { top: '15%' }\n        }}\n      >\n        {/* Button3 */}\n        <UiEntity\n          uiTransform={{\n            width: getScaledSize(150),\n            height: getScaledSize(45),\n            margin: { right: '5%' },\n            alignItems: 'center',\n            justifyContent: 'center',\n            alignContent: 'flex-start',\n            display: displayButton(3) ? 'flex' : 'none'\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: getTheme()\n            },\n            uvs: getImageAtlasMapping(darkButtonSection)\n          }}\n          uiText={{ value: getButtonText(2), fontSize: getScaledFontSize(16) }}\n          onMouseDown={() => {\n            buttonClick(3)\n          }}\n        ></UiEntity>\n\n        {/* Button4 */}\n        <UiEntity\n          uiTransform={{\n            width: getScaledSize(150),\n            height: getScaledSize(45),\n            alignItems: 'center',\n            justifyContent: 'center',\n            alignContent: 'flex-start',\n            display: displayButton(4) ? 'flex' : 'none'\n          }}\n          uiBackground={{\n            textureMode: 'stretch',\n            texture: {\n              src: getTheme()\n            },\n            uvs: getImageAtlasMapping(darkButtonSection)\n          }}\n          uiText={{ value: getButtonText(3), fontSize: getScaledFontSize(16) }}\n          onMouseDown={() => {\n            buttonClick(4)\n          }}\n        ></UiEntity>\n      </UiEntity>\n    </UiEntity>\n  )\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "dcl-npc-toolkit",
|
|
3
|
-
"version": "1.1.4-
|
|
3
|
+
"version": "1.1.4-20230620173040.commit-0c1ebfe",
|
|
4
4
|
"description": "A collection of tools for creating Non-Player-Characters (NPCs). These are capable of having conversations with the player, and play different animations.",
|
|
5
5
|
"main": "./dist/index.js",
|
|
6
6
|
"typings": "./dist/index.d.ts",
|
|
@@ -33,5 +33,5 @@
|
|
|
33
33
|
"files": [
|
|
34
34
|
"dist"
|
|
35
35
|
],
|
|
36
|
-
"commit": "
|
|
36
|
+
"commit": "0c1ebfe9c331a4944d32d1f3f14e2ab6a958fa52"
|
|
37
37
|
}
|