@imposium-hub/components 1.44.4 → 1.45.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/esm/Util.d.ts +19 -0
- package/dist/esm/Util.js +233 -0
- package/dist/esm/Util.js.map +1 -0
- package/dist/esm/components/Tooltip.d.ts +7 -0
- package/dist/esm/components/Tooltip.js +32 -0
- package/dist/esm/components/Tooltip.js.map +1 -0
- package/dist/esm/components/app-wrapper/AppWrapper.d.ts +27 -0
- package/dist/esm/components/app-wrapper/AppWrapper.js +185 -0
- package/dist/esm/components/app-wrapper/AppWrapper.js.map +1 -0
- package/dist/esm/components/asset-details/AssetDetails.d.ts +2 -0
- package/dist/esm/components/asset-details/AssetDetails.js +52 -0
- package/dist/esm/components/asset-details/AssetDetails.js.map +1 -0
- package/dist/esm/components/assets/AssetField.d.ts +2 -0
- package/dist/esm/components/assets/AssetField.js +121 -0
- package/dist/esm/components/assets/AssetField.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableComplexTagCell.d.ts +2 -0
- package/dist/esm/components/assets/AssetsTableComplexTagCell.js +48 -0
- package/dist/esm/components/assets/AssetsTableComplexTagCell.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableDateCell.d.ts +6 -0
- package/dist/esm/components/assets/AssetsTableDateCell.js +6 -0
- package/dist/esm/components/assets/AssetsTableDateCell.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableDropzone.d.ts +10 -0
- package/dist/esm/components/assets/AssetsTableDropzone.js +20 -0
- package/dist/esm/components/assets/AssetsTableDropzone.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableDurationCell.d.ts +3 -0
- package/dist/esm/components/assets/AssetsTableDurationCell.js +29 -0
- package/dist/esm/components/assets/AssetsTableDurationCell.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableNameCell.d.ts +2 -0
- package/dist/esm/components/assets/AssetsTableNameCell.js +34 -0
- package/dist/esm/components/assets/AssetsTableNameCell.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableNameFilter.d.ts +2 -0
- package/dist/esm/components/assets/AssetsTableNameFilter.js +20 -0
- package/dist/esm/components/assets/AssetsTableNameFilter.js.map +1 -0
- package/dist/esm/components/assets/AssetsTablePreviewCell.d.ts +20 -0
- package/dist/esm/components/assets/AssetsTablePreviewCell.js +76 -0
- package/dist/esm/components/assets/AssetsTablePreviewCell.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableSelectCell.d.ts +2 -0
- package/dist/esm/components/assets/AssetsTableSelectCell.js +38 -0
- package/dist/esm/components/assets/AssetsTableSelectCell.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableSelectFilter.d.ts +2 -0
- package/dist/esm/components/assets/AssetsTableSelectFilter.js +27 -0
- package/dist/esm/components/assets/AssetsTableSelectFilter.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableStatusCell.d.ts +6 -0
- package/dist/esm/components/assets/AssetsTableStatusCell.js +9 -0
- package/dist/esm/components/assets/AssetsTableStatusCell.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableTagsCell.d.ts +7 -0
- package/dist/esm/components/assets/AssetsTableTagsCell.js +6 -0
- package/dist/esm/components/assets/AssetsTableTagsCell.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableTagsFilter.d.ts +2 -0
- package/dist/esm/components/assets/AssetsTableTagsFilter.js +20 -0
- package/dist/esm/components/assets/AssetsTableTagsFilter.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableTagsPivot.d.ts +2 -0
- package/dist/esm/components/assets/AssetsTableTagsPivot.js +52 -0
- package/dist/esm/components/assets/AssetsTableTagsPivot.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableTypeCell.d.ts +6 -0
- package/dist/esm/components/assets/AssetsTableTypeCell.js +7 -0
- package/dist/esm/components/assets/AssetsTableTypeCell.js.map +1 -0
- package/dist/esm/components/assets/AssetsTableTypeFilter.d.ts +2 -0
- package/dist/esm/components/assets/AssetsTableTypeFilter.js +47 -0
- package/dist/esm/components/assets/AssetsTableTypeFilter.js.map +1 -0
- package/dist/esm/components/assets/AssetsTypeIcon.d.ts +6 -0
- package/dist/esm/components/assets/AssetsTypeIcon.js +38 -0
- package/dist/esm/components/assets/AssetsTypeIcon.js.map +1 -0
- package/dist/esm/components/assets/AssetsUploadMenu.d.ts +2 -0
- package/dist/esm/components/assets/AssetsUploadMenu.js +52 -0
- package/dist/esm/components/assets/AssetsUploadMenu.js.map +1 -0
- package/dist/esm/components/assets/DataTableDnDWrapper.d.ts +11 -0
- package/dist/esm/components/assets/DataTableDnDWrapper.js +17 -0
- package/dist/esm/components/assets/DataTableDnDWrapper.js.map +1 -0
- package/dist/esm/components/assets/DroppableAssetRenderer.d.ts +7 -0
- package/dist/esm/components/assets/DroppableAssetRenderer.js +17 -0
- package/dist/esm/components/assets/DroppableAssetRenderer.js.map +1 -0
- package/dist/esm/components/assets/FontAssetPreview.d.ts +15 -0
- package/dist/esm/components/assets/FontAssetPreview.js +53 -0
- package/dist/esm/components/assets/FontAssetPreview.js.map +1 -0
- package/dist/esm/components/assets/PreviewNotAvailable.d.ts +6 -0
- package/dist/esm/components/assets/PreviewNotAvailable.js +15 -0
- package/dist/esm/components/assets/PreviewNotAvailable.js.map +1 -0
- package/dist/esm/components/auth-gate/AuthGate.d.ts +2 -0
- package/dist/esm/components/auth-gate/AuthGate.js +50 -0
- package/dist/esm/components/auth-gate/AuthGate.js.map +1 -0
- package/dist/esm/components/button/Button.d.ts +23 -0
- package/dist/esm/components/button/Button.js +51 -0
- package/dist/esm/components/button/Button.js.map +1 -0
- package/dist/esm/components/button/Button.stories.d.ts +10 -0
- package/dist/esm/components/button/Button.stories.js +83 -0
- package/dist/esm/components/button/Button.stories.js.map +1 -0
- package/dist/esm/components/button-group-field/ButtonGroupField.d.ts +28 -0
- package/dist/esm/components/button-group-field/ButtonGroupField.js +45 -0
- package/dist/esm/components/button-group-field/ButtonGroupField.js.map +1 -0
- package/dist/esm/components/button-group-field/ButtonGroupField.stories.d.ts +8 -0
- package/dist/esm/components/button-group-field/ButtonGroupField.stories.js +23 -0
- package/dist/esm/components/button-group-field/ButtonGroupField.stories.js.map +1 -0
- package/dist/esm/components/button-menu/ButtonMenu.d.ts +24 -0
- package/dist/esm/components/button-menu/ButtonMenu.js +97 -0
- package/dist/esm/components/button-menu/ButtonMenu.js.map +1 -0
- package/dist/esm/components/button-menu/ButtonMenu.stories.d.ts +8 -0
- package/dist/esm/components/button-menu/ButtonMenu.stories.js +20 -0
- package/dist/esm/components/button-menu/ButtonMenu.stories.js.map +1 -0
- package/dist/esm/components/button-menu/ButtonMenuItem.d.ts +11 -0
- package/dist/esm/components/button-menu/ButtonMenuItem.js +12 -0
- package/dist/esm/components/button-menu/ButtonMenuItem.js.map +1 -0
- package/dist/esm/components/card/Card.d.ts +24 -0
- package/dist/esm/components/card/Card.js +86 -0
- package/dist/esm/components/card/Card.js.map +1 -0
- package/dist/esm/components/card/Card.stories.d.ts +8 -0
- package/dist/esm/components/card/Card.stories.js +13 -0
- package/dist/esm/components/card/Card.stories.js.map +1 -0
- package/dist/esm/components/checkbox-field/CheckboxField.d.ts +18 -0
- package/dist/esm/components/checkbox-field/CheckboxField.js +22 -0
- package/dist/esm/components/checkbox-field/CheckboxField.js.map +1 -0
- package/dist/esm/components/checkbox-field/CheckboxField.stories.d.ts +8 -0
- package/dist/esm/components/checkbox-field/CheckboxField.stories.js +12 -0
- package/dist/esm/components/checkbox-field/CheckboxField.stories.js.map +1 -0
- package/dist/esm/components/color-field/ColorField.d.ts +31 -0
- package/dist/esm/components/color-field/ColorField.js +73 -0
- package/dist/esm/components/color-field/ColorField.js.map +1 -0
- package/dist/esm/components/color-field/ColorFiled.stories.d.ts +8 -0
- package/dist/esm/components/color-field/ColorFiled.stories.js +13 -0
- package/dist/esm/components/color-field/ColorFiled.stories.js.map +1 -0
- package/dist/esm/components/compositions/TextLayer.d.ts +26 -0
- package/dist/esm/components/compositions/TextLayer.js +176 -0
- package/dist/esm/components/compositions/TextLayer.js.map +1 -0
- package/dist/esm/components/controlled-list/ControlledList.d.ts +13 -0
- package/dist/esm/components/controlled-list/ControlledList.js +28 -0
- package/dist/esm/components/controlled-list/ControlledList.js.map +1 -0
- package/dist/esm/components/controlled-list/ControlledList.stories.d.ts +8 -0
- package/dist/esm/components/controlled-list/ControlledList.stories.js +11 -0
- package/dist/esm/components/controlled-list/ControlledList.stories.js.map +1 -0
- package/dist/esm/components/data-table/DataTable.d.ts +37 -0
- package/dist/esm/components/data-table/DataTable.js +186 -0
- package/dist/esm/components/data-table/DataTable.js.map +1 -0
- package/dist/esm/components/data-table/DataTablePaginator.d.ts +14 -0
- package/dist/esm/components/data-table/DataTablePaginator.js +38 -0
- package/dist/esm/components/data-table/DataTablePaginator.js.map +1 -0
- package/dist/esm/components/data-table/Paginator.d.ts +3 -0
- package/dist/esm/components/data-table/Paginator.js +41 -0
- package/dist/esm/components/data-table/Paginator.js.map +1 -0
- package/dist/esm/components/determinate-loader/DeterminateLoader.d.ts +5 -0
- package/dist/esm/components/determinate-loader/DeterminateLoader.js +8 -0
- package/dist/esm/components/determinate-loader/DeterminateLoader.js.map +1 -0
- package/dist/esm/components/determinate-loader/DeterminateLoader.stories.d.ts +9 -0
- package/dist/esm/components/determinate-loader/DeterminateLoader.stories.js +21 -0
- package/dist/esm/components/determinate-loader/DeterminateLoader.stories.js.map +1 -0
- package/dist/esm/components/dropdown/Dropdown.d.ts +27 -0
- package/dist/esm/components/dropdown/Dropdown.js +94 -0
- package/dist/esm/components/dropdown/Dropdown.js.map +1 -0
- package/dist/esm/components/dropdown/dropdown.stories.d.ts +20 -0
- package/dist/esm/components/dropdown/dropdown.stories.js +15 -0
- package/dist/esm/components/dropdown/dropdown.stories.js.map +1 -0
- package/dist/esm/components/field-wrapper/FieldWrapper.d.ts +26 -0
- package/dist/esm/components/field-wrapper/FieldWrapper.js +81 -0
- package/dist/esm/components/field-wrapper/FieldWrapper.js.map +1 -0
- package/dist/esm/components/field-wrapper/FieldWrapper.stories.d.ts +8 -0
- package/dist/esm/components/field-wrapper/FieldWrapper.stories.js +12 -0
- package/dist/esm/components/field-wrapper/FieldWrapper.stories.js.map +1 -0
- package/dist/esm/components/h-rule/HRule.d.ts +3 -0
- package/dist/esm/components/h-rule/HRule.js +10 -0
- package/dist/esm/components/h-rule/HRule.js.map +1 -0
- package/dist/esm/components/h-rule/HRule.stories.d.ts +7 -0
- package/dist/esm/components/h-rule/HRule.stories.js +13 -0
- package/dist/esm/components/h-rule/HRule.stories.js.map +1 -0
- package/dist/esm/components/header/Header.d.ts +55 -0
- package/dist/esm/components/header/Header.js +240 -0
- package/dist/esm/components/header/Header.js.map +1 -0
- package/dist/esm/components/list-field/ListField.d.ts +35 -0
- package/dist/esm/components/list-field/ListField.js +95 -0
- package/dist/esm/components/list-field/ListField.js.map +1 -0
- package/dist/esm/components/list-field/ListField.stories.d.ts +8 -0
- package/dist/esm/components/list-field/ListField.stories.js +10 -0
- package/dist/esm/components/list-field/ListField.stories.js.map +1 -0
- package/dist/esm/components/log-viewer/LogViewer.d.ts +21 -0
- package/dist/esm/components/log-viewer/LogViewer.js +61 -0
- package/dist/esm/components/log-viewer/LogViewer.js.map +1 -0
- package/dist/esm/components/media-variable-field/MediaVariableField.d.ts +27 -0
- package/dist/esm/components/media-variable-field/MediaVariableField.js +135 -0
- package/dist/esm/components/media-variable-field/MediaVariableField.js.map +1 -0
- package/dist/esm/components/modal/Modal.d.ts +16 -0
- package/dist/esm/components/modal/Modal.js +36 -0
- package/dist/esm/components/modal/Modal.js.map +1 -0
- package/dist/esm/components/modal/Modal.stories.d.ts +8 -0
- package/dist/esm/components/modal/Modal.stories.js +28 -0
- package/dist/esm/components/modal/Modal.stories.js.map +1 -0
- package/dist/esm/components/no-access/NoAccess.d.ts +6 -0
- package/dist/esm/components/no-access/NoAccess.js +23 -0
- package/dist/esm/components/no-access/NoAccess.js.map +1 -0
- package/dist/esm/components/number-field/NumberField.d.ts +26 -0
- package/dist/esm/components/number-field/NumberField.js +48 -0
- package/dist/esm/components/number-field/NumberField.js.map +1 -0
- package/dist/esm/components/number-field/NumberField.stories.d.ts +8 -0
- package/dist/esm/components/number-field/NumberField.stories.js +16 -0
- package/dist/esm/components/number-field/NumberField.stories.js.map +1 -0
- package/dist/esm/components/players/AudioPlayer.d.ts +17 -0
- package/dist/esm/components/players/AudioPlayer.js +30 -0
- package/dist/esm/components/players/AudioPlayer.js.map +1 -0
- package/dist/esm/components/players/ImagePlayer.d.ts +20 -0
- package/dist/esm/components/players/ImagePlayer.js +42 -0
- package/dist/esm/components/players/ImagePlayer.js.map +1 -0
- package/dist/esm/components/players/ImagePreview.d.ts +19 -0
- package/dist/esm/components/players/ImagePreview.js +38 -0
- package/dist/esm/components/players/ImagePreview.js.map +1 -0
- package/dist/esm/components/players/ImageSequencePlayer.d.ts +20 -0
- package/dist/esm/components/players/ImageSequencePlayer.js +41 -0
- package/dist/esm/components/players/ImageSequencePlayer.js.map +1 -0
- package/dist/esm/components/players/TemplatePlayer.d.ts +17 -0
- package/dist/esm/components/players/TemplatePlayer.js +31 -0
- package/dist/esm/components/players/TemplatePlayer.js.map +1 -0
- package/dist/esm/components/players/VideoPlayer.d.ts +40 -0
- package/dist/esm/components/players/VideoPlayer.js +81 -0
- package/dist/esm/components/players/VideoPlayer.js.map +1 -0
- package/dist/esm/components/players/VideoPreview.d.ts +16 -0
- package/dist/esm/components/players/VideoPreview.js +34 -0
- package/dist/esm/components/players/VideoPreview.js.map +1 -0
- package/dist/esm/components/portal/Portal.d.ts +7 -0
- package/dist/esm/components/portal/Portal.js +15 -0
- package/dist/esm/components/portal/Portal.js.map +1 -0
- package/dist/esm/components/publish-wizard/PublishWizard.d.ts +35 -0
- package/dist/esm/components/publish-wizard/PublishWizard.js +309 -0
- package/dist/esm/components/publish-wizard/PublishWizard.js.map +1 -0
- package/dist/esm/components/publish-wizard/publish/APIIntegration.d.ts +5 -0
- package/dist/esm/components/publish-wizard/publish/APIIntegration.js +18 -0
- package/dist/esm/components/publish-wizard/publish/APIIntegration.js.map +1 -0
- package/dist/esm/components/publish-wizard/publish/EmailWorkflow.d.ts +2 -0
- package/dist/esm/components/publish-wizard/publish/EmailWorkflow.js +347 -0
- package/dist/esm/components/publish-wizard/publish/EmailWorkflow.js.map +1 -0
- package/dist/esm/components/publish-wizard/publish/HubSpotFlow.d.ts +16 -0
- package/dist/esm/components/publish-wizard/publish/HubSpotFlow.js +49 -0
- package/dist/esm/components/publish-wizard/publish/HubSpotFlow.js.map +1 -0
- package/dist/esm/components/publish-wizard/publish/PublishStatusIndicator.d.ts +2 -0
- package/dist/esm/components/publish-wizard/publish/PublishStatusIndicator.js +60 -0
- package/dist/esm/components/publish-wizard/publish/PublishStatusIndicator.js.map +1 -0
- package/dist/esm/components/publish-wizard/publish/WebpageHosted.d.ts +19 -0
- package/dist/esm/components/publish-wizard/publish/WebpageHosted.js +100 -0
- package/dist/esm/components/publish-wizard/publish/WebpageHosted.js.map +1 -0
- package/dist/esm/components/section/Section.d.ts +3 -0
- package/dist/esm/components/section/Section.js +17 -0
- package/dist/esm/components/section/Section.js.map +1 -0
- package/dist/esm/components/section/Section.stories.d.ts +7 -0
- package/dist/esm/components/section/Section.stories.js +33 -0
- package/dist/esm/components/section/Section.stories.js.map +1 -0
- package/dist/esm/components/select-field/SelectField.d.ts +28 -0
- package/dist/esm/components/select-field/SelectField.js +68 -0
- package/dist/esm/components/select-field/SelectField.js.map +1 -0
- package/dist/esm/components/select-field/SelectField.stories.d.ts +8 -0
- package/dist/esm/components/select-field/SelectField.stories.js +9 -0
- package/dist/esm/components/select-field/SelectField.stories.js.map +1 -0
- package/dist/esm/components/service-icon/ServiceIcon.d.ts +7 -0
- package/dist/esm/components/service-icon/ServiceIcon.js +52 -0
- package/dist/esm/components/service-icon/ServiceIcon.js.map +1 -0
- package/dist/esm/components/service-icon/ServiceIcon.test.d.ts +0 -0
- package/dist/esm/components/service-icon/ServiceIcon.test.js +1 -0
- package/dist/esm/components/service-icon/ServiceIcon.test.js.map +1 -0
- package/dist/esm/components/shortcut-menu/ShortcutMenu.d.ts +6 -0
- package/dist/esm/components/shortcut-menu/ShortcutMenu.js +14 -0
- package/dist/esm/components/shortcut-menu/ShortcutMenu.js.map +1 -0
- package/dist/esm/components/shortcut-menu/ShortcutMenu.stories.d.ts +7 -0
- package/dist/esm/components/shortcut-menu/ShortcutMenu.stories.js +15 -0
- package/dist/esm/components/shortcut-menu/ShortcutMenu.stories.js.map +1 -0
- package/dist/esm/components/slider-field/SliderField.d.ts +28 -0
- package/dist/esm/components/slider-field/SliderField.js +48 -0
- package/dist/esm/components/slider-field/SliderField.js.map +1 -0
- package/dist/esm/components/slider-field/SliderField.stories.d.ts +8 -0
- package/dist/esm/components/slider-field/SliderField.stories.js +15 -0
- package/dist/esm/components/slider-field/SliderField.stories.js.map +1 -0
- package/dist/esm/components/spinner/Spinner.d.ts +3 -0
- package/dist/esm/components/spinner/Spinner.js +8 -0
- package/dist/esm/components/spinner/Spinner.js.map +1 -0
- package/dist/esm/components/story-previewer/StoryPreviewer.d.ts +2 -0
- package/dist/esm/components/story-previewer/StoryPreviewer.js +488 -0
- package/dist/esm/components/story-previewer/StoryPreviewer.js.map +1 -0
- package/dist/esm/components/tabs/Tabs.d.ts +13 -0
- package/dist/esm/components/tabs/Tabs.js +131 -0
- package/dist/esm/components/tabs/Tabs.js.map +1 -0
- package/dist/esm/components/tabs/Tabs.stories.d.ts +9 -0
- package/dist/esm/components/tabs/Tabs.stories.js +36 -0
- package/dist/esm/components/tabs/Tabs.stories.js.map +1 -0
- package/dist/esm/components/tag/Tag.d.ts +8 -0
- package/dist/esm/components/tag/Tag.js +17 -0
- package/dist/esm/components/tag/Tag.js.map +1 -0
- package/dist/esm/components/tag/Tag.test.d.ts +0 -0
- package/dist/esm/components/tag/Tag.test.js +1 -0
- package/dist/esm/components/tag/Tag.test.js.map +1 -0
- package/dist/esm/components/text-area-field/TextAreaField.d.ts +41 -0
- package/dist/esm/components/text-area-field/TextAreaField.js +117 -0
- package/dist/esm/components/text-area-field/TextAreaField.js.map +1 -0
- package/dist/esm/components/text-area-field/TextAreaField.stories.d.ts +8 -0
- package/dist/esm/components/text-area-field/TextAreaField.stories.js +9 -0
- package/dist/esm/components/text-area-field/TextAreaField.stories.js.map +1 -0
- package/dist/esm/components/text-field/TextField.d.ts +63 -0
- package/dist/esm/components/text-field/TextField.js +304 -0
- package/dist/esm/components/text-field/TextField.js.map +1 -0
- package/dist/esm/components/text-field/TextField.stories.d.ts +8 -0
- package/dist/esm/components/text-field/TextField.stories.js +9 -0
- package/dist/esm/components/text-field/TextField.stories.js.map +1 -0
- package/dist/esm/components/toast-service/ToastService.d.ts +6 -0
- package/dist/esm/components/toast-service/ToastService.js +50 -0
- package/dist/esm/components/toast-service/ToastService.js.map +1 -0
- package/dist/esm/constants/api.d.ts +5 -0
- package/dist/esm/constants/api.js +6 -0
- package/dist/esm/constants/api.js.map +1 -0
- package/dist/esm/constants/assets.d.ts +17 -0
- package/dist/esm/constants/assets.js +23 -0
- package/dist/esm/constants/assets.js.map +1 -0
- package/dist/esm/constants/compositions.d.ts +60 -0
- package/dist/esm/constants/compositions.js +132 -0
- package/dist/esm/constants/compositions.js.map +1 -0
- package/dist/esm/constants/copy.d.ts +181 -0
- package/dist/esm/constants/copy.js +191 -0
- package/dist/esm/constants/copy.js.map +1 -0
- package/dist/esm/constants/dnd.d.ts +1 -0
- package/dist/esm/constants/dnd.js +4 -0
- package/dist/esm/constants/dnd.js.map +1 -0
- package/dist/esm/constants/icons.d.ts +59 -0
- package/dist/esm/constants/icons.js +119 -0
- package/dist/esm/constants/icons.js.map +1 -0
- package/dist/esm/constants/player.d.ts +1 -0
- package/dist/esm/constants/player.js +2 -0
- package/dist/esm/constants/player.js.map +1 -0
- package/dist/esm/constants/previewer.d.ts +1 -0
- package/dist/esm/constants/previewer.js +6 -0
- package/dist/esm/constants/previewer.js.map +1 -0
- package/dist/esm/constants/variables.d.ts +13 -0
- package/dist/esm/constants/variables.js +19 -0
- package/dist/esm/constants/variables.js.map +1 -0
- package/dist/esm/index.d.ts +94 -0
- package/dist/esm/index.js +106 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/interfaces/experience.d.ts +30 -0
- package/dist/esm/interfaces/experience.js +2 -0
- package/dist/esm/interfaces/experience.js.map +1 -0
- package/dist/esm/redux/actions/access.d.ts +16 -0
- package/dist/esm/redux/actions/access.js +127 -0
- package/dist/esm/redux/actions/access.js.map +1 -0
- package/dist/esm/redux/actions/active-batch.d.ts +12 -0
- package/dist/esm/redux/actions/active-batch.js +167 -0
- package/dist/esm/redux/actions/active-batch.js.map +1 -0
- package/dist/esm/redux/actions/asset-filters.d.ts +3 -0
- package/dist/esm/redux/actions/asset-filters.js +7 -0
- package/dist/esm/redux/actions/asset-filters.js.map +1 -0
- package/dist/esm/redux/actions/asset-list.d.ts +11 -0
- package/dist/esm/redux/actions/asset-list.js +144 -0
- package/dist/esm/redux/actions/asset-list.js.map +1 -0
- package/dist/esm/redux/actions/asset-tags.d.ts +5 -0
- package/dist/esm/redux/actions/asset-tags.js +22 -0
- package/dist/esm/redux/actions/asset-tags.js.map +1 -0
- package/dist/esm/redux/actions/asset-uploads.d.ts +7 -0
- package/dist/esm/redux/actions/asset-uploads.js +134 -0
- package/dist/esm/redux/actions/asset-uploads.js.map +1 -0
- package/dist/esm/redux/actions/auth.d.ts +9 -0
- package/dist/esm/redux/actions/auth.js +25 -0
- package/dist/esm/redux/actions/auth.js.map +1 -0
- package/dist/esm/redux/actions/publish.d.ts +7 -0
- package/dist/esm/redux/actions/publish.js +68 -0
- package/dist/esm/redux/actions/publish.js.map +1 -0
- package/dist/esm/redux/actions/selected-assets.d.ts +7 -0
- package/dist/esm/redux/actions/selected-assets.js +44 -0
- package/dist/esm/redux/actions/selected-assets.js.map +1 -0
- package/dist/esm/redux/reducers/access.d.ts +2 -0
- package/dist/esm/redux/reducers/access.js +24 -0
- package/dist/esm/redux/reducers/access.js.map +1 -0
- package/dist/esm/redux/reducers/active-batch.d.ts +2 -0
- package/dist/esm/redux/reducers/active-batch.js +105 -0
- package/dist/esm/redux/reducers/active-batch.js.map +1 -0
- package/dist/esm/redux/reducers/asset-filters.d.ts +2 -0
- package/dist/esm/redux/reducers/asset-filters.js +21 -0
- package/dist/esm/redux/reducers/asset-filters.js.map +1 -0
- package/dist/esm/redux/reducers/asset-list.d.ts +2 -0
- package/dist/esm/redux/reducers/asset-list.js +84 -0
- package/dist/esm/redux/reducers/asset-list.js.map +1 -0
- package/dist/esm/redux/reducers/asset-tags.d.ts +2 -0
- package/dist/esm/redux/reducers/asset-tags.js +12 -0
- package/dist/esm/redux/reducers/asset-tags.js.map +1 -0
- package/dist/esm/redux/reducers/asset-uploads.d.ts +2 -0
- package/dist/esm/redux/reducers/asset-uploads.js +45 -0
- package/dist/esm/redux/reducers/asset-uploads.js.map +1 -0
- package/dist/esm/redux/reducers/auth.d.ts +3 -0
- package/dist/esm/redux/reducers/auth.js +27 -0
- package/dist/esm/redux/reducers/auth.js.map +1 -0
- package/dist/esm/redux/reducers/publish.d.ts +11 -0
- package/dist/esm/redux/reducers/publish.js +18 -0
- package/dist/esm/redux/reducers/publish.js.map +1 -0
- package/dist/esm/redux/reducers/selected-assets.d.ts +2 -0
- package/dist/esm/redux/reducers/selected-assets.js +20 -0
- package/dist/esm/redux/reducers/selected-assets.js.map +1 -0
- package/dist/esm/services/API-Legacy.d.ts +7 -0
- package/dist/esm/services/API-Legacy.js +44 -0
- package/dist/esm/services/API-Legacy.js.map +1 -0
- package/dist/esm/services/API.d.ts +181 -0
- package/dist/esm/services/API.js +965 -0
- package/dist/esm/services/API.js.map +1 -0
- package/dist/esm/services/Auth0.d.ts +18 -0
- package/dist/esm/services/Auth0.js +67 -0
- package/dist/esm/services/Auth0.js.map +1 -0
- package/dist/esm/services/Session.d.ts +25 -0
- package/dist/esm/services/Session.js +165 -0
- package/dist/esm/services/Session.js.map +1 -0
- package/dist/esm/services/Storage.d.ts +4 -0
- package/dist/esm/services/Storage.js +26 -0
- package/dist/esm/services/Storage.js.map +1 -0
- package/dist/esm/services/Timer.d.ts +15 -0
- package/dist/esm/services/Timer.js +25 -0
- package/dist/esm/services/Timer.js.map +1 -0
- package/dist/esm/utils/routing.d.ts +1 -0
- package/dist/esm/utils/routing.js +13 -0
- package/dist/esm/utils/routing.js.map +1 -0
- package/dist/esm/utils/template-generator.d.ts +8 -0
- package/dist/esm/utils/template-generator.js +22 -0
- package/dist/esm/utils/template-generator.js.map +1 -0
- package/package.json +6 -3
|
@@ -0,0 +1,488 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { VARIABLE_TYPES, BOOLEAN_DEFAULT_OPTIONS } from '../../constants/variables';
|
|
3
|
+
import { OUTPUT_TYPES } from '../../constants/previewer';
|
|
4
|
+
import TextField from '../text-field/TextField';
|
|
5
|
+
import Button from '../button/Button';
|
|
6
|
+
import Spinner from '../spinner/Spinner';
|
|
7
|
+
import NumberField from '../number-field/NumberField';
|
|
8
|
+
import SelectField from '../select-field/SelectField';
|
|
9
|
+
import ButtonGroupField from '../button-group-field/ButtonGroupField';
|
|
10
|
+
import FieldWrapper from '../field-wrapper/FieldWrapper';
|
|
11
|
+
import HRule from '../h-rule/HRule';
|
|
12
|
+
import VideoPlayer from '../players/VideoPlayer';
|
|
13
|
+
import ImagePlayer from '../players/ImagePlayer';
|
|
14
|
+
import MediaVariableField from '../media-variable-field/MediaVariableField';
|
|
15
|
+
import ReactResizeDetector from 'react-resize-detector';
|
|
16
|
+
import { previewer as copy } from '../../constants/copy';
|
|
17
|
+
import { formattedTime } from '../../Util';
|
|
18
|
+
import Timer from '../../services/Timer';
|
|
19
|
+
import LogViewer from '../log-viewer/LogViewer';
|
|
20
|
+
import { connect } from 'react-redux';
|
|
21
|
+
class StoryPreviewer extends React.PureComponent {
|
|
22
|
+
timer;
|
|
23
|
+
evtHandlers;
|
|
24
|
+
TIMEOUT = '02:00';
|
|
25
|
+
constructor(props) {
|
|
26
|
+
super(props);
|
|
27
|
+
const inventory = this.getInventoryDefaults();
|
|
28
|
+
const inventoryOptions = this.getInventoryOptions();
|
|
29
|
+
this.state = {
|
|
30
|
+
inventory,
|
|
31
|
+
inventoryOptions,
|
|
32
|
+
experienceId: null,
|
|
33
|
+
jobId: null,
|
|
34
|
+
experience: null,
|
|
35
|
+
timeElapsed: 0,
|
|
36
|
+
activeOutput: '',
|
|
37
|
+
rendering: false,
|
|
38
|
+
isTimeOut: false,
|
|
39
|
+
};
|
|
40
|
+
this.timer = new Timer({
|
|
41
|
+
interval: 1000,
|
|
42
|
+
onUpdate: (t) => {
|
|
43
|
+
this.setState({ timeElapsed: t });
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
this.evtHandlers = {
|
|
47
|
+
toggleOutput: (e) => this.toggleActiveOutput(e),
|
|
48
|
+
createExp: () => this.createExperience(),
|
|
49
|
+
gotExperience: null
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
componentWillUnmount() {
|
|
53
|
+
const { api, onError } = this.props;
|
|
54
|
+
const { experienceId } = this.state;
|
|
55
|
+
this.timer.stop();
|
|
56
|
+
this.evtHandlers.gotExperience = null;
|
|
57
|
+
api.cancelExperiencePolling();
|
|
58
|
+
}
|
|
59
|
+
getInventoryOptions() {
|
|
60
|
+
const { variables } = this.props;
|
|
61
|
+
const options = {};
|
|
62
|
+
for (const i in variables) {
|
|
63
|
+
if (variables.hasOwnProperty(i)) {
|
|
64
|
+
const inv = variables[i];
|
|
65
|
+
if (inv.defaultItem && inv.defaultItem.type) {
|
|
66
|
+
if (inv.defaultItem.type.toLowerCase() === VARIABLE_TYPES.ENUM) {
|
|
67
|
+
options[inv.id] = inv.defaultItem.options;
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return options;
|
|
73
|
+
}
|
|
74
|
+
getInventoryDefaults() {
|
|
75
|
+
const { variables } = this.props;
|
|
76
|
+
const newInv = {};
|
|
77
|
+
for (const i in variables) {
|
|
78
|
+
if (variables.hasOwnProperty(i)) {
|
|
79
|
+
const inv = variables[i];
|
|
80
|
+
newInv[inv.id] = this.getVariableValue(inv.previewItem);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
return newInv;
|
|
84
|
+
}
|
|
85
|
+
checkInventoryDefaults(prevVariables) {
|
|
86
|
+
const { variables } = this.props;
|
|
87
|
+
const newInv = { ...this.state.inventory };
|
|
88
|
+
for (const i in variables) {
|
|
89
|
+
if (variables.hasOwnProperty(i)) {
|
|
90
|
+
const newVar = variables[i];
|
|
91
|
+
const prevVar = prevVariables[i];
|
|
92
|
+
if (prevVar) {
|
|
93
|
+
const prevValue = this.getVariableValue(prevVar.previewItem);
|
|
94
|
+
const newValue = this.getVariableValue(newVar.previewItem);
|
|
95
|
+
if (newVar.type !== prevVar.type || prevValue !== newValue) {
|
|
96
|
+
newInv[i] = newValue;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
return newInv;
|
|
102
|
+
}
|
|
103
|
+
getVariableValue(previewItem) {
|
|
104
|
+
if (previewItem && previewItem.type) {
|
|
105
|
+
const type = previewItem.type.toLowerCase();
|
|
106
|
+
if (type === VARIABLE_TYPES.IMAGE || type === VARIABLE_TYPES.VIDEO || type === VARIABLE_TYPES.AUDIO) {
|
|
107
|
+
return previewItem.url;
|
|
108
|
+
}
|
|
109
|
+
else {
|
|
110
|
+
return previewItem.src;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
return undefined;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
componentDidMount() {
|
|
118
|
+
// if the experience ID is set when the previewer is mounted, get that experience
|
|
119
|
+
const { experienceId, jobId } = this.props;
|
|
120
|
+
if (experienceId && jobId) {
|
|
121
|
+
this.setState({
|
|
122
|
+
jobId
|
|
123
|
+
}, () => {
|
|
124
|
+
this.getExperience(experienceId);
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
componentDidUpdate(prevProps, prevState) {
|
|
129
|
+
if (prevProps.storyId !== this.props.storyId) {
|
|
130
|
+
this.evtHandlers.gotExperience = null;
|
|
131
|
+
}
|
|
132
|
+
if (prevProps.variables !== this.props.variables) {
|
|
133
|
+
let inventory;
|
|
134
|
+
const inventoryOptions = this.getInventoryOptions();
|
|
135
|
+
if (prevProps.storyId === this.props.storyId) {
|
|
136
|
+
inventory = this.checkInventoryDefaults(prevProps.variables);
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
inventory = this.getInventoryDefaults();
|
|
140
|
+
}
|
|
141
|
+
this.setState({
|
|
142
|
+
inventoryOptions,
|
|
143
|
+
inventory
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
if (this.props.notifications) {
|
|
147
|
+
if (this.props.notifications[0]) {
|
|
148
|
+
if (this.props.notifications[0]['type'] === 'error') {
|
|
149
|
+
this.setState({ isTimeOut: true });
|
|
150
|
+
}
|
|
151
|
+
if (this.props.notifications[0]['type'] === 'info') {
|
|
152
|
+
this.setState({ isTimeOut: false });
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
if (prevState.timeElapsed !== this.state.timeElapsed) {
|
|
157
|
+
if (formattedTime(this.state.timeElapsed) === this.TIMEOUT && !this.state.experience) {
|
|
158
|
+
const { onError, api } = this.props;
|
|
159
|
+
const { experienceId } = this.state;
|
|
160
|
+
api.cancelExperiencePolling()
|
|
161
|
+
.then(() => {
|
|
162
|
+
onError(copy.runExpError.replace('[expId]', experienceId));
|
|
163
|
+
this.resetState(true, () => {
|
|
164
|
+
this.setState({ isTimeOut: true });
|
|
165
|
+
});
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
variableInputChanged(key, value) {
|
|
171
|
+
const inventory = { ...this.state.inventory };
|
|
172
|
+
inventory[key] = value;
|
|
173
|
+
this.setState({
|
|
174
|
+
inventory
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
getViewerOptions() {
|
|
178
|
+
const opts = [];
|
|
179
|
+
const { experience: { output }, jobId } = this.state;
|
|
180
|
+
const videos = output.videos;
|
|
181
|
+
const images = output.images;
|
|
182
|
+
if (videos) {
|
|
183
|
+
for (const key in videos) {
|
|
184
|
+
if (videos.hasOwnProperty(key)) {
|
|
185
|
+
const v = {
|
|
186
|
+
label: `Video: ${key}`,
|
|
187
|
+
value: `${OUTPUT_TYPES.VIDEO}.${key}`
|
|
188
|
+
};
|
|
189
|
+
opts.push(v);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
if (images) {
|
|
194
|
+
for (const key in images) {
|
|
195
|
+
if (images.hasOwnProperty(key)) {
|
|
196
|
+
const i = {
|
|
197
|
+
label: `Image: ${key}`,
|
|
198
|
+
value: `${OUTPUT_TYPES.IMAGE}.${key}`
|
|
199
|
+
};
|
|
200
|
+
opts.push(i);
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
if (jobId) {
|
|
205
|
+
opts.push({
|
|
206
|
+
label: copy.btnLog,
|
|
207
|
+
value: `${OUTPUT_TYPES.LOG}.${jobId}`
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
return opts;
|
|
211
|
+
}
|
|
212
|
+
renderVariableFields() {
|
|
213
|
+
const { inventory, inventoryOptions } = this.state;
|
|
214
|
+
const storyInventory = this.props.variables;
|
|
215
|
+
const fields = [];
|
|
216
|
+
for (const i in storyInventory) {
|
|
217
|
+
if (storyInventory.hasOwnProperty(i)) {
|
|
218
|
+
const inv = storyInventory[i];
|
|
219
|
+
switch (inv.type.toLowerCase()) {
|
|
220
|
+
case VARIABLE_TYPES.TEXT:
|
|
221
|
+
fields.push(React.createElement(TextField, { label: inv.name, key: inv.id, value: inventory[inv.id], onChange: (v) => this.variableInputChanged(inv.id, v) }));
|
|
222
|
+
break;
|
|
223
|
+
case VARIABLE_TYPES.NUMBER:
|
|
224
|
+
fields.push(React.createElement(NumberField, { label: inv.name, key: inv.id, value: inventory[inv.id], onChange: (v) => this.variableInputChanged(inv.id, v) }));
|
|
225
|
+
break;
|
|
226
|
+
case VARIABLE_TYPES.ENUM:
|
|
227
|
+
fields.push(React.createElement(SelectField, { label: inv.name, key: inv.id, value: inventory[inv.id], options: inventoryOptions[inv.id], onChange: (v) => this.variableInputChanged(inv.id, v) }));
|
|
228
|
+
break;
|
|
229
|
+
case VARIABLE_TYPES.BOOLEAN:
|
|
230
|
+
fields.push(React.createElement(ButtonGroupField, { label: inv.name, key: inv.id, value: inventory[inv.id], options: BOOLEAN_DEFAULT_OPTIONS, onChange: (v) => this.variableInputChanged(inv.id, v) }));
|
|
231
|
+
break;
|
|
232
|
+
case VARIABLE_TYPES.IMAGE:
|
|
233
|
+
fields.push(React.createElement(FieldWrapper, { label: inv.name, key: inv.id },
|
|
234
|
+
React.createElement(MediaVariableField, { value: inventory[inv.id], type: inv.type, onChange: (v) => this.variableInputChanged(inv.id, v) })));
|
|
235
|
+
break;
|
|
236
|
+
case VARIABLE_TYPES.VIDEO:
|
|
237
|
+
fields.push(React.createElement(FieldWrapper, { label: inv.name, key: inv.id },
|
|
238
|
+
React.createElement(MediaVariableField, { type: inv.type, value: inventory[inv.id], onChange: (v) => this.variableInputChanged(inv.id, v) })));
|
|
239
|
+
break;
|
|
240
|
+
case VARIABLE_TYPES.AUDIO:
|
|
241
|
+
fields.push(React.createElement(FieldWrapper, { label: inv.name, key: inv.id },
|
|
242
|
+
React.createElement(MediaVariableField, { type: inv.type, value: inventory[inv.id], onChange: (v) => this.variableInputChanged(inv.id, v) })));
|
|
243
|
+
break;
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
return fields;
|
|
248
|
+
}
|
|
249
|
+
getFirstOutput(experience) {
|
|
250
|
+
const videos = experience.output.videos;
|
|
251
|
+
const images = experience.output.images;
|
|
252
|
+
if (videos) {
|
|
253
|
+
for (const key in videos) {
|
|
254
|
+
if (videos.hasOwnProperty(key)) {
|
|
255
|
+
return `${OUTPUT_TYPES.VIDEO}.${key}`;
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
else if (images) {
|
|
260
|
+
for (const key in images) {
|
|
261
|
+
if (images.hasOwnProperty(key)) {
|
|
262
|
+
return `${OUTPUT_TYPES.IMAGE}.${key}`;
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
else {
|
|
267
|
+
return null;
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
getExperience(experienceId, triggerJob = false, compositionId, useWorkingCopy) {
|
|
271
|
+
if (!this.timer.running) {
|
|
272
|
+
this.timer.start();
|
|
273
|
+
}
|
|
274
|
+
const { api, onError, onExperenceLoaded, onJobCreated } = this.props;
|
|
275
|
+
this.setState({
|
|
276
|
+
rendering: true
|
|
277
|
+
}, () => {
|
|
278
|
+
this.setState({
|
|
279
|
+
experienceId
|
|
280
|
+
}, () => {
|
|
281
|
+
if (triggerJob) {
|
|
282
|
+
api.triggerEvent(experienceId, compositionId, useWorkingCopy).then((resTrigger) => {
|
|
283
|
+
this.setState({
|
|
284
|
+
jobId: resTrigger.job_id
|
|
285
|
+
}, () => {
|
|
286
|
+
if (onJobCreated) {
|
|
287
|
+
onJobCreated(experienceId, resTrigger.job_id);
|
|
288
|
+
}
|
|
289
|
+
this.evtHandlers.gotExperience = (resVideo) => {
|
|
290
|
+
this.timer.stop();
|
|
291
|
+
if (onExperenceLoaded) {
|
|
292
|
+
onExperenceLoaded(resVideo);
|
|
293
|
+
}
|
|
294
|
+
this.setState({
|
|
295
|
+
rendering: false,
|
|
296
|
+
activeOutput: this.getFirstOutput(resVideo),
|
|
297
|
+
experience: resVideo,
|
|
298
|
+
});
|
|
299
|
+
};
|
|
300
|
+
const pollingPromise = api.getExperience(experienceId, true).then((resVideo) => {
|
|
301
|
+
if (this.evtHandlers.gotExperience) {
|
|
302
|
+
this.evtHandlers.gotExperience(resVideo);
|
|
303
|
+
}
|
|
304
|
+
}).catch((e) => {
|
|
305
|
+
this.resetState();
|
|
306
|
+
if (onError) {
|
|
307
|
+
if (e.error) {
|
|
308
|
+
onError(e.error);
|
|
309
|
+
}
|
|
310
|
+
else {
|
|
311
|
+
onError(copy.runExpError.replace('[expId]', experienceId));
|
|
312
|
+
}
|
|
313
|
+
}
|
|
314
|
+
});
|
|
315
|
+
});
|
|
316
|
+
}).catch((e) => {
|
|
317
|
+
this.resetState();
|
|
318
|
+
if (onError) {
|
|
319
|
+
onError(copy.triggerExpError.replace('[expId]', experienceId));
|
|
320
|
+
}
|
|
321
|
+
});
|
|
322
|
+
}
|
|
323
|
+
else {
|
|
324
|
+
this.evtHandlers.gotExperience = (resVideo) => {
|
|
325
|
+
this.timer.stop();
|
|
326
|
+
if (onExperenceLoaded) {
|
|
327
|
+
onExperenceLoaded(resVideo);
|
|
328
|
+
}
|
|
329
|
+
this.setState({
|
|
330
|
+
rendering: false,
|
|
331
|
+
activeOutput: this.getFirstOutput(resVideo),
|
|
332
|
+
experience: resVideo
|
|
333
|
+
});
|
|
334
|
+
};
|
|
335
|
+
api.getExperience(experienceId, true).then((resVideo) => {
|
|
336
|
+
if (this.evtHandlers.gotExperience) {
|
|
337
|
+
this.evtHandlers.gotExperience(resVideo);
|
|
338
|
+
}
|
|
339
|
+
}).catch((e) => {
|
|
340
|
+
this.resetState();
|
|
341
|
+
if (onError) {
|
|
342
|
+
if (e.error) {
|
|
343
|
+
onError(e.error);
|
|
344
|
+
}
|
|
345
|
+
else {
|
|
346
|
+
onError(copy.runExpError.replace('[expId]', experienceId));
|
|
347
|
+
}
|
|
348
|
+
}
|
|
349
|
+
});
|
|
350
|
+
}
|
|
351
|
+
});
|
|
352
|
+
});
|
|
353
|
+
}
|
|
354
|
+
createExperience() {
|
|
355
|
+
const { storyId, onNotification, onError, api, onExperienceCreated, compositionId, useWorkingCopy } = this.props;
|
|
356
|
+
this.resetState(false, () => {
|
|
357
|
+
this.setState({
|
|
358
|
+
rendering: true,
|
|
359
|
+
isTimeOut: false,
|
|
360
|
+
}, () => {
|
|
361
|
+
this.timer.start();
|
|
362
|
+
if (onNotification) {
|
|
363
|
+
onNotification(copy.runExpStart);
|
|
364
|
+
}
|
|
365
|
+
api.createExperience(storyId, this.state.inventory, compositionId, useWorkingCopy).then((resExp) => {
|
|
366
|
+
if (onNotification) {
|
|
367
|
+
onNotification(copy.expId.replace('[expId]', resExp.id));
|
|
368
|
+
}
|
|
369
|
+
if (onExperienceCreated) {
|
|
370
|
+
onExperienceCreated(resExp);
|
|
371
|
+
}
|
|
372
|
+
this.getExperience(resExp.id, true, compositionId, useWorkingCopy);
|
|
373
|
+
}).catch((e) => {
|
|
374
|
+
this.resetState();
|
|
375
|
+
const { data, status } = e.response;
|
|
376
|
+
if (onError) {
|
|
377
|
+
if (data && data.error) {
|
|
378
|
+
onError(`${copy.createExpError}: ${data.error}`);
|
|
379
|
+
}
|
|
380
|
+
else {
|
|
381
|
+
onError(`${copy.createExpError}: ${e}`);
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
});
|
|
385
|
+
});
|
|
386
|
+
});
|
|
387
|
+
}
|
|
388
|
+
resetState(isTimeOut, callback) {
|
|
389
|
+
this.timer.stop();
|
|
390
|
+
this.setState({
|
|
391
|
+
rendering: false,
|
|
392
|
+
experienceId: null,
|
|
393
|
+
experience: null,
|
|
394
|
+
jobId: null,
|
|
395
|
+
timeElapsed: !isTimeOut ? 0 : this.state.timeElapsed,
|
|
396
|
+
activeOutput: null,
|
|
397
|
+
isTimeOut: false,
|
|
398
|
+
}, () => {
|
|
399
|
+
if (callback) {
|
|
400
|
+
callback();
|
|
401
|
+
}
|
|
402
|
+
});
|
|
403
|
+
}
|
|
404
|
+
renderViewerContent() {
|
|
405
|
+
const { rendering, experience, timeElapsed, activeOutput, isTimeOut } = this.state;
|
|
406
|
+
const { api, onError } = this.props;
|
|
407
|
+
if (rendering) {
|
|
408
|
+
return React.createElement("div", { className: 'running-prompt' },
|
|
409
|
+
React.createElement(Spinner, null),
|
|
410
|
+
React.createElement("br", null),
|
|
411
|
+
React.createElement("h1", null,
|
|
412
|
+
"\u00A0 ",
|
|
413
|
+
copy.expRunning),
|
|
414
|
+
React.createElement("p", null,
|
|
415
|
+
copy.time,
|
|
416
|
+
"\u00A0",
|
|
417
|
+
formattedTime(timeElapsed)));
|
|
418
|
+
}
|
|
419
|
+
else if (isTimeOut || isTimeOut === undefined) {
|
|
420
|
+
return (React.createElement("div", { className: 'running-prompt error-wrapper' },
|
|
421
|
+
React.createElement("h1", null,
|
|
422
|
+
"\u00A0 ",
|
|
423
|
+
copy.runExpErrorDes),
|
|
424
|
+
React.createElement("p", null,
|
|
425
|
+
copy.time,
|
|
426
|
+
"\u00A0",
|
|
427
|
+
formattedTime(timeElapsed))));
|
|
428
|
+
}
|
|
429
|
+
else if (experience && activeOutput) {
|
|
430
|
+
let player;
|
|
431
|
+
let url;
|
|
432
|
+
const outputArr = activeOutput.split('.');
|
|
433
|
+
const type = outputArr[0];
|
|
434
|
+
const key = outputArr[1];
|
|
435
|
+
if (type === OUTPUT_TYPES.IMAGE) {
|
|
436
|
+
url = experience.output.images[key];
|
|
437
|
+
player = React.createElement(ImagePlayer, { url: url, active: true });
|
|
438
|
+
}
|
|
439
|
+
else if (type === OUTPUT_TYPES.VIDEO) {
|
|
440
|
+
const output = experience.output.videos[key];
|
|
441
|
+
const mWidth = (output.width !== undefined) ? parseInt(output.width, 10) : null;
|
|
442
|
+
const mHeight = (output.height !== undefined) ? parseInt(output.height, 10) : null;
|
|
443
|
+
url = output.url;
|
|
444
|
+
player = React.createElement(VideoPlayer, { url: url, active: true, maxWidth: mWidth, allowManualScale: true, maxHeight: mHeight });
|
|
445
|
+
}
|
|
446
|
+
else if (type === OUTPUT_TYPES.LOG) {
|
|
447
|
+
player = React.createElement("div", { className: 'log' },
|
|
448
|
+
React.createElement(LogViewer, { api: api, onError: onError, jobId: key }));
|
|
449
|
+
}
|
|
450
|
+
return React.createElement(ReactResizeDetector, { handleWidth: true, handleHeight: true }, player);
|
|
451
|
+
}
|
|
452
|
+
return null;
|
|
453
|
+
}
|
|
454
|
+
toggleActiveOutput(e) {
|
|
455
|
+
this.setState({
|
|
456
|
+
activeOutput: e
|
|
457
|
+
});
|
|
458
|
+
}
|
|
459
|
+
render() {
|
|
460
|
+
const { rendering, experience, activeOutput } = this.state;
|
|
461
|
+
const renderCopy = (experience) ? copy.btnReRender : copy.btnRender;
|
|
462
|
+
const btnRender = (!rendering) ?
|
|
463
|
+
React.createElement(Button, { size: 'large', onClick: this.evtHandlers.createExp, color: 'primary', style: 'bold' }, renderCopy) : null;
|
|
464
|
+
let viewerButtons;
|
|
465
|
+
let expIdField;
|
|
466
|
+
if (experience) {
|
|
467
|
+
const viewerOpts = this.getViewerOptions();
|
|
468
|
+
viewerButtons = React.createElement(SelectField, { width: '130px', options: viewerOpts, value: activeOutput, onChange: this.evtHandlers.toggleOutput });
|
|
469
|
+
expIdField = React.createElement(TextField, { readOnly: true, width: '360px', label: copy.expIdField, showCopy: true, value: experience.id });
|
|
470
|
+
}
|
|
471
|
+
return React.createElement("div", { className: 'story-viewer viewer' },
|
|
472
|
+
React.createElement("div", { className: 'variables' },
|
|
473
|
+
React.createElement("h2", null, copy.previewVars),
|
|
474
|
+
React.createElement(HRule, null),
|
|
475
|
+
this.renderVariableFields()),
|
|
476
|
+
React.createElement("div", { className: 'viewer-content' },
|
|
477
|
+
React.createElement("div", { className: 'content-header' },
|
|
478
|
+
btnRender,
|
|
479
|
+
React.createElement("div", { className: 'output' }, viewerButtons),
|
|
480
|
+
React.createElement("div", { className: 'right-interface' }, expIdField)),
|
|
481
|
+
React.createElement("div", { className: 'content-wrapper' }, this.renderViewerContent())));
|
|
482
|
+
}
|
|
483
|
+
}
|
|
484
|
+
const mapStateToProps = (state) => {
|
|
485
|
+
return { notifications: state.notifications };
|
|
486
|
+
};
|
|
487
|
+
export default connect(mapStateToProps, {})(StoryPreviewer);
|
|
488
|
+
//# sourceMappingURL=StoryPreviewer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StoryPreviewer.js","sourceRoot":"","sources":["../../../../src/components/story-previewer/StoryPreviewer.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
export interface ITab {
|
|
3
|
+
content?: any;
|
|
4
|
+
key?: string;
|
|
5
|
+
canClose?: boolean;
|
|
6
|
+
resize?: boolean;
|
|
7
|
+
label: any;
|
|
8
|
+
menuButtons?: JSX.Element;
|
|
9
|
+
}
|
|
10
|
+
declare const _default: React.ForwardRefExoticComponent<Pick<Omit<Omit<Omit<any, "targetRef"> & {
|
|
11
|
+
targetRef?: any;
|
|
12
|
+
}, "width">, "height">, string | number | symbol> & React.RefAttributes<HTMLElement>>;
|
|
13
|
+
export default _default;
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { withResizeDetector } from 'react-resize-detector';
|
|
3
|
+
import ButtonMenu from '../button-menu/ButtonMenu';
|
|
4
|
+
import ButtonMenuItem from '../button-menu/ButtonMenuItem';
|
|
5
|
+
import Button from '../button/Button';
|
|
6
|
+
import { ICON_TIMES, ICON_BARS } from '../../constants/icons';
|
|
7
|
+
class Tabs extends React.PureComponent {
|
|
8
|
+
headerRef;
|
|
9
|
+
constructor(props) {
|
|
10
|
+
super(props);
|
|
11
|
+
this.headerRef = React.createRef();
|
|
12
|
+
this.state = {
|
|
13
|
+
allowableTabsInView: 0,
|
|
14
|
+
isMenuOpen: false,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
componentDidMount() {
|
|
18
|
+
// Count how many tabs fit into parent element and round down
|
|
19
|
+
const allowableTabsInView = Math.floor(this.allowableNumOfTabs());
|
|
20
|
+
this.setState({ allowableTabsInView });
|
|
21
|
+
}
|
|
22
|
+
componentDidUpdate(prevprops) {
|
|
23
|
+
// Count how many tabs fit into parent element and round down
|
|
24
|
+
const allowableTabsInView = Math.floor(this.allowableNumOfTabs());
|
|
25
|
+
this.setState({ allowableTabsInView });
|
|
26
|
+
}
|
|
27
|
+
// Calculate number of tabs to allow before moving them to the burger menu
|
|
28
|
+
allowableNumOfTabs() {
|
|
29
|
+
const { options, tabPadding } = this.props;
|
|
30
|
+
let totalTabWidths = 0;
|
|
31
|
+
const container = this.headerRef.current;
|
|
32
|
+
if (container) {
|
|
33
|
+
const contentWidth = container.offsetWidth;
|
|
34
|
+
for (let i = 0; i < options.length; i++) {
|
|
35
|
+
const option = options[i];
|
|
36
|
+
const buttonWidth = option.canClose || option.menuButtons ? 20 : 0;
|
|
37
|
+
let div = document.createElement('div');
|
|
38
|
+
div.className = 'tab-header-option';
|
|
39
|
+
div.innerHTML = option.label;
|
|
40
|
+
container.appendChild(div);
|
|
41
|
+
totalTabWidths += div.offsetWidth + buttonWidth;
|
|
42
|
+
container.removeChild(div);
|
|
43
|
+
div = null;
|
|
44
|
+
if (totalTabWidths >= contentWidth - tabPadding - 25) {
|
|
45
|
+
return i;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
return options.length;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
renderContent() {
|
|
52
|
+
const { options, activeTab, keepMounted, width, height } = this.props;
|
|
53
|
+
if (keepMounted) {
|
|
54
|
+
const contentArray = [];
|
|
55
|
+
for (const option of options) {
|
|
56
|
+
const active = (option.key === activeTab);
|
|
57
|
+
const content = React.cloneElement(option.content, {
|
|
58
|
+
active,
|
|
59
|
+
width,
|
|
60
|
+
height
|
|
61
|
+
});
|
|
62
|
+
contentArray.push(content);
|
|
63
|
+
}
|
|
64
|
+
if (contentArray.length > 0) {
|
|
65
|
+
return contentArray;
|
|
66
|
+
}
|
|
67
|
+
else {
|
|
68
|
+
return null;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
for (const option of options) {
|
|
73
|
+
if (option.key === activeTab || !activeTab) {
|
|
74
|
+
return option.content;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
return null;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
renderHeader() {
|
|
81
|
+
const { options, activeTab } = this.props;
|
|
82
|
+
const headerOptions = [];
|
|
83
|
+
const menuOptions = [];
|
|
84
|
+
let activeTabInMenu = false;
|
|
85
|
+
for (let i = 0; i < options.length; i++) {
|
|
86
|
+
const { canClose, key, label, menuButtons } = options[i];
|
|
87
|
+
const btnClose = (canClose) ?
|
|
88
|
+
React.createElement(Button, { style: 'subtle', size: 'small', onClick: (e) => {
|
|
89
|
+
e.preventDefault();
|
|
90
|
+
e.stopPropagation();
|
|
91
|
+
this.props.onClose(key);
|
|
92
|
+
} }, ICON_TIMES) : null;
|
|
93
|
+
const buttonMenus = menuButtons ?
|
|
94
|
+
menuButtons
|
|
95
|
+
:
|
|
96
|
+
null;
|
|
97
|
+
const activeClass = (key === activeTab) ? 'active' : '';
|
|
98
|
+
if (i < this.state.allowableTabsInView) {
|
|
99
|
+
headerOptions.push(React.createElement("div", { className: `tab-header-option ${activeClass}`, onClick: () => this.props.onChange(key), key: key },
|
|
100
|
+
label,
|
|
101
|
+
btnClose,
|
|
102
|
+
buttonMenus));
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
if (activeTab === key && !activeTabInMenu) {
|
|
106
|
+
activeTabInMenu = true;
|
|
107
|
+
}
|
|
108
|
+
menuOptions.push(React.createElement(ButtonMenuItem, { key: key, label: React.createElement("span", null,
|
|
109
|
+
label,
|
|
110
|
+
btnClose,
|
|
111
|
+
buttonMenus), onClick: (e) => {
|
|
112
|
+
this.props.onChange(key);
|
|
113
|
+
}, active: activeTab === key }));
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
const btnOpenMenu = React.createElement(Button, { size: 'large', style: 'subtle', color: activeTabInMenu ? 'primary' : null }, ICON_BARS);
|
|
117
|
+
return (React.createElement(React.Fragment, null,
|
|
118
|
+
headerOptions,
|
|
119
|
+
menuOptions.length > 0 ? (React.createElement("span", { className: 'tab-header-menu' },
|
|
120
|
+
React.createElement(ButtonMenu, { position: 'left', items: menuOptions, onClick: (open) => {
|
|
121
|
+
this.setState({ isMenuOpen: open });
|
|
122
|
+
}, isOpen: this.state.isMenuOpen, button: btnOpenMenu }))) : null));
|
|
123
|
+
}
|
|
124
|
+
render() {
|
|
125
|
+
return (React.createElement("div", { className: 'tabs' },
|
|
126
|
+
React.createElement("div", { ref: this.headerRef, className: 'tab-header' }, this.renderHeader()),
|
|
127
|
+
React.createElement("div", { className: 'tab-content' }, this.renderContent())));
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
export default withResizeDetector(Tabs);
|
|
131
|
+
//# sourceMappingURL=Tabs.js.map
|