dcl-npc-toolkit 1.1.2-20230614195844.commit-f135f0d → 1.1.3-20230615194800.commit-278b488

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/systems.js CHANGED
@@ -99,7 +99,7 @@ export function inputListenerSystem() {
99
99
  }
100
100
  }
101
101
  }
102
- if (PET && PEP) {
102
+ if (SET && SEP) {
103
103
  if (activeNPC) {
104
104
  let dialogData = npcDialogComponent.get(activeNPC);
105
105
  if (!dialogData.visible || Date.now() - dialogData.openTime < 100)
@@ -112,7 +112,7 @@ export function inputListenerSystem() {
112
112
  }
113
113
  }
114
114
  }
115
- if (SET && SEP) {
115
+ if (PET && PEP) {
116
116
  if (activeNPC) {
117
117
  let dialogData = npcDialogComponent.get(activeNPC);
118
118
  if (!dialogData.visible || Date.now() - dialogData.openTime < 100)
@@ -126,4 +126,4 @@ export function inputListenerSystem() {
126
126
  }
127
127
  }
128
128
  }
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"systems.js","sourceRoot":"","sources":["../src/systems.ts"],"names":[],"mappings":"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","sourcesContent":["import { Entity, InputAction, PointerEventType, TextShape, Transform, engine, inputSystem } from \"@dcl/sdk/ecs\";\nimport { IsFollowingPath, IsTypingBubble, IsTypingDialog, TrackUserFlag } from \"./components\";\nimport { activeNPC, walkingTimers } from \"./npc\";\nimport { ConfirmMode, confirmText, npcDialogComponent, rushText, skipDialogs } from \"./dialog\";\nimport { bubbles, next } from \"./bubble\";\nimport { Quaternion, Vector3 } from \"@dcl/sdk/math\";\n\nexport function handlePathTimes(dt:number) {\n    for (const [entity] of engine.getEntitiesWith(IsFollowingPath)) {\n        if(walkingTimers.has(entity)){\n            let elapsed:number = walkingTimers.get(entity)!\n            elapsed += dt\n            walkingTimers.set(entity, walkingTimers.get(entity)! + dt)\n        }\n        else{\n            walkingTimers.set(entity, dt)\n        }\n    }\n  }\n\nexport function handleDialogTyping(dt:number) {\n    for (const [entity] of engine.getEntitiesWith(IsTypingDialog)) {\n        let dialogData = npcDialogComponent.get(entity)\n        if(!dialogData.typing){\n            return\n        }\n\n        dialogData.timer += dt\n        if (dialogData.timer >= 2 / dialogData.speed) {\n            let charsToAdd = Math.floor(dialogData.timer / (1 / dialogData.speed))\n            dialogData.timer = 0\n\n            dialogData.visibleChars += charsToAdd\n\n            if (dialogData.visibleChars >= dialogData.fullText.length) {\n                dialogData.typing = false\n                dialogData.visibleChars = dialogData.fullText.length\n                IsTypingDialog.deleteFrom(entity)\n            }\n\n            dialogData.visibleText = dialogData.fullText.substr(0, dialogData.visibleChars)\n        }\n    }\n  }\n\n  export function handleBubbletyping(dt:number) {\n    for (const [entity] of engine.getEntitiesWith(IsTypingBubble)) {\n        let dialogData = bubbles.get(entity)\n        if(dialogData.done){\n            continue\n        }\n\n        dialogData.timer += dt\n\n        if (!dialogData.typing) {\n            if (dialogData.timer > dialogData.timeOn) {\n                //dialogData.isBubbleOpen = false\n                dialogData.done = true\n                dialogData.typing = false\n                dialogData.timer = 0\n                next(entity)\n            }\n          }\n       else if (dialogData.timer >= 2 / dialogData.speed) {\n            let charsToAdd = Math.floor(dialogData.timer / (1 / dialogData.speed))\n            dialogData.timer = 0\n            dialogData.visibleChars += charsToAdd\n        \n            if (dialogData.visibleChars >= dialogData.fullText.length || dialogData.done) {\n                dialogData.typing = false\n                dialogData.visibleChars = dialogData.fullText.length\n                IsTypingDialog.deleteFrom(entity)\n            }\n            TextShape.getMutable(dialogData.text).text = dialogData.fullText.substr(0, dialogData.visibleChars)\n        }\n    }\n  }\n\nexport function faceUserSystem(dt: number) {\n  for (const [entity, track] of engine.getEntitiesWith(TrackUserFlag)) {\n    if (track.active) {\n      const player = Transform.get(engine.PlayerEntity)\n      let lookAtTarget = Vector3.create(player.position.x, player.position.y, player.position.z)\n      let direction = Vector3.subtract(lookAtTarget, Transform.get(entity).position)\n\n      let transform = Transform.getMutable(entity)\n      transform.rotation = Quaternion.slerp(transform.rotation, Quaternion.lookRotation(direction), dt * track.rotSpeed)\n\n      if (track.lockXZRotation) {\n        transform.rotation.x = 0\n        transform.rotation.z = 0\n      }\n    }\n  }\n}\n\nexport function inputListenerSystem(){\n  const PET = inputSystem.isTriggered(InputAction.IA_PRIMARY,PointerEventType.PET_DOWN)\n  const PEP = inputSystem.isPressed(InputAction.IA_PRIMARY)\n\n  const PPET = inputSystem.isTriggered(InputAction.IA_POINTER,PointerEventType.PET_DOWN)\n  const PPEP = inputSystem.isPressed(InputAction.IA_POINTER)\n\n  const SET = inputSystem.isTriggered(InputAction.IA_SECONDARY,PointerEventType.PET_DOWN)\n  const SEP = inputSystem.isPressed(InputAction.IA_SECONDARY)\n\n  if(PPET && PPEP){\n    if(activeNPC){\n      let dialogData = npcDialogComponent.get(activeNPC)\n      if(!dialogData.visible || Date.now() - dialogData.openTime < 100)return\n      if(dialogData.typing){\n        rushText(activeNPC)\n      }else if(!dialogData.isQuestion){\n        confirmText(activeNPC, ConfirmMode.Next)\n      }\n    }\n  }\n\n  if(PET && PEP){\n    if(activeNPC){\n      let dialogData = npcDialogComponent.get(activeNPC)\n      if(!dialogData.visible || Date.now() - dialogData.openTime < 100)return\n      if(dialogData.isQuestion){\n        confirmText(activeNPC, ConfirmMode.Confirm)\n      }else if(!dialogData.isQuestion){\n        confirmText(activeNPC, ConfirmMode.Next)\n      }\n    }\n  }\n\n  if(SET && SEP){\n    if(activeNPC){\n      let dialogData = npcDialogComponent.get(activeNPC)\n      if(!dialogData.visible || Date.now() - dialogData.openTime < 100)return\n      if(dialogData.isQuestion){\n        confirmText(activeNPC, ConfirmMode.Cancel)\n      }else if(dialogData.script[dialogData.index].skipable && !dialogData.isFixedScreen){\n        skipDialogs(activeNPC)\n      }\n    }\n  }\n\n\n\n//\n}"]}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"systems.js","sourceRoot":"","sources":["../src/systems.ts"],"names":[],"mappings":"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","sourcesContent":["import { Entity, InputAction, PointerEventType, TextShape, Transform, engine, inputSystem } from \"@dcl/sdk/ecs\";\nimport { IsFollowingPath, IsTypingBubble, IsTypingDialog, TrackUserFlag } from \"./components\";\nimport { activeNPC, walkingTimers } from \"./npc\";\nimport { ConfirmMode, confirmText, npcDialogComponent, rushText, skipDialogs } from \"./dialog\";\nimport { bubbles, next } from \"./bubble\";\nimport { Quaternion, Vector3 } from \"@dcl/sdk/math\";\n\nexport function handlePathTimes(dt:number) {\n    for (const [entity] of engine.getEntitiesWith(IsFollowingPath)) {\n        if(walkingTimers.has(entity)){\n            let elapsed:number = walkingTimers.get(entity)!\n            elapsed += dt\n            walkingTimers.set(entity, walkingTimers.get(entity)! + dt)\n        }\n        else{\n            walkingTimers.set(entity, dt)\n        }\n    }\n  }\n\nexport function handleDialogTyping(dt:number) {\n    for (const [entity] of engine.getEntitiesWith(IsTypingDialog)) {\n        let dialogData = npcDialogComponent.get(entity)\n        if(!dialogData.typing){\n            return\n        }\n\n        dialogData.timer += dt\n        if (dialogData.timer >= 2 / dialogData.speed) {\n            let charsToAdd = Math.floor(dialogData.timer / (1 / dialogData.speed))\n            dialogData.timer = 0\n\n            dialogData.visibleChars += charsToAdd\n\n            if (dialogData.visibleChars >= dialogData.fullText.length) {\n                dialogData.typing = false\n                dialogData.visibleChars = dialogData.fullText.length\n                IsTypingDialog.deleteFrom(entity)\n            }\n\n            dialogData.visibleText = dialogData.fullText.substr(0, dialogData.visibleChars)\n        }\n    }\n  }\n\n  export function handleBubbletyping(dt:number) {\n    for (const [entity] of engine.getEntitiesWith(IsTypingBubble)) {\n        let dialogData = bubbles.get(entity)\n        if(dialogData.done){\n            continue\n        }\n\n        dialogData.timer += dt\n\n        if (!dialogData.typing) {\n            if (dialogData.timer > dialogData.timeOn) {\n                //dialogData.isBubbleOpen = false\n                dialogData.done = true\n                dialogData.typing = false\n                dialogData.timer = 0\n                next(entity)\n            }\n          }\n       else if (dialogData.timer >= 2 / dialogData.speed) {\n            let charsToAdd = Math.floor(dialogData.timer / (1 / dialogData.speed))\n            dialogData.timer = 0\n            dialogData.visibleChars += charsToAdd\n        \n            if (dialogData.visibleChars >= dialogData.fullText.length || dialogData.done) {\n                dialogData.typing = false\n                dialogData.visibleChars = dialogData.fullText.length\n                IsTypingDialog.deleteFrom(entity)\n            }\n            TextShape.getMutable(dialogData.text).text = dialogData.fullText.substr(0, dialogData.visibleChars)\n        }\n    }\n  }\n\nexport function faceUserSystem(dt: number) {\n  for (const [entity, track] of engine.getEntitiesWith(TrackUserFlag)) {\n    if (track.active) {\n      const player = Transform.get(engine.PlayerEntity)\n      let lookAtTarget = Vector3.create(player.position.x, player.position.y, player.position.z)\n      let direction = Vector3.subtract(lookAtTarget, Transform.get(entity).position)\n\n      let transform = Transform.getMutable(entity)\n      transform.rotation = Quaternion.slerp(transform.rotation, Quaternion.lookRotation(direction), dt * track.rotSpeed)\n\n      if (track.lockXZRotation) {\n        transform.rotation.x = 0\n        transform.rotation.z = 0\n      }\n    }\n  }\n}\n\nexport function inputListenerSystem(){\n  const PET = inputSystem.isTriggered(InputAction.IA_PRIMARY,PointerEventType.PET_DOWN)\n  const PEP = inputSystem.isPressed(InputAction.IA_PRIMARY)\n\n  const PPET = inputSystem.isTriggered(InputAction.IA_POINTER,PointerEventType.PET_DOWN)\n  const PPEP = inputSystem.isPressed(InputAction.IA_POINTER)\n\n  const SET = inputSystem.isTriggered(InputAction.IA_SECONDARY,PointerEventType.PET_DOWN)\n  const SEP = inputSystem.isPressed(InputAction.IA_SECONDARY)\n\n  if(PPET && PPEP){\n    if(activeNPC){\n      let dialogData = npcDialogComponent.get(activeNPC)\n      if(!dialogData.visible || Date.now() - dialogData.openTime < 100)return\n      if(dialogData.typing){\n        rushText(activeNPC)\n      }else if(!dialogData.isQuestion){\n        confirmText(activeNPC, ConfirmMode.Next)\n      }\n    }\n  }\n\n  if(SET && SEP){\n    if(activeNPC){\n      let dialogData = npcDialogComponent.get(activeNPC)\n      if(!dialogData.visible || Date.now() - dialogData.openTime < 100)return\n      if(dialogData.isQuestion){\n        confirmText(activeNPC, ConfirmMode.Confirm)\n      }else if(!dialogData.isQuestion){\n        confirmText(activeNPC, ConfirmMode.Next)\n      }\n    }\n  }\n\n  if(PET && PEP){\n    if(activeNPC){\n      let dialogData = npcDialogComponent.get(activeNPC)\n      if(!dialogData.visible || Date.now() - dialogData.openTime < 100)return\n      if(dialogData.isQuestion){\n        confirmText(activeNPC, ConfirmMode.Cancel)\n      }else if(dialogData.script[dialogData.index].skipable && !dialogData.isFixedScreen){\n        skipDialogs(activeNPC)\n      }\n    }\n  }\n\n\n\n//\n}"]}
package/dist/ui.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import ReactEcs from "@dcl/sdk/react-ecs";
1
+ import ReactEcs from '@dcl/sdk/react-ecs';
2
2
  export declare let lightTheme: string;
