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 +3 -3
- package/dist/ui.d.ts +1 -1
- package/dist/ui.js +118 -94
- package/package.json +2 -2
package/dist/systems.js
CHANGED
|
@@ -99,7 +99,7 @@ export function inputListenerSystem() {
|
|
|
99
99
|
}
|
|
100
100
|
}
|
|
101
101
|
}
|
|
102
|
-
if (
|
|
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 (
|
|
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":"AAAA,OAAO,EAAyC,SAAS,EAAE,SAAS,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,cAAc,CAAC;AAChH,OAAO,EAAE,eAAe,EAAE,cAAc,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAC9F,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,OAAO,CAAC;AACjD,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,kBAAkB,EAAE,QAAQ,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AAC/F,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAEpD,MAAM,UAAU,eAAe,CAAC,EAAS;IACrC,KAAK,MAAM,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,eAAe,CAAC,eAAe,CAAC,EAAE;QAC5D,IAAG,aAAa,CAAC,GAAG,CAAC,MAAM,CAAC,EAAC;YACzB,IAAI,OAAO,GAAU,aAAa,CAAC,GAAG,CAAC,MAAM,CAAE,CAAA;YAC/C,OAAO,IAAI,EAAE,CAAA;YACb,aAAa,CAAC,GAAG,CAAC,MAAM,EAAE,aAAa,CAAC,GAAG,CAAC,MAAM,CAAE,GAAG,EAAE,CAAC,CAAA;SAC7D;aACG;YACA,aAAa,CAAC,GAAG,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;SAChC;KACJ;AACH,CAAC;AAEH,MAAM,UAAU,kBAAkB,CAAC,EAAS;IACxC,KAAK,MAAM,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,eAAe,CAAC,cAAc,CAAC,EAAE;QAC3D,IAAI,UAAU,GAAG,kBAAkB,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;QAC/C,IAAG,CAAC,UAAU,CAAC,MAAM,EAAC;YAClB,OAAM;SACT;QAED,UAAU,CAAC,KAAK,IAAI,EAAE,CAAA;QACtB,IAAI,UAAU,CAAC,KAAK,IAAI,CAAC,GAAG,UAAU,CAAC,KAAK,EAAE;YAC1C,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAA;YACtE,UAAU,CAAC,KAAK,GAAG,CAAC,CAAA;YAEpB,UAAU,CAAC,YAAY,IAAI,UAAU,CAAA;YAErC,IAAI,UAAU,CAAC,YAAY,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,EAAE;gBACvD,UAAU,CAAC,MAAM,GAAG,KAAK,CAAA;gBACzB,UAAU,CAAC,YAAY,GAAG,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAA;gBACpD,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;aACpC;YAED,UAAU,CAAC,WAAW,GAAG,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAE,UAAU,CAAC,YAAY,CAAC,CAAA;SAClF;KACJ;AACH,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,EAAS;IAC1C,KAAK,MAAM,CAAC,MAAM,CAAC,IAAI,MAAM,CAAC,eAAe,CAAC,cAAc,CAAC,EAAE;QAC3D,IAAI,UAAU,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;QACpC,IAAG,UAAU,CAAC,IAAI,EAAC;YACf,SAAQ;SACX;QAED,UAAU,CAAC,KAAK,IAAI,EAAE,CAAA;QAEtB,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE;YACpB,IAAI,UAAU,CAAC,KAAK,GAAG,UAAU,CAAC,MAAM,EAAE;gBAEtC,UAAU,CAAC,IAAI,GAAG,IAAI,CAAA;gBACtB,UAAU,CAAC,MAAM,GAAG,KAAK,CAAA;gBACzB,UAAU,CAAC,KAAK,GAAG,CAAC,CAAA;gBACpB,IAAI,CAAC,MAAM,CAAC,CAAA;aACf;SACF;aACC,IAAI,UAAU,CAAC,KAAK,IAAI,CAAC,GAAG,UAAU,CAAC,KAAK,EAAE;YAC9C,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC,CAAA;YACtE,UAAU,CAAC,KAAK,GAAG,CAAC,CAAA;YACpB,UAAU,CAAC,YAAY,IAAI,UAAU,CAAA;YAErC,IAAI,UAAU,CAAC,YAAY,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,IAAI,UAAU,CAAC,IAAI,EAAE;gBAC1E,UAAU,CAAC,MAAM,GAAG,KAAK,CAAA;gBACzB,UAAU,CAAC,YAAY,GAAG,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAA;gBACpD,cAAc,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;aACpC;YACD,SAAS,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,IAAI,GAAG,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAE,UAAU,CAAC,YAAY,CAAC,CAAA;SACtG;KACJ;AACH,CAAC;AAEH,MAAM,UAAU,cAAc,CAAC,EAAU;IACvC,KAAK,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,eAAe,CAAC,aAAa,CAAC,EAAE;QACnE,IAAI,KAAK,CAAC,MAAM,EAAE;YAChB,MAAM,MAAM,GAAG,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,YAAY,CAAC,CAAA;YACjD,IAAI,YAAY,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAA;YAC1F,IAAI,SAAS,GAAG,OAAO,CAAC,QAAQ,CAAC,YAAY,EAAE,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,CAAA;YAE9E,IAAI,SAAS,GAAG,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;YAC5C,SAAS,CAAC,QAAQ,GAAG,UAAU,CAAC,KAAK,CAAC,SAAS,CAAC,QAAQ,EAAE,UAAU,CAAC,YAAY,CAAC,SAAS,CAAC,EAAE,EAAE,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAA;YAElH,IAAI,KAAK,CAAC,cAAc,EAAE;gBACxB,SAAS,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAA;gBACxB,SAAS,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAA;aACzB;SACF;KACF;AACH,CAAC;AAED,MAAM,UAAU,mBAAmB;IACjC,MAAM,GAAG,GAAG,WAAW,CAAC,WAAW,MAAkD,CAAA;IACrF,MAAM,GAAG,GAAG,WAAW,CAAC,SAAS,GAAwB,CAAA;IAEzD,MAAM,IAAI,GAAG,WAAW,CAAC,WAAW,MAAkD,CAAA;IACtF,MAAM,IAAI,GAAG,WAAW,CAAC,SAAS,GAAwB,CAAA;IAE1D,MAAM,GAAG,GAAG,WAAW,CAAC,WAAW,MAAoD,CAAA;IACvF,MAAM,GAAG,GAAG,WAAW,CAAC,SAAS,GAA0B,CAAA;IAE3D,IAAG,IAAI,IAAI,IAAI,EAAC;QACd,IAAG,SAAS,EAAC;YACX,IAAI,UAAU,GAAG,kBAAkB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;YAClD,IAAG,CAAC,UAAU,CAAC,OAAO,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,UAAU,CAAC,QAAQ,GAAG,GAAG;gBAAC,OAAM;YACvE,IAAG,UAAU,CAAC,MAAM,EAAC;gBACnB,QAAQ,CAAC,SAAS,CAAC,CAAA;aACpB;iBAAK,IAAG,CAAC,UAAU,CAAC,UAAU,EAAC;gBAC9B,WAAW,CAAC,SAAS,EAAE,WAAW,CAAC,IAAI,CAAC,CAAA;aACzC;SACF;KACF;IAED,IAAG,GAAG,IAAI,GAAG,EAAC;QACZ,IAAG,SAAS,EAAC;YACX,IAAI,UAAU,GAAG,kBAAkB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;YAClD,IAAG,CAAC,UAAU,CAAC,OAAO,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,UAAU,CAAC,QAAQ,GAAG,GAAG;gBAAC,OAAM;YACvE,IAAG,UAAU,CAAC,UAAU,EAAC;gBACvB,WAAW,CAAC,SAAS,EAAE,WAAW,CAAC,OAAO,CAAC,CAAA;aAC5C;iBAAK,IAAG,CAAC,UAAU,CAAC,UAAU,EAAC;gBAC9B,WAAW,CAAC,SAAS,EAAE,WAAW,CAAC,IAAI,CAAC,CAAA;aACzC;SACF;KACF;IAED,IAAG,GAAG,IAAI,GAAG,EAAC;QACZ,IAAG,SAAS,EAAC;YACX,IAAI,UAAU,GAAG,kBAAkB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAA;YAClD,IAAG,CAAC,UAAU,CAAC,OAAO,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,UAAU,CAAC,QAAQ,GAAG,GAAG;gBAAC,OAAM;YACvE,IAAG,UAAU,CAAC,UAAU,EAAC;gBACvB,WAAW,CAAC,SAAS,EAAE,WAAW,CAAC,MAAM,CAAC,CAAA;aAC3C;iBAAK,IAAG,UAAU,CAAC,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,QAAQ,IAAI,CAAC,UAAU,CAAC,aAAa,EAAC;gBACjF,WAAW,CAAC,SAAS,CAAC,CAAA;aACvB;SACF;KACF;AAKH,CAAC","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
package/dist/ui.js
CHANGED
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
import ReactEcs, { UiEntity
|
|
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
|
|
3
|
-
import { sourcesComponentsCoordinates } from
|
|
4
|
-
import { activeNPC } from
|
|
5
|
-
export let lightTheme =
|
|
6
|
-
export let darkTheme =
|
|
7
|
-
export let bubblesTexture =
|
|
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.
|
|
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.
|
|
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:
|
|
86
|
-
position: { bottom: positionPortaitY(), left: positionPortaitX() }
|
|
85
|
+
positionType: 'absolute',
|
|
86
|
+
position: { bottom: positionPortaitY(), left: positionPortaitX() }
|
|
87
87
|
}, uiBackground: {
|
|
88
|
-
textureMode:
|
|
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:
|
|
98
|
-
position: { bottom: positionImageY(), right: positionImageX() }
|
|
97
|
+
positionType: 'absolute',
|
|
98
|
+
position: { bottom: positionImageY(), right: positionImageX() }
|
|
99
99
|
}, uiBackground: {
|
|
100
|
-
textureMode:
|
|
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:
|
|
110
|
-
position: { bottom: '7%', left: '25%' }
|
|
109
|
+
positionType: 'absolute',
|
|
110
|
+
position: { bottom: '7%', left: '25%' }
|
|
111
111
|
}, uiBackground: {
|
|
112
|
-
textureMode:
|
|
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:
|
|
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:
|
|
134
|
-
position: { bottom: '5%', right: '2%' }
|
|
133
|
+
positionType: 'absolute',
|
|
134
|
+
position: { bottom: '5%', right: '2%' }
|
|
135
135
|
}, uiBackground: {
|
|
136
|
-
textureMode:
|
|
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:
|
|
144
|
-
alignItems:
|
|
143
|
+
alignSelf: 'flex-start',
|
|
144
|
+
alignItems: 'flex-start',
|
|
145
145
|
justifyContent: 'flex-start',
|
|
146
|
-
flexDirection:
|
|
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:
|
|
156
|
-
alignItems:
|
|
157
|
-
flexDirection:
|
|
158
|
-
justifyContent:
|
|
159
|
-
display: displayFirstButtonContainer() ?
|
|
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:
|
|
164
|
-
height:
|
|
163
|
+
width: '150px',
|
|
164
|
+
height: '45px',
|
|
165
165
|
margin: { right: '5%' },
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
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:
|
|
181
|
-
height:
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
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:
|
|
197
|
-
alignItems:
|
|
198
|
-
flexDirection:
|
|
199
|
-
justifyContent:
|
|
220
|
+
width: '300px',
|
|
221
|
+
alignItems: 'center',
|
|
222
|
+
flexDirection: 'row',
|
|
223
|
+
justifyContent: 'space-between',
|
|
200
224
|
margin: { top: 20 },
|
|
201
|
-
display: displaySecondButtonContainer() ?
|
|
225
|
+
display: displaySecondButtonContainer() ? 'flex' : 'none',
|
|
202
226
|
position: { top: '15%' }
|
|
203
227
|
} },
|
|
204
228
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
205
|
-
width:
|
|
206
|
-
height:
|
|
229
|
+
width: '150px',
|
|
230
|
+
height: '45px',
|
|
207
231
|
margin: { right: '5%' },
|
|
208
|
-
alignItems:
|
|
209
|
-
justifyContent:
|
|
210
|
-
alignContent:
|
|
211
|
-
display: displayButton(3) ?
|
|
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:
|
|
223
|
-
height:
|
|
224
|
-
alignItems:
|
|
225
|
-
justifyContent:
|
|
226
|
-
alignContent:
|
|
227
|
-
display: displayButton(4) ?
|
|
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":"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","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.
|
|
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": "
|
|
36
|
+
"commit": "278b488053b000071746707a45a0b2b929d48b71"
|
|
37
37
|
}
|