dcl-npc-toolkit 1.1.4-20230616202545.commit-3fbe034 → 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/README.md CHANGED
@@ -391,7 +391,17 @@ export function setupUi() {
391
391
 
392
392
  ```
393
393
 
394
-
394
+
395
+ Note: The UI drawn by this library library requires fetching images from an external URL. For the scene to allow you to do this, you must include the `ALLOW_MEDIA_HOSTNAMES` scene permission and add `decentraland.org` to the list of allowed domains in your `scene.json` file. Learn more about [image permissions](https://docs.decentraland.org/creator/development-guide/sdk7/materials/#textures-from-an-external-url).
396
+
397
+ ```json
398
+ "requiredPermissions": [
399
+ "ALLOW_MEDIA_HOSTNAMES"
400
+ ],
401
+ "allowedMediaHostnames": [
402
+ "decentraland.org"
403
+ ],
404
+ ```
395
405
 
396
406
 
397
407
 
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: { bottom: positionPortaitY(), left: positionPortaitX() }
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: '300px',
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: '150px',
164
- height: '45px',
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: '25px',
182
- height: '25px',
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: '150px',
193
- height: '45px',
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: '25px',
210
- height: '25px',
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: '300px',
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: '150px',
230
- height: '45px',
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: '150px',
247
- height: '45px',
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-20230616202545.commit-3fbe034",
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": "3fbe034592f33b7f22e335aca7fa99cd2658f613"
36
+ "commit": "0c1ebfe9c331a4944d32d1f3f14e2ab6a958fa52"
37
37
  }