3
3
  export declare let darkTheme: string;
4
4
  export declare let bubblesTexture: string;
package/dist/ui.js CHANGED
@@ -1,54 +1,54 @@
1
- import ReactEcs, { UiEntity, } from "@dcl/sdk/react-ecs";
2
- import { buttonClick, displayButton, displayDialog, displayFirstButtonContainer, displayImage, displayPortrait, displaySecondButtonContainer, displaySkipable, getButtonText, getFontSize, getImage, getImageAtlasMapping, getLeftClickTheme, getPortrait, getSkipableTheme, getText, getTextColor, getTextPosition, getTheme, handleDialogClick, imageHeight, imageWidth, portraitHeight, portraitWidth, positionImageX, positionImageY, positionPortaitX, positionPortaitY, realHeight, realWidth, skipDialogs, } from "./dialog";
3
- import { sourcesComponentsCoordinates } from "./uiResources";
4
- import { activeNPC } from "./npc";
5
- export let lightTheme = "https://decentraland.org/images/ui/light-atlas-v3.png";
6
- export let darkTheme = "https://decentraland.org/images/ui/dark-atlas-v3.png";
7
- export let bubblesTexture = "https://decentraland.org/images/ui/dialog-bubbles.png";
1
+ import ReactEcs, { UiEntity } from '@dcl/sdk/react-ecs';
2
+ import { buttonClick, displayButton, displayDialog, displayFirstButtonContainer, displayImage, displayPortrait, displaySecondButtonContainer, displaySkipable, getButtonText, getFontSize, getImage, getImageAtlasMapping, getLeftClickTheme, getPortrait, getSkipableTheme, getText, getTextColor, getTextPosition, getTheme, handleDialogClick, imageHeight, imageWidth, portraitHeight, portraitWidth, positionImageX, positionImageY, positionPortaitX, positionPortaitY, realHeight, realWidth, skipDialogs } from './dialog';
3
+ import { sourcesComponentsCoordinates } from './uiResources';
4
+ import { activeNPC } from './npc';
5
+ export let lightTheme = 'https://decentraland.org/images/ui/light-atlas-v3.png';
6
+ export let darkTheme = 'https://decentraland.org/images/ui/dark-atlas-v3.png';
7
+ export let bubblesTexture = 'https://decentraland.org/images/ui/dialog-bubbles.png';
8
8
  export let section = {
9
9
  ...sourcesComponentsCoordinates.backgrounds.NPCDialog,
10
10
  atlasHeight: sourcesComponentsCoordinates.atlasHeight,
11
- atlasWidth: sourcesComponentsCoordinates.atlasWidth,
11
+ atlasWidth: sourcesComponentsCoordinates.atlasWidth
12
12
  };
