@dcl/asset-packs 2.11.6 → 2.11.7

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.
@@ -45,7 +45,9 @@ export function RewardsControl({ engine, state }) {
45
45
  margin: { bottom: 32 * scaleFactor },
46
46
  } },
47
47
  ReactEcs.createElement(Label, { value: "<b>Selected Airdrop</b>", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: { margin: { bottom: 16 * scaleFactor } } }),
48
- ReactEcs.createElement(Dropdown, { key: "RewardsItemSelector", acceptEmpty: true, emptyLabel: "Select your airdrop", options: [...rewardItems.map(item => item.customName)], selectedIndex: state.rewardsControl.selectedRewardItem ?? -1, onChange: idx => (state.rewardsControl.selectedRewardItem = idx), textAlign: "middle-left", fontSize: 14 * scaleFactor, uiTransform: {
48
+ ReactEcs.createElement(Dropdown, { key: "RewardsItemSelector", acceptEmpty: true, emptyLabel: "Select your airdrop", options: [
49
+ ...rewardItems.map((item) => item.customName),
50
+ ], selectedIndex: state.rewardsControl.selectedRewardItem ?? -1, onChange: idx => (state.rewardsControl.selectedRewardItem = idx), textAlign: "middle-left", fontSize: 14 * scaleFactor, uiTransform: {
49
51
  width: '100%',
50
52
  height: 40 * scaleFactor,
51
53
  }, uiBackground: { color: Color4.White() }, color: Color4.Black() })),
@@ -69,7 +71,7 @@ function handleRelease(engine, state) {
69
71
  const rewardItem = Rewards.getOrNull(selectedRewardItem.entity);
70
72
  if (!rewardItem)
71
73
  return;
72
- const action = Actions.getOrNull(selectedRewardItem.entity)?.value.find($ => $.name === 'Airdrop');
74
+ const action = Actions.getOrNull(selectedRewardItem.entity)?.value.find(($) => $.name === 'Airdrop');
73
75
  if (action) {
74
76
  const actionEvents = getActionEvents(selectedRewardItem.entity);
75
77
  actionEvents.emit(action.name, getPayload(action));
@@ -82,10 +84,10 @@ function handleClear(engine, state) {
82
84
  const rewardItem = Rewards.getOrNull(selectedRewardItem.entity);
83
85
  if (!rewardItem)
84
86
  return;
85
- const action = Actions.getOrNull(selectedRewardItem.entity)?.value.find($ => $.name === 'Invisible');
87
+ const action = Actions.getOrNull(selectedRewardItem.entity)?.value.find(($) => $.name === 'Invisible');
86
88
  if (action) {
87
89
  const actionEvents = getActionEvents(selectedRewardItem.entity);
88
90
  actionEvents.emit(action.name, getPayload(action));
89
91
  }
90
92
  }
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RewardsControl.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/RewardsControl.tsx"],"names":[],"mappings":"AACA,OAAO,QAAQ,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AACrE,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAc,eAAe,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACxF,OAAO,EAAE,gBAAgB,EAAE,MAAM,OAAO,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAG1C,MAAM,KAAK,GAAG;IACZ,eAAe,EAAE,GAAG,WAAW,iDAAiD;IAChF,IAAI,EAAE,GAAG,WAAW,8CAA8C;CAC1D,CAAC;AAGX,SAAS,6BAA6B,CAAC,MAAe;IACpD,MAAM,EAAE,UAAU,EAAE,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IAC7C,MAAM,oBAAoB,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC;IAC5E,OAAO,oBAAoB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC;AAC5F,CAAC;AAED,SAAS,cAAc,CAAC,MAAe;IACrC,MAAM,0BAA0B,GAAG,6BAA6B,CAAC,MAAM,CAAC,CAAC;IAEzE,IACE,CAAC,0BAA0B;QAC3B,CAAC,0BAA0B,CAAC,WAAW;QACvC,0BAA0B,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC;QAEnD,OAAO,EAAE,CAAC;IAEZ,OAAO,KAAK,CAAC,IAAI,CAAC,0BAA0B,CAAC,WAAW,CAAC,CAAC;AAC5D,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAE,MAAM,EAAE,KAAK,EAAqC;IACjF,MAAM,WAAW,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAC7C,MAAM,WAAW,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IAE3C,OAAO,CACL,uBAAC,QAAQ,IACP,WAAW,EAAE;YACX,KAAK,EAAE,MAAM;YACb,MAAM,EAAE,MAAM;YACd,aAAa,EAAE,QAAQ;SACxB;QAGD,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,aAAa,EAAE,KAAK;gBACpB,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE;gBACpC,MAAM,EAAE,EAAE,GAAG,WAAW;aACzB;YAED,uBAAC,QAAQ,IACP,WAAW,EAAE,EAAE,KAAK,EAAE,EAAE,GAAG,WAAW,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE,EAClE,YAAY,EAAE;oBACZ,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE;oBACrB,WAAW,EAAE,SAAS;oBACtB,OAAO,EAAE,EAAE,GAAG,EAAE,KAAK,CAAC,eAAe,EAAE;iBACxC,GACD;YACF,uBAAC,KAAK,IACJ,KAAK,EAAC,iBAAiB,EACvB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,GACrB,CACO;QAEX,uBAAC,QAAQ,IACP,WAAW,EAAE;gBACX,aAAa,EAAE,QAAQ;gBACvB,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE;aACrC;YAED,uBAAC,KAAK,IACJ,KAAK,EAAC,yBAAyB,EAC/B,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,WAAW,EAAE,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE,EAAE,GACrD;YAEF,uBAAC,QAAQ,IACP,GAAG,EAAC,qBAAqB,EACzB,WAAW,QACX,UAAU,EAAC,qBAAqB,EAChC,OAAO,EAAE,CAAC,GAAG,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,EACtD,aAAa,EAAE,KAAK,CAAC,cAAc,CAAC,kBAAkB,IAAI,CAAC,CAAC,EAC5D,QAAQ,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,cAAc,CAAC,kBAAkB,GAAG,GAAG,CAAC,EAChE,SAAS,EAAC,aAAa,EACvB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,WAAW,EAAE;oBACX,KAAK,EAAE,MAAM;oBACb,MAAM,EAAE,EAAE,GAAG,WAAW;iBACzB,EACD,YAAY,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EAAE,EACvC,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,GACrB,CACO;QAEX,uBAAC,QAAQ,IAAC,WAAW,EAAE,EAAE,aAAa,EAAE,QAAQ,EAAE;YAChD,uBAAC,KAAK,IACJ,KAAK,EAAC,gBAAgB,EACtB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,WAAW,EAAE,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE,EAAE,GACrD;YAEF,uBAAC,QAAQ,IAAC,WAAW,EAAE,EAAE,aAAa,EAAE,KAAK,EAAE;gBAC7C,uBAAC,MAAM,IACL,EAAE,EAAC,yBAAyB,EAC5B,KAAK,EAAC,gBAAgB,EACtB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,WAAW,EAAE;wBACX,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE,GAAG,WAAW,EAAE;wBACnC,UAAU,EAAE,QAAQ;wBACpB,cAAc,EAAE,QAAQ;qBACzB,EACD,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,aAAa,EAAE;wBACb,MAAM,EAAE,EAAE,GAAG,WAAW;wBACxB,KAAK,EAAE,EAAE,GAAG,WAAW;qBACxB,EACD,WAAW,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC,MAAM,EAAE,KAAK,CAAC,EAC/C,QAAQ,EAAE,KAAK,CAAC,cAAc,CAAC,kBAAkB,KAAK,SAAS,GAC/D;gBACF,uBAAC,MAAM,IACL,EAAE,EAAC,uBAAuB,EAC1B,KAAK,EAAC,cAAc,EACpB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,WAAW,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,EAC7C,QAAQ,EAAE,KAAK,CAAC,cAAc,CAAC,kBAAkB,KAAK,SAAS,GAC/D,CACO,CAQF,CACF,CACZ,CAAC;AACJ,CAAC;AAED,SAAS,aAAa,CAAC,MAAe,EAAE,KAAY;IAClD,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACnD,MAAM,WAAW,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IAC3C,MAAM,kBAAkB,GAAG,WAAW,CAAC,KAAK,CAAC,cAAc,CAAC,kBAAmB,CAAC,CAAC;IACjF,MAAM,UAAU,GAAG,OAAO,CAAC,SAAS,CAAC,kBAAkB,CAAC,MAAgB,CAAC,CAAC;IAE1E,IAAI,CAAC,UAAU;QAAE,OAAO;IAExB,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,kBAAkB,CAAC,MAAgB,CAAC,EAAE,KAAK,CAAC,IAAI,CAC/E,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,SAAS,CAC1B,CAAC;IACF,IAAI,MAAM,EAAE,CAAC;QACX,MAAM,YAAY,GAAG,eAAe,CAAC,kBAAkB,CAAC,MAAgB,CAAC,CAAC;QAC1E,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;IACrD,CAAC;AACH,CAAC;AAED,SAAS,WAAW,CAAC,MAAe,EAAE,KAAY;IAChD,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACnD,MAAM,WAAW,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC;IAC3C,MAAM,kBAAkB,GAAG,WAAW,CAAC,KAAK,CAAC,cAAc,CAAC,kBAAmB,CAAC,CAAC;IACjF,MAAM,UAAU,GAAG,OAAO,CAAC,SAAS,CAAC,kBAAkB,CAAC,MAAgB,CAAC,CAAC;IAC1E,IAAI,CAAC,UAAU;QAAE,OAAO;IAExB,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC,kBAAkB,CAAC,MAAgB,CAAC,EAAE,KAAK,CAAC,IAAI,CAC/E,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,WAAW,CAC5B,CAAC;IAEF,IAAI,MAAM,EAAE,CAAC;QACX,MAAM,YAAY,GAAG,eAAe,CAAC,kBAAkB,CAAC,MAAgB,CAAC,CAAC;QAC1E,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;IACrD,CAAC;AACH,CAAC","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label, Dropdown } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { AdminTools, getActionEvents, getComponents, getPayload } from '../definitions';\nimport { getScaleUIFactor } from '../ui';\nimport { Button } from './Button';\nimport { CONTENT_URL } from './constants';\nimport { State } from './types';\n\nconst ICONS = {\n  REWARDS_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/rewards-control.png`,\n  SEND: `${CONTENT_URL}/admin_toolkit/assets/icons/rewards-send.png`,\n} as const;\n\n// Helper Functions\nfunction getAdminToolkitRewardsControl(engine: IEngine) {\n  const { AdminTools } = getComponents(engine);\n  const adminToolkitEntities = Array.from(engine.getEntitiesWith(AdminTools));\n  return adminToolkitEntities.length > 0 ? adminToolkitEntities[0][1].rewardsControl : null;\n}\n\nfunction getRewardItems(engine: IEngine): NonNullable<AdminTools['rewardsControl']['rewardItems']> {\n  const adminToolkitRewardsControl = getAdminToolkitRewardsControl(engine);\n\n  if (\n    !adminToolkitRewardsControl ||\n    !adminToolkitRewardsControl.rewardItems ||\n    adminToolkitRewardsControl.rewardItems.length === 0\n  )\n    return [];\n\n  return Array.from(adminToolkitRewardsControl.rewardItems);\n}\n\nexport function RewardsControl({ engine, state }: { engine: IEngine; state: State }) {\n  const scaleFactor = getScaleUIFactor(engine);\n  const rewardItems = getRewardItems(engine);\n\n  return (\n    <UiEntity\n      uiTransform={{\n        width: '100%',\n        height: '100%',\n        flexDirection: 'column',\n      }}\n    >\n      {/* Header */}\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'row',\n          margin: { bottom: 32 * scaleFactor },\n          height: 30 * scaleFactor,\n        }}\n      >\n        <UiEntity\n          uiTransform={{ width: 30 * scaleFactor, height: 30 * scaleFactor }}\n          uiBackground={{\n            color: Color4.White(),\n            textureMode: 'stretch',\n            texture: { src: ICONS.REWARDS_CONTROL },\n          }}\n        />\n        <Label\n          value=\"<b>AIRDROPS</b>\"\n          fontSize={24 * scaleFactor}\n          color={Color4.White()}\n        />\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'column',\n          margin: { bottom: 32 * scaleFactor },\n        }}\n      >\n        <Label\n          value=\"<b>Selected Airdrop</b>\"\n          fontSize={16 * scaleFactor}\n          color={Color4.White()}\n          uiTransform={{ margin: { bottom: 16 * scaleFactor } }}\n        />\n\n        <Dropdown\n          key=\"RewardsItemSelector\"\n          acceptEmpty\n          emptyLabel=\"Select your airdrop\"\n          options={[...rewardItems.map(item => item.customName)]}\n          selectedIndex={state.rewardsControl.selectedRewardItem ?? -1}\n          onChange={idx => (state.rewardsControl.selectedRewardItem = idx)}\n          textAlign=\"middle-left\"\n          fontSize={14 * scaleFactor}\n          uiTransform={{\n            width: '100%',\n            height: 40 * scaleFactor,\n          }}\n          uiBackground={{ color: Color4.White() }}\n          color={Color4.Black()}\n        />\n      </UiEntity>\n\n      <UiEntity uiTransform={{ flexDirection: 'column' }}>\n        <Label\n          value=\"<b>Actions</b>\"\n          fontSize={16 * scaleFactor}\n          color={Color4.White()}\n          uiTransform={{ margin: { bottom: 16 * scaleFactor } }}\n        />\n\n        <UiEntity uiTransform={{ flexDirection: 'row' }}>\n          <Button\n            id=\"rewards_control_release\"\n            value=\"<b>Release</b>\"\n            fontSize={16 * scaleFactor}\n            uiTransform={{\n              margin: { right: 16 * scaleFactor },\n              alignItems: 'center',\n              justifyContent: 'center',\n            }}\n            icon={ICONS.SEND}\n            iconTransform={{\n              height: 25 * scaleFactor,\n              width: 25 * scaleFactor,\n            }}\n            onMouseDown={() => handleRelease(engine, state)}\n            disabled={state.rewardsControl.selectedRewardItem === undefined}\n          />\n          <Button\n            id=\"rewards_control_clear\"\n            value=\"<b>Clear</b>\"\n            fontSize={16 * scaleFactor}\n            onMouseDown={() => handleClear(engine, state)}\n            disabled={state.rewardsControl.selectedRewardItem === undefined}\n          />\n        </UiEntity>\n\n        {/* TODO: Get supply values from rewards-server, it required a signedFetch but the one sent by the explorer is rejected */}\n        {/* <Label\n          value={`Redeemed: ${state.rewardsControl.redeemedCount}/`}\n          fontSize={14}\n          color={Color4.create(187 / 255, 187 / 255, 187 / 255, 1)}\n        /> */}\n      </UiEntity>\n    </UiEntity>\n  );\n}\n\nfunction handleRelease(engine: IEngine, state: State) {\n  const { Actions, Rewards } = getComponents(engine);\n  const rewardItems = getRewardItems(engine);\n  const selectedRewardItem = rewardItems[state.rewardsControl.selectedRewardItem!];\n  const rewardItem = Rewards.getOrNull(selectedRewardItem.entity as Entity);\n\n  if (!rewardItem) return;\n\n  const action = Actions.getOrNull(selectedRewardItem.entity as Entity)?.value.find(\n    $ => $.name === 'Airdrop',\n  );\n  if (action) {\n    const actionEvents = getActionEvents(selectedRewardItem.entity as Entity);\n    actionEvents.emit(action.name, getPayload(action));\n  }\n}\n\nfunction handleClear(engine: IEngine, state: State) {\n  const { Actions, Rewards } = getComponents(engine);\n  const rewardItems = getRewardItems(engine);\n  const selectedRewardItem = rewardItems[state.rewardsControl.selectedRewardItem!];\n  const rewardItem = Rewards.getOrNull(selectedRewardItem.entity as Entity);\n  if (!rewardItem) return;\n\n  const action = Actions.getOrNull(selectedRewardItem.entity as Entity)?.value.find(\n    $ => $.name === 'Invisible',\n  );\n\n  if (action) {\n    const actionEvents = getActionEvents(selectedRewardItem.entity as Entity);\n    actionEvents.emit(action.name, getPayload(action));\n  }\n}\n"]}
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RewardsControl.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/RewardsControl.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label, Dropdown } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { AdminTools, getActionEvents, getComponents, getPayload, Action } from '../definitions';\nimport { getScaleUIFactor } from '../ui';\nimport { Button } from './Button';\nimport { CONTENT_URL } from './constants';\nimport { State } from './types';\n\nconst ICONS = {\n  REWARDS_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/rewards-control.png`,\n  SEND: `${CONTENT_URL}/admin_toolkit/assets/icons/rewards-send.png`,\n} as const;\n\n// Helper Functions\nfunction getAdminToolkitRewardsControl(engine: IEngine) {\n  const { AdminTools } = getComponents(engine);\n  const adminToolkitEntities = Array.from(engine.getEntitiesWith(AdminTools));\n  return adminToolkitEntities.length > 0 ? adminToolkitEntities[0][1].rewardsControl : null;\n}\n\nfunction getRewardItems(engine: IEngine): NonNullable<AdminTools['rewardsControl']['rewardItems']> {\n  const adminToolkitRewardsControl = getAdminToolkitRewardsControl(engine);\n\n  if (\n    !adminToolkitRewardsControl ||\n    !adminToolkitRewardsControl.rewardItems ||\n    adminToolkitRewardsControl.rewardItems.length === 0\n  )\n    return [];\n\n  return Array.from(adminToolkitRewardsControl.rewardItems);\n}\n\nexport function RewardsControl({ engine, state }: { engine: IEngine; state: State }) {\n  const scaleFactor = getScaleUIFactor(engine);\n  const rewardItems = getRewardItems(engine);\n\n  return (\n    <UiEntity\n      uiTransform={{\n        width: '100%',\n        height: '100%',\n        flexDirection: 'column',\n      }}\n    >\n      {/* Header */}\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'row',\n          margin: { bottom: 32 * scaleFactor },\n          height: 30 * scaleFactor,\n        }}\n      >\n        <UiEntity\n          uiTransform={{ width: 30 * scaleFactor, height: 30 * scaleFactor }}\n          uiBackground={{\n            color: Color4.White(),\n            textureMode: 'stretch',\n            texture: { src: ICONS.REWARDS_CONTROL },\n          }}\n        />\n        <Label\n          value=\"<b>AIRDROPS</b>\"\n          fontSize={24 * scaleFactor}\n          color={Color4.White()}\n        />\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          flexDirection: 'column',\n          margin: { bottom: 32 * scaleFactor },\n        }}\n      >\n        <Label\n          value=\"<b>Selected Airdrop</b>\"\n          fontSize={16 * scaleFactor}\n          color={Color4.White()}\n          uiTransform={{ margin: { bottom: 16 * scaleFactor } }}\n        />\n\n        <Dropdown\n          key=\"RewardsItemSelector\"\n          acceptEmpty\n          emptyLabel=\"Select your airdrop\"\n          options={[\n            ...rewardItems.map(\n              (item: NonNullable<AdminTools['rewardsControl']['rewardItems']>[0]) =>\n                item.customName,\n            ),\n          ]}\n          selectedIndex={state.rewardsControl.selectedRewardItem ?? -1}\n          onChange={idx => (state.rewardsControl.selectedRewardItem = idx)}\n          textAlign=\"middle-left\"\n          fontSize={14 * scaleFactor}\n          uiTransform={{\n            width: '100%',\n            height: 40 * scaleFactor,\n          }}\n          uiBackground={{ color: Color4.White() }}\n          color={Color4.Black()}\n        />\n      </UiEntity>\n\n      <UiEntity uiTransform={{ flexDirection: 'column' }}>\n        <Label\n          value=\"<b>Actions</b>\"\n          fontSize={16 * scaleFactor}\n          color={Color4.White()}\n          uiTransform={{ margin: { bottom: 16 * scaleFactor } }}\n        />\n\n        <UiEntity uiTransform={{ flexDirection: 'row' }}>\n          <Button\n            id=\"rewards_control_release\"\n            value=\"<b>Release</b>\"\n            fontSize={16 * scaleFactor}\n            uiTransform={{\n              margin: { right: 16 * scaleFactor },\n              alignItems: 'center',\n              justifyContent: 'center',\n            }}\n            icon={ICONS.SEND}\n            iconTransform={{\n              height: 25 * scaleFactor,\n              width: 25 * scaleFactor,\n            }}\n            onMouseDown={() => handleRelease(engine, state)}\n            disabled={state.rewardsControl.selectedRewardItem === undefined}\n          />\n          <Button\n            id=\"rewards_control_clear\"\n            value=\"<b>Clear</b>\"\n            fontSize={16 * scaleFactor}\n            onMouseDown={() => handleClear(engine, state)}\n            disabled={state.rewardsControl.selectedRewardItem === undefined}\n          />\n        </UiEntity>\n\n        {/* TODO: Get supply values from rewards-server, it required a signedFetch but the one sent by the explorer is rejected */}\n        {/* <Label\n          value={`Redeemed: ${state.rewardsControl.redeemedCount}/`}\n          fontSize={14}\n          color={Color4.create(187 / 255, 187 / 255, 187 / 255, 1)}\n        /> */}\n      </UiEntity>\n    </UiEntity>\n  );\n}\n\nfunction handleRelease(engine: IEngine, state: State) {\n  const { Actions, Rewards } = getComponents(engine);\n  const rewardItems = getRewardItems(engine);\n  const selectedRewardItem = rewardItems[state.rewardsControl.selectedRewardItem!];\n  const rewardItem = Rewards.getOrNull(selectedRewardItem.entity as Entity);\n\n  if (!rewardItem) return;\n\n  const action = Actions.getOrNull(selectedRewardItem.entity as Entity)?.value.find(\n    ($: Action) => $.name === 'Airdrop',\n  );\n  if (action) {\n    const actionEvents = getActionEvents(selectedRewardItem.entity as Entity);\n    actionEvents.emit(action.name, getPayload(action));\n  }\n}\n\nfunction handleClear(engine: IEngine, state: State) {\n  const { Actions, Rewards } = getComponents(engine);\n  const rewardItems = getRewardItems(engine);\n  const selectedRewardItem = rewardItems[state.rewardsControl.selectedRewardItem!];\n  const rewardItem = Rewards.getOrNull(selectedRewardItem.entity as Entity);\n  if (!rewardItem) return;\n\n  const action = Actions.getOrNull(selectedRewardItem.entity as Entity)?.value.find(\n    ($: Action) => $.name === 'Invisible',\n  );\n\n  if (action) {\n    const actionEvents = getActionEvents(selectedRewardItem.entity as Entity);\n    actionEvents.emit(action.name, getPayload(action));\n  }\n}\n"]}
@@ -66,7 +66,7 @@ function SmartItemSelector({ engine, smartItems, selectedIndex, onSelect, }) {
66
66
  ReactEcs.createElement(Label, { value: "<b>Selected Smart Item</b>", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: {
67
67
  margin: { bottom: 16 * scaleFactor },
68
68
  } }),
69
- ReactEcs.createElement(Dropdown, { key: "SmartItemsControlDropdownSelector", acceptEmpty: true, emptyLabel: "Select Smart Item", options: smartItems.map(item => item.customName), selectedIndex: selectedIndex ?? -1, onChange: onSelect, textAlign: "middle-left", fontSize: 14 * scaleFactor, uiTransform: {
69
+ ReactEcs.createElement(Dropdown, { key: "SmartItemsControlDropdownSelector", acceptEmpty: true, emptyLabel: "Select Smart Item", options: smartItems.map((item) => item.customName), selectedIndex: selectedIndex ?? -1, onChange: onSelect, textAlign: "middle-left", fontSize: 14 * scaleFactor, uiTransform: {
70
70
  height: 40 * scaleFactor,
71
71
  width: '100%',
72
72
  }, uiBackground: { color: Color4.White() }, color: Color4.Black() })));
@@ -80,7 +80,7 @@ function ActionSelector({ engine, actions, selectedIndex, disabled, onChange, })
80
80
  ReactEcs.createElement(Label, { value: "<b>Actions</b>", fontSize: 16 * scaleFactor, color: Color4.White(), uiTransform: {
81
81
  margin: { bottom: 16 * scaleFactor },
82
82
  } }),
83
- actions.length ? (ReactEcs.createElement(Dropdown, { acceptEmpty: true, emptyLabel: "Select Action", options: actions.map(action => action.name), selectedIndex: selectedIndex, onChange: onChange, disabled: disabled, textAlign: "middle-left", fontSize: 14 * scaleFactor, uiTransform: {
83
+ actions.length ? (ReactEcs.createElement(Dropdown, { acceptEmpty: true, emptyLabel: "Select Action", options: actions.map((action) => action.name), selectedIndex: selectedIndex, onChange: onChange, disabled: disabled, textAlign: "middle-left", fontSize: 14 * scaleFactor, uiTransform: {
84
84
  height: 40 * scaleFactor,
85
85
  width: '100%',
86
86
  }, uiBackground: {
@@ -117,7 +117,7 @@ export function SmartItemsControl({ engine, state }) {
117
117
  ? getSmartItemActions(engine, smartItems[state.smartItemsControl.selectedSmartItem])
118
118
  : [];
119
119
  const selectedActionIndex = state.smartItemsControl.selectedSmartItem !== undefined
120
- ? actions.findIndex(action => {
120
+ ? actions.findIndex((action) => {
121
121
  const selectedSmartItem = smartItems[state.smartItemsControl.selectedSmartItem];
122
122
  const stateSelectedAction = state.smartItemsControl.smartItems.get(selectedSmartItem.entity)?.selectedAction;
123
123
  return action.name === (stateSelectedAction ?? selectedSmartItem.defaultAction);
@@ -141,4 +141,4 @@ export function SmartItemsControl({ engine, state }) {
141
141
  } }),
142
142
  ReactEcs.createElement(ActionButtons, { engine: engine, state: state, smartItems: smartItems, actions: actions, selectedAction: selectedActionIndex !== undefined ? actions[selectedActionIndex] : undefined }))));
143
143
  }
144
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SmartItemsControl.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/SmartItemsControl.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport ReactEcs, { Dropdown, Label, UiEntity } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { Action, AdminTools, getActionEvents, getComponents, getPayload } from '../definitions';\nimport { getExplorerComponents } from '../components';\nimport { getScaleUIFactor } from '../ui';\nimport { Button } from './Button';\nimport { CONTENT_URL } from './constants';\nimport { State } from './types';\nimport { Header } from './Header';\nimport { Card } from './Card';\nimport { getSmartItems } from '.';\n\n// Constants\nconst ICONS = {\n  SMART_ITEM_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/smart-item-control.png`,\n} as const;\n\nfunction getSmartItemActions(\n  engine: IEngine,\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n) {\n  const { Actions } = getComponents(engine);\n  if (!smartItem || !Actions.has(smartItem.entity as Entity)) return [];\n\n  const actions = Array.from(Actions.get(smartItem.entity as Entity).value);\n  return actions;\n}\n\n// Event Handlers\nfunction handleExecuteAction(\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n  action: Action,\n) {\n  const actionEvents = getActionEvents(smartItem.entity as Entity);\n  actionEvents.emit(action.name, getPayload(action));\n}\n\nfunction handleSelectSmartItem(\n  state: State,\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>,\n  idx: number,\n) {\n  state.smartItemsControl.selectedSmartItem = idx;\n  const smartItem = smartItems[idx];\n\n  if (!state.smartItemsControl.smartItems.has(smartItem.entity as Entity)) {\n    const stateSmartItems = new Map(state.smartItemsControl.smartItems);\n    stateSmartItems.set(smartItem.entity as Entity, {\n      visible: true,\n      selectedAction: smartItem.defaultAction,\n    });\n    state.smartItemsControl = {\n      ...state.smartItemsControl,\n      smartItems: new Map(stateSmartItems),\n    };\n  }\n}\n\nfunction handleSelectAction(\n  state: State,\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n  action: Action,\n) {\n  const stateSmartItems = new Map(state.smartItemsControl.smartItems);\n  stateSmartItems.set(smartItem.entity as Entity, {\n    ...stateSmartItems.get(smartItem.entity as Entity)!,\n    selectedAction: action.name,\n  });\n\n  state.smartItemsControl = {\n    ...state.smartItemsControl,\n    smartItems: new Map(stateSmartItems),\n  };\n}\n\nfunction handleHideShowEntity(\n  engine: IEngine,\n  state: State,\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>,\n) {\n  const { VisibilityComponent } = getExplorerComponents(engine);\n\n  const smartItemEntity = smartItems[state.smartItemsControl.selectedSmartItem!].entity as Entity;\n  const smartItem = state.smartItemsControl.smartItems.get(smartItemEntity);\n\n  const toggleVisibility = !smartItem!.visible;\n  state.smartItemsControl.smartItems.get(smartItemEntity)!.visible = toggleVisibility;\n\n  const visibility = VisibilityComponent.getOrCreateMutable(smartItemEntity);\n  visibility.visible = toggleVisibility;\n}\n\nfunction SmartItemSelector({\n  engine,\n  smartItems,\n  selectedIndex,\n  onSelect,\n}: {\n  engine: IEngine;\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>;\n  selectedIndex: number | undefined;\n  onSelect: (idx: number) => void;\n}) {\n  const scaleFactor = getScaleUIFactor(engine);\n\n  return (\n    <UiEntity\n      key=\"SmartItemsControlDropdownWrapper\"\n      uiTransform={{\n        flexDirection: 'column',\n        margin: { bottom: 32 * scaleFactor },\n      }}\n    >\n      <Label\n        value=\"<b>Selected Smart Item</b>\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { bottom: 16 * scaleFactor },\n        }}\n      />\n      <Dropdown\n        key=\"SmartItemsControlDropdownSelector\"\n        acceptEmpty\n        emptyLabel=\"Select Smart Item\"\n        options={smartItems.map(item => item.customName)}\n        selectedIndex={selectedIndex ?? -1}\n        onChange={onSelect}\n        textAlign=\"middle-left\"\n        fontSize={14 * scaleFactor}\n        uiTransform={{\n          height: 40 * scaleFactor,\n          width: '100%',\n        }}\n        uiBackground={{ color: Color4.White() }}\n        color={Color4.Black()}\n      />\n    </UiEntity>\n  );\n}\n\nfunction ActionSelector({\n  engine,\n  actions,\n  selectedIndex,\n  disabled,\n  onChange,\n}: {\n  engine: IEngine;\n  actions: Action[];\n  selectedIndex: number | undefined;\n  disabled: boolean;\n  onChange: (idx: number) => void;\n}) {\n  const scaleFactor = getScaleUIFactor(engine);\n\n  return (\n    <UiEntity\n      uiTransform={{\n        flexDirection: 'column',\n        margin: { bottom: 32 * scaleFactor },\n      }}\n    >\n      <Label\n        value=\"<b>Actions</b>\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { bottom: 16 * scaleFactor },\n        }}\n      />\n      {actions.length ? (\n        <Dropdown\n          acceptEmpty\n          emptyLabel=\"Select Action\"\n          options={actions.map(action => action.name)}\n          selectedIndex={selectedIndex}\n          onChange={onChange}\n          disabled={disabled}\n          textAlign=\"middle-left\"\n          fontSize={14 * scaleFactor}\n          uiTransform={{\n            height: 40 * scaleFactor,\n            width: '100%',\n          }}\n          uiBackground={{\n            color: disabled ? Color4.Gray() : Color4.White(),\n          }}\n          color={Color4.Black()}\n        />\n      ) : (\n        <UiEntity />\n      )}\n    </UiEntity>\n  );\n}\n\nfunction ActionButtons({\n  engine,\n  state,\n  smartItems,\n  actions,\n  selectedAction,\n}: {\n  engine: IEngine;\n  state: State;\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>;\n  actions: Action[];\n  selectedAction: Action | undefined;\n}) {\n  const scaleFactor = getScaleUIFactor(engine);\n\n  const selectedSmartItem =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? smartItems[state.smartItemsControl.selectedSmartItem]\n      : undefined;\n\n  const isVisible =\n    selectedSmartItem &&\n    state.smartItemsControl.smartItems.get(selectedSmartItem.entity as Entity)?.visible;\n\n  return (\n    <UiEntity\n      uiTransform={{\n        flexDirection: 'row',\n      }}\n    >\n      <Button\n        id=\"smart_items_control_restart\"\n        value=\"<b>Play Action</b>\"\n        variant=\"text\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { right: 8 * scaleFactor },\n          height: 40 * scaleFactor,\n        }}\n        labelTransform={{\n          margin: { left: 10 * scaleFactor, right: 10 * scaleFactor },\n        }}\n        disabled={!selectedSmartItem || !selectedAction}\n        onMouseDown={() => {\n          if (selectedSmartItem && selectedAction) {\n            handleExecuteAction(selectedSmartItem, selectedAction);\n          }\n        }}\n      />\n      <Button\n        id=\"smart_items_control_hide_show\"\n        value={`<b>${isVisible ? 'Hide' : 'Show'} Entity</b>`}\n        variant=\"text\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        onMouseDown={() => handleHideShowEntity(engine, state, smartItems)}\n        disabled={!selectedSmartItem}\n        uiTransform={{ margin: { right: 8 * scaleFactor } }}\n        labelTransform={{\n          margin: { left: 10 * scaleFactor, right: 10 * scaleFactor },\n        }}\n      />\n    </UiEntity>\n  );\n}\n\n// Main Component\nexport function SmartItemsControl({ engine, state }: { engine: IEngine; state: State }) {\n  const smartItems = getSmartItems(engine);\n  const actions =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? getSmartItemActions(engine, smartItems[state.smartItemsControl.selectedSmartItem])\n      : [];\n\n  const selectedActionIndex =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? actions.findIndex(action => {\n          const selectedSmartItem = smartItems[state.smartItemsControl.selectedSmartItem!];\n          const stateSelectedAction = state.smartItemsControl.smartItems.get(\n            selectedSmartItem.entity as Entity,\n          )?.selectedAction;\n\n          return action.name === (stateSelectedAction ?? selectedSmartItem.defaultAction);\n        })\n      : undefined;\n  const scaleFactor = getScaleUIFactor(engine);\n\n  return (\n    <Card scaleFactor={scaleFactor}>\n      <UiEntity\n        key=\"SmartItemsControl\"\n        uiTransform={{\n          height: '100%',\n          width: '100%',\n          flexDirection: 'column',\n        }}\n      >\n        <Header\n          iconSrc={ICONS.SMART_ITEM_CONTROL}\n          title=\"SMART ITEM ACTIONS\"\n          scaleFactor={scaleFactor}\n        />\n\n        <SmartItemSelector\n          engine={engine}\n          smartItems={smartItems}\n          selectedIndex={state.smartItemsControl.selectedSmartItem}\n          onSelect={idx => {\n            handleSelectSmartItem(state, smartItems, idx);\n          }}\n        />\n\n        <ActionSelector\n          engine={engine}\n          actions={actions}\n          selectedIndex={selectedActionIndex}\n          disabled={state.smartItemsControl.selectedSmartItem === undefined}\n          onChange={idx => {\n            if (state.smartItemsControl.selectedSmartItem !== undefined) {\n              handleSelectAction(\n                state,\n                smartItems[state.smartItemsControl.selectedSmartItem],\n                actions[idx],\n              );\n            }\n          }}\n        />\n\n        <ActionButtons\n          engine={engine}\n          state={state}\n          smartItems={smartItems}\n          actions={actions}\n          selectedAction={\n            selectedActionIndex !== undefined ? actions[selectedActionIndex] : undefined\n          }\n        />\n      </UiEntity>\n    </Card>\n  );\n}\n"]}
144
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"SmartItemsControl.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/SmartItemsControl.tsx"],"names":[],"mappings":"AACA,OAAO,QAAQ,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AACrE,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAsB,eAAe,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAChG,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,gBAAgB,EAAE,MAAM,OAAO,CAAC;AACzC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE1C,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAC9B,OAAO,EAAE,aAAa,EAAE,MAAM,GAAG,CAAC;AAGlC,MAAM,KAAK,GAAG;IACZ,kBAAkB,EAAE,GAAG,WAAW,oDAAoD;CAC9E,CAAC;AAEX,SAAS,mBAAmB,CAC1B,MAAe,EACf,SAAwE;IAExE,MAAM,EAAE,OAAO,EAAE,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IAC1C,IAAI,CAAC,SAAS,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,MAAgB,CAAC;QAAE,OAAO,EAAE,CAAC;IAEtE,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,MAAgB,CAAC,CAAC,KAAK,CAAC,CAAC;IAC1E,OAAO,OAAO,CAAC;AACjB,CAAC;AAGD,SAAS,mBAAmB,CAC1B,SAAwE,EACxE,MAAc;IAEd,MAAM,YAAY,GAAG,eAAe,CAAC,SAAS,CAAC,MAAgB,CAAC,CAAC;IACjE,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC;AACrD,CAAC;AAED,SAAS,qBAAqB,CAC5B,KAAY,EACZ,UAAsE,EACtE,GAAW;IAEX,KAAK,CAAC,iBAAiB,CAAC,iBAAiB,GAAG,GAAG,CAAC;IAChD,MAAM,SAAS,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC;IAElC,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,MAAgB,CAAC,EAAE,CAAC;QACxE,MAAM,eAAe,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QACpE,eAAe,CAAC,GAAG,CAAC,SAAS,CAAC,MAAgB,EAAE;YAC9C,OAAO,EAAE,IAAI;YACb,cAAc,EAAE,SAAS,CAAC,aAAa;SACxC,CAAC,CAAC;QACH,KAAK,CAAC,iBAAiB,GAAG;YACxB,GAAG,KAAK,CAAC,iBAAiB;YAC1B,UAAU,EAAE,IAAI,GAAG,CAAC,eAAe,CAAC;SACrC,CAAC;IACJ,CAAC;AACH,CAAC;AAED,SAAS,kBAAkB,CACzB,KAAY,EACZ,SAAwE,EACxE,MAAc;IAEd,MAAM,eAAe,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;IACpE,eAAe,CAAC,GAAG,CAAC,SAAS,CAAC,MAAgB,EAAE;QAC9C,GAAG,eAAe,CAAC,GAAG,CAAC,SAAS,CAAC,MAAgB,CAAE;QACnD,cAAc,EAAE,MAAM,CAAC,IAAI;KAC5B,CAAC,CAAC;IAEH,KAAK,CAAC,iBAAiB,GAAG;QACxB,GAAG,KAAK,CAAC,iBAAiB;QAC1B,UAAU,EAAE,IAAI,GAAG,CAAC,eAAe,CAAC;KACrC,CAAC;AACJ,CAAC;AAED,SAAS,oBAAoB,CAC3B,MAAe,EACf,KAAY,EACZ,UAAsE;IAEtE,MAAM,EAAE,mBAAmB,EAAE,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;IAE9D,MAAM,eAAe,GAAG,UAAU,CAAC,KAAK,CAAC,iBAAiB,CAAC,iBAAkB,CAAC,CAAC,MAAgB,CAAC;IAChG,MAAM,SAAS,GAAG,KAAK,CAAC,iBAAiB,CAAC,UAAU,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;IAE1E,MAAM,gBAAgB,GAAG,CAAC,SAAU,CAAC,OAAO,CAAC;IAC7C,KAAK,CAAC,iBAAiB,CAAC,UAAU,CAAC,GAAG,CAAC,eAAe,CAAE,CAAC,OAAO,GAAG,gBAAgB,CAAC;IAEpF,MAAM,UAAU,GAAG,mBAAmB,CAAC,kBAAkB,CAAC,eAAe,CAAC,CAAC;IAC3E,UAAU,CAAC,OAAO,GAAG,gBAAgB,CAAC;AACxC,CAAC;AAED,SAAS,iBAAiB,CAAC,EACzB,MAAM,EACN,UAAU,EACV,aAAa,EACb,QAAQ,GAMT;IACC,MAAM,WAAW,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAE7C,OAAO,CACL,uBAAC,QAAQ,IACP,GAAG,EAAC,kCAAkC,EACtC,WAAW,EAAE;YACX,aAAa,EAAE,QAAQ;YACvB,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE;SACrC;QAED,uBAAC,KAAK,IACJ,KAAK,EAAC,4BAA4B,EAClC,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,WAAW,EAAE;gBACX,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE;aACrC,GACD;QACF,uBAAC,QAAQ,IACP,GAAG,EAAC,mCAAmC,EACvC,WAAW,QACX,UAAU,EAAC,mBAAmB,EAC9B,OAAO,EAAE,UAAU,CAAC,GAAG,CACrB,CAAC,IAAmE,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,CACzF,EACD,aAAa,EAAE,aAAa,IAAI,CAAC,CAAC,EAClC,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAC,aAAa,EACvB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,WAAW,EAAE;gBACX,MAAM,EAAE,EAAE,GAAG,WAAW;gBACxB,KAAK,EAAE,MAAM;aACd,EACD,YAAY,EAAE,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EAAE,EACvC,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,GACrB,CACO,CACZ,CAAC;AACJ,CAAC;AAED,SAAS,cAAc,CAAC,EACtB,MAAM,EACN,OAAO,EACP,aAAa,EACb,QAAQ,EACR,QAAQ,GAOT;IACC,MAAM,WAAW,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAE7C,OAAO,CACL,uBAAC,QAAQ,IACP,WAAW,EAAE;YACX,aAAa,EAAE,QAAQ;YACvB,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE;SACrC;QAED,uBAAC,KAAK,IACJ,KAAK,EAAC,gBAAgB,EACtB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,WAAW,EAAE;gBACX,MAAM,EAAE,EAAE,MAAM,EAAE,EAAE,GAAG,WAAW,EAAE;aACrC,GACD;QACD,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAChB,uBAAC,QAAQ,IACP,WAAW,QACX,UAAU,EAAC,eAAe,EAC1B,OAAO,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,MAAc,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,EACrD,aAAa,EAAE,aAAa,EAC5B,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAC,aAAa,EACvB,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,WAAW,EAAE;gBACX,MAAM,EAAE,EAAE,GAAG,WAAW;gBACxB,KAAK,EAAE,MAAM;aACd,EACD,YAAY,EAAE;gBACZ,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,EAAE;aACjD,EACD,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,GACrB,CACH,CAAC,CAAC,CAAC,CACF,uBAAC,QAAQ,OAAG,CACb,CACQ,CACZ,CAAC;AACJ,CAAC;AAED,SAAS,aAAa,CAAC,EACrB,MAAM,EACN,KAAK,EACL,UAAU,EACV,OAAO,EACP,cAAc,GAOf;IACC,MAAM,WAAW,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAE7C,MAAM,iBAAiB,GACrB,KAAK,CAAC,iBAAiB,CAAC,iBAAiB,KAAK,SAAS;QACrD,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,iBAAiB,CAAC,iBAAiB,CAAC;QACvD,CAAC,CAAC,SAAS,CAAC;IAEhB,MAAM,SAAS,GACb,iBAAiB;QACjB,KAAK,CAAC,iBAAiB,CAAC,UAAU,CAAC,GAAG,CAAC,iBAAiB,CAAC,MAAgB,CAAC,EAAE,OAAO,CAAC;IAEtF,OAAO,CACL,uBAAC,QAAQ,IACP,WAAW,EAAE;YACX,aAAa,EAAE,KAAK;SACrB;QAED,uBAAC,MAAM,IACL,EAAE,EAAC,6BAA6B,EAChC,KAAK,EAAC,oBAAoB,EAC1B,OAAO,EAAC,MAAM,EACd,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,WAAW,EAAE;gBACX,MAAM,EAAE,EAAE,KAAK,EAAE,CAAC,GAAG,WAAW,EAAE;gBAClC,MAAM,EAAE,EAAE,GAAG,WAAW;aACzB,EACD,cAAc,EAAE;gBACd,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,WAAW,EAAE,KAAK,EAAE,EAAE,GAAG,WAAW,EAAE;aAC5D,EACD,QAAQ,EAAE,CAAC,iBAAiB,IAAI,CAAC,cAAc,EAC/C,WAAW,EAAE,GAAG,EAAE;gBAChB,IAAI,iBAAiB,IAAI,cAAc,EAAE,CAAC;oBACxC,mBAAmB,CAAC,iBAAiB,EAAE,cAAc,CAAC,CAAC;gBACzD,CAAC;YACH,CAAC,GACD;QACF,uBAAC,MAAM,IACL,EAAE,EAAC,+BAA+B,EAClC,KAAK,EAAE,MAAM,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,aAAa,EACrD,OAAO,EAAC,MAAM,EACd,QAAQ,EAAE,EAAE,GAAG,WAAW,EAC1B,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,EACrB,WAAW,EAAE,GAAG,EAAE,CAAC,oBAAoB,CAAC,MAAM,EAAE,KAAK,EAAE,UAAU,CAAC,EAClE,QAAQ,EAAE,CAAC,iBAAiB,EAC5B,WAAW,EAAE,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,CAAC,GAAG,WAAW,EAAE,EAAE,EACnD,cAAc,EAAE;gBACd,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,GAAG,WAAW,EAAE,KAAK,EAAE,EAAE,GAAG,WAAW,EAAE;aAC5D,GACD,CACO,CACZ,CAAC;AACJ,CAAC;AAGD,MAAM,UAAU,iBAAiB,CAAC,EAAE,MAAM,EAAE,KAAK,EAAqC;IACpF,MAAM,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC,CAAC;IACzC,MAAM,OAAO,GACX,KAAK,CAAC,iBAAiB,CAAC,iBAAiB,KAAK,SAAS;QACrD,CAAC,CAAC,mBAAmB,CAAC,MAAM,EAAE,UAAU,CAAC,KAAK,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,CAAC;QACpF,CAAC,CAAC,EAAE,CAAC;IAET,MAAM,mBAAmB,GACvB,KAAK,CAAC,iBAAiB,CAAC,iBAAiB,KAAK,SAAS;QACrD,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,MAAc,EAAE,EAAE;YACnC,MAAM,iBAAiB,GACrB,UAAU,CAAC,KAAK,CAAC,iBAAiB,CAAC,iBAAkB,CAAC,CAAC;YACzD,MAAM,mBAAmB,GAAG,KAAK,CAAC,iBAAiB,CAAC,UAAU,CAAC,GAAG,CAChE,iBAAiB,CAAC,MAAgB,CACnC,EAAE,cAAc,CAAC;YAElB,OAAO,MAAM,CAAC,IAAI,KAAK,CAAC,mBAAmB,IAAI,iBAAiB,CAAC,aAAa,CAAC,CAAC;QAClF,CAAC,CAAC;QACJ,CAAC,CAAC,SAAS,CAAC;IAChB,MAAM,WAAW,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;IAE7C,OAAO,CACL,uBAAC,IAAI,IAAC,WAAW,EAAE,WAAW;QAC5B,uBAAC,QAAQ,IACP,GAAG,EAAC,mBAAmB,EACvB,WAAW,EAAE;gBACX,MAAM,EAAE,MAAM;gBACd,KAAK,EAAE,MAAM;gBACb,aAAa,EAAE,QAAQ;aACxB;YAED,uBAAC,MAAM,IACL,OAAO,EAAE,KAAK,CAAC,kBAAkB,EACjC,KAAK,EAAC,oBAAoB,EAC1B,WAAW,EAAE,WAAW,GACxB;YAEF,uBAAC,iBAAiB,IAChB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,UAAU,EACtB,aAAa,EAAE,KAAK,CAAC,iBAAiB,CAAC,iBAAiB,EACxD,QAAQ,EAAE,GAAG,CAAC,EAAE;oBACd,qBAAqB,CAAC,KAAK,EAAE,UAAU,EAAE,GAAG,CAAC,CAAC;gBAChD,CAAC,GACD;YAEF,uBAAC,cAAc,IACb,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,OAAO,EAChB,aAAa,EAAE,mBAAmB,EAClC,QAAQ,EAAE,KAAK,CAAC,iBAAiB,CAAC,iBAAiB,KAAK,SAAS,EACjE,QAAQ,EAAE,GAAG,CAAC,EAAE;oBACd,IAAI,KAAK,CAAC,iBAAiB,CAAC,iBAAiB,KAAK,SAAS,EAAE,CAAC;wBAC5D,kBAAkB,CAChB,KAAK,EACL,UAAU,CAAC,KAAK,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,EACrD,OAAO,CAAC,GAAG,CAAC,CACb,CAAC;oBACJ,CAAC;gBACH,CAAC,GACD;YAEF,uBAAC,aAAa,IACZ,MAAM,EAAE,MAAM,EACd,KAAK,EAAE,KAAK,EACZ,UAAU,EAAE,UAAU,EACtB,OAAO,EAAE,OAAO,EAChB,cAAc,EACZ,mBAAmB,KAAK,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,SAAS,GAE9E,CACO,CACN,CACR,CAAC;AACJ,CAAC","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport ReactEcs, { Dropdown, Label, UiEntity } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { Action, AdminTools, getActionEvents, getComponents, getPayload } from '../definitions';\nimport { getExplorerComponents } from '../components';\nimport { getScaleUIFactor } from '../ui';\nimport { Button } from './Button';\nimport { CONTENT_URL } from './constants';\nimport { State } from './types';\nimport { Header } from './Header';\nimport { Card } from './Card';\nimport { getSmartItems } from '.';\n\n// Constants\nconst ICONS = {\n  SMART_ITEM_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/smart-item-control.png`,\n} as const;\n\nfunction getSmartItemActions(\n  engine: IEngine,\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n) {\n  const { Actions } = getComponents(engine);\n  if (!smartItem || !Actions.has(smartItem.entity as Entity)) return [];\n\n  const actions = Array.from(Actions.get(smartItem.entity as Entity).value);\n  return actions;\n}\n\n// Event Handlers\nfunction handleExecuteAction(\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n  action: Action,\n) {\n  const actionEvents = getActionEvents(smartItem.entity as Entity);\n  actionEvents.emit(action.name, getPayload(action));\n}\n\nfunction handleSelectSmartItem(\n  state: State,\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>,\n  idx: number,\n) {\n  state.smartItemsControl.selectedSmartItem = idx;\n  const smartItem = smartItems[idx];\n\n  if (!state.smartItemsControl.smartItems.has(smartItem.entity as Entity)) {\n    const stateSmartItems = new Map(state.smartItemsControl.smartItems);\n    stateSmartItems.set(smartItem.entity as Entity, {\n      visible: true,\n      selectedAction: smartItem.defaultAction,\n    });\n    state.smartItemsControl = {\n      ...state.smartItemsControl,\n      smartItems: new Map(stateSmartItems),\n    };\n  }\n}\n\nfunction handleSelectAction(\n  state: State,\n  smartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0],\n  action: Action,\n) {\n  const stateSmartItems = new Map(state.smartItemsControl.smartItems);\n  stateSmartItems.set(smartItem.entity as Entity, {\n    ...stateSmartItems.get(smartItem.entity as Entity)!,\n    selectedAction: action.name,\n  });\n\n  state.smartItemsControl = {\n    ...state.smartItemsControl,\n    smartItems: new Map(stateSmartItems),\n  };\n}\n\nfunction handleHideShowEntity(\n  engine: IEngine,\n  state: State,\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>,\n) {\n  const { VisibilityComponent } = getExplorerComponents(engine);\n\n  const smartItemEntity = smartItems[state.smartItemsControl.selectedSmartItem!].entity as Entity;\n  const smartItem = state.smartItemsControl.smartItems.get(smartItemEntity);\n\n  const toggleVisibility = !smartItem!.visible;\n  state.smartItemsControl.smartItems.get(smartItemEntity)!.visible = toggleVisibility;\n\n  const visibility = VisibilityComponent.getOrCreateMutable(smartItemEntity);\n  visibility.visible = toggleVisibility;\n}\n\nfunction SmartItemSelector({\n  engine,\n  smartItems,\n  selectedIndex,\n  onSelect,\n}: {\n  engine: IEngine;\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>;\n  selectedIndex: number | undefined;\n  onSelect: (idx: number) => void;\n}) {\n  const scaleFactor = getScaleUIFactor(engine);\n\n  return (\n    <UiEntity\n      key=\"SmartItemsControlDropdownWrapper\"\n      uiTransform={{\n        flexDirection: 'column',\n        margin: { bottom: 32 * scaleFactor },\n      }}\n    >\n      <Label\n        value=\"<b>Selected Smart Item</b>\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { bottom: 16 * scaleFactor },\n        }}\n      />\n      <Dropdown\n        key=\"SmartItemsControlDropdownSelector\"\n        acceptEmpty\n        emptyLabel=\"Select Smart Item\"\n        options={smartItems.map(\n          (item: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0]) => item.customName,\n        )}\n        selectedIndex={selectedIndex ?? -1}\n        onChange={onSelect}\n        textAlign=\"middle-left\"\n        fontSize={14 * scaleFactor}\n        uiTransform={{\n          height: 40 * scaleFactor,\n          width: '100%',\n        }}\n        uiBackground={{ color: Color4.White() }}\n        color={Color4.Black()}\n      />\n    </UiEntity>\n  );\n}\n\nfunction ActionSelector({\n  engine,\n  actions,\n  selectedIndex,\n  disabled,\n  onChange,\n}: {\n  engine: IEngine;\n  actions: Action[];\n  selectedIndex: number | undefined;\n  disabled: boolean;\n  onChange: (idx: number) => void;\n}) {\n  const scaleFactor = getScaleUIFactor(engine);\n\n  return (\n    <UiEntity\n      uiTransform={{\n        flexDirection: 'column',\n        margin: { bottom: 32 * scaleFactor },\n      }}\n    >\n      <Label\n        value=\"<b>Actions</b>\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { bottom: 16 * scaleFactor },\n        }}\n      />\n      {actions.length ? (\n        <Dropdown\n          acceptEmpty\n          emptyLabel=\"Select Action\"\n          options={actions.map((action: Action) => action.name)}\n          selectedIndex={selectedIndex}\n          onChange={onChange}\n          disabled={disabled}\n          textAlign=\"middle-left\"\n          fontSize={14 * scaleFactor}\n          uiTransform={{\n            height: 40 * scaleFactor,\n            width: '100%',\n          }}\n          uiBackground={{\n            color: disabled ? Color4.Gray() : Color4.White(),\n          }}\n          color={Color4.Black()}\n        />\n      ) : (\n        <UiEntity />\n      )}\n    </UiEntity>\n  );\n}\n\nfunction ActionButtons({\n  engine,\n  state,\n  smartItems,\n  actions,\n  selectedAction,\n}: {\n  engine: IEngine;\n  state: State;\n  smartItems: NonNullable<AdminTools['smartItemsControl']['smartItems']>;\n  actions: Action[];\n  selectedAction: Action | undefined;\n}) {\n  const scaleFactor = getScaleUIFactor(engine);\n\n  const selectedSmartItem =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? smartItems[state.smartItemsControl.selectedSmartItem]\n      : undefined;\n\n  const isVisible =\n    selectedSmartItem &&\n    state.smartItemsControl.smartItems.get(selectedSmartItem.entity as Entity)?.visible;\n\n  return (\n    <UiEntity\n      uiTransform={{\n        flexDirection: 'row',\n      }}\n    >\n      <Button\n        id=\"smart_items_control_restart\"\n        value=\"<b>Play Action</b>\"\n        variant=\"text\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        uiTransform={{\n          margin: { right: 8 * scaleFactor },\n          height: 40 * scaleFactor,\n        }}\n        labelTransform={{\n          margin: { left: 10 * scaleFactor, right: 10 * scaleFactor },\n        }}\n        disabled={!selectedSmartItem || !selectedAction}\n        onMouseDown={() => {\n          if (selectedSmartItem && selectedAction) {\n            handleExecuteAction(selectedSmartItem, selectedAction);\n          }\n        }}\n      />\n      <Button\n        id=\"smart_items_control_hide_show\"\n        value={`<b>${isVisible ? 'Hide' : 'Show'} Entity</b>`}\n        variant=\"text\"\n        fontSize={16 * scaleFactor}\n        color={Color4.White()}\n        onMouseDown={() => handleHideShowEntity(engine, state, smartItems)}\n        disabled={!selectedSmartItem}\n        uiTransform={{ margin: { right: 8 * scaleFactor } }}\n        labelTransform={{\n          margin: { left: 10 * scaleFactor, right: 10 * scaleFactor },\n        }}\n      />\n    </UiEntity>\n  );\n}\n\n// Main Component\nexport function SmartItemsControl({ engine, state }: { engine: IEngine; state: State }) {\n  const smartItems = getSmartItems(engine);\n  const actions =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? getSmartItemActions(engine, smartItems[state.smartItemsControl.selectedSmartItem])\n      : [];\n\n  const selectedActionIndex =\n    state.smartItemsControl.selectedSmartItem !== undefined\n      ? actions.findIndex((action: Action) => {\n          const selectedSmartItem: NonNullable<AdminTools['smartItemsControl']['smartItems']>[0] =\n            smartItems[state.smartItemsControl.selectedSmartItem!];\n          const stateSelectedAction = state.smartItemsControl.smartItems.get(\n            selectedSmartItem.entity as Entity,\n          )?.selectedAction;\n\n          return action.name === (stateSelectedAction ?? selectedSmartItem.defaultAction);\n        })\n      : undefined;\n  const scaleFactor = getScaleUIFactor(engine);\n\n  return (\n    <Card scaleFactor={scaleFactor}>\n      <UiEntity\n        key=\"SmartItemsControl\"\n        uiTransform={{\n          height: '100%',\n          width: '100%',\n          flexDirection: 'column',\n        }}\n      >\n        <Header\n          iconSrc={ICONS.SMART_ITEM_CONTROL}\n          title=\"SMART ITEM ACTIONS\"\n          scaleFactor={scaleFactor}\n        />\n\n        <SmartItemSelector\n          engine={engine}\n          smartItems={smartItems}\n          selectedIndex={state.smartItemsControl.selectedSmartItem}\n          onSelect={idx => {\n            handleSelectSmartItem(state, smartItems, idx);\n          }}\n        />\n\n        <ActionSelector\n          engine={engine}\n          actions={actions}\n          selectedIndex={selectedActionIndex}\n          disabled={state.smartItemsControl.selectedSmartItem === undefined}\n          onChange={idx => {\n            if (state.smartItemsControl.selectedSmartItem !== undefined) {\n              handleSelectAction(\n                state,\n                smartItems[state.smartItemsControl.selectedSmartItem],\n                actions[idx],\n              );\n            }\n          }}\n        />\n\n        <ActionButtons\n          engine={engine}\n          state={state}\n          smartItems={smartItems}\n          actions={actions}\n          selectedAction={\n            selectedActionIndex !== undefined ? actions[selectedActionIndex] : undefined\n          }\n        />\n      </UiEntity>\n    </Card>\n  );\n}\n"]}
@@ -64,7 +64,7 @@ export function VideoControl({ engine, state }) {
64
64
  margin: { bottom: 16 * scaleFactor },
65
65
  } },
66
66
  videoPlayers.length > 1 && (ReactEcs.createElement(UiEntity, { uiTransform: { flexDirection: 'column' } },
67
- ReactEcs.createElement(Dropdown, { options: videoPlayers.map(player => `<b>${player.customName}</b>`), selectedIndex: state.videoControl.selectedVideoPlayer ?? 0, onChange: idx => (state.videoControl.selectedVideoPlayer = idx), textAlign: "middle-left", fontSize: 16 * scaleFactor, uiTransform: {
67
+ ReactEcs.createElement(Dropdown, { options: videoPlayers.map((player) => `<b>${player.customName}</b>`), selectedIndex: state.videoControl.selectedVideoPlayer ?? 0, onChange: idx => (state.videoControl.selectedVideoPlayer = idx), textAlign: "middle-left", fontSize: 16 * scaleFactor, uiTransform: {
68
68
  margin: { right: 8 * scaleFactor },
69
69
  width: '100%',
70
70
  }, uiBackground: { color: Color4.White() } }))),
@@ -118,4 +118,4 @@ function CustomButton({ active, scaleFactor, value, id, onClick, icon, selected,
118
118
  } })),
119
119
  active && (ReactEcs.createElement(Active, { scaleFactor: scaleFactor, engine: engine, uiTransform: { width: '100%', margin: { top: 6 * scaleFactor } } }))));
120
120
  }
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/admin-toolkit-ui/VideoControl/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import { IEngine } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity, Dropdown } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { getScaleUIFactor } from '../../ui';\nimport { Button } from '../Button';\nimport { CONTENT_URL } from '../constants';\nimport { State } from '../types';\nimport { Header } from '../Header';\nimport {\n  getVideoPlayers,\n  isDclCast,\n  isLiveStream,\n  isVideoUrl,\n  useSelectedVideoPlayer,\n} from './utils';\nimport { Card } from '../Card';\nimport { VideoControlURL } from './VideoUrl';\nimport { LiveStream } from './LiveStream';\nimport { Active } from '../Active';\nimport DclCast from './DclCast';\n\n// Constants\nexport const ICONS = {\n  VIDEO_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control.png`,\n  PREVIOUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-previous-button.png`,\n  FORWARD_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-forward-button.png`,\n  PLAY_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-play-button.png`,\n  MUTE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-mute.png`,\n  LOOP: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-loop.png`,\n  VOLUME_MINUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-volume-minus-button.png`,\n  VOLUME_PLUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-volume-plus-button.png`,\n  VIDEO_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-video-icon.png`,\n  LIVE_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-live.png`,\n  DCL_CAST_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-dcl-cast.png`,\n  INFO: `${CONTENT_URL}/admin_toolkit/assets/icons/info.png`,\n} as const;\n\nexport const VOLUME_STEP = 0.1;\nexport const DEFAULT_VOLUME = 1;\n\nexport const COLORS = {\n  WHITE: Color4.White(),\n  GRAY: Color4.create(160 / 255, 155 / 255, 168 / 255, 1),\n  SUCCESS: Color4.fromHexString('#34CE77'),\n} as const;\n\n// Main component\nexport function VideoControl({ engine, state }: { engine: IEngine; state: State }) {\n  const [selectedEntity, selectedVideo] = useSelectedVideoPlayer(engine) ?? [];\n  const scaleFactor = getScaleUIFactor(engine);\n  const videoPlayers = getVideoPlayers(engine);\n  const [selected, setSelected] = ReactEcs.useState<'video-url' | 'live' | 'dcl-cast' | undefined>(\n    undefined,\n  );\n\n  ReactEcs.useEffect(() => {\n    setSelected(\n      selectedVideo && isDclCast(selectedVideo.src)\n        ? 'dcl-cast'\n        : selectedVideo && isVideoUrl(selectedVideo.src)\n          ? 'video-url'\n          : 'live',\n    );\n  }, [state.videoControl.selectedVideoPlayer]);\n\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column', width: '100%', height: '100%' }}>\n      <Card\n        scaleFactor={scaleFactor}\n        uiTransform={{\n          padding: {\n            top: 32 * scaleFactor,\n            right: 32 * scaleFactor,\n            bottom: 0,\n            left: 32 * scaleFactor,\n          },\n        }}\n      >\n        <UiEntity\n          uiTransform={{\n            width: '100%',\n            height: '100%',\n            flexDirection: 'column',\n          }}\n        >\n          {/* Header */}\n          <Header\n            iconSrc={ICONS.VIDEO_CONTROL}\n            title=\"<b>VIDEO SCREENS</b>\"\n            scaleFactor={scaleFactor}\n          />\n          {videoPlayers.length > 1 && (\n            <Label\n              value=\"<b>Current Screen</b>\"\n              fontSize={16 * scaleFactor}\n              color={Color4.White()}\n              uiTransform={{ margin: { bottom: 16 * scaleFactor } }}\n            />\n          )}\n\n          <UiEntity\n            uiTransform={{\n              flexDirection: 'column',\n              margin: { bottom: 16 * scaleFactor },\n            }}\n          >\n            {videoPlayers.length > 1 && (\n              <UiEntity uiTransform={{ flexDirection: 'column' }}>\n                <Dropdown\n                  options={videoPlayers.map(player => `<b>${player.customName}</b>`)}\n                  selectedIndex={state.videoControl.selectedVideoPlayer ?? 0}\n                  onChange={idx => (state.videoControl.selectedVideoPlayer = idx)}\n                  textAlign=\"middle-left\"\n                  fontSize={16 * scaleFactor}\n                  uiTransform={{\n                    margin: { right: 8 * scaleFactor },\n                    width: '100%',\n                  }}\n                  uiBackground={{ color: Color4.White() }}\n                />\n              </UiEntity>\n            )}\n            <Label\n              fontSize={16 * scaleFactor}\n              value=\"<b>Media Source</b>\"\n              color={Color4.White()}\n              uiTransform={{\n                margin: { bottom: 2 * scaleFactor, top: 16 * scaleFactor },\n              }}\n            />\n            <UiEntity\n              uiTransform={{\n                margin: { top: 10 * scaleFactor },\n                flexDirection: 'row',\n                width: '100%',\n                justifyContent: 'space-between',\n              }}\n            >\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_url\"\n                  value=\"<b>VIDEO URL</b>\"\n                  icon={ICONS.VIDEO_SOURCE}\n                  onClick={() => setSelected('video-url')}\n                  scaleFactor={scaleFactor}\n                  selected={selected === 'video-url'}\n                  active={selectedVideo && isVideoUrl(selectedVideo.src)}\n                />\n              </UiEntity>\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_dcl_cast\"\n                  value=\"<b>DCL CAST</b>\"\n                  icon={ICONS.DCL_CAST_SOURCE}\n                  onClick={() => setSelected('dcl-cast')}\n                  scaleFactor={scaleFactor}\n                  selected={selected === 'dcl-cast'}\n                  active={selectedVideo && isDclCast(selectedVideo.src)}\n                />\n              </UiEntity>\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_live\"\n                  value=\"<b>STREAM</b>\"\n                  icon={ICONS.LIVE_SOURCE}\n                  onClick={() => setSelected('live')}\n                  active={selectedVideo && isLiveStream(selectedVideo.src)}\n                  scaleFactor={scaleFactor}\n                  selected={selected === 'live'}\n                />\n              </UiEntity>\n            </UiEntity>\n          </UiEntity>\n        </UiEntity>\n      </Card>\n      {selected && selectedEntity && (\n        <Card scaleFactor={scaleFactor}>\n          {selected === 'video-url' && (\n            <VideoControlURL\n              engine={engine}\n              scaleFactor={scaleFactor}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n          {selected === 'live' && (\n            <LiveStream\n              engine={engine}\n              scaleFactor={scaleFactor}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n          {selected === 'dcl-cast' && (\n            <DclCast\n              engine={engine}\n              state={state}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n        </Card>\n      )}\n    </UiEntity>\n  );\n}\n\ninterface Props {\n  id: string;\n  value: string;\n  onClick(): void;\n  selected: boolean;\n  scaleFactor: number;\n  icon: string;\n  engine: IEngine;\n  active?: boolean;\n}\n\nfunction CustomButton({ active, scaleFactor, value, id, onClick, icon, selected, engine }: Props) {\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column', height: '100%', width: '100%' }}>\n      <UiEntity uiTransform={{ width: '100%' }}>\n        <Button\n          id={id}\n          onMouseDown={onClick}\n          value={value}\n          fontSize={14 * scaleFactor}\n          icon={icon}\n          iconTransform={{\n            width: 24 * scaleFactor,\n            height: 24 * scaleFactor,\n            margin: { right: 8 * scaleFactor },\n          }}\n          color={selected ? Color4.Black() : Color4.fromHexString('#FCFCFC')}\n          iconBackground={{\n            color: selected ? Color4.Black() : Color4.fromHexString('#FCFCFC'),\n          }}\n          uiBackground={{\n            color: selected ? Color4.White() : Color4.fromHexString('#43404A'),\n          }}\n          uiTransform={{\n            padding: {\n              top: 6 * scaleFactor,\n              bottom: 6 * scaleFactor,\n            },\n            borderRadius: 6 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            width: '100%',\n            height: 36 * scaleFactor,\n          }}\n        />\n      </UiEntity>\n\n      {active && (\n        <Active\n          scaleFactor={scaleFactor}\n          engine={engine}\n          uiTransform={{ width: '100%', margin: { top: 6 * scaleFactor } }}\n        />\n      )}\n    </UiEntity>\n  );\n}\n"]}
121
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/admin-toolkit-ui/VideoControl/index.tsx"],"names":[],"mappings":"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","sourcesContent":["import { IEngine } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity, Dropdown } from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { getScaleUIFactor } from '../../ui';\nimport { Button } from '../Button';\nimport { CONTENT_URL } from '../constants';\nimport { State } from '../types';\nimport type { AdminTools } from '../../definitions';\nimport { Header } from '../Header';\nimport {\n  getVideoPlayers,\n  isDclCast,\n  isLiveStream,\n  isVideoUrl,\n  useSelectedVideoPlayer,\n} from './utils';\nimport { Card } from '../Card';\nimport { VideoControlURL } from './VideoUrl';\nimport { LiveStream } from './LiveStream';\nimport { Active } from '../Active';\nimport DclCast from './DclCast';\n\n// Constants\nexport const ICONS = {\n  VIDEO_CONTROL: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control.png`,\n  PREVIOUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-previous-button.png`,\n  FORWARD_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-forward-button.png`,\n  PLAY_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-play-button.png`,\n  MUTE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-mute.png`,\n  LOOP: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-loop.png`,\n  VOLUME_MINUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-volume-minus-button.png`,\n  VOLUME_PLUS_BUTTON: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-volume-plus-button.png`,\n  VIDEO_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-video-icon.png`,\n  LIVE_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-live.png`,\n  DCL_CAST_SOURCE: `${CONTENT_URL}/admin_toolkit/assets/icons/video-control-dcl-cast.png`,\n  INFO: `${CONTENT_URL}/admin_toolkit/assets/icons/info.png`,\n} as const;\n\nexport const VOLUME_STEP = 0.1;\nexport const DEFAULT_VOLUME = 1;\n\nexport const COLORS = {\n  WHITE: Color4.White(),\n  GRAY: Color4.create(160 / 255, 155 / 255, 168 / 255, 1),\n  SUCCESS: Color4.fromHexString('#34CE77'),\n} as const;\n\n// Main component\nexport function VideoControl({ engine, state }: { engine: IEngine; state: State }) {\n  const [selectedEntity, selectedVideo] = useSelectedVideoPlayer(engine) ?? [];\n  const scaleFactor = getScaleUIFactor(engine);\n  const videoPlayers = getVideoPlayers(engine);\n  const [selected, setSelected] = ReactEcs.useState<'video-url' | 'live' | 'dcl-cast' | undefined>(\n    undefined,\n  );\n\n  ReactEcs.useEffect(() => {\n    setSelected(\n      selectedVideo && isDclCast(selectedVideo.src)\n        ? 'dcl-cast'\n        : selectedVideo && isVideoUrl(selectedVideo.src)\n          ? 'video-url'\n          : 'live',\n    );\n  }, [state.videoControl.selectedVideoPlayer]);\n\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column', width: '100%', height: '100%' }}>\n      <Card\n        scaleFactor={scaleFactor}\n        uiTransform={{\n          padding: {\n            top: 32 * scaleFactor,\n            right: 32 * scaleFactor,\n            bottom: 0,\n            left: 32 * scaleFactor,\n          },\n        }}\n      >\n        <UiEntity\n          uiTransform={{\n            width: '100%',\n            height: '100%',\n            flexDirection: 'column',\n          }}\n        >\n          {/* Header */}\n          <Header\n            iconSrc={ICONS.VIDEO_CONTROL}\n            title=\"<b>VIDEO SCREENS</b>\"\n            scaleFactor={scaleFactor}\n          />\n          {videoPlayers.length > 1 && (\n            <Label\n              value=\"<b>Current Screen</b>\"\n              fontSize={16 * scaleFactor}\n              color={Color4.White()}\n              uiTransform={{ margin: { bottom: 16 * scaleFactor } }}\n            />\n          )}\n\n          <UiEntity\n            uiTransform={{\n              flexDirection: 'column',\n              margin: { bottom: 16 * scaleFactor },\n            }}\n          >\n            {videoPlayers.length > 1 && (\n              <UiEntity uiTransform={{ flexDirection: 'column' }}>\n                <Dropdown\n                  options={videoPlayers.map(\n                    (player: NonNullable<AdminTools['videoControl']['videoPlayers']>[0]) =>\n                      `<b>${player.customName}</b>`,\n                  )}\n                  selectedIndex={state.videoControl.selectedVideoPlayer ?? 0}\n                  onChange={idx => (state.videoControl.selectedVideoPlayer = idx)}\n                  textAlign=\"middle-left\"\n                  fontSize={16 * scaleFactor}\n                  uiTransform={{\n                    margin: { right: 8 * scaleFactor },\n                    width: '100%',\n                  }}\n                  uiBackground={{ color: Color4.White() }}\n                />\n              </UiEntity>\n            )}\n            <Label\n              fontSize={16 * scaleFactor}\n              value=\"<b>Media Source</b>\"\n              color={Color4.White()}\n              uiTransform={{\n                margin: { bottom: 2 * scaleFactor, top: 16 * scaleFactor },\n              }}\n            />\n            <UiEntity\n              uiTransform={{\n                margin: { top: 10 * scaleFactor },\n                flexDirection: 'row',\n                width: '100%',\n                justifyContent: 'space-between',\n              }}\n            >\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_url\"\n                  value=\"<b>VIDEO URL</b>\"\n                  icon={ICONS.VIDEO_SOURCE}\n                  onClick={() => setSelected('video-url')}\n                  scaleFactor={scaleFactor}\n                  selected={selected === 'video-url'}\n                  active={selectedVideo && isVideoUrl(selectedVideo.src)}\n                />\n              </UiEntity>\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_dcl_cast\"\n                  value=\"<b>DCL CAST</b>\"\n                  icon={ICONS.DCL_CAST_SOURCE}\n                  onClick={() => setSelected('dcl-cast')}\n                  scaleFactor={scaleFactor}\n                  selected={selected === 'dcl-cast'}\n                  active={selectedVideo && isDclCast(selectedVideo.src)}\n                />\n              </UiEntity>\n              <UiEntity\n                uiTransform={{\n                  width: '30%',\n                }}\n              >\n                <CustomButton\n                  engine={engine}\n                  id=\"video_control_live\"\n                  value=\"<b>STREAM</b>\"\n                  icon={ICONS.LIVE_SOURCE}\n                  onClick={() => setSelected('live')}\n                  active={selectedVideo && isLiveStream(selectedVideo.src)}\n                  scaleFactor={scaleFactor}\n                  selected={selected === 'live'}\n                />\n              </UiEntity>\n            </UiEntity>\n          </UiEntity>\n        </UiEntity>\n      </Card>\n      {selected && selectedEntity && (\n        <Card scaleFactor={scaleFactor}>\n          {selected === 'video-url' && (\n            <VideoControlURL\n              engine={engine}\n              scaleFactor={scaleFactor}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n          {selected === 'live' && (\n            <LiveStream\n              engine={engine}\n              scaleFactor={scaleFactor}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n          {selected === 'dcl-cast' && (\n            <DclCast\n              engine={engine}\n              state={state}\n              entity={selectedEntity}\n              video={selectedVideo}\n            />\n          )}\n        </Card>\n      )}\n    </UiEntity>\n  );\n}\n\ninterface Props {\n  id: string;\n  value: string;\n  onClick(): void;\n  selected: boolean;\n  scaleFactor: number;\n  icon: string;\n  engine: IEngine;\n  active?: boolean;\n}\n\nfunction CustomButton({ active, scaleFactor, value, id, onClick, icon, selected, engine }: Props) {\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column', height: '100%', width: '100%' }}>\n      <UiEntity uiTransform={{ width: '100%' }}>\n        <Button\n          id={id}\n          onMouseDown={onClick}\n          value={value}\n          fontSize={14 * scaleFactor}\n          icon={icon}\n          iconTransform={{\n            width: 24 * scaleFactor,\n            height: 24 * scaleFactor,\n            margin: { right: 8 * scaleFactor },\n          }}\n          color={selected ? Color4.Black() : Color4.fromHexString('#FCFCFC')}\n          iconBackground={{\n            color: selected ? Color4.Black() : Color4.fromHexString('#FCFCFC'),\n          }}\n          uiBackground={{\n            color: selected ? Color4.White() : Color4.fromHexString('#43404A'),\n          }}\n          uiTransform={{\n            padding: {\n              top: 6 * scaleFactor,\n              bottom: 6 * scaleFactor,\n            },\n            borderRadius: 6 * scaleFactor,\n            alignItems: 'center',\n            justifyContent: 'center',\n            width: '100%',\n            height: 36 * scaleFactor,\n          }}\n        />\n      </UiEntity>\n\n      {active && (\n        <Active\n          scaleFactor={scaleFactor}\n          engine={engine}\n          uiTransform={{ width: '100%', margin: { top: 6 * scaleFactor } }}\n        />\n      )}\n    </UiEntity>\n  );\n}\n"]}
@@ -1,4 +1,5 @@
1
1
  import { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';
2
+ import { AdminTools } from '../../definitions';
2
3
  interface VideoPlayerControls {
3
4
  play(): void;
4
5
  pause(): void;
@@ -17,10 +18,7 @@ export declare function getAdminToolkitVideoControl(engine: IEngine): DeepReadon
17
18
  customName: import("@dcl/ecs").ISchema<string>;
18
19
  }>[] | undefined>;
19
20
  }>> | null;
20
- export declare function getVideoPlayers(engine: IEngine): DeepReadonlyObject<import("@dcl/ecs").MapResult<{
21
- entity: import("@dcl/ecs").ISchema<number>;
22
- customName: import("@dcl/ecs").ISchema<string>;
23
- }>>[];
21
+ export declare function getVideoPlayers(engine: IEngine): NonNullable<AdminTools['videoControl']['videoPlayers']>;
24
22
  export declare function createVideoPlayerControls(entity: Entity, engine: IEngine): VideoPlayerControls;
25
23
  export declare function useSelectedVideoPlayer(engine: IEngine): [Entity, DeepReadonlyObject<PBVideoPlayer>] | null;
26
24
  export declare function isDclCast(url: string): boolean;
@@ -83,9 +83,12 @@ export function useSelectedVideoPlayer(engine) {
83
83
  const videoPlayers = getVideoPlayers(engine);
84
84
  if (videoPlayers.length === 0)
85
85
  return null;
86
- const entity = videoPlayers[state.videoControl.selectedVideoPlayer ?? 0].entity;
86
+ const selectedVideoPlayer = videoPlayers[state.videoControl.selectedVideoPlayer ?? 0];
87
+ if (!selectedVideoPlayer)
88
+ return null;
89
+ const entity = selectedVideoPlayer.entity;
87
90
  const videoPlayer = VideoPlayer.getOrNull(entity);
88
- return [entity, videoPlayer];
91
+ return videoPlayer ? [entity, videoPlayer] : null;
89
92
  }
90
93
  export function isDclCast(url) {
91
94
  return url.startsWith(LIVEKIT_STREAM_SRC) && state.videoControl.selectedStream === 'dcl-cast';
@@ -96,4 +99,4 @@ export function isLiveStream(url) {
96
99
  export function isVideoUrl(url) {
97
100
  return url.startsWith(VIDEO_URL_TYPE);
98
101
  }
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/admin-toolkit-ui/VideoControl/utils.tsx"],"names":[],"mappings":"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","sourcesContent":["import { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport { getComponents, LIVEKIT_STREAM_SRC, VIDEO_URL_TYPE } from '../../definitions';\nimport { getExplorerComponents } from '../../components';\nimport { nextTickFunctions, state } from '../index';\nimport { DEFAULT_VOLUME } from '.';\n\n// Types\ninterface VideoPlayerControls {\n  play(): void;\n  pause(): void;\n  restart(): void;\n  setVolume(volume: number): void;\n  setSource(url: string): void;\n  setLoop(loop: boolean): void;\n}\n\nexport function getAdminToolkitVideoControl(engine: IEngine) {\n  const { AdminTools } = getComponents(engine);\n  const adminToolkitEntities = Array.from(engine.getEntitiesWith(AdminTools));\n  return adminToolkitEntities.length > 0 ? adminToolkitEntities[0][1].videoControl : null;\n}\n\nexport function getVideoPlayers(engine: IEngine) {\n  const adminToolkitVideoControl = getAdminToolkitVideoControl(engine);\n\n  if (\n    !adminToolkitVideoControl ||\n    !adminToolkitVideoControl.videoPlayers ||\n    adminToolkitVideoControl.videoPlayers.length === 0\n  )\n    return [];\n\n  return Array.from(adminToolkitVideoControl.videoPlayers);\n}\n\nfunction checkVideoPlayerSound(entity: Entity, engine: IEngine) {\n  const videoControl = getAdminToolkitVideoControl(engine);\n  const { VideoPlayer } = getExplorerComponents(engine);\n\n  if (videoControl?.disableVideoPlayersSound) {\n    const video = VideoPlayer.get(entity);\n    if (video.volume) {\n      VideoPlayer.getMutable(entity).volume = 0;\n    }\n  }\n}\n\nexport function createVideoPlayerControls(entity: Entity, engine: IEngine): VideoPlayerControls {\n  const videoControl = getAdminToolkitVideoControl(engine);\n  const { VideoPlayer } = getExplorerComponents(engine);\n\n  checkVideoPlayerSound(entity, engine);\n\n  return {\n    play: () => {\n      const video = VideoPlayer.getMutable(entity);\n      video.playing = true;\n      video.position = undefined;\n    },\n    pause: () => {\n      const video = VideoPlayer.getMutable(entity);\n      video.playing = false;\n      video.position = undefined;\n    },\n    restart: () => {\n      const video = VideoPlayer.getMutable(entity);\n      video.playing = false;\n      video.position = 0;\n      nextTickFunctions.push(() => {\n        const video = VideoPlayer.getMutable(entity);\n        video.position = undefined;\n        video.playing = true;\n      });\n    },\n    setVolume: volumeOrStep => {\n      // Don't allow volume changes if sound is disabled\n      if (videoControl?.disableVideoPlayersSound) {\n        return;\n      }\n      const video = VideoPlayer.getMutable(entity);\n      video.position = undefined;\n      if (volumeOrStep === 0) {\n        video.volume = 0;\n      } else {\n        const steps = Math.round((video.volume ?? DEFAULT_VOLUME) * 10);\n        const newSteps = Math.max(0, Math.min(10, steps + (volumeOrStep as number) * 10));\n        video.volume = newSteps / 10;\n      }\n    },\n    setSource: url => {\n      VideoPlayer.getMutable(entity).src = url;\n      nextTickFunctions.push(() => {\n        VideoPlayer.getMutable(entity).playing = true;\n      });\n    },\n    setLoop(loop) {\n      const video = VideoPlayer.getMutable(entity);\n      video.loop = loop;\n      video.position = undefined;\n    },\n  };\n}\n\nexport function useSelectedVideoPlayer(\n  engine: IEngine,\n): [Entity, DeepReadonlyObject<PBVideoPlayer>] | null {\n  const { VideoPlayer } = getExplorerComponents(engine);\n  const videoPlayers = getVideoPlayers(engine);\n\n  if (videoPlayers.length === 0) return null;\n\n  const entity = videoPlayers[state.videoControl.selectedVideoPlayer ?? 0].entity as Entity;\n  const videoPlayer = VideoPlayer.getOrNull(entity);\n  return [entity, videoPlayer!];\n}\n\nexport function isDclCast(url: string) {\n  return url.startsWith(LIVEKIT_STREAM_SRC) && state.videoControl.selectedStream === 'dcl-cast';\n}\n\nexport function isLiveStream(url: string): boolean {\n  return url.startsWith(LIVEKIT_STREAM_SRC) && state.videoControl.selectedStream === 'live';\n}\n\nexport function isVideoUrl(url: string): boolean {\n  return url.startsWith(VIDEO_URL_TYPE);\n}\n"]}
102
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../src/admin-toolkit-ui/VideoControl/utils.tsx"],"names":[],"mappings":"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","sourcesContent":["import { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport { getComponents, LIVEKIT_STREAM_SRC, VIDEO_URL_TYPE, AdminTools } from '../../definitions';\nimport { getExplorerComponents } from '../../components';\nimport { nextTickFunctions, state } from '../index';\nimport { DEFAULT_VOLUME } from '.';\n\n// Types\ninterface VideoPlayerControls {\n  play(): void;\n  pause(): void;\n  restart(): void;\n  setVolume(volume: number): void;\n  setSource(url: string): void;\n  setLoop(loop: boolean): void;\n}\n\nexport function getAdminToolkitVideoControl(engine: IEngine) {\n  const { AdminTools } = getComponents(engine);\n  const adminToolkitEntities = Array.from(engine.getEntitiesWith(AdminTools));\n  return adminToolkitEntities.length > 0 ? adminToolkitEntities[0][1].videoControl : null;\n}\n\nexport function getVideoPlayers(\n  engine: IEngine,\n): NonNullable<AdminTools['videoControl']['videoPlayers']> {\n  const adminToolkitVideoControl = getAdminToolkitVideoControl(engine);\n\n  if (\n    !adminToolkitVideoControl ||\n    !adminToolkitVideoControl.videoPlayers ||\n    adminToolkitVideoControl.videoPlayers.length === 0\n  )\n    return [];\n\n  return Array.from(adminToolkitVideoControl.videoPlayers);\n}\n\nfunction checkVideoPlayerSound(entity: Entity, engine: IEngine) {\n  const videoControl = getAdminToolkitVideoControl(engine);\n  const { VideoPlayer } = getExplorerComponents(engine);\n\n  if (videoControl?.disableVideoPlayersSound) {\n    const video = VideoPlayer.get(entity);\n    if (video.volume) {\n      VideoPlayer.getMutable(entity).volume = 0;\n    }\n  }\n}\n\nexport function createVideoPlayerControls(entity: Entity, engine: IEngine): VideoPlayerControls {\n  const videoControl = getAdminToolkitVideoControl(engine);\n  const { VideoPlayer } = getExplorerComponents(engine);\n\n  checkVideoPlayerSound(entity, engine);\n\n  return {\n    play: () => {\n      const video = VideoPlayer.getMutable(entity);\n      video.playing = true;\n      video.position = undefined;\n    },\n    pause: () => {\n      const video = VideoPlayer.getMutable(entity);\n      video.playing = false;\n      video.position = undefined;\n    },\n    restart: () => {\n      const video = VideoPlayer.getMutable(entity);\n      video.playing = false;\n      video.position = 0;\n      nextTickFunctions.push(() => {\n        const video = VideoPlayer.getMutable(entity);\n        video.position = undefined;\n        video.playing = true;\n      });\n    },\n    setVolume: volumeOrStep => {\n      // Don't allow volume changes if sound is disabled\n      if (videoControl?.disableVideoPlayersSound) {\n        return;\n      }\n      const video = VideoPlayer.getMutable(entity);\n      video.position = undefined;\n      if (volumeOrStep === 0) {\n        video.volume = 0;\n      } else {\n        const steps = Math.round((video.volume ?? DEFAULT_VOLUME) * 10);\n        const newSteps = Math.max(0, Math.min(10, steps + (volumeOrStep as number) * 10));\n        video.volume = newSteps / 10;\n      }\n    },\n    setSource: url => {\n      VideoPlayer.getMutable(entity).src = url;\n      nextTickFunctions.push(() => {\n        VideoPlayer.getMutable(entity).playing = true;\n      });\n    },\n    setLoop(loop) {\n      const video = VideoPlayer.getMutable(entity);\n      video.loop = loop;\n      video.position = undefined;\n    },\n  };\n}\n\nexport function useSelectedVideoPlayer(\n  engine: IEngine,\n): [Entity, DeepReadonlyObject<PBVideoPlayer>] | null {\n  const { VideoPlayer } = getExplorerComponents(engine);\n  const videoPlayers = getVideoPlayers(engine);\n\n  if (videoPlayers.length === 0) return null;\n\n  const selectedVideoPlayer = videoPlayers[state.videoControl.selectedVideoPlayer ?? 0];\n  if (!selectedVideoPlayer) return null;\n\n  const entity = selectedVideoPlayer.entity as Entity;\n  const videoPlayer = VideoPlayer.getOrNull(entity);\n  return videoPlayer ? [entity, videoPlayer] : null;\n}\n\nexport function isDclCast(url: string) {\n  return url.startsWith(LIVEKIT_STREAM_SRC) && state.videoControl.selectedStream === 'dcl-cast';\n}\n\nexport function isLiveStream(url: string): boolean {\n  return url.startsWith(LIVEKIT_STREAM_SRC) && state.videoControl.selectedStream === 'live';\n}\n\nexport function isVideoUrl(url: string): boolean {\n  return url.startsWith(VIDEO_URL_TYPE);\n}\n"]}