@dcl/asset-packs 2.8.1 → 2.9.1
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/bin/index.js +13767 -14696
- package/dist/actions.js +2 -2
- package/dist/admin-toolkit-ui/Button.d.ts +2 -3
- package/dist/admin-toolkit-ui/Button.js +7 -2
- package/dist/admin-toolkit-ui/FeedbackButton.d.ts +8 -0
- package/dist/admin-toolkit-ui/FeedbackButton.js +49 -0
- package/dist/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.js +6 -27
- package/dist/admin-toolkit-ui/VideoControl/DclCast/styles.js +12 -1
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.d.ts +1 -1
- package/dist/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.js +6 -5
- package/dist/bin/index.js +13767 -14696
- package/dist/helpers.d.ts +7 -0
- package/dist/helpers.js +48 -0
- package/dist/triggers.js +9 -13
- package/package.json +5 -6
|
@@ -50,10 +50,15 @@ const HOVER_STATE = {
|
|
|
50
50
|
};
|
|
51
51
|
export const Button = (props) => {
|
|
52
52
|
const { id, value, onMouseDown, icon, onlyIcon, iconTransform, iconBackground, iconRight, iconRightTransform, fontSize = 14, color = Color4.Black(), disabled, uiBackground, uiTransform, labelTransform, iconRightBackground, variant = 'primary', } = props;
|
|
53
|
+
const buttonId = `button_${id}`;
|
|
53
54
|
ReactEcs.useEffect(() => {
|
|
54
55
|
buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE);
|
|
55
56
|
}, [disabled]);
|
|
56
|
-
|
|
57
|
+
ReactEcs.useEffect(() => {
|
|
58
|
+
return () => {
|
|
59
|
+
buttonStates.delete(buttonId);
|
|
60
|
+
};
|
|
61
|
+
}, []);
|
|
57
62
|
if (!buttonStates.has(buttonId)) {
|
|
58
63
|
buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE);
|
|
59
64
|
}
|
|
@@ -94,4 +99,4 @@ export const Button = (props) => {
|
|
|
94
99
|
...iconRightBackground,
|
|
95
100
|
} }))));
|
|
96
101
|
};
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Button.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/Button.tsx"],"names":[],"mappings":"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","sourcesContent":["import ReactEcs, {\n  UiEntity,\n  Label,\n  UiButtonProps,\n  UiTransformProps,\n  UiBackgroundProps,\n} from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { scaleFactor } from '.';\n\nexport const BTN_BACKGROUND_COLOR = {\n  primary: {\n    active: Color4.create(252 / 255, 252 / 255, 252 / 255, 1),\n    hover: Color4.create(207 / 255, 205 / 255, 212 / 255, 1),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 1),\n  },\n  secondary: {\n    active: Color4.create(252 / 255, 252 / 255, 252 / 255, 0),\n    hover: Color4.create(207 / 255, 205 / 255, 212 / 255, 0),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 0),\n  },\n  text: {\n    active: Color4.create(0, 0, 0, 0),\n    hover: Color4.create(24 / 255, 24 / 255, 24 / 255, 1),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 1),\n  },\n};\n\nexport const BTN_BORDER_COLOR = {\n  primary: {\n    active: Color4.Clear(),\n    hover: Color4.Clear(),\n    disabled: Color4.Clear(),\n  },\n  secondary: {\n    active: Color4.White(),\n    hover: Color4.White(),\n    disabled: Color4.fromHexString('#323232'),\n  },\n  text: {\n    active: Color4.Clear(),\n    hover: Color4.Clear(),\n    disabled: Color4.Clear(),\n  },\n};\n\ntype ButtonVariant = 'primary' | 'secondary' | 'text';\n\ninterface ButtonStateProps {\n  getColor: (variant: ButtonVariant) => Color4;\n  borderColor: (variant: ButtonVariant) => Color4;\n}\n\n// Store button states and visual properties in a Map\nconst buttonStates = new Map<string, ButtonStateProps>();\n\n// Pre-compute the visual states\nconst ACTIVE_STATE: ButtonStateProps = {\n  getColor: variant => BTN_BACKGROUND_COLOR[variant].active,\n  borderColor: variant => BTN_BORDER_COLOR[variant].active,\n};\n\nconst DISABLED_STATE: ButtonStateProps = {\n  getColor: variant => BTN_BACKGROUND_COLOR[variant].disabled,\n  borderColor: variant => BTN_BORDER_COLOR[variant].disabled,\n};\n\nconst HOVER_STATE: ButtonStateProps = {\n  getColor: variant => BTN_BACKGROUND_COLOR[variant].hover,\n  borderColor: variant => BTN_BORDER_COLOR[variant].hover,\n};\n\ninterface CompositeButtonProps extends Omit<UiButtonProps, 'value' | 'variant'> {\n  id: string;\n  value?: string;\n  icon?: string;\n  iconRight?: string;\n  iconRightTransform?: UiTransformProps;\n  onlyIcon?: boolean;\n  iconTransform?: UiTransformProps;\n  iconBackground?: UiBackgroundProps;\n  iconRightBackground?: UiBackgroundProps;\n  variant?: ButtonVariant;\n  labelTransform?: UiTransformProps;\n}\n\nexport const Button = (props: CompositeButtonProps) => {\n  const {\n    id,\n    value,\n    onMouseDown,\n    icon,\n    onlyIcon,\n    iconTransform,\n    iconBackground,\n    iconRight,\n    iconRightTransform,\n    fontSize = 14,\n    color = Color4.Black(),\n    disabled,\n    uiBackground,\n    uiTransform,\n    labelTransform,\n    iconRightBackground,\n    variant = 'primary',\n  } = props;\n\n  ReactEcs.useEffect(() => {\n    buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE);\n  }, [disabled]);\n\n  const buttonId = `button_${id}`;\n\n  // Get or set initial state\n  if (!buttonStates.has(buttonId)) {\n    buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE);\n  }\n\n  const buttonState = buttonStates.get(buttonId)!;\n\n  return (\n    <UiEntity\n      uiTransform={{\n        borderColor: buttonState.borderColor(variant),\n        borderWidth: 2 * scaleFactor,\n        borderRadius: 12 * scaleFactor,\n        ...uiTransform,\n      }}\n      uiBackground={{\n        color: buttonState.getColor(variant),\n        ...uiBackground,\n      }}\n      onMouseDown={() => {\n        if (disabled) {\n          return;\n        }\n        onMouseDown?.();\n      }}\n      onMouseEnter={() => {\n        if (!disabled) {\n          buttonStates.set(buttonId, HOVER_STATE);\n        }\n      }}\n      onMouseLeave={() => {\n        buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE);\n      }}\n    >\n      {icon && (\n        <UiEntity\n          uiTransform={iconTransform}\n          uiBackground={{\n            texture: {\n              src: icon,\n            },\n            textureMode: 'stretch',\n            ...iconBackground,\n          }}\n        />\n      )}\n      {!onlyIcon && !!value ? (\n        <Label\n          value={value}\n          color={color}\n          fontSize={fontSize}\n          uiTransform={labelTransform}\n        />\n      ) : null}\n      {iconRight && (\n        <UiEntity\n          uiTransform={iconRightTransform}\n          uiBackground={{\n            texture: {\n              src: iconRight,\n            },\n            textureMode: 'stretch',\n            ...iconRightBackground,\n          }}\n        />\n      )}\n    </UiEntity>\n  );\n};\n"]}
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Button.js","sourceRoot":"","sources":["../../src/admin-toolkit-ui/Button.tsx"],"names":[],"mappings":"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","sourcesContent":["import ReactEcs, {\n  UiEntity,\n  Label,\n  UiButtonProps,\n  UiTransformProps,\n  UiBackgroundProps,\n} from '@dcl/react-ecs';\nimport { Color4 } from '@dcl/sdk/math';\nimport { scaleFactor } from '.';\n\nexport const BTN_BACKGROUND_COLOR = {\n  primary: {\n    active: Color4.create(252 / 255, 252 / 255, 252 / 255, 1),\n    hover: Color4.create(207 / 255, 205 / 255, 212 / 255, 1),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 1),\n  },\n  secondary: {\n    active: Color4.create(252 / 255, 252 / 255, 252 / 255, 0),\n    hover: Color4.create(207 / 255, 205 / 255, 212 / 255, 0),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 0),\n  },\n  text: {\n    active: Color4.create(0, 0, 0, 0),\n    hover: Color4.create(24 / 255, 24 / 255, 24 / 255, 1),\n    disabled: Color4.create(74 / 255, 74 / 255, 74 / 255, 1),\n  },\n};\n\nexport const BTN_BORDER_COLOR = {\n  primary: {\n    active: Color4.Clear(),\n    hover: Color4.Clear(),\n    disabled: Color4.Clear(),\n  },\n  secondary: {\n    active: Color4.White(),\n    hover: Color4.White(),\n    disabled: Color4.fromHexString('#323232'),\n  },\n  text: {\n    active: Color4.Clear(),\n    hover: Color4.Clear(),\n    disabled: Color4.Clear(),\n  },\n};\n\nexport type ButtonVariant = 'primary' | 'secondary' | 'text';\n\ninterface ButtonStateProps {\n  getColor: (variant: ButtonVariant) => Color4;\n  borderColor: (variant: ButtonVariant) => Color4;\n}\n\n// Store button states and visual properties in a Map\nconst buttonStates = new Map<string, ButtonStateProps>();\n\n// Pre-compute the visual states\nconst ACTIVE_STATE: ButtonStateProps = {\n  getColor: variant => BTN_BACKGROUND_COLOR[variant].active,\n  borderColor: variant => BTN_BORDER_COLOR[variant].active,\n};\n\nconst DISABLED_STATE: ButtonStateProps = {\n  getColor: variant => BTN_BACKGROUND_COLOR[variant].disabled,\n  borderColor: variant => BTN_BORDER_COLOR[variant].disabled,\n};\n\nconst HOVER_STATE: ButtonStateProps = {\n  getColor: variant => BTN_BACKGROUND_COLOR[variant].hover,\n  borderColor: variant => BTN_BORDER_COLOR[variant].hover,\n};\n\nexport interface CompositeButtonProps extends Omit<UiButtonProps, 'value' | 'variant'> {\n  id: string;\n  value?: string;\n  icon?: string;\n  iconRight?: string;\n  iconRightTransform?: UiTransformProps;\n  onlyIcon?: boolean;\n  iconTransform?: UiTransformProps;\n  iconBackground?: UiBackgroundProps;\n  iconRightBackground?: UiBackgroundProps;\n  variant?: ButtonVariant;\n  labelTransform?: UiTransformProps;\n}\n\nexport const Button = (props: CompositeButtonProps) => {\n  const {\n    id,\n    value,\n    onMouseDown,\n    icon,\n    onlyIcon,\n    iconTransform,\n    iconBackground,\n    iconRight,\n    iconRightTransform,\n    fontSize = 14,\n    color = Color4.Black(),\n    disabled,\n    uiBackground,\n    uiTransform,\n    labelTransform,\n    iconRightBackground,\n    variant = 'primary',\n  } = props;\n\n  const buttonId = `button_${id}`;\n\n  ReactEcs.useEffect(() => {\n    buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE);\n  }, [disabled]);\n\n  // Cleanup on unmount\n  ReactEcs.useEffect(() => {\n    return () => {\n      buttonStates.delete(buttonId);\n    };\n  }, []);\n\n  // Get or set initial state\n  if (!buttonStates.has(buttonId)) {\n    buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE);\n  }\n\n  const buttonState = buttonStates.get(buttonId)!;\n\n  return (\n    <UiEntity\n      uiTransform={{\n        borderColor: buttonState.borderColor(variant),\n        borderWidth: 2 * scaleFactor,\n        borderRadius: 12 * scaleFactor,\n        ...uiTransform,\n      }}\n      uiBackground={{\n        color: buttonState.getColor(variant),\n        ...uiBackground,\n      }}\n      onMouseDown={() => {\n        if (disabled) {\n          return;\n        }\n        onMouseDown?.();\n      }}\n      onMouseEnter={() => {\n        if (!disabled) {\n          buttonStates.set(buttonId, HOVER_STATE);\n        }\n      }}\n      onMouseLeave={() => {\n        buttonStates.set(buttonId, disabled ? DISABLED_STATE : ACTIVE_STATE);\n      }}\n    >\n      {icon && (\n        <UiEntity\n          uiTransform={iconTransform}\n          uiBackground={{\n            texture: {\n              src: icon,\n            },\n            textureMode: 'stretch',\n            ...iconBackground,\n          }}\n        />\n      )}\n      {!onlyIcon && !!value ? (\n        <Label\n          value={value}\n          color={color}\n          fontSize={fontSize}\n          uiTransform={labelTransform}\n        />\n      ) : null}\n      {iconRight && (\n        <UiEntity\n          uiTransform={iconRightTransform}\n          uiBackground={{\n            texture: {\n              src: iconRight,\n            },\n            textureMode: 'stretch',\n            ...iconRightBackground,\n          }}\n        />\n      )}\n    </UiEntity>\n  );\n};\n"]}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import ReactEcs from '@dcl/react-ecs';
|
|
2
|
+
import { type CompositeButtonProps } from './Button';
|
|
3
|
+
interface FeedbackButtonProps extends CompositeButtonProps {
|
|
4
|
+
feedbackLabel?: string;
|
|
5
|
+
feedbackDurationSeconds?: number;
|
|
6
|
+
}
|
|
7
|
+
export declare const FeedbackButton: (props: FeedbackButtonProps) => ReactEcs.JSX.Element;
|
|
8
|
+
export {};
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';
|
|
2
|
+
import { Color4 } from '@dcl/sdk/math';
|
|
3
|
+
import { startTimeout, stopTimeout } from '../timer';
|
|
4
|
+
import { Button } from './Button';
|
|
5
|
+
import { state } from '.';
|
|
6
|
+
const FEEDBACK_TIMEOUT_ACTION_PREFIX = 'feedback_button_';
|
|
7
|
+
const getUiBackgroundColor = (variant) => {
|
|
8
|
+
switch (variant) {
|
|
9
|
+
case 'primary':
|
|
10
|
+
return Color4.fromHexString('#FFFFFF');
|
|
11
|
+
default:
|
|
12
|
+
return Color4.fromHexString('#43404A');
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
const getLabelTextColor = (variant) => {
|
|
16
|
+
switch (variant) {
|
|
17
|
+
case 'primary':
|
|
18
|
+
return Color4.Black();
|
|
19
|
+
default:
|
|
20
|
+
return Color4.White();
|
|
21
|
+
}
|
|
22
|
+
};
|
|
23
|
+
export const FeedbackButton = (props) => {
|
|
24
|
+
const { id, feedbackLabel = '<b>Link Copied</b>', feedbackDurationSeconds = 2, onMouseDown, ...buttonProps } = props;
|
|
25
|
+
const [showFeedback, setShowFeedback] = ReactEcs.useState(false);
|
|
26
|
+
const timeoutAction = `${FEEDBACK_TIMEOUT_ACTION_PREFIX}${id}`;
|
|
27
|
+
const handleClick = () => {
|
|
28
|
+
stopTimeout(state.adminToolkitUiEntity, timeoutAction);
|
|
29
|
+
setShowFeedback(true);
|
|
30
|
+
startTimeout(state.adminToolkitUiEntity, timeoutAction, feedbackDurationSeconds, () => {
|
|
31
|
+
setShowFeedback(false);
|
|
32
|
+
});
|
|
33
|
+
if (onMouseDown)
|
|
34
|
+
onMouseDown();
|
|
35
|
+
};
|
|
36
|
+
ReactEcs.useEffect(() => {
|
|
37
|
+
return () => {
|
|
38
|
+
stopTimeout(state.adminToolkitUiEntity, timeoutAction);
|
|
39
|
+
};
|
|
40
|
+
}, []);
|
|
41
|
+
return (ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
42
|
+
flexDirection: 'row',
|
|
43
|
+
alignItems: 'center',
|
|
44
|
+
} },
|
|
45
|
+
showFeedback && (ReactEcs.createElement(UiEntity, { uiTransform: buttonProps.uiTransform, uiBackground: { color: getUiBackgroundColor(buttonProps.variant) } },
|
|
46
|
+
ReactEcs.createElement(Label, { value: feedbackLabel, color: getLabelTextColor(buttonProps.variant), fontSize: buttonProps.fontSize }))),
|
|
47
|
+
!showFeedback && (ReactEcs.createElement(Button, { id: id, onMouseDown: handleClick, ...buttonProps }))));
|
|
48
|
+
};
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRmVlZGJhY2tCdXR0b24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYWRtaW4tdG9vbGtpdC11aS9GZWVkYmFja0J1dHRvbi50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxRQUFRLEVBQUUsRUFBRSxRQUFRLEVBQUUsS0FBSyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDM0QsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUNyRCxPQUFPLEVBQUUsTUFBTSxFQUE0QyxNQUFNLFVBQVUsQ0FBQztBQUM1RSxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sR0FBRyxDQUFDO0FBRTFCLE1BQU0sOEJBQThCLEdBQUcsa0JBQWtCLENBQUM7QUFPMUQsTUFBTSxvQkFBb0IsR0FBRyxDQUFDLE9BQXVCLEVBQUUsRUFBRTtJQUN2RCxRQUFRLE9BQU8sRUFBRSxDQUFDO1FBQ2hCLEtBQUssU0FBUztZQUNaLE9BQU8sTUFBTSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUN6QztZQUNFLE9BQU8sTUFBTSxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsQ0FBQztJQUMzQyxDQUFDO0FBQ0gsQ0FBQyxDQUFDO0FBRUYsTUFBTSxpQkFBaUIsR0FBRyxDQUFDLE9BQXVCLEVBQUUsRUFBRTtJQUNwRCxRQUFRLE9BQU8sRUFBRSxDQUFDO1FBQ2hCLEtBQUssU0FBUztZQUNaLE9BQU8sTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3hCO1lBQ0UsT0FBTyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUM7SUFDMUIsQ0FBQztBQUNILENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxDQUFDLEtBQTBCLEVBQUUsRUFBRTtJQUMzRCxNQUFNLEVBQ0osRUFBRSxFQUNGLGFBQWEsR0FBRyxvQkFBb0IsRUFDcEMsdUJBQXVCLEdBQUcsQ0FBQyxFQUMzQixXQUFXLEVBQ1gsR0FBRyxXQUFXLEVBQ2YsR0FBRyxLQUFLLENBQUM7SUFFVixNQUFNLENBQUMsWUFBWSxFQUFFLGVBQWUsQ0FBQyxHQUFHLFFBQVEsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakUsTUFBTSxhQUFhLEdBQUcsR0FBRyw4QkFBOEIsR0FBRyxFQUFFLEVBQUUsQ0FBQztJQUUvRCxNQUFNLFdBQVcsR0FBRyxHQUFHLEVBQUU7UUFFdkIsV0FBVyxDQUFDLEtBQUssQ0FBQyxvQkFBb0IsRUFBRSxhQUFhLENBQUMsQ0FBQztRQUd2RCxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUM7UUFHdEIsWUFBWSxDQUFDLEtBQUssQ0FBQyxvQkFBb0IsRUFBRSxhQUFhLEVBQUUsdUJBQXVCLEVBQUUsR0FBRyxFQUFFO1lBQ3BGLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN6QixDQUFDLENBQUMsQ0FBQztRQUdILElBQUksV0FBVztZQUFFLFdBQVcsRUFBRSxDQUFDO0lBQ2pDLENBQUMsQ0FBQztJQUVGLFFBQVEsQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFO1FBQ3RCLE9BQU8sR0FBRyxFQUFFO1lBQ1YsV0FBVyxDQUFDLEtBQUssQ0FBQyxvQkFBb0IsRUFBRSxhQUFhLENBQUMsQ0FBQztRQUN6RCxDQUFDLENBQUM7SUFDSixDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUM7SUFFUCxPQUFPLENBQ0wsdUJBQUMsUUFBUSxJQUNQLFdBQVcsRUFBRTtZQUNYLGFBQWEsRUFBRSxLQUFLO1lBQ3BCLFVBQVUsRUFBRSxRQUFRO1NBQ3JCO1FBRUEsWUFBWSxJQUFJLENBQ2YsdUJBQUMsUUFBUSxJQUNQLFdBQVcsRUFBRSxXQUFXLENBQUMsV0FBVyxFQUNwQyxZQUFZLEVBQUUsRUFBRSxLQUFLLEVBQUUsb0JBQW9CLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBRWxFLHVCQUFDLEtBQUssSUFDSixLQUFLLEVBQUUsYUFBYSxFQUNwQixLQUFLLEVBQUUsaUJBQWlCLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxFQUM3QyxRQUFRLEVBQUUsV0FBVyxDQUFDLFFBQVEsR0FDOUIsQ0FDTyxDQUNaO1FBQ0EsQ0FBQyxZQUFZLElBQUksQ0FDaEIsdUJBQUMsTUFBTSxJQUNMLEVBQUUsRUFBRSxFQUFFLEVBQ04sV0FBVyxFQUFFLFdBQVcsS0FDcEIsV0FBVyxHQUNmLENBQ0gsQ0FDUSxDQUNaLENBQUM7QUFDSixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3RFY3MsIHsgVWlFbnRpdHksIExhYmVsIH0gZnJvbSAnQGRjbC9yZWFjdC1lY3MnO1xuaW1wb3J0IHsgQ29sb3I0IH0gZnJvbSAnQGRjbC9zZGsvbWF0aCc7XG5pbXBvcnQgeyBzdGFydFRpbWVvdXQsIHN0b3BUaW1lb3V0IH0gZnJvbSAnLi4vdGltZXInO1xuaW1wb3J0IHsgQnV0dG9uLCBCdXR0b25WYXJpYW50LCB0eXBlIENvbXBvc2l0ZUJ1dHRvblByb3BzIH0gZnJvbSAnLi9CdXR0b24nO1xuaW1wb3J0IHsgc3RhdGUgfSBmcm9tICcuJztcblxuY29uc3QgRkVFREJBQ0tfVElNRU9VVF9BQ1RJT05fUFJFRklYID0gJ2ZlZWRiYWNrX2J1dHRvbl8nO1xuXG5pbnRlcmZhY2UgRmVlZGJhY2tCdXR0b25Qcm9wcyBleHRlbmRzIENvbXBvc2l0ZUJ1dHRvblByb3BzIHtcbiAgZmVlZGJhY2tMYWJlbD86IHN0cmluZztcbiAgZmVlZGJhY2tEdXJhdGlvblNlY29uZHM/OiBudW1iZXI7XG59XG5cbmNvbnN0IGdldFVpQmFja2dyb3VuZENvbG9yID0gKHZhcmlhbnQ/OiBCdXR0b25WYXJpYW50KSA9PiB7XG4gIHN3aXRjaCAodmFyaWFudCkge1xuICAgIGNhc2UgJ3ByaW1hcnknOlxuICAgICAgcmV0dXJuIENvbG9yNC5mcm9tSGV4U3RyaW5nKCcjRkZGRkZGJyk7XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiBDb2xvcjQuZnJvbUhleFN0cmluZygnIzQzNDA0QScpO1xuICB9XG59O1xuXG5jb25zdCBnZXRMYWJlbFRleHRDb2xvciA9ICh2YXJpYW50PzogQnV0dG9uVmFyaWFudCkgPT4ge1xuICBzd2l0Y2ggKHZhcmlhbnQpIHtcbiAgICBjYXNlICdwcmltYXJ5JzpcbiAgICAgIHJldHVybiBDb2xvcjQuQmxhY2soKTtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIENvbG9yNC5XaGl0ZSgpO1xuICB9XG59O1xuXG5leHBvcnQgY29uc3QgRmVlZGJhY2tCdXR0b24gPSAocHJvcHM6IEZlZWRiYWNrQnV0dG9uUHJvcHMpID0+IHtcbiAgY29uc3Qge1xuICAgIGlkLFxuICAgIGZlZWRiYWNrTGFiZWwgPSAnPGI+TGluayBDb3BpZWQ8L2I+JyxcbiAgICBmZWVkYmFja0R1cmF0aW9uU2Vjb25kcyA9IDIsXG4gICAgb25Nb3VzZURvd24sXG4gICAgLi4uYnV0dG9uUHJvcHNcbiAgfSA9IHByb3BzO1xuXG4gIGNvbnN0IFtzaG93RmVlZGJhY2ssIHNldFNob3dGZWVkYmFja10gPSBSZWFjdEVjcy51c2VTdGF0ZShmYWxzZSk7XG4gIGNvbnN0IHRpbWVvdXRBY3Rpb24gPSBgJHtGRUVEQkFDS19USU1FT1VUX0FDVElPTl9QUkVGSVh9JHtpZH1gO1xuXG4gIGNvbnN0IGhhbmRsZUNsaWNrID0gKCkgPT4ge1xuICAgIC8vIFN0b3AgYW55IGV4aXN0aW5nIHRpbWVvdXRcbiAgICBzdG9wVGltZW91dChzdGF0ZS5hZG1pblRvb2xraXRVaUVudGl0eSwgdGltZW91dEFjdGlvbik7XG5cbiAgICAvLyBTaG93IGZlZWRiYWNrXG4gICAgc2V0U2hvd0ZlZWRiYWNrKHRydWUpO1xuXG4gICAgLy8gU3RhcnQgdGltZW91dCB0byBoaWRlIGZlZWRiYWNrXG4gICAgc3RhcnRUaW1lb3V0KHN0YXRlLmFkbWluVG9vbGtpdFVpRW50aXR5LCB0aW1lb3V0QWN0aW9uLCBmZWVkYmFja0R1cmF0aW9uU2Vjb25kcywgKCkgPT4ge1xuICAgICAgc2V0U2hvd0ZlZWRiYWNrKGZhbHNlKTtcbiAgICB9KTtcblxuICAgIC8vIENhbGwgb3JpZ2luYWwgb25Nb3VzZURvd24gaGFuZGxlclxuICAgIGlmIChvbk1vdXNlRG93bikgb25Nb3VzZURvd24oKTtcbiAgfTtcblxuICBSZWFjdEVjcy51c2VFZmZlY3QoKCkgPT4ge1xuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBzdG9wVGltZW91dChzdGF0ZS5hZG1pblRvb2xraXRVaUVudGl0eSwgdGltZW91dEFjdGlvbik7XG4gICAgfTtcbiAgfSwgW10pO1xuXG4gIHJldHVybiAoXG4gICAgPFVpRW50aXR5XG4gICAgICB1aVRyYW5zZm9ybT17e1xuICAgICAgICBmbGV4RGlyZWN0aW9uOiAncm93JyxcbiAgICAgICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgICB9fVxuICAgID5cbiAgICAgIHtzaG93RmVlZGJhY2sgJiYgKFxuICAgICAgICA8VWlFbnRpdHlcbiAgICAgICAgICB1aVRyYW5zZm9ybT17YnV0dG9uUHJvcHMudWlUcmFuc2Zvcm19XG4gICAgICAgICAgdWlCYWNrZ3JvdW5kPXt7IGNvbG9yOiBnZXRVaUJhY2tncm91bmRDb2xvcihidXR0b25Qcm9wcy52YXJpYW50KSB9fVxuICAgICAgICA+XG4gICAgICAgICAgPExhYmVsXG4gICAgICAgICAgICB2YWx1ZT17ZmVlZGJhY2tMYWJlbH1cbiAgICAgICAgICAgIGNvbG9yPXtnZXRMYWJlbFRleHRDb2xvcihidXR0b25Qcm9wcy52YXJpYW50KX1cbiAgICAgICAgICAgIGZvbnRTaXplPXtidXR0b25Qcm9wcy5mb250U2l6ZX1cbiAgICAgICAgICAvPlxuICAgICAgICA8L1VpRW50aXR5PlxuICAgICAgKX1cbiAgICAgIHshc2hvd0ZlZWRiYWNrICYmIChcbiAgICAgICAgPEJ1dHRvblxuICAgICAgICAgIGlkPXtpZH1cbiAgICAgICAgICBvbk1vdXNlRG93bj17aGFuZGxlQ2xpY2t9XG4gICAgICAgICAgey4uLmJ1dHRvblByb3BzfVxuICAgICAgICAvPlxuICAgICAgKX1cbiAgICA8L1VpRW50aXR5PlxuICApO1xufTtcbiJdfQ==
|
|
@@ -2,6 +2,7 @@ import ReactEcs, { Label, UiEntity } from '@dcl/react-ecs';
|
|
|
2
2
|
import { copyToClipboard } from '~system/RestrictedActions';
|
|
3
3
|
import { Color4 } from '@dcl/sdk/math';
|
|
4
4
|
import { Button } from '../../Button';
|
|
5
|
+
import { FeedbackButton } from '../../FeedbackButton';
|
|
5
6
|
import { VideoControlVolume } from '../VolumeControl';
|
|
6
7
|
import { createVideoPlayerControls, isDclCast } from '../utils';
|
|
7
8
|
import { LIVEKIT_STREAM_SRC } from '../LiveStream';
|
|
@@ -41,21 +42,12 @@ const DclCastInfo = ({ scaleFactor, state, engine, onResetRoomId, entity, video,
|
|
|
41
42
|
color: colors.gray,
|
|
42
43
|
textAlign: 'top-left',
|
|
43
44
|
} })),
|
|
44
|
-
ReactEcs.createElement(
|
|
45
|
+
ReactEcs.createElement(FeedbackButton, { id: "dcl_cast_copy_stream_link", value: "<b>Copy Link</b>", variant: "text", fontSize: 18 * scaleFactor, color: colors.white, iconRight: ICONS.COPY_TO_CLIPBOARD_ICON, iconRightTransform: styles.iconSmall, labelTransform: styles.marginRightSmall, uiTransform: styles.copyLinkButton, onMouseDown: () => {
|
|
45
46
|
state.videoControl.dclCast?.streamLink &&
|
|
46
47
|
copyToClipboard({
|
|
47
48
|
text: state.videoControl.dclCast.streamLink,
|
|
48
49
|
});
|
|
49
|
-
} },
|
|
50
|
-
ReactEcs.createElement(Label, { value: '<b>Copy Link</b>', fontSize: 18 * scaleFactor, color: colors.white, uiTransform: styles.marginRightSmall }),
|
|
51
|
-
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
52
|
-
...styles.iconSmall,
|
|
53
|
-
}, uiBackground: {
|
|
54
|
-
texture: {
|
|
55
|
-
src: ICONS.COPY_TO_CLIPBOARD_ICON,
|
|
56
|
-
},
|
|
57
|
-
...backgrounds.iconStretch,
|
|
58
|
-
} }))),
|
|
50
|
+
} })),
|
|
59
51
|
ReactEcs.createElement(UiEntity, { uiTransform: styles.separatorLine }),
|
|
60
52
|
ReactEcs.createElement(UiEntity, { uiTransform: styles.rowCenterSpaceBetween },
|
|
61
53
|
ReactEcs.createElement(UiEntity, { uiTransform: styles.textInfoContainer },
|
|
@@ -66,29 +58,16 @@ const DclCastInfo = ({ scaleFactor, state, engine, onResetRoomId, entity, video,
|
|
|
66
58
|
color: colors.gray,
|
|
67
59
|
textAlign: 'top-left',
|
|
68
60
|
} })),
|
|
69
|
-
ReactEcs.createElement(
|
|
70
|
-
display: 'flex',
|
|
71
|
-
flexDirection: 'row',
|
|
72
|
-
alignItems: 'center',
|
|
73
|
-
}, onMouseDown: () => {
|
|
61
|
+
ReactEcs.createElement(FeedbackButton, { id: "dcl_cast_copy_watcher_link", value: "<b>Copy Link</b>", variant: "text", fontSize: 18 * scaleFactor, color: colors.white, iconRight: ICONS.COPY_TO_CLIPBOARD_ICON, iconRightTransform: styles.iconSmall, labelTransform: styles.marginRightSmall, uiTransform: styles.copyLinkButton, onMouseDown: () => {
|
|
74
62
|
state.videoControl.dclCast?.watcherLink &&
|
|
75
63
|
copyToClipboard({
|
|
76
64
|
text: state.videoControl.dclCast.watcherLink,
|
|
77
65
|
});
|
|
78
|
-
} },
|
|
79
|
-
ReactEcs.createElement(Label, { value: '<b>Copy Link</b>', fontSize: 18 * scaleFactor, color: colors.white, uiTransform: styles.marginRightSmall }),
|
|
80
|
-
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
81
|
-
...styles.iconSmall,
|
|
82
|
-
}, uiBackground: {
|
|
83
|
-
texture: {
|
|
84
|
-
src: ICONS.COPY_TO_CLIPBOARD_ICON,
|
|
85
|
-
},
|
|
86
|
-
...backgrounds.iconStretch,
|
|
87
|
-
} }))))),
|
|
66
|
+
} })))),
|
|
88
67
|
ReactEcs.createElement(UiEntity, { uiTransform: styles.columnWithMarginTop },
|
|
89
68
|
ReactEcs.createElement(VideoControlVolume, { engine: engine, entity: entity, video: video, label: "<b>Cast volume</b>" }),
|
|
90
69
|
ReactEcs.createElement(UiEntity, null,
|
|
91
70
|
ReactEcs.createElement(Button, { id: "dcl_cast_reset_room_id", value: "<b>Reset Room</b>", variant: "text", fontSize: 16 * scaleFactor, color: colors.danger, uiTransform: styles.resetButton, onMouseDown: onResetRoomId })))));
|
|
92
71
|
};
|
|
93
72
|
export default DclCastInfo;
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DclCastInfo.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport { DeepReadonlyObject, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity } from '@dcl/react-ecs';\nimport { copyToClipboard } from '~system/RestrictedActions';\nimport { Color4 } from '@dcl/sdk/math';\nimport { Button } from '../../Button';\nimport { State } from '../../types';\nimport { VideoControlVolume } from '../VolumeControl';\nimport { createVideoPlayerControls, isDclCast } from '../utils';\nimport { LIVEKIT_STREAM_SRC } from '../LiveStream';\nimport { getDclCastStyles, getDclCastColors, getDclCastBackgrounds } from './styles';\nimport { CONTENT_URL } from '../../constants';\n\nconst ICONS = {\n  COPY_TO_CLIPBOARD_ICON: `${CONTENT_URL}/admin_toolkit/assets/icons/copy-to-clipboard.png`,\n};\n\nconst DclCastInfo = ({\n  scaleFactor,\n  state,\n  engine,\n  onResetRoomId,\n  entity,\n  video,\n}: {\n  scaleFactor: number;\n  state: State;\n  engine: IEngine;\n  onResetRoomId: () => Promise<void>;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n}) => {\n  const controls = createVideoPlayerControls(entity, engine);\n  const styles = getDclCastStyles(scaleFactor);\n  const colors = getDclCastColors();\n  const backgrounds = getDclCastBackgrounds();\n  return (\n    <UiEntity uiTransform={styles.fullContainer}>\n      <UiEntity uiTransform={styles.mainBorderedContainer}>\n        <UiEntity uiTransform={styles.headerRow}>\n          <UiEntity uiTransform={styles.columnFlexStart}>\n            <Label\n              value={'<b>Room ID</b>'}\n              fontSize={24 * scaleFactor}\n              color={Color4.White()}\n            />\n            <Label\n              value={`Expires in ${state.videoControl.dclCast?.expiresInDays} days`}\n              fontSize={14 * scaleFactor}\n              color={colors.gray}\n              uiTransform={styles.marginTopSmall}\n            />\n          </UiEntity>\n          {video?.src && isDclCast(video.src) ? (\n            <Button\n              id=\"dcl_cast_deactivate\"\n              value=\"<b>Deactivate</b>\"\n              variant=\"text\"\n              fontSize={16 * scaleFactor}\n              color={colors.white}\n              uiTransform={styles.activateButton}\n              onMouseDown={() => {\n                controls.setSource('');\n                state.videoControl.selectedStream = undefined;\n              }}\n            />\n          ) : (\n            <Button\n              id=\"dcl_cast_activate\"\n              value=\"<b>Activate</b>\"\n              labelTransform={styles.activateButtonLabel}\n              uiTransform={styles.activateButton}\n              fontSize={16 * scaleFactor}\n              uiBackground={backgrounds.success}\n              color={colors.black}\n              onMouseDown={() => {\n                controls.setSource(LIVEKIT_STREAM_SRC);\n                state.videoControl.selectedStream = 'dcl-cast';\n              }}\n            />\n          )}\n        </UiEntity>\n        <UiEntity uiTransform={styles.columnContainer}>\n          <UiEntity uiTransform={styles.rowCenterSpaceBetween}>\n            <UiEntity\n              uiTransform={{\n                display: 'flex',\n                flexDirection: 'column',\n              }}\n            >\n              <Label\n                value={'<b>Cast speakers</b>'}\n                fontSize={18 * scaleFactor}\n                color={colors.white}\n              />\n              <UiEntity\n                uiText={{\n                  value: 'This link grants streaming access.',\n                  fontSize: 14 * scaleFactor,\n                  color: colors.gray,\n                  textAlign: 'top-left',\n                }}\n              />\n            </UiEntity>\n            <UiEntity\n              uiTransform={styles.rowCenter}\n              onMouseDown={() => {\n                state.videoControl.dclCast?.streamLink &&\n                  copyToClipboard({\n                    text: state.videoControl.dclCast.streamLink,\n                  });\n              }}\n            >\n              <Label\n                value={'<b>Copy Link</b>'}\n                fontSize={18 * scaleFactor}\n                color={colors.white}\n                uiTransform={styles.marginRightSmall}\n              />\n              <UiEntity\n                uiTransform={{\n                  ...styles.iconSmall,\n                }}\n                uiBackground={{\n                  texture: {\n                    src: ICONS.COPY_TO_CLIPBOARD_ICON,\n                  },\n                  ...backgrounds.iconStretch,\n                }}\n              />\n            </UiEntity>\n          </UiEntity>\n          <UiEntity uiTransform={styles.separatorLine} />\n          <UiEntity uiTransform={styles.rowCenterSpaceBetween}>\n            <UiEntity uiTransform={styles.textInfoContainer}>\n              <Label\n                value={'<b>Viewers</b>'}\n                fontSize={18 * scaleFactor}\n                color={colors.white}\n              />\n              <UiEntity\n                uiText={{\n                  value: 'This link grants viewing access.',\n                  fontSize: 14 * scaleFactor,\n                  color: colors.gray,\n                  textAlign: 'top-left',\n                }}\n              />\n            </UiEntity>\n            <UiEntity\n              uiTransform={{\n                display: 'flex',\n                flexDirection: 'row',\n                alignItems: 'center',\n              }}\n              onMouseDown={() => {\n                state.videoControl.dclCast?.watcherLink &&\n                  copyToClipboard({\n                    text: state.videoControl.dclCast.watcherLink,\n                  });\n              }}\n            >\n              <Label\n                value={'<b>Copy Link</b>'}\n                fontSize={18 * scaleFactor}\n                color={colors.white}\n                uiTransform={styles.marginRightSmall}\n              />\n              <UiEntity\n                uiTransform={{\n                  ...styles.iconSmall,\n                }}\n                uiBackground={{\n                  texture: {\n                    src: ICONS.COPY_TO_CLIPBOARD_ICON,\n                  },\n                  ...backgrounds.iconStretch,\n                }}\n              />\n            </UiEntity>\n          </UiEntity>\n        </UiEntity>\n      </UiEntity>\n      <UiEntity uiTransform={styles.columnWithMarginTop}>\n        <VideoControlVolume\n          engine={engine}\n          entity={entity}\n          video={video}\n          label=\"<b>Cast volume</b>\"\n        />\n        <UiEntity>\n          <Button\n            id=\"dcl_cast_reset_room_id\"\n            value=\"<b>Reset Room</b>\"\n            variant=\"text\"\n            fontSize={16 * scaleFactor}\n            color={colors.danger}\n            uiTransform={styles.resetButton}\n            onMouseDown={onResetRoomId}\n          />\n        </UiEntity>\n      </UiEntity>\n    </UiEntity>\n  );\n};\n\nexport default DclCastInfo;\n"]}
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DclCastInfo.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/DclCast/DclCastInfo.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Entity, IEngine } from '@dcl/ecs';\nimport { DeepReadonlyObject, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { Label, UiEntity } from '@dcl/react-ecs';\nimport { copyToClipboard } from '~system/RestrictedActions';\nimport { Color4 } from '@dcl/sdk/math';\nimport { Button } from '../../Button';\nimport { FeedbackButton } from '../../FeedbackButton';\nimport { State } from '../../types';\nimport { VideoControlVolume } from '../VolumeControl';\nimport { createVideoPlayerControls, isDclCast } from '../utils';\nimport { LIVEKIT_STREAM_SRC } from '../LiveStream';\nimport { getDclCastStyles, getDclCastColors, getDclCastBackgrounds } from './styles';\nimport { CONTENT_URL } from '../../constants';\n\nconst ICONS = {\n  COPY_TO_CLIPBOARD_ICON: `${CONTENT_URL}/admin_toolkit/assets/icons/copy-to-clipboard.png`,\n};\n\nconst DclCastInfo = ({\n  scaleFactor,\n  state,\n  engine,\n  onResetRoomId,\n  entity,\n  video,\n}: {\n  scaleFactor: number;\n  state: State;\n  engine: IEngine;\n  onResetRoomId: () => Promise<void>;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n}) => {\n  const controls = createVideoPlayerControls(entity, engine);\n  const styles = getDclCastStyles(scaleFactor);\n  const colors = getDclCastColors();\n  const backgrounds = getDclCastBackgrounds();\n  return (\n    <UiEntity uiTransform={styles.fullContainer}>\n      <UiEntity uiTransform={styles.mainBorderedContainer}>\n        <UiEntity uiTransform={styles.headerRow}>\n          <UiEntity uiTransform={styles.columnFlexStart}>\n            <Label\n              value={'<b>Room ID</b>'}\n              fontSize={24 * scaleFactor}\n              color={Color4.White()}\n            />\n            <Label\n              value={`Expires in ${state.videoControl.dclCast?.expiresInDays} days`}\n              fontSize={14 * scaleFactor}\n              color={colors.gray}\n              uiTransform={styles.marginTopSmall}\n            />\n          </UiEntity>\n          {video?.src && isDclCast(video.src) ? (\n            <Button\n              id=\"dcl_cast_deactivate\"\n              value=\"<b>Deactivate</b>\"\n              variant=\"text\"\n              fontSize={16 * scaleFactor}\n              color={colors.white}\n              uiTransform={styles.activateButton}\n              onMouseDown={() => {\n                controls.setSource('');\n                state.videoControl.selectedStream = undefined;\n              }}\n            />\n          ) : (\n            <Button\n              id=\"dcl_cast_activate\"\n              value=\"<b>Activate</b>\"\n              labelTransform={styles.activateButtonLabel}\n              uiTransform={styles.activateButton}\n              fontSize={16 * scaleFactor}\n              uiBackground={backgrounds.success}\n              color={colors.black}\n              onMouseDown={() => {\n                controls.setSource(LIVEKIT_STREAM_SRC);\n                state.videoControl.selectedStream = 'dcl-cast';\n              }}\n            />\n          )}\n        </UiEntity>\n        <UiEntity uiTransform={styles.columnContainer}>\n          <UiEntity uiTransform={styles.rowCenterSpaceBetween}>\n            <UiEntity\n              uiTransform={{\n                display: 'flex',\n                flexDirection: 'column',\n              }}\n            >\n              <Label\n                value={'<b>Cast speakers</b>'}\n                fontSize={18 * scaleFactor}\n                color={colors.white}\n              />\n              <UiEntity\n                uiText={{\n                  value: 'This link grants streaming access.',\n                  fontSize: 14 * scaleFactor,\n                  color: colors.gray,\n                  textAlign: 'top-left',\n                }}\n              />\n            </UiEntity>\n            <FeedbackButton\n              id=\"dcl_cast_copy_stream_link\"\n              value=\"<b>Copy Link</b>\"\n              variant=\"text\"\n              fontSize={18 * scaleFactor}\n              color={colors.white}\n              iconRight={ICONS.COPY_TO_CLIPBOARD_ICON}\n              iconRightTransform={styles.iconSmall}\n              labelTransform={styles.marginRightSmall}\n              uiTransform={styles.copyLinkButton}\n              onMouseDown={() => {\n                state.videoControl.dclCast?.streamLink &&\n                  copyToClipboard({\n                    text: state.videoControl.dclCast.streamLink,\n                  });\n              }}\n            />\n          </UiEntity>\n          <UiEntity uiTransform={styles.separatorLine} />\n          <UiEntity uiTransform={styles.rowCenterSpaceBetween}>\n            <UiEntity uiTransform={styles.textInfoContainer}>\n              <Label\n                value={'<b>Viewers</b>'}\n                fontSize={18 * scaleFactor}\n                color={colors.white}\n              />\n              <UiEntity\n                uiText={{\n                  value: 'This link grants viewing access.',\n                  fontSize: 14 * scaleFactor,\n                  color: colors.gray,\n                  textAlign: 'top-left',\n                }}\n              />\n            </UiEntity>\n            <FeedbackButton\n              id=\"dcl_cast_copy_watcher_link\"\n              value=\"<b>Copy Link</b>\"\n              variant=\"text\"\n              fontSize={18 * scaleFactor}\n              color={colors.white}\n              iconRight={ICONS.COPY_TO_CLIPBOARD_ICON}\n              iconRightTransform={styles.iconSmall}\n              labelTransform={styles.marginRightSmall}\n              uiTransform={styles.copyLinkButton}\n              onMouseDown={() => {\n                state.videoControl.dclCast?.watcherLink &&\n                  copyToClipboard({\n                    text: state.videoControl.dclCast.watcherLink,\n                  });\n              }}\n            />\n          </UiEntity>\n        </UiEntity>\n      </UiEntity>\n      <UiEntity uiTransform={styles.columnWithMarginTop}>\n        <VideoControlVolume\n          engine={engine}\n          entity={entity}\n          video={video}\n          label=\"<b>Cast volume</b>\"\n        />\n        <UiEntity>\n          <Button\n            id=\"dcl_cast_reset_room_id\"\n            value=\"<b>Reset Room</b>\"\n            variant=\"text\"\n            fontSize={16 * scaleFactor}\n            color={colors.danger}\n            uiTransform={styles.resetButton}\n            onMouseDown={onResetRoomId}\n          />\n        </UiEntity>\n      </UiEntity>\n    </UiEntity>\n  );\n};\n\nexport default DclCastInfo;\n"]}
|
|
@@ -105,6 +105,17 @@ export const getDclCastStyles = (scaleFactor) => ({
|
|
|
105
105
|
padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },
|
|
106
106
|
height: 42 * scaleFactor,
|
|
107
107
|
},
|
|
108
|
+
copyLinkButton: {
|
|
109
|
+
flexDirection: 'row',
|
|
110
|
+
alignItems: 'center',
|
|
111
|
+
borderRadius: 8 * scaleFactor,
|
|
112
|
+
padding: {
|
|
113
|
+
top: 4 * scaleFactor,
|
|
114
|
+
bottom: 4 * scaleFactor,
|
|
115
|
+
left: 8 * scaleFactor,
|
|
116
|
+
right: 8 * scaleFactor,
|
|
117
|
+
},
|
|
118
|
+
},
|
|
108
119
|
iconSmall: {
|
|
109
120
|
width: 20 * scaleFactor,
|
|
110
121
|
height: 20 * scaleFactor,
|
|
@@ -148,4 +159,4 @@ export const getDclCastBackgrounds = () => ({
|
|
|
148
159
|
textureMode: 'stretch',
|
|
149
160
|
},
|
|
150
161
|
});
|
|
151
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/DclCast/styles.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport { UiTransformProps } from '@dcl/react-ecs';\n\nexport const getDclCastStyles = (scaleFactor: number): Record<string, UiTransformProps> => ({\n  fullContainer: {\n    flexDirection: 'column',\n    width: '100%',\n    height: '100%',\n  },\n\n  fullWidthWithBottomMargin: {\n    width: '100%',\n    margin: { bottom: 24 * scaleFactor },\n  },\n\n  rowSpaceBetween: {\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'flex-start',\n  },\n\n  rowCenter: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n  },\n\n  rowCenterSpaceBetween: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n    justifyContent: 'space-between',\n    width: '100%',\n  },\n\n  columnContainer: {\n    display: 'flex',\n    flexDirection: 'column',\n    width: '100%',\n    alignItems: 'flex-start',\n  },\n\n  columnFlexStart: {\n    display: 'flex',\n    flexDirection: 'column',\n    alignItems: 'flex-start',\n    width: 'auto',\n  },\n\n  columnCentered: {\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'column',\n    justifyContent: 'center',\n    alignItems: 'center',\n  },\n\n  columnWithMarginTop: {\n    display: 'flex',\n    flexDirection: 'column',\n    margin: { top: 8 * scaleFactor },\n  },\n\n  marginBottomSmall: {\n    margin: { bottom: 8 * scaleFactor },\n  },\n\n  marginTopSmall: {\n    margin: { top: -4 * scaleFactor },\n  },\n\n  marginRightSmall: {\n    margin: { right: 4 * scaleFactor },\n  },\n\n  mainBorderedContainer: {\n    width: '100%',\n    height: '100%',\n    borderWidth: 2 * scaleFactor,\n    borderColor: Color4.fromHexString('#716B7C'),\n    flexDirection: 'column',\n    borderRadius: 12 * scaleFactor,\n    padding: {\n      left: 16 * scaleFactor,\n      right: 16 * scaleFactor,\n      top: 24 * scaleFactor,\n      bottom: 8 * scaleFactor,\n    },\n  },\n\n  headerRow: {\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'flex-start',\n    margin: { bottom: 18 * scaleFactor },\n  },\n\n  activateButton: {\n    minWidth: 120 * scaleFactor,\n    height: 42 * scaleFactor,\n    padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n  },\n\n  activateButtonLabel: {\n    margin: { left: 20 * scaleFactor, right: 20 * scaleFactor },\n  },\n\n  retryButton: {\n    margin: { top: 16 * scaleFactor },\n    padding: {\n      top: 8 * scaleFactor,\n      bottom: 8 * scaleFactor,\n      left: 16 * scaleFactor,\n      right: 16 * scaleFactor,\n    },\n  },\n\n  resetButton: {\n    margin: { right: 8 * scaleFactor, top: 20 * scaleFactor },\n    padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n    height: 42 * scaleFactor,\n  },\n\n  iconSmall: {\n    width: 20 * scaleFactor,\n    height: 20 * scaleFactor,\n  },\n\n  loadingContainer: {\n    minHeight: 400 * scaleFactor,\n  },\n\n  separatorLine: {\n    margin: { top: 16 * scaleFactor, bottom: 16 * scaleFactor },\n    width: '100%',\n    height: 1 * scaleFactor,\n    borderWidth: 1,\n    borderColor: Color4.fromHexString('#43404A'),\n  },\n\n  textInfoContainer: {\n    display: 'flex',\n    flexDirection: 'column',\n    margin: { bottom: 4 * scaleFactor },\n  },\n\n  rowWithBottomMargin: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n    justifyContent: 'space-between',\n    width: '100%',\n    margin: { bottom: 8 * scaleFactor },\n  },\n});\n\nexport const getDclCastColors = () => ({\n  white: Color4.White(),\n  black: Color4.Black(),\n  gray: Color4.fromHexString('#716B7C'),\n  lightGray: Color4.fromHexString('#A09BA8'),\n  success: Color4.fromHexString('#34CE77'),\n  danger: Color4.fromHexString('#FB3B3B'),\n  darkGray: Color4.Gray(),\n});\n\nexport const getDclCastBackgrounds = () => ({\n  success: { color: Color4.fromHexString('#34CE77') },\n  iconStretch: {\n    textureMode: 'stretch' as const,\n  },\n});\n"]}
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styles.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/DclCast/styles.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport { UiTransformProps } from '@dcl/react-ecs';\n\nexport const getDclCastStyles = (scaleFactor: number): Record<string, UiTransformProps> => ({\n  fullContainer: {\n    flexDirection: 'column',\n    width: '100%',\n    height: '100%',\n  },\n\n  fullWidthWithBottomMargin: {\n    width: '100%',\n    margin: { bottom: 24 * scaleFactor },\n  },\n\n  rowSpaceBetween: {\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'flex-start',\n  },\n\n  rowCenter: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n  },\n\n  rowCenterSpaceBetween: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n    justifyContent: 'space-between',\n    width: '100%',\n  },\n\n  columnContainer: {\n    display: 'flex',\n    flexDirection: 'column',\n    width: '100%',\n    alignItems: 'flex-start',\n  },\n\n  columnFlexStart: {\n    display: 'flex',\n    flexDirection: 'column',\n    alignItems: 'flex-start',\n    width: 'auto',\n  },\n\n  columnCentered: {\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'column',\n    justifyContent: 'center',\n    alignItems: 'center',\n  },\n\n  columnWithMarginTop: {\n    display: 'flex',\n    flexDirection: 'column',\n    margin: { top: 8 * scaleFactor },\n  },\n\n  marginBottomSmall: {\n    margin: { bottom: 8 * scaleFactor },\n  },\n\n  marginTopSmall: {\n    margin: { top: -4 * scaleFactor },\n  },\n\n  marginRightSmall: {\n    margin: { right: 4 * scaleFactor },\n  },\n\n  mainBorderedContainer: {\n    width: '100%',\n    height: '100%',\n    borderWidth: 2 * scaleFactor,\n    borderColor: Color4.fromHexString('#716B7C'),\n    flexDirection: 'column',\n    borderRadius: 12 * scaleFactor,\n    padding: {\n      left: 16 * scaleFactor,\n      right: 16 * scaleFactor,\n      top: 24 * scaleFactor,\n      bottom: 8 * scaleFactor,\n    },\n  },\n\n  headerRow: {\n    width: '100%',\n    display: 'flex',\n    flexDirection: 'row',\n    justifyContent: 'space-between',\n    alignItems: 'flex-start',\n    margin: { bottom: 18 * scaleFactor },\n  },\n\n  activateButton: {\n    minWidth: 120 * scaleFactor,\n    height: 42 * scaleFactor,\n    padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n  },\n\n  activateButtonLabel: {\n    margin: { left: 20 * scaleFactor, right: 20 * scaleFactor },\n  },\n\n  retryButton: {\n    margin: { top: 16 * scaleFactor },\n    padding: {\n      top: 8 * scaleFactor,\n      bottom: 8 * scaleFactor,\n      left: 16 * scaleFactor,\n      right: 16 * scaleFactor,\n    },\n  },\n\n  resetButton: {\n    margin: { right: 8 * scaleFactor, top: 20 * scaleFactor },\n    padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n    height: 42 * scaleFactor,\n  },\n\n  copyLinkButton: {\n    flexDirection: 'row',\n    alignItems: 'center',\n    borderRadius: 8 * scaleFactor,\n    padding: {\n      top: 4 * scaleFactor,\n      bottom: 4 * scaleFactor,\n      left: 8 * scaleFactor,\n      right: 8 * scaleFactor,\n    },\n  },\n\n  iconSmall: {\n    width: 20 * scaleFactor,\n    height: 20 * scaleFactor,\n  },\n\n  loadingContainer: {\n    minHeight: 400 * scaleFactor,\n  },\n\n  separatorLine: {\n    margin: { top: 16 * scaleFactor, bottom: 16 * scaleFactor },\n    width: '100%',\n    height: 1 * scaleFactor,\n    borderWidth: 1,\n    borderColor: Color4.fromHexString('#43404A'),\n  },\n\n  textInfoContainer: {\n    display: 'flex',\n    flexDirection: 'column',\n    margin: { bottom: 4 * scaleFactor },\n  },\n\n  rowWithBottomMargin: {\n    display: 'flex',\n    flexDirection: 'row',\n    alignItems: 'center',\n    justifyContent: 'space-between',\n    width: '100%',\n    margin: { bottom: 8 * scaleFactor },\n  },\n});\n\nexport const getDclCastColors = () => ({\n  white: Color4.White(),\n  black: Color4.Black(),\n  gray: Color4.fromHexString('#716B7C'),\n  lightGray: Color4.fromHexString('#A09BA8'),\n  success: Color4.fromHexString('#34CE77'),\n  danger: Color4.fromHexString('#FB3B3B'),\n  darkGray: Color4.Gray(),\n});\n\nexport const getDclCastBackgrounds = () => ({\n  success: { color: Color4.fromHexString('#34CE77') },\n  iconStretch: {\n    textureMode: 'stretch' as const,\n  },\n});\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';
|
|
1
|
+
import type { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';
|
|
2
2
|
import ReactEcs from '@dcl/react-ecs';
|
|
3
3
|
export declare function ShowStreamKey({ scaleFactor, engine, video, entity, onReset, endsAt, }: {
|
|
4
4
|
endsAt: number;
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { Color4 } from '@dcl/sdk/math';
|
|
2
2
|
import ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';
|
|
3
|
-
import { copyToClipboard } from '~system/RestrictedActions';
|
|
4
3
|
import { COLORS } from '..';
|
|
5
4
|
import { createVideoPlayerControls } from '../utils';
|
|
6
5
|
import { VideoControlVolume } from '../VolumeControl';
|
|
7
6
|
import { Button } from '../../Button';
|
|
7
|
+
import { FeedbackButton } from '../../FeedbackButton';
|
|
8
8
|
import { LIVEKIT_STREAM_SRC } from '../../../definitions';
|
|
9
9
|
import { ERROR_ICON } from '../../Error';
|
|
10
10
|
import { CONTENT_URL } from '../../constants';
|
|
@@ -12,6 +12,7 @@ import { getStreamKey } from '../api';
|
|
|
12
12
|
import { LoadingDots } from '../../Loading';
|
|
13
13
|
import { startTimeout, stopTimeout, startInterval, stopInterval } from '../../../timer';
|
|
14
14
|
import { state } from '../..';
|
|
15
|
+
import { copyToClipboard } from '~system/RestrictedActions';
|
|
15
16
|
const STREAM_ICONS = {
|
|
16
17
|
eyeShow: `${CONTENT_URL}/admin_toolkit/assets/icons/eye.png`,
|
|
17
18
|
eyeHide: `${CONTENT_URL}/admin_toolkit/assets/icons/eye-off.png`,
|
|
@@ -60,13 +61,13 @@ export function ShowStreamKey({ scaleFactor, engine, video, entity, onReset, end
|
|
|
60
61
|
alignItems: 'center',
|
|
61
62
|
}, uiBackground: { color: Color4.White() } },
|
|
62
63
|
ReactEcs.createElement(Label, { uiTransform: { margin: { left: 16 * scaleFactor } }, fontSize: 16 * scaleFactor, value: `<b>${RTMP_SERVER_URL}</b>`, color: Color4.fromHexString('#A09BA8') }),
|
|
63
|
-
ReactEcs.createElement(
|
|
64
|
+
ReactEcs.createElement(FeedbackButton, { id: "video_control_copy_rtmp_server", value: "<b>Copy</b>", variant: "primary", fontSize: 16 * scaleFactor, uiTransform: {
|
|
64
65
|
margin: { right: 8 * scaleFactor },
|
|
65
66
|
padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },
|
|
66
67
|
}, onMouseDown: async () => {
|
|
67
68
|
copyToClipboard({ text: RTMP_SERVER_URL });
|
|
68
69
|
} })),
|
|
69
|
-
ReactEcs.createElement(Label, { value: "<b>Stream Key
|
|
70
|
+
ReactEcs.createElement(Label, { value: "<b>Stream Key</b>", color: Color4.White(), fontSize: 16 * scaleFactor, uiTransform: {
|
|
70
71
|
margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },
|
|
71
72
|
} }),
|
|
72
73
|
ReactEcs.createElement(UiEntity, { uiTransform: {
|
|
@@ -118,7 +119,7 @@ export function ShowStreamKey({ scaleFactor, engine, video, entity, onReset, end
|
|
|
118
119
|
setShowStreamkey(!showStreamkey);
|
|
119
120
|
}
|
|
120
121
|
} }),
|
|
121
|
-
ReactEcs.createElement(
|
|
122
|
+
ReactEcs.createElement(FeedbackButton, { id: "video_control_copy_stream_key", value: "<b>Copy</b>", variant: "primary", fontSize: 16 * scaleFactor, uiTransform: {
|
|
122
123
|
margin: { right: 8 * scaleFactor },
|
|
123
124
|
padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },
|
|
124
125
|
minWidth: 60 * scaleFactor,
|
|
@@ -208,4 +209,4 @@ function formatTimeRemaining(endsAt) {
|
|
|
208
209
|
return `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;
|
|
209
210
|
}
|
|
210
211
|
}
|
|
211
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ShowStreamKey.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';\nimport { copyToClipboard } from '~system/RestrictedActions';\nimport { COLORS } from '..';\nimport { createVideoPlayerControls } from '../utils';\nimport { VideoControlVolume } from '../VolumeControl';\nimport { Button } from '../../Button';\nimport { LIVEKIT_STREAM_SRC } from '../../../definitions';\nimport { ERROR_ICON } from '../../Error';\nimport { CONTENT_URL } from '../../constants';\nimport { getStreamKey } from '../api';\nimport { LoadingDots } from '../../Loading';\nimport { startTimeout, stopTimeout, startInterval, stopInterval } from '../../../timer';\nimport { state } from '../..';\n\nconst STREAM_ICONS = {\n  eyeShow: `${CONTENT_URL}/admin_toolkit/assets/icons/eye.png`,\n  eyeHide: `${CONTENT_URL}/admin_toolkit/assets/icons/eye-off.png`,\n};\n\nconst AUTO_HIDE_DURATION_SECONDS = 30;\nconst STREAM_KEY_TIMEOUT_ACTION = 'video_control_stream_key_timeout';\nconst STREAM_KEY_INTERVAL_ACTION = 'video_control_stream_key_interval';\nconst RTMP_SERVER_URL = 'rtmps://dcl.rtmp.livekit.cloud/x';\n\nexport function ShowStreamKey({\n  scaleFactor,\n  engine,\n  video,\n  entity,\n  onReset,\n  endsAt,\n}: {\n  endsAt: number;\n  scaleFactor: number;\n  engine: IEngine;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n  onReset(): void;\n}) {\n  const controls = createVideoPlayerControls(entity, engine);\n  const [showStreamkey, setShowStreamkey] = ReactEcs.useState(false);\n  const [loading, setLoading] = ReactEcs.useState(false);\n  const [streamKey, setStreamKey] = ReactEcs.useState<string | undefined>(undefined);\n  const [timeRemaining, setTimeRemaining] = ReactEcs.useState(AUTO_HIDE_DURATION_SECONDS);\n\n  // auto-hide stream key after specified duration\n  ReactEcs.useEffect(() => {\n    if (streamKey) {\n      setTimeRemaining(AUTO_HIDE_DURATION_SECONDS);\n\n      startTimeout(\n        state.adminToolkitUiEntity,\n        STREAM_KEY_TIMEOUT_ACTION,\n        AUTO_HIDE_DURATION_SECONDS,\n        () => {\n          setStreamKey(undefined);\n          setShowStreamkey(false);\n          setTimeRemaining(0);\n        },\n      );\n\n      startInterval(state.adminToolkitUiEntity, STREAM_KEY_INTERVAL_ACTION, 0.1, () => {\n        setTimeRemaining(prev => Math.max(0, prev - 0.1));\n      });\n\n      return () => {\n        stopTimeout(state.adminToolkitUiEntity, STREAM_KEY_TIMEOUT_ACTION);\n        stopInterval(state.adminToolkitUiEntity, STREAM_KEY_INTERVAL_ACTION);\n      };\n    } else {\n      setTimeRemaining(0);\n    }\n  }, [streamKey]);\n\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column' }}>\n      <Label\n        value=\"<b>RTMP Server</b>\"\n        color={Color4.White()}\n        fontSize={16 * scaleFactor}\n        uiTransform={{\n          margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },\n        }}\n      />\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          margin: { bottom: 8 * scaleFactor, top: 8 * scaleFactor },\n          height: 42 * scaleFactor,\n          borderRadius: 12 * scaleFactor,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          alignItems: 'center',\n        }}\n        uiBackground={{ color: Color4.White() }}\n      >\n        <Label\n          uiTransform={{ margin: { left: 16 * scaleFactor } }}\n          fontSize={16 * scaleFactor}\n          value={`<b>${RTMP_SERVER_URL}</b>`}\n          color={Color4.fromHexString('#A09BA8')}\n        />\n        <Button\n          id=\"video_control_copy_rtmp_server\"\n          value=\"<b>Copy</b>\"\n          variant=\"primary\"\n          fontSize={16 * scaleFactor}\n          uiTransform={{\n            margin: { right: 8 * scaleFactor },\n            padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n          }}\n          onMouseDown={async () => {\n            copyToClipboard({ text: RTMP_SERVER_URL });\n          }}\n        />\n      </UiEntity>\n      <Label\n        value=\"<b>Stream Key<b>\"\n        color={Color4.White()}\n        fontSize={16 * scaleFactor}\n        uiTransform={{\n          margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },\n        }}\n      />\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          margin: { bottom: 8 * scaleFactor, top: 8 * scaleFactor },\n          height: 42 * scaleFactor,\n          borderRadius: 12 * scaleFactor,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          alignItems: 'center',\n        }}\n        uiBackground={{ color: Color4.White() }}\n      >\n        <UiEntity\n          uiTransform={{\n            flexDirection: 'row',\n            alignItems: 'center',\n            justifyContent: 'flex-start',\n          }}\n        >\n          {loading ? (\n            <UiEntity\n              uiTransform={{\n                margin: { left: 16 * scaleFactor },\n              }}\n            >\n              <LoadingDots\n                scaleFactor={scaleFactor}\n                engine={engine}\n              />\n            </UiEntity>\n          ) : (\n            <Label\n              uiTransform={{\n                margin: { left: 16 * scaleFactor },\n                flexShrink: 1,\n              }}\n              fontSize={16 * scaleFactor}\n              value={`<b>${showStreamkey && streamKey ? streamKey : '************'}</b>`}\n              color={Color4.fromHexString('#A09BA8')}\n            />\n          )}\n        </UiEntity>\n\n        <UiEntity\n          uiTransform={{\n            flexDirection: 'row',\n            alignItems: 'center',\n            flexShrink: 0,\n          }}\n        >\n          <UiEntity\n            uiTransform={{\n              width: 25 * scaleFactor,\n              height: 25 * scaleFactor,\n              margin: { right: 10 * scaleFactor },\n            }}\n            uiBackground={{\n              textureMode: 'stretch',\n              texture: {\n                src: showStreamkey && streamKey ? STREAM_ICONS.eyeHide : STREAM_ICONS.eyeShow,\n              },\n              color: Color4.Black(),\n            }}\n            onMouseDown={async () => {\n              if (!streamKey) {\n                setLoading(true);\n                const [error, data] = await getStreamKey();\n                setLoading(false);\n                if (!error && data?.streamingKey) {\n                  setStreamKey(data.streamingKey);\n                  setShowStreamkey(true);\n                }\n              } else {\n                setShowStreamkey(!showStreamkey);\n              }\n            }}\n          />\n          <Button\n            id=\"video_control_copy_stream_key\"\n            value=\"<b>Copy</b>\"\n            variant=\"primary\"\n            fontSize={16 * scaleFactor}\n            uiTransform={{\n              margin: { right: 8 * scaleFactor },\n              padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n              minWidth: 60 * scaleFactor,\n            }}\n            onMouseDown={async () => {\n              if (streamKey) {\n                copyToClipboard({ text: streamKey });\n              } else {\n                setLoading(true);\n                const [error, data] = await getStreamKey();\n                setLoading(false);\n                if (!error && data?.streamingKey) {\n                  setStreamKey(data.streamingKey);\n                  copyToClipboard({ text: data.streamingKey });\n                }\n              }\n            }}\n          />\n        </UiEntity>\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 4 * scaleFactor,\n          margin: { top: 8 * scaleFactor },\n          display: streamKey && timeRemaining > 0 && showStreamkey ? 'flex' : 'none',\n        }}\n        uiBackground={{ color: Color4.fromHexString('#FFFFFF1A') }}\n      >\n        <UiEntity\n          uiTransform={{\n            width: `${(timeRemaining / AUTO_HIDE_DURATION_SECONDS) * 100}%`,\n            height: '100%',\n          }}\n          uiBackground={{ color: Color4.fromHexString('#00D3FF') }}\n        />\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 40 * scaleFactor,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          margin: { top: 10 * scaleFactor, bottom: 16 * scaleFactor },\n        }}\n      >\n        {endsAt > Date.now() ? (\n          <UiEntity uiTransform={{ flexDirection: 'column' }}>\n            <Label\n              value=\"Stream expires in:\"\n              color={Color4.fromHexString('#FFFFFFB2')}\n              fontSize={14 * scaleFactor}\n            />\n            <Label\n              value={formatTimeRemaining(endsAt)}\n              color={Color4.fromHexString('#FFFFFFB2')}\n              fontSize={14 * scaleFactor}\n            />\n          </UiEntity>\n        ) : (\n          <UiEntity\n            uiTransform={{\n              flexDirection: 'row',\n              margin: { right: 10 * scaleFactor },\n              borderWidth: 2,\n              borderColor: Color4.Green(),\n            }}\n          >\n            <UiEntity\n              uiTransform={{\n                width: 15 * scaleFactor,\n                height: 15 * scaleFactor,\n                margin: { right: 4 * scaleFactor, top: 4 * scaleFactor },\n              }}\n              uiBackground={{\n                textureMode: 'stretch',\n                texture: {\n                  src: ERROR_ICON,\n                },\n              }}\n            />\n            <Label\n              fontSize={14 * scaleFactor}\n              textAlign=\"middle-left\"\n              color={Color4.fromHexString('#FF0000')}\n              value=\"Stream timed out. Please restart stream in broadcasting software.\"\n            />\n          </UiEntity>\n        )}\n        {video?.src === LIVEKIT_STREAM_SRC && state.videoControl.selectedStream === 'live' ? (\n          <Button\n            id=\"video_control_share_screen_clear\"\n            value=\"<b>Deactivate</b>\"\n            variant=\"text\"\n            fontSize={16 * scaleFactor}\n            color={Color4.White()}\n            uiTransform={{\n              minWidth: 120 * scaleFactor,\n              margin: { right: 8 * scaleFactor },\n              padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n            }}\n            onMouseDown={() => {\n              controls.setSource('');\n              state.videoControl.selectedStream = undefined;\n            }}\n          />\n        ) : (\n          <Button\n            id=\"video_control_share_screen_share\"\n            value=\"<b>Activate</b>\"\n            labelTransform={{\n              margin: { left: 20 * scaleFactor, right: 20 * scaleFactor },\n            }}\n            uiTransform={{\n              minWidth: 120 * scaleFactor,\n            }}\n            fontSize={16 * scaleFactor}\n            uiBackground={{ color: COLORS.SUCCESS }}\n            color={Color4.Black()}\n            onMouseDown={() => {\n              controls.setSource(LIVEKIT_STREAM_SRC);\n              state.videoControl.selectedStream = 'live';\n            }}\n          />\n        )}\n      </UiEntity>\n      <VideoControlVolume\n        engine={engine}\n        label=\"<b>Stream Volume</b>\"\n        entity={entity}\n        video={video}\n      />\n      <UiEntity>\n        <Button\n          id=\"video_control_reset_stream_key\"\n          value=\"<b>Reset Stream Key</b>\"\n          variant=\"text\"\n          fontSize={16 * scaleFactor}\n          color={Color4.fromHexString('#FB3B3B')}\n          uiTransform={{\n            margin: { right: 8 * scaleFactor, top: 20 * scaleFactor },\n            padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n          }}\n          onMouseDown={() => onReset()}\n        />\n      </UiEntity>\n    </UiEntity>\n  );\n}\n\n// Helper function to format time remaining - shows days if > 1 day, otherwise shows hh:mm:ss\nfunction formatTimeRemaining(endsAt: number): string {\n  const now = Date.now();\n  const timeRemaining = Math.max(0, endsAt - now);\n\n  const days = Math.floor(timeRemaining / (1000 * 60 * 60 * 24));\n\n  if (days >= 1) {\n    return `${days} ${days === 1 ? 'day' : 'days'}`;\n  } else {\n    const hours = Math.floor(timeRemaining / (1000 * 60 * 60));\n    const minutes = Math.floor((timeRemaining % (1000 * 60 * 60)) / (1000 * 60));\n    const seconds = Math.floor((timeRemaining % (1000 * 60)) / 1000);\n    return `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;\n  }\n}\n"]}
|
|
212
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ShowStreamKey.js","sourceRoot":"","sources":["../../../../src/admin-toolkit-ui/VideoControl/LiveStream/ShowStreamKey.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Color4 } from '@dcl/sdk/math';\nimport type { DeepReadonlyObject, Entity, IEngine, PBVideoPlayer } from '@dcl/ecs';\nimport ReactEcs, { UiEntity, Label } from '@dcl/react-ecs';\nimport { COLORS } from '..';\nimport { createVideoPlayerControls } from '../utils';\nimport { VideoControlVolume } from '../VolumeControl';\nimport { Button } from '../../Button';\nimport { FeedbackButton } from '../../FeedbackButton';\nimport { LIVEKIT_STREAM_SRC } from '../../../definitions';\nimport { ERROR_ICON } from '../../Error';\nimport { CONTENT_URL } from '../../constants';\nimport { getStreamKey } from '../api';\nimport { LoadingDots } from '../../Loading';\nimport { startTimeout, stopTimeout, startInterval, stopInterval } from '../../../timer';\nimport { state } from '../..';\nimport { copyToClipboard } from '~system/RestrictedActions';\n\nconst STREAM_ICONS = {\n  eyeShow: `${CONTENT_URL}/admin_toolkit/assets/icons/eye.png`,\n  eyeHide: `${CONTENT_URL}/admin_toolkit/assets/icons/eye-off.png`,\n};\n\nconst AUTO_HIDE_DURATION_SECONDS = 30;\nconst STREAM_KEY_TIMEOUT_ACTION = 'video_control_stream_key_timeout';\nconst STREAM_KEY_INTERVAL_ACTION = 'video_control_stream_key_interval';\nconst RTMP_SERVER_URL = 'rtmps://dcl.rtmp.livekit.cloud/x';\n\nexport function ShowStreamKey({\n  scaleFactor,\n  engine,\n  video,\n  entity,\n  onReset,\n  endsAt,\n}: {\n  endsAt: number;\n  scaleFactor: number;\n  engine: IEngine;\n  entity: Entity;\n  video: DeepReadonlyObject<PBVideoPlayer> | undefined;\n  onReset(): void;\n}) {\n  const controls = createVideoPlayerControls(entity, engine);\n  const [showStreamkey, setShowStreamkey] = ReactEcs.useState(false);\n  const [loading, setLoading] = ReactEcs.useState(false);\n  const [streamKey, setStreamKey] = ReactEcs.useState<string | undefined>(undefined);\n  const [timeRemaining, setTimeRemaining] = ReactEcs.useState(AUTO_HIDE_DURATION_SECONDS);\n\n  // auto-hide stream key after specified duration\n  ReactEcs.useEffect(() => {\n    if (streamKey) {\n      setTimeRemaining(AUTO_HIDE_DURATION_SECONDS);\n\n      startTimeout(\n        state.adminToolkitUiEntity,\n        STREAM_KEY_TIMEOUT_ACTION,\n        AUTO_HIDE_DURATION_SECONDS,\n        () => {\n          setStreamKey(undefined);\n          setShowStreamkey(false);\n          setTimeRemaining(0);\n        },\n      );\n\n      startInterval(state.adminToolkitUiEntity, STREAM_KEY_INTERVAL_ACTION, 0.1, () => {\n        setTimeRemaining(prev => Math.max(0, prev - 0.1));\n      });\n\n      return () => {\n        stopTimeout(state.adminToolkitUiEntity, STREAM_KEY_TIMEOUT_ACTION);\n        stopInterval(state.adminToolkitUiEntity, STREAM_KEY_INTERVAL_ACTION);\n      };\n    } else {\n      setTimeRemaining(0);\n    }\n  }, [streamKey]);\n\n  return (\n    <UiEntity uiTransform={{ flexDirection: 'column' }}>\n      <Label\n        value=\"<b>RTMP Server</b>\"\n        color={Color4.White()}\n        fontSize={16 * scaleFactor}\n        uiTransform={{\n          margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },\n        }}\n      />\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          margin: { bottom: 8 * scaleFactor, top: 8 * scaleFactor },\n          height: 42 * scaleFactor,\n          borderRadius: 12 * scaleFactor,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          alignItems: 'center',\n        }}\n        uiBackground={{ color: Color4.White() }}\n      >\n        <Label\n          uiTransform={{ margin: { left: 16 * scaleFactor } }}\n          fontSize={16 * scaleFactor}\n          value={`<b>${RTMP_SERVER_URL}</b>`}\n          color={Color4.fromHexString('#A09BA8')}\n        />\n        <FeedbackButton\n          id=\"video_control_copy_rtmp_server\"\n          value=\"<b>Copy</b>\"\n          variant=\"primary\"\n          fontSize={16 * scaleFactor}\n          uiTransform={{\n            margin: { right: 8 * scaleFactor },\n            padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n          }}\n          onMouseDown={async () => {\n            copyToClipboard({ text: RTMP_SERVER_URL });\n          }}\n        />\n      </UiEntity>\n      <Label\n        value=\"<b>Stream Key</b>\"\n        color={Color4.White()}\n        fontSize={16 * scaleFactor}\n        uiTransform={{\n          margin: { top: 16 * scaleFactor, bottom: 8 * scaleFactor },\n        }}\n      />\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          margin: { bottom: 8 * scaleFactor, top: 8 * scaleFactor },\n          height: 42 * scaleFactor,\n          borderRadius: 12 * scaleFactor,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          alignItems: 'center',\n        }}\n        uiBackground={{ color: Color4.White() }}\n      >\n        <UiEntity\n          uiTransform={{\n            flexDirection: 'row',\n            alignItems: 'center',\n            justifyContent: 'flex-start',\n          }}\n        >\n          {loading ? (\n            <UiEntity\n              uiTransform={{\n                margin: { left: 16 * scaleFactor },\n              }}\n            >\n              <LoadingDots\n                scaleFactor={scaleFactor}\n                engine={engine}\n              />\n            </UiEntity>\n          ) : (\n            <Label\n              uiTransform={{\n                margin: { left: 16 * scaleFactor },\n                flexShrink: 1,\n              }}\n              fontSize={16 * scaleFactor}\n              value={`<b>${showStreamkey && streamKey ? streamKey : '************'}</b>`}\n              color={Color4.fromHexString('#A09BA8')}\n            />\n          )}\n        </UiEntity>\n\n        <UiEntity\n          uiTransform={{\n            flexDirection: 'row',\n            alignItems: 'center',\n            flexShrink: 0,\n          }}\n        >\n          <UiEntity\n            uiTransform={{\n              width: 25 * scaleFactor,\n              height: 25 * scaleFactor,\n              margin: { right: 10 * scaleFactor },\n            }}\n            uiBackground={{\n              textureMode: 'stretch',\n              texture: {\n                src: showStreamkey && streamKey ? STREAM_ICONS.eyeHide : STREAM_ICONS.eyeShow,\n              },\n              color: Color4.Black(),\n            }}\n            onMouseDown={async () => {\n              if (!streamKey) {\n                setLoading(true);\n                const [error, data] = await getStreamKey();\n                setLoading(false);\n                if (!error && data?.streamingKey) {\n                  setStreamKey(data.streamingKey);\n                  setShowStreamkey(true);\n                }\n              } else {\n                setShowStreamkey(!showStreamkey);\n              }\n            }}\n          />\n          <FeedbackButton\n            id=\"video_control_copy_stream_key\"\n            value=\"<b>Copy</b>\"\n            variant=\"primary\"\n            fontSize={16 * scaleFactor}\n            uiTransform={{\n              margin: { right: 8 * scaleFactor },\n              padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n              minWidth: 60 * scaleFactor,\n            }}\n            onMouseDown={async () => {\n              if (streamKey) {\n                copyToClipboard({ text: streamKey });\n              } else {\n                setLoading(true);\n                const [error, data] = await getStreamKey();\n                setLoading(false);\n                if (!error && data?.streamingKey) {\n                  setStreamKey(data.streamingKey);\n                  copyToClipboard({ text: data.streamingKey });\n                }\n              }\n            }}\n          />\n        </UiEntity>\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 4 * scaleFactor,\n          margin: { top: 8 * scaleFactor },\n          display: streamKey && timeRemaining > 0 && showStreamkey ? 'flex' : 'none',\n        }}\n        uiBackground={{ color: Color4.fromHexString('#FFFFFF1A') }}\n      >\n        <UiEntity\n          uiTransform={{\n            width: `${(timeRemaining / AUTO_HIDE_DURATION_SECONDS) * 100}%`,\n            height: '100%',\n          }}\n          uiBackground={{ color: Color4.fromHexString('#00D3FF') }}\n        />\n      </UiEntity>\n\n      <UiEntity\n        uiTransform={{\n          width: '100%',\n          height: 40 * scaleFactor,\n          flexDirection: 'row',\n          justifyContent: 'space-between',\n          margin: { top: 10 * scaleFactor, bottom: 16 * scaleFactor },\n        }}\n      >\n        {endsAt > Date.now() ? (\n          <UiEntity uiTransform={{ flexDirection: 'column' }}>\n            <Label\n              value=\"Stream expires in:\"\n              color={Color4.fromHexString('#FFFFFFB2')}\n              fontSize={14 * scaleFactor}\n            />\n            <Label\n              value={formatTimeRemaining(endsAt)}\n              color={Color4.fromHexString('#FFFFFFB2')}\n              fontSize={14 * scaleFactor}\n            />\n          </UiEntity>\n        ) : (\n          <UiEntity\n            uiTransform={{\n              flexDirection: 'row',\n              margin: { right: 10 * scaleFactor },\n              borderWidth: 2,\n              borderColor: Color4.Green(),\n            }}\n          >\n            <UiEntity\n              uiTransform={{\n                width: 15 * scaleFactor,\n                height: 15 * scaleFactor,\n                margin: { right: 4 * scaleFactor, top: 4 * scaleFactor },\n              }}\n              uiBackground={{\n                textureMode: 'stretch',\n                texture: {\n                  src: ERROR_ICON,\n                },\n              }}\n            />\n            <Label\n              fontSize={14 * scaleFactor}\n              textAlign=\"middle-left\"\n              color={Color4.fromHexString('#FF0000')}\n              value=\"Stream timed out. Please restart stream in broadcasting software.\"\n            />\n          </UiEntity>\n        )}\n        {video?.src === LIVEKIT_STREAM_SRC && state.videoControl.selectedStream === 'live' ? (\n          <Button\n            id=\"video_control_share_screen_clear\"\n            value=\"<b>Deactivate</b>\"\n            variant=\"text\"\n            fontSize={16 * scaleFactor}\n            color={Color4.White()}\n            uiTransform={{\n              minWidth: 120 * scaleFactor,\n              margin: { right: 8 * scaleFactor },\n              padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n            }}\n            onMouseDown={() => {\n              controls.setSource('');\n              state.videoControl.selectedStream = undefined;\n            }}\n          />\n        ) : (\n          <Button\n            id=\"video_control_share_screen_share\"\n            value=\"<b>Activate</b>\"\n            labelTransform={{\n              margin: { left: 20 * scaleFactor, right: 20 * scaleFactor },\n            }}\n            uiTransform={{\n              minWidth: 120 * scaleFactor,\n            }}\n            fontSize={16 * scaleFactor}\n            uiBackground={{ color: COLORS.SUCCESS }}\n            color={Color4.Black()}\n            onMouseDown={() => {\n              controls.setSource(LIVEKIT_STREAM_SRC);\n              state.videoControl.selectedStream = 'live';\n            }}\n          />\n        )}\n      </UiEntity>\n      <VideoControlVolume\n        engine={engine}\n        label=\"<b>Stream Volume</b>\"\n        entity={entity}\n        video={video}\n      />\n      <UiEntity>\n        <Button\n          id=\"video_control_reset_stream_key\"\n          value=\"<b>Reset Stream Key</b>\"\n          variant=\"text\"\n          fontSize={16 * scaleFactor}\n          color={Color4.fromHexString('#FB3B3B')}\n          uiTransform={{\n            margin: { right: 8 * scaleFactor, top: 20 * scaleFactor },\n            padding: { left: 8 * scaleFactor, right: 8 * scaleFactor },\n          }}\n          onMouseDown={() => onReset()}\n        />\n      </UiEntity>\n    </UiEntity>\n  );\n}\n\n// Helper function to format time remaining - shows days if > 1 day, otherwise shows hh:mm:ss\nfunction formatTimeRemaining(endsAt: number): string {\n  const now = Date.now();\n  const timeRemaining = Math.max(0, endsAt - now);\n\n  const days = Math.floor(timeRemaining / (1000 * 60 * 60 * 24));\n\n  if (days >= 1) {\n    return `${days} ${days === 1 ? 'day' : 'days'}`;\n  } else {\n    const hours = Math.floor(timeRemaining / (1000 * 60 * 60));\n    const minutes = Math.floor((timeRemaining % (1000 * 60 * 60)) / (1000 * 60));\n    const seconds = Math.floor((timeRemaining % (1000 * 60)) / 1000);\n    return `${hours.toString().padStart(2, '0')}:${minutes.toString().padStart(2, '0')}:${seconds.toString().padStart(2, '0')}`;\n  }\n}\n"]}
|