13
13
  export let skipButtonSection = {
14
14
  ...sourcesComponentsCoordinates.buttons.F,
15
15
  atlasHeight: sourcesComponentsCoordinates.atlasHeight,
16
- atlasWidth: sourcesComponentsCoordinates.atlasWidth,
16
+ atlasWidth: sourcesComponentsCoordinates.atlasWidth
17
17
  };
18
18
  export let skipButtonSectionBlack = {
19
19
  ...sourcesComponentsCoordinates.buttons.FBlack,
20
20
  atlasHeight: sourcesComponentsCoordinates.atlasHeight,
21
- atlasWidth: sourcesComponentsCoordinates.atlasWidth,
21
+ atlasWidth: sourcesComponentsCoordinates.atlasWidth
22
22
  };
23
23
  export let leftClickSection = {
24
24
  ...sourcesComponentsCoordinates.icons.ClickWhite,
25
25
  atlasHeight: sourcesComponentsCoordinates.atlasHeight,
26
- atlasWidth: sourcesComponentsCoordinates.atlasWidth,
26
+ atlasWidth: sourcesComponentsCoordinates.atlasWidth
27
27
  };
28
28
  export let leftClickSectionbBlack = {
29
29
  ...sourcesComponentsCoordinates.icons.ClickDark,
30
30
  atlasHeight: sourcesComponentsCoordinates.atlasHeight,
31
- atlasWidth: sourcesComponentsCoordinates.atlasWidth,
31
+ atlasWidth: sourcesComponentsCoordinates.atlasWidth
32
32
  };
33
33
  export let primaryButtonSection = {
34
34
  ...sourcesComponentsCoordinates.buttons.E,
35
35
  atlasHeight: sourcesComponentsCoordinates.atlasHeight,
36
- atlasWidth: sourcesComponentsCoordinates.atlasWidth,
36
+ atlasWidth: sourcesComponentsCoordinates.atlasWidth
37
37
  };
38
38
  export let secondaryButtonSection = {
39
39
  ...sourcesComponentsCoordinates.buttons.F,
40
40
  atlasHeight: sourcesComponentsCoordinates.atlasHeight,
41
- atlasWidth: sourcesComponentsCoordinates.atlasWidth,
41
+ atlasWidth: sourcesComponentsCoordinates.atlasWidth
42
42
  };
43
43
  export let darkButtonSection = {
44
- ...sourcesComponentsCoordinates.buttons.dark,
44
+ ...sourcesComponentsCoordinates.buttons.buttonF,
45
45
  atlasHeight: sourcesComponentsCoordinates.atlasHeight,
46
- atlasWidth: sourcesComponentsCoordinates.atlasWidth,
46
+ atlasWidth: sourcesComponentsCoordinates.atlasWidth
47
47
  };
48
48
  export let redButtonSection = {
49
- ...sourcesComponentsCoordinates.buttons.red,
49
+ ...sourcesComponentsCoordinates.buttons.buttonE,
50
50
  atlasHeight: sourcesComponentsCoordinates.atlasHeight,
51
- atlasWidth: sourcesComponentsCoordinates.atlasWidth,
51
+ atlasWidth: sourcesComponentsCoordinates.atlasWidth
52
52
  };
53
53
  export const NpcUtilsUi = () => {
54
54
  const width = realWidth(700);
@@ -62,19 +62,19 @@ export const NpcUtilsUi = () => {
62
62
  position: { bottom: '15%', left: '50%' },
63
63
  margin: { top: -height / 2, left: -width / 2 },
64
64
  width,
65
- height,
65
+ height
66
66
  } },
67
67
  ReactEcs.createElement(UiEntity, { uiTransform: {
68
68
  positionType: 'absolute',
69
69
  position: { top: 0, left: 0 },
70
70
  width: '100%',
71
- height: '100%',
71
+ height: '100%'
72
72
  }, uiBackground: {
73
73
  textureMode: 'stretch',
74
74
  texture: {
75
- src: getTheme(),
75
+ src: getTheme()
76
76
  },
77
- uvs: getImageAtlasMapping(section),
77
+ uvs: getImageAtlasMapping(section)
78
78
  }, onMouseDown: () => {
79
79
  handleDialogClick();
80
80
  } }),
@@ -82,69 +82,69 @@ export const NpcUtilsUi = () => {
82
82
  display: displayPortrait() ? 'flex' : 'none',
83
83
  width: portraitWidth(),
84
84
  height: portraitHeight(),
85
- positionType: "absolute",
86
- position: { bottom: positionPortaitY(), left: positionPortaitX() },
85
+ positionType: 'absolute',
86
+ position: { bottom: positionPortaitY(), left: positionPortaitX() }
87
87
  }, uiBackground: {
88
- textureMode: "stretch",
88
+ textureMode: 'stretch',
89
89
  texture: {
90
- src: getPortrait(),
91
- },
90
+ src: getPortrait()
91
+ }
92
92
  } }),
93
93
  ReactEcs.createElement(UiEntity, { uiTransform: {
94
94
  display: displayImage() ? 'flex' : 'none',
95
95
  width: imageWidth(),
96
96
  height: imageHeight(),
97
- positionType: "absolute",
98
- position: { bottom: positionImageY(), right: positionImageX() },
97
+ positionType: 'absolute',
98
+ position: { bottom: positionImageY(), right: positionImageX() }
99
99
  }, uiBackground: {
100
- textureMode: "stretch",
100
+ textureMode: 'stretch',
101
101
  texture: {
102
- src: getImage(),
103
- },
102
+ src: getImage()
103
+ }
104
104
  } }),
105
105
  ReactEcs.createElement(UiEntity, { uiTransform: {
106
106
  display: displaySkipable() ? 'flex' : 'none',
107
107
  width: 15,
108
108
  height: 15,
109
- positionType: "absolute",
110
- position: { bottom: '7%', left: '25%' },
109
+ positionType: 'absolute',
110
+ position: { bottom: '7%', left: '25%' }
111
111
  }, uiBackground: {
112
- textureMode: "stretch",
112
+ textureMode: 'stretch',
113
113
  texture: {
114
- src: getTheme(),
114
+ src: getTheme()
115
115
  },
116
- uvs: getImageAtlasMapping(getSkipableTheme()),
116
+ uvs: getImageAtlasMapping(getSkipableTheme())
117
117
  }, onMouseDown: () => {
118
118
  skipDialogs(activeNPC);
119
119
  } },
120
120
  ReactEcs.createElement(UiEntity, { uiTransform: {
121
121
  display: 'flex',
122
- positionType: "absolute",
123
- position: { left: '215%' },
122
+ positionType: 'absolute',
123
+ position: { left: '215%' }
124
124
  }, uiText: {
125
125
  value: 'Skip',
126
126
  color: getTextColor(),
127
- fontSize: 12,
127
+ fontSize: 12
128
128
  } })),
129
129
  ReactEcs.createElement(UiEntity, { uiTransform: {
130
130
  display: 'flex',
131
131
  width: 24,
132
132
  height: 36,
133
- positionType: "absolute",
134
- position: { bottom: '5%', right: '2%' },
133
+ positionType: 'absolute',
134
+ position: { bottom: '5%', right: '2%' }
135
135
  }, uiBackground: {
136
- textureMode: "stretch",
136
+ textureMode: 'stretch',
137
137
  texture: {
138
- src: getTheme(),
138
+ src: getTheme()
139
139
  },
140
- uvs: getImageAtlasMapping(getLeftClickTheme()),
140
+ uvs: getImageAtlasMapping(getLeftClickTheme())
141
141
  } }),
142
142
  ReactEcs.createElement(UiEntity, { uiTransform: {
143
- alignSelf: "flex-start",
144
- alignItems: "flex-start",
143
+ alignSelf: 'flex-start',
144
+ alignItems: 'flex-start',
145
145
  justifyContent: 'flex-start',
146
- flexDirection: "row",
147
- position: getTextPosition(),
146
+ flexDirection: 'row',
147
+ position: getTextPosition()
148
148
  }, uiText: {
149
149
  value: getText(),
150
150
  color: getTextColor(),
@@ -152,87 +152,111 @@ export const NpcUtilsUi = () => {
152
152
  textAlign: 'middle-left'
153
153
  } }),
154
154
  ReactEcs.createElement(UiEntity, { uiTransform: {
155
- width: "300px",
156
- alignItems: "center",
157
- flexDirection: "row",
158
- justifyContent: "space-between",
159
- display: displayFirstButtonContainer() ? "flex" : "none",
155
+ width: '300px',
156
+ alignItems: 'center',
157
+ flexDirection: 'row',
158
+ justifyContent: 'space-between',
159
+ display: displayFirstButtonContainer() ? 'flex' : 'none',
160
160
  position: { top: '20%' }
161
161
  } },
162
162
  ReactEcs.createElement(UiEntity, { uiTransform: {
163
- width: "150px",
164
- height: "45px",
163
+ width: '150px',
164
+ height: '45px',
165
165
  margin: { right: '5%' },
166
- alignItems: "center",
167
- justifyContent: "center",
168
- alignContent: "flex-start",
169
- display: displayButton(1) ? "flex" : "none",
166
+ flexDirection: 'row',
167
+ alignItems: 'center',
168
+ justifyContent: 'flex-start',
169
+ alignContent: 'flex-start',
170
+ display: displayButton(1) ? 'flex' : 'none'
170
171
  }, uiBackground: {
171
172
  textureMode: 'stretch',
172
173
  texture: {
173
- src: getTheme(),
174
+ src: getTheme()
174
175
  },
175
- uvs: getImageAtlasMapping(darkButtonSection),
176
+ uvs: getImageAtlasMapping(darkButtonSection)
176
177
  }, uiText: { value: getButtonText(0), fontSize: 16 }, onMouseDown: () => {
177
178
  buttonClick(0);
178
- } }),
179
+ } },
180
+ ReactEcs.createElement(UiEntity, { uiTransform: {
181
+ width: '25px',
182
+ height: '25px',
183
+ position: { left: 5 }
184
+ }, uiBackground: {
185
+ textureMode: 'stretch',
186
+ texture: {
187
+ src: getTheme()
188
+ },
189
+ uvs: getImageAtlasMapping(secondaryButtonSection)
190
+ } })),
179
191
  ReactEcs.createElement(UiEntity, { uiTransform: {
180
- width: "150px",
181
- height: "45px",
182
- alignItems: "center",
183
- justifyContent: "center",
184
- alignContent: "flex-start",
185
- display: displayButton(2) ? "flex" : "none",
192
+ width: '150px',
193
+ height: '45px',
194
+ flexDirection: 'row',
195
+ alignItems: 'center',
196
+ justifyContent: 'flex-start',
197
+ alignContent: 'flex-start',
198
+ display: displayButton(2) ? 'flex' : 'none'
186
199
  }, uiBackground: {
187
200
  textureMode: 'stretch',
188
201
  texture: {
189
- src: getTheme(),
202
+ src: getTheme()
190
203
  },
191
- uvs: getImageAtlasMapping(redButtonSection),
204
+ uvs: getImageAtlasMapping(redButtonSection)
192
205
  }, uiText: { value: getButtonText(1), fontSize: 16 }, onMouseDown: () => {
193
206
  buttonClick(1);
194
- } })),
207
+ } },
208
+ ReactEcs.createElement(UiEntity, { uiTransform: {
209
+ width: '25px',
210
+ height: '25px',
211
+ position: { left: 5 }
212
+ }, uiBackground: {
213
+ textureMode: 'stretch',
214
+ texture: {
215
+ src: getTheme()
216
+ },
217
+ uvs: getImageAtlasMapping(primaryButtonSection)
218
+ } }))),
195
219
  ReactEcs.createElement(UiEntity, { uiTransform: {
196
- width: "300px",
197
- alignItems: "center",
198
- flexDirection: "row",
199
- justifyContent: "space-between",
220
+ width: '300px',
221
+ alignItems: 'center',
222
+ flexDirection: 'row',
223
+ justifyContent: 'space-between',
200
224
  margin: { top: 20 },
201
- display: displaySecondButtonContainer() ? "flex" : "none",
225
+ display: displaySecondButtonContainer() ? 'flex' : 'none',
202
226
  position: { top: '15%' }
203
227
  } },
204
228
  ReactEcs.createElement(UiEntity, { uiTransform: {
205
- width: "150px",
206
- height: "45px",
229
+ width: '150px',
230
+ height: '45px',
207
231
  margin: { right: '5%' },
208
- alignItems: "center",
209
- justifyContent: "center",
210
- alignContent: "flex-start",
211
- display: displayButton(3) ? "flex" : "none",
232
+ alignItems: 'center',
233
+ justifyContent: 'center',
234
+ alignContent: 'flex-start',
235
+ display: displayButton(3) ? 'flex' : 'none'
212
236
  }, uiBackground: {
213
237
  textureMode: 'stretch',
214
238
  texture: {
215
- src: getTheme(),
239
+ src: getTheme()
216
240
  },
217
- uvs: getImageAtlasMapping(darkButtonSection),
241
+ uvs: getImageAtlasMapping(darkButtonSection)
218
242
  }, uiText: { value: getButtonText(2), fontSize: 16 }, onMouseDown: () => {
219
243
  buttonClick(3);
220
244
  } }),
221
245
  ReactEcs.createElement(UiEntity, { uiTransform: {
222
- width: "150px",
223
- height: "45px",
224
- alignItems: "center",
225
- justifyContent: "center",
226
- alignContent: "flex-start",
227
- display: displayButton(4) ? "flex" : "none",
246
+ width: '150px',
247
+ height: '45px',
248
+ alignItems: 'center',
249
+ justifyContent: 'center',
250
+ alignContent: 'flex-start',
251
+ display: displayButton(4) ? 'flex' : 'none'
228
252
  }, uiBackground: {
229
253
  textureMode: 'stretch',
230
254
  texture: {
231
- src: getTheme(),
255
+ src: getTheme()
232
256
  },
233
- uvs: getImageAtlasMapping(darkButtonSection),
257
+ uvs: getImageAtlasMapping(darkButtonSection)
234
258
  }, uiText: { value: getButtonText(3), fontSize: 16 }, onMouseDown: () => {
235
259
  buttonClick(4);
236
260
  } }))));
237
261
  };
238
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui.js","sourceRoot":"","sources":["../src/ui.tsx"],"names":[],"mappings":"AACA,OAAO,QAAQ,EAAE,EAIf,QAAQ,GACT,MAAM,oBAAoB,CAAC;AAE5B,OAAO,EACL,WAAW,EAEX,aAAa,EACb,aAAa,EACb,2BAA2B,EAC3B,YAAY,EACZ,eAAe,EACf,4BAA4B,EAC5B,eAAe,EACf,aAAa,EACb,WAAW,EACX,QAAQ,EACR,oBAAoB,EACpB,iBAAiB,EACjB,WAAW,EACX,gBAAgB,EAChB,OAAO,EACP,YAAY,EACZ,eAAe,EACf,QAAQ,EACR,iBAAiB,EACjB,WAAW,EACX,UAAU,EACV,cAAc,EACd,aAAa,EACb,cAAc,EACd,cAAc,EACd,gBAAgB,EAChB,gBAAgB,EAGhB,UAAU,EACV,SAAS,EACT,WAAW,GACZ,MAAM,UAAU,CAAC;AAClB,OAAO,EAAE,4BAA4B,EAAE,MAAM,eAAe,CAAC;AAC7D,OAAO,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAElC,MAAM,CAAC,IAAI,UAAU,GAAG,uDAAuD,CAAC;AAChF,MAAM,CAAC,IAAI,SAAS,GAAG,sDAAsD,CAAC;AAE9E,MAAM,CAAC,IAAI,cAAc,GACvB,uDAAuD,CAAC;AAE1D,MAAM,CAAC,IAAI,OAAO,GAAG;IACnB,GAAG,4BAA4B,CAAC,WAAW,CAAC,SAAS;IACrD,WAAW,EAAE,4BAA4B,CAAC,WAAW;IACrD,UAAU,EAAE,4BAA4B,CAAC,UAAU;CACpD,CAAC;AAEF,MAAM,CAAC,IAAI,iBAAiB,GAAG;IAC9B,GAAG,4BAA4B,CAAC,OAAO,CAAC,CAAC;IACzC,WAAW,EAAE,4BAA4B,CAAC,WAAW;IACrD,UAAU,EAAE,4BAA4B,CAAC,UAAU;CACjD,CAAC;AAEJ,MAAM,CAAC,IAAI,sBAAsB,GAAG;IACnC,GAAG,4BAA4B,CAAC,OAAO,CAAC,MAAM;IAC9C,WAAW,EAAE,4BAA4B,CAAC,WAAW;IACrD,UAAU,EAAE,4BAA4B,CAAC,UAAU;CACjD,CAAC;AAEJ,MAAM,CAAC,IAAI,gBAAgB,GAAG;IAC7B,GAAG,4BAA4B,CAAC,KAAK,CAAC,UAAU;IAChD,WAAW,EAAE,4BAA4B,CAAC,WAAW;IACrD,UAAU,EAAE,4BAA4B,CAAC,UAAU;CACjD,CAAC;AAEJ,MAAM,CAAC,IAAI,sBAAsB,GAAG;IACnC,GAAG,4BAA4B,CAAC,KAAK,CAAC,SAAS;IAC/C,WAAW,EAAE,4BAA4B,CAAC,WAAW;IACrD,UAAU,EAAE,4BAA4B,CAAC,UAAU;CACjD,CAAC;AAEJ,MAAM,CAAC,IAAI,oBAAoB,GAAG;IAChC,GAAG,4BAA4B,CAAC,OAAO,CAAC,CAAC;IACzC,WAAW,EAAE,4BAA4B,CAAC,WAAW;IACrD,UAAU,EAAE,4BAA4B,CAAC,UAAU;CAClD,CAAC;AAEJ,MAAM,CAAC,IAAI,sBAAsB,GAAG;IAClC,GAAG,4BAA4B,CAAC,OAAO,CAAC,CAAC;IACzC,WAAW,EAAE,4BAA4B,CAAC,WAAW;IACrD,UAAU,EAAE,4BAA4B,CAAC,UAAU;CAClD,CAAC;AAEJ,MAAM,CAAC,IAAI,iBAAiB,GAAG;IAC7B,GAAG,4BAA4B,CAAC,OAAO,CAAC,IAAI;IAC5C,WAAW,EAAE,4BAA4B,CAAC,WAAW;IACrD,UAAU,EAAE,4BAA4B,CAAC,UAAU;CAClD,CAAC;AAEJ,MAAM,CAAC,IAAI,gBAAgB,GAAG;IAC5B,GAAG,4BAA4B,CAAC,OAAO,CAAC,GAAG;IAC3C,WAAW,EAAE,4BAA4B,CAAC,WAAW;IACrD,UAAU,EAAE,4BAA4B,CAAC,UAAU;CAClD,CAAC;AAEJ,MAAM,CAAC,MAAM,UAAU,GAAG,GAAG,EAAE;IAC7B,MAAM,KAAK,GAAG,SAAS,CAAC,GAAG,CAAC,CAAC;IAC7B,MAAM,MAAM,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC;IAEjC,OAAM,CACJ,uBAAC,QAAQ,IACT,WAAW,EAAE;YACX,OAAO,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;YAC1C,aAAa,EAAE,QAAQ;YACvB,UAAU,EAAE,QAAQ;YACpB,cAAc,EAAE,QAAQ;YACxB,YAAY,EAAE,UAAU;YACxB,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE;YACxC,MAAM,EAAE,EAAE,GAAG,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,KAAK,GAAG,CAAC,EAAE;YAC9C,KAAK;YACL,MAAM;SACP;QAED,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,YAAY,EAAE,UAAU;gBACxB,QAAQ,EAAE,EAAE,GAAG,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE;gBAC7B,KAAK,EAAE,MAAM;gBACb,MAAM,EAAE,MAAM;aACf,EACD,YAAY,EAAE;gBACZ,WAAW,EAAE,SAAS;gBACtB,OAAO,EAAE;oBACP,GAAG,EAAE,QAAQ,EAAE;iBAChB;gBACD,GAAG,EAAE,oBAAoB,CAAC,OAAO,CAAC;aACnC,EACD,WAAW,EAAE,GAAG,EAAE;gBACZ,iBAAiB,EAAE,CAAC;YAC1B,CAAC,GACD;QAEE,uBAAC,QAAQ,IACL,WAAW,EAAE;gBACX,OAAO,EAAE,eAAe,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;gBAC5C,KAAK,EAAE,aAAa,EAAE;gBACtB,MAAM,EAAE,cAAc,EAAE;gBACxB,YAAY,EAAE,UAAU;gBACxB,QAAQ,EAAE,EAAE,MAAM,EAAE,gBAAgB,EAAE,EAAE,IAAI,EAAC,gBAAgB,EAAE,EAAE;aAClE,EACD,YAAY,EAAE;gBACZ,WAAW,EAAE,SAAS;gBAC/B,OAAO,EAAE;oBACR,GAAG,EAAE,WAAW,EAAE;iBAChB;aAEK,GACD;QAEJ,uBAAC,QAAQ,IACL,WAAW,EAAE;gBACX,OAAO,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;gBACzC,KAAK,EAAE,UAAU,EAAE;gBACnB,MAAM,EAAE,WAAW,EAAE;gBACrB,YAAY,EAAE,UAAU;gBACxB,QAAQ,EAAE,EAAE,MAAM,EAAE,cAAc,EAAE,EAAE,KAAK,EAAC,cAAc,EAAE,EAAE;aAC/D,EACD,YAAY,EAAE;gBACZ,WAAW,EAAE,SAAS;gBAC/B,OAAO,EAAE;oBACR,GAAG,EAAE,QAAQ,EAAE;iBACb;aAEK,GACD;QAEJ,uBAAC,QAAQ,IACL,WAAW,EAAE;gBACX,OAAO,EAAE,eAAe,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;gBAC5C,KAAK,EAAE,EAAE;gBACT,MAAM,EAAE,EAAE;gBACV,YAAY,EAAE,UAAU;gBACxB,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAC,KAAK,EAAE;aACvC,EACD,YAAY,EAAE;gBACZ,WAAW,EAAE,SAAS;gBAC7B,OAAO,EAAE;oBACJ,GAAG,EAAE,QAAQ,EAAE;iBACd;gBACD,GAAG,EAAE,oBAAoB,CAAC,gBAAgB,EAAE,CAAC;aAC5C,EACD,WAAW,EAAE,GAAG,EAAE;gBACd,WAAW,CAAC,SAAS,CAAC,CAAC;YAC3B,CAAC;YAGD,uBAAC,QAAQ,IACT,WAAW,EAAE;oBACX,OAAO,EAAE,MAAM;oBACf,YAAY,EAAE,UAAU;oBACxB,QAAQ,EAAE,EAAE,IAAI,EAAE,MAAM,EAAC;iBAC1B,EACD,MAAM,EAAE;oBACN,KAAK,EAAE,MAAM;oBACb,KAAK,EAAE,YAAY,EAAE;oBACrB,QAAQ,EAAE,EAAE;iBACb,GACD,CACS;QAEf,uBAAC,QAAQ,IACH,WAAW,EAAE;gBACX,OAAO,EAAC,MAAM;gBACd,KAAK,EAAE,EAAE;gBACT,MAAM,EAAE,EAAE;gBACV,YAAY,EAAE,UAAU;gBACxB,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAC,IAAI,EAAE;aACvC,EACD,YAAY,EAAE;gBACZ,WAAW,EAAE,SAAS;gBAC/B,OAAO,EAAE;oBACR,GAAG,EAAE,QAAQ,EAAE;iBACb;gBACD,GAAG,EAAE,oBAAoB,CAAC,iBAAiB,EAAE,CAAC;aACxC,GACD;QAEF,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,SAAS,EAAC,YAAY;gBACtB,UAAU,EAAE,YAAY;gBACxB,cAAc,EAAC,YAAY;gBAC3B,aAAa,EAAE,KAAK;gBACpB,QAAQ,EAAE,eAAe,EAAE;aAC5B,EACD,MAAM,EAAE;gBACN,KAAK,EAAE,OAAO,EAAE;gBAChB,KAAK,EAAE,YAAY,EAAE;gBACrB,QAAQ,EAAE,WAAW,EAAE;gBACvB,SAAS,EAAC,aAAa;aACxB,GACS;QAEZ,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,KAAK,EAAE,OAAO;gBACd,UAAU,EAAE,QAAQ;gBACpB,aAAa,EAAE,KAAK;gBACpB,cAAc,EAAE,eAAe;gBAC/B,OAAO,EAAE,2BAA2B,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;gBACxD,QAAQ,EAAC,EAAC,GAAG,EAAE,KAAK,EAAC;aACtB;YAGD,uBAAC,QAAQ,IACP,WAAW,EAAE;oBACX,KAAK,EAAE,OAAO;oBACd,MAAM,EAAE,MAAM;oBACd,MAAM,EAAC,EAAC,KAAK,EAAC,IAAI,EAAC;oBACnB,UAAU,EAAE,QAAQ;oBACpB,cAAc,EAAE,QAAQ;oBACxB,YAAY,EAAE,YAAY;oBAC1B,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;iBAC5C,EACD,YAAY,EAAE;oBACZ,WAAW,EAAE,SAAS;oBACtB,OAAO,EAAE;wBACP,GAAG,EAAE,QAAQ,EAAE;qBAChB;oBACD,GAAG,EAAE,oBAAoB,CAAC,iBAAiB,CAAC;iBAC7C,EACD,MAAM,EAAE,EAAE,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,EACjD,WAAW,EAAE,GAAG,EAAE;oBAChB,WAAW,CAAC,CAAC,CAAC,CAAC;gBACjB,CAAC,GACS;YAGZ,uBAAC,QAAQ,IACP,WAAW,EAAE;oBACX,KAAK,EAAE,OAAO;oBACd,MAAM,EAAE,MAAM;oBACd,UAAU,EAAE,QAAQ;oBACpB,cAAc,EAAE,QAAQ;oBACxB,YAAY,EAAE,YAAY;oBAC1B,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;iBAC5C,EACD,YAAY,EAAE;oBACZ,WAAW,EAAE,SAAS;oBACtB,OAAO,EAAE;wBACP,GAAG,EAAE,QAAQ,EAAE;qBAChB;oBACD,GAAG,EAAE,oBAAoB,CAAC,gBAAgB,CAAC;iBAC5C,EACD,MAAM,EAAE,EAAE,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,EACjD,WAAW,EAAE,GAAG,EAAE;oBAChB,WAAW,CAAC,CAAC,CAAC,CAAC;gBACjB,CAAC,GACS,CACH;QAGX,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,KAAK,EAAE,OAAO;gBACd,UAAU,EAAE,QAAQ;gBACpB,aAAa,EAAE,KAAK;gBACpB,cAAc,EAAE,eAAe;gBAC/B,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE;gBACnB,OAAO,EAAE,4BAA4B,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;gBACzD,QAAQ,EAAC,EAAC,GAAG,EAAE,KAAK,EAAC;aAEtB;YAGD,uBAAC,QAAQ,IACP,WAAW,EAAE;oBACX,KAAK,EAAE,OAAO;oBACd,MAAM,EAAE,MAAM;oBACd,MAAM,EAAC,EAAC,KAAK,EAAC,IAAI,EAAC;oBACnB,UAAU,EAAE,QAAQ;oBACpB,cAAc,EAAE,QAAQ;oBACxB,YAAY,EAAE,YAAY;oBAC1B,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;iBAC5C,EACD,YAAY,EAAE;oBACZ,WAAW,EAAE,SAAS;oBACtB,OAAO,EAAE;wBACP,GAAG,EAAE,QAAQ,EAAE;qBAChB;oBACD,GAAG,EAAE,oBAAoB,CAAC,iBAAiB,CAAC;iBAC7C,EACD,MAAM,EAAE,EAAE,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,EACjD,WAAW,EAAE,GAAG,EAAE;oBAChB,WAAW,CAAC,CAAC,CAAC,CAAC;gBACjB,CAAC,GACS;YAGZ,uBAAC,QAAQ,IACP,WAAW,EAAE;oBACX,KAAK,EAAE,OAAO;oBACd,MAAM,EAAE,MAAM;oBACd,UAAU,EAAE,QAAQ;oBACpB,cAAc,EAAE,QAAQ;oBACxB,YAAY,EAAE,YAAY;oBAC1B,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;iBAC5C,EACD,YAAY,EAAE;oBACZ,WAAW,EAAE,SAAS;oBACtB,OAAO,EAAE;wBACP,GAAG,EAAE,QAAQ,EAAE;qBAChB;oBACD,GAAG,EAAE,oBAAoB,CAAC,iBAAiB,CAAC;iBAC7C,EACD,MAAM,EAAE,EAAE,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,EACjD,WAAW,EAAE,GAAG,EAAE;oBAChB,WAAW,CAAC,CAAC,CAAC,CAAC;gBACjB,CAAC,GACS,CACH,CACF,CAEhB,CAAA;AACD,CAAC,CAAC","sourcesContent":["import { Color4 } from \"@dcl/sdk/math\";\nimport ReactEcs, {\n  Button,\n  Label,\n  ReactEcsRenderer,\n  UiEntity,\n} 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 =\n  \"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\t...sourcesComponentsCoordinates.buttons.F,\n\tatlasHeight: sourcesComponentsCoordinates.atlasHeight,\n\tatlasWidth: sourcesComponentsCoordinates.atlasWidth,\n  };\n\nexport let skipButtonSectionBlack = {\n\t...sourcesComponentsCoordinates.buttons.FBlack,\n\tatlasHeight: sourcesComponentsCoordinates.atlasHeight,\n\tatlasWidth: sourcesComponentsCoordinates.atlasWidth,\n  };\n\nexport let leftClickSection = {\n\t...sourcesComponentsCoordinates.icons.ClickWhite,\n\tatlasHeight: sourcesComponentsCoordinates.atlasHeight,\n\tatlasWidth: sourcesComponentsCoordinates.atlasWidth,\n  };\n\nexport let leftClickSectionbBlack = {\n\t...sourcesComponentsCoordinates.icons.ClickDark,\n\tatlasHeight: sourcesComponentsCoordinates.atlasHeight,\n\tatlasWidth: 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.dark,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth,\n  };\n\nexport let redButtonSection = {\n  ...sourcesComponentsCoordinates.buttons.red,\n  atlasHeight: sourcesComponentsCoordinates.atlasHeight,\n  atlasWidth: sourcesComponentsCoordinates.atlasWidth,\n  };\n\nexport const NpcUtilsUi = () => {\n  const width = realWidth(700);\n  const height = realHeight(225);\n\nreturn(\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\t\t\ttexture: {\n\t\t\t\tsrc: getPortrait(),\n\t\t\t  },\n\t\t\t  // 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\t\t\ttexture: {\n\t\t\t\tsrc: getImage(),\n\t\t\t  },\n\t\t\t  // 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\t\t\t  texture: {\n          src: getTheme(),\n          },\n          uvs: getImageAtlasMapping(getSkipableTheme()),\n          }}\n          onMouseDown={() => {\n              skipDialogs(activeNPC);\n          }}\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   \t<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\t\t\ttexture: {\n\t\t\t\tsrc: getTheme(),\n\t\t\t  },\n\t\t\t  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 */}\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(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          ></UiEntity>\n\n          {/* Button2 */}\n          <UiEntity\n            uiTransform={{\n              width: \"150px\",\n              height: \"45px\",\n              alignItems: \"center\",\n              justifyContent: \"center\",\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          ></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        >\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};\n"]}
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"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "dcl-npc-toolkit",
3
- "version": "1.1.2-20230614195844.commit-f135f0d",
3
+ "version": "1.1.3-20230615194800.commit-278b488",
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": "f135f0d70b2a4a7197e3690925b44f3635e5f8c0"
36
+ "commit": "278b488053b000071746707a45a0b2b929d48b71"
37
37
  }