@imposium-hub/components 2.14.11 → 2.15.0-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/dist/cjs/components/app-wrapper/AppWrapper.d.ts +1 -0
- package/dist/cjs/components/app-wrapper/AppWrapper.js +1 -1
- package/dist/cjs/components/app-wrapper/AppWrapper.js.map +1 -1
- package/dist/cjs/components/app-wrapper/AppWrapperV2.d.ts +26 -0
- package/dist/cjs/components/app-wrapper/AppWrapperV2.js +266 -0
- package/dist/cjs/components/app-wrapper/AppWrapperV2.js.map +1 -0
- package/dist/cjs/components/app-wrapper/AppWrapperV3.d.ts +19 -0
- package/dist/cjs/components/app-wrapper/AppWrapperV3.js +195 -0
- package/dist/cjs/components/app-wrapper/AppWrapperV3.js.map +1 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_BACKUP_73190.d.ts +27 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_BACKUP_73190.js +243 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_BACKUP_73190.js.map +1 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_BASE_73190.d.ts +28 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_BASE_73190.js +255 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_BASE_73190.js.map +1 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_LOCAL_73190.d.ts +27 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_LOCAL_73190.js +243 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_LOCAL_73190.js.map +1 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_REMOTE_73190.d.ts +28 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_REMOTE_73190.js +251 -0
- package/dist/cjs/components/app-wrapper/AppWrapper_REMOTE_73190.js.map +1 -0
- package/dist/cjs/components/auth-gate/AuthGate.d.ts +2 -0
- package/dist/cjs/components/auth-gate/AuthGate.js +105 -0
- package/dist/cjs/components/auth-gate/AuthGate.js.map +1 -0
- package/dist/cjs/components/change-report/ChangeReportTree.d.ts +10 -0
- package/dist/cjs/components/change-report/ChangeReportTree.js +95 -0
- package/dist/cjs/components/change-report/ChangeReportTree.js.map +1 -0
- package/dist/cjs/components/dropdown/{Dropdown.stories.js → dropdown.stories.js} +1 -1
- package/dist/cjs/components/dropdown/{Dropdown.stories.js.map → dropdown.stories.js.map} +1 -1
- package/dist/cjs/components/edit-guide-modal/EditGuideModal.d.ts +8 -0
- package/dist/cjs/components/edit-guide-modal/EditGuideModal.js +132 -0
- package/dist/cjs/components/edit-guide-modal/EditGuideModal.js.map +1 -0
- package/dist/cjs/components/edit-marker-modal/EditMarkerModal.d.ts +8 -0
- package/dist/cjs/components/edit-marker-modal/EditMarkerModal.js +104 -0
- package/dist/cjs/components/edit-marker-modal/EditMarkerModal.js.map +1 -0
- package/dist/cjs/components/error-message-preview/ErrorMessagePreview.d.ts +15 -0
- package/dist/cjs/components/error-message-preview/ErrorMessagePreview.js +91 -0
- package/dist/cjs/components/error-message-preview/ErrorMessagePreview.js.map +1 -0
- package/dist/cjs/components/feature-flag-wrapper/FeatureFlagWrapper.d.ts +7 -0
- package/dist/cjs/components/feature-flag-wrapper/FeatureFlagWrapper.js +48 -0
- package/dist/cjs/components/feature-flag-wrapper/FeatureFlagWrapper.js.map +1 -0
- package/dist/cjs/components/header/Header_BACKUP_73021.d.ts +33 -0
- package/dist/cjs/components/header/Header_BACKUP_73021.js +393 -0
- package/dist/cjs/components/header/Header_BACKUP_73021.js.map +1 -0
- package/dist/cjs/components/header/Header_BASE_73021.d.ts +29 -0
- package/dist/cjs/components/header/Header_BASE_73021.js +376 -0
- package/dist/cjs/components/header/Header_BASE_73021.js.map +1 -0
- package/dist/cjs/components/header/Header_LOCAL_73021.d.ts +33 -0
- package/dist/cjs/components/header/Header_LOCAL_73021.js +382 -0
- package/dist/cjs/components/header/Header_LOCAL_73021.js.map +1 -0
- package/dist/cjs/components/header/Header_REMOTE_73021.d.ts +30 -0
- package/dist/cjs/components/header/Header_REMOTE_73021.js +386 -0
- package/dist/cjs/components/header/Header_REMOTE_73021.js.map +1 -0
- package/dist/cjs/components/header/StoryDropdown.d.ts +6 -0
- package/dist/cjs/components/header/StoryDropdown.js +111 -0
- package/dist/cjs/components/header/StoryDropdown.js.map +1 -0
- package/dist/cjs/components/number-field/NumberField.d.ts +2 -2
- package/dist/cjs/components/number-field/NumberField.js +4 -7
- package/dist/cjs/components/number-field/NumberField.js.map +1 -1
- package/dist/cjs/components/publish-wizard/PublishWizard.d.ts +4 -3
- package/dist/cjs/components/publish-wizard/PublishWizard.js +104 -38
- package/dist/cjs/components/publish-wizard/PublishWizard.js.map +1 -1
- package/dist/cjs/components/replace-files-modal/ReplaceFilesModal.d.ts +11 -0
- package/dist/cjs/components/replace-files-modal/ReplaceFilesModal.js +213 -0
- package/dist/cjs/components/replace-files-modal/ReplaceFilesModal.js.map +1 -0
- package/dist/cjs/components/service-icon/ServiceIcon.test.d.ts +0 -0
- package/dist/cjs/components/service-icon/ServiceIcon.test.js +1 -0
- package/dist/cjs/components/service-icon/ServiceIcon.test.js.map +1 -0
- package/dist/cjs/components/tag/Tag.test.d.ts +0 -0
- package/dist/cjs/components/tag/Tag.test.js +1 -0
- package/dist/cjs/components/tag/Tag.test.js.map +1 -0
- package/dist/cjs/constants/copy.d.ts +9 -0
- package/dist/cjs/constants/copy.js +13 -2
- package/dist/cjs/constants/copy.js.map +1 -1
- package/dist/cjs/constants/snippets.d.ts +18 -0
- package/dist/cjs/constants/snippets.js +3 -0
- package/dist/cjs/constants/snippets.js.map +1 -0
- package/dist/cjs/index.d.ts +3 -1
- package/dist/cjs/index.js +3 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/redux/actions/auth.d.ts +9 -0
- package/dist/cjs/redux/actions/auth.js +30 -0
- package/dist/cjs/redux/actions/auth.js.map +1 -0
- package/dist/cjs/redux/reducers/auth.d.ts +3 -0
- package/dist/cjs/redux/reducers/auth.js +67 -0
- package/dist/cjs/redux/reducers/auth.js.map +1 -0
- package/dist/cjs/services/API.d.ts +2 -0
- package/dist/cjs/services/API.js +6 -0
- package/dist/cjs/services/API.js.map +1 -1
- package/dist/cjs/services/Auth0.d.ts +18 -0
- package/dist/cjs/services/Auth0.js +102 -0
- package/dist/cjs/services/Auth0.js.map +1 -0
- package/dist/cjs/services/Session.d.ts +26 -0
- package/dist/cjs/services/Session.js +155 -0
- package/dist/cjs/services/Session.js.map +1 -0
- package/dist/esm/components/app-wrapper/AppWrapper.d.ts +1 -0
- package/dist/esm/components/app-wrapper/AppWrapper.js +1 -1
- package/dist/esm/components/app-wrapper/AppWrapper.js.map +1 -1
- package/dist/esm/components/app-wrapper/AppWrapperV2.d.ts +26 -0
- package/dist/esm/components/app-wrapper/AppWrapperV2.js +142 -0
- package/dist/esm/components/app-wrapper/AppWrapperV2.js.map +1 -0
- package/dist/esm/components/app-wrapper/AppWrapperV3.d.ts +19 -0
- package/dist/esm/components/app-wrapper/AppWrapperV3.js +88 -0
- package/dist/esm/components/app-wrapper/AppWrapperV3.js.map +1 -0
- package/dist/esm/components/app-wrapper/AppWrapper_BACKUP_73190.d.ts +27 -0
- package/dist/esm/components/app-wrapper/AppWrapper_BACKUP_73190.js +194 -0
- package/dist/esm/components/app-wrapper/AppWrapper_BACKUP_73190.js.map +1 -0
- package/dist/esm/components/app-wrapper/AppWrapper_BASE_73190.d.ts +28 -0
- package/dist/esm/components/app-wrapper/AppWrapper_BASE_73190.js +208 -0
- package/dist/esm/components/app-wrapper/AppWrapper_BASE_73190.js.map +1 -0
- package/dist/esm/components/app-wrapper/AppWrapper_LOCAL_73190.d.ts +27 -0
- package/dist/esm/components/app-wrapper/AppWrapper_LOCAL_73190.js +194 -0
- package/dist/esm/components/app-wrapper/AppWrapper_LOCAL_73190.js.map +1 -0
- package/dist/esm/components/app-wrapper/AppWrapper_REMOTE_73190.d.ts +28 -0
- package/dist/esm/components/app-wrapper/AppWrapper_REMOTE_73190.js +204 -0
- package/dist/esm/components/app-wrapper/AppWrapper_REMOTE_73190.js.map +1 -0
- package/dist/esm/components/auth-gate/AuthGate.d.ts +2 -0
- package/dist/esm/components/auth-gate/AuthGate.js +59 -0
- package/dist/esm/components/auth-gate/AuthGate.js.map +1 -0
- package/dist/esm/components/change-report/ChangeReportTree.d.ts +10 -0
- package/dist/esm/components/change-report/ChangeReportTree.js +42 -0
- package/dist/esm/components/change-report/ChangeReportTree.js.map +1 -0
- package/dist/esm/components/dropdown/{Dropdown.stories.js → dropdown.stories.js} +1 -1
- package/dist/esm/components/dropdown/{Dropdown.stories.js.map → dropdown.stories.js.map} +1 -1
- package/dist/esm/components/edit-guide-modal/EditGuideModal.d.ts +8 -0
- package/dist/esm/components/edit-guide-modal/EditGuideModal.js +65 -0
- package/dist/esm/components/edit-guide-modal/EditGuideModal.js.map +1 -0
- package/dist/esm/components/edit-marker-modal/EditMarkerModal.d.ts +8 -0
- package/dist/esm/components/edit-marker-modal/EditMarkerModal.js +72 -0
- package/dist/esm/components/edit-marker-modal/EditMarkerModal.js.map +1 -0
- package/dist/esm/components/error-message-preview/ErrorMessagePreview.d.ts +15 -0
- package/dist/esm/components/error-message-preview/ErrorMessagePreview.js +35 -0
- package/dist/esm/components/error-message-preview/ErrorMessagePreview.js.map +1 -0
- package/dist/esm/components/feature-flag-wrapper/FeatureFlagWrapper.d.ts +7 -0
- package/dist/esm/components/feature-flag-wrapper/FeatureFlagWrapper.js +10 -0
- package/dist/esm/components/feature-flag-wrapper/FeatureFlagWrapper.js.map +1 -0
- package/dist/esm/components/header/Header_BACKUP_73021.d.ts +33 -0
- package/dist/esm/components/header/Header_BACKUP_73021.js +336 -0
- package/dist/esm/components/header/Header_BACKUP_73021.js.map +1 -0
- package/dist/esm/components/header/Header_BASE_73021.d.ts +29 -0
- package/dist/esm/components/header/Header_BASE_73021.js +322 -0
- package/dist/esm/components/header/Header_BASE_73021.js.map +1 -0
- package/dist/esm/components/header/Header_LOCAL_73021.d.ts +33 -0
- package/dist/esm/components/header/Header_LOCAL_73021.js +328 -0
- package/dist/esm/components/header/Header_LOCAL_73021.js.map +1 -0
- package/dist/esm/components/header/Header_REMOTE_73021.d.ts +30 -0
- package/dist/esm/components/header/Header_REMOTE_73021.js +329 -0
- package/dist/esm/components/header/Header_REMOTE_73021.js.map +1 -0
- package/dist/esm/components/header/StoryDropdown.d.ts +6 -0
- package/dist/esm/components/header/StoryDropdown.js +82 -0
- package/dist/esm/components/header/StoryDropdown.js.map +1 -0
- package/dist/esm/components/number-field/NumberField.d.ts +2 -2
- package/dist/esm/components/number-field/NumberField.js +4 -5
- package/dist/esm/components/number-field/NumberField.js.map +1 -1
- package/dist/esm/components/publish-wizard/PublishWizard.d.ts +4 -3
- package/dist/esm/components/publish-wizard/PublishWizard.js +92 -38
- package/dist/esm/components/publish-wizard/PublishWizard.js.map +1 -1
- package/dist/esm/components/replace-files-modal/ReplaceFilesModal.d.ts +11 -0
- package/dist/esm/components/replace-files-modal/ReplaceFilesModal.js +141 -0
- package/dist/esm/components/replace-files-modal/ReplaceFilesModal.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/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/constants/copy.d.ts +9 -0
- package/dist/esm/constants/copy.js +13 -2
- package/dist/esm/constants/copy.js.map +1 -1
- package/dist/esm/constants/snippets.d.ts +18 -0
- package/dist/esm/constants/snippets.js +2 -0
- package/dist/esm/constants/snippets.js.map +1 -0
- package/dist/esm/index.d.ts +3 -1
- package/dist/esm/index.js +2 -1
- package/dist/esm/index.js.map +1 -1
- 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/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/services/API.d.ts +2 -0
- package/dist/esm/services/API.js +6 -0
- package/dist/esm/services/API.js.map +1 -1
- package/dist/esm/services/Auth0.d.ts +18 -0
- package/dist/esm/services/Auth0.js +68 -0
- package/dist/esm/services/Auth0.js.map +1 -0
- package/dist/esm/services/Session.d.ts +26 -0
- package/dist/esm/services/Session.js +107 -0
- package/dist/esm/services/Session.js.map +1 -0
- package/dist/styles.css +127 -0
- package/dist/styles.less +152 -0
- package/less/components/change-report.less +115 -0
- package/less/components/publish-wizard.less +36 -0
- package/less/entry.less +1 -0
- package/package.json +6 -17
- package/src/components/app-wrapper/AppWrapper.tsx +6 -1
- package/src/components/change-report/ChangeReportTree.tsx +125 -0
- package/src/components/number-field/NumberField.tsx +9 -15
- package/src/components/publish-wizard/PublishWizard.tsx +144 -45
- package/src/components/service-icon/ServiceIcon.test.tsx +0 -0
- package/src/components/tag/Tag.test.tsx +0 -0
- package/src/constants/copy.ts +16 -2
- package/src/constants/snippets.ts +25 -0
- package/src/index.ts +7 -1
- package/src/services/API.ts +8 -0
- package/tsconfig.json +1 -1
- package/src/components/advanced-number-field/AdvancedNumberField.test.tsx +0 -724
- package/src/components/anchor-field/AnchorField.test.tsx +0 -130
- package/src/components/asset-details/AssetDetails.test.tsx +0 -494
- package/src/components/assets/AssetField.test.tsx +0 -449
- package/src/components/assets/AssetsTableAssetIdCell.test.tsx +0 -142
- package/src/components/assets/AssetsTableAssetIdFilter.test.tsx +0 -95
- package/src/components/assets/AssetsTableComplexTagCell.test.tsx +0 -161
- package/src/components/assets/AssetsTableDateCell.test.tsx +0 -106
- package/src/components/assets/AssetsTableDropzone.test.tsx +0 -132
- package/src/components/assets/AssetsTableDurationCell.test.tsx +0 -119
- package/src/components/assets/AssetsTableGlobalCell.test.tsx +0 -46
- package/src/components/assets/AssetsTableNameCell.test.tsx +0 -166
- package/src/components/assets/AssetsTableNameFilter.test.tsx +0 -95
- package/src/components/assets/AssetsTablePreviewCell.test.tsx +0 -191
- package/src/components/assets/AssetsTableRateCell.test.tsx +0 -87
- package/src/components/assets/AssetsTableSelectCell.test.tsx +0 -156
- package/src/components/assets/AssetsTableSelectFilter.test.tsx +0 -119
- package/src/components/assets/AssetsTableStatusCell.test.tsx +0 -60
- package/src/components/number-field/NumberField.test.tsx +0 -383
- package/src/components/text-field/TextField.test.tsx +0 -988
- package/src/test/setup.ts +0 -91
- package/src/test/utils.tsx +0 -44
- package/tsconfig.eslint.json +0 -8
- package/vitest.config.ts +0 -31
- /package/dist/cjs/components/dropdown/{Dropdown.stories.d.ts → dropdown.stories.d.ts} +0 -0
- /package/dist/esm/components/dropdown/{Dropdown.stories.d.ts → dropdown.stories.d.ts} +0 -0
- /package/src/components/dropdown/{Dropdown.stories.tsx → dropdown.stories.tsx} +0 -0
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import NoAccess from '../no-access/NoAccess';
|
|
3
|
+
import Header from '../header/Header';
|
|
4
|
+
import SessionService from '../../services/Session';
|
|
5
|
+
import AuthService from '../../services/Auth0';
|
|
6
|
+
import { connect } from 'react-redux';
|
|
7
|
+
import { bindActionCreators } from 'redux';
|
|
8
|
+
import { login, clearCachedAuth } from '../../redux/actions/auth';
|
|
9
|
+
import { cacheAccessData, clearCachedAccessList } from '../../redux/actions/access';
|
|
10
|
+
import { validateAccessLevel } from '../../Util';
|
|
11
|
+
class AppWrapper extends React.Component {
|
|
12
|
+
static RESTRICTED_REQUEST = (React.createElement(NoAccess, { key: 'restriction-msg', type: 'request' }));
|
|
13
|
+
static RESTRICTED_BLOCK = (React.createElement(NoAccess, { key: 'restriction-msg', type: 'restrict' }));
|
|
14
|
+
static NO_ORGS = (React.createElement(NoAccess, { key: 'restriction-msg', type: 'no-orgs' }));
|
|
15
|
+
constructor(p) {
|
|
16
|
+
super(p);
|
|
17
|
+
this.state = {
|
|
18
|
+
blockRender: true,
|
|
19
|
+
restrictAccess: false
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
componentDidMount = () => {
|
|
23
|
+
const { auth, access, auth0ClientId, auth0Domain, isFreshUser } = this.props;
|
|
24
|
+
const session = SessionService.getSession();
|
|
25
|
+
AuthService.bindToClient(auth0ClientId, auth0Domain);
|
|
26
|
+
const validAccessLevel = validateAccessLevel(this.props.organizationId, this.props.serviceId, this.props.access);
|
|
27
|
+
if (!this.state.restrictAccess && !validAccessLevel) {
|
|
28
|
+
this.setState({ restrictAccess: true });
|
|
29
|
+
}
|
|
30
|
+
if (this.state.restrictAccess && validAccessLevel) {
|
|
31
|
+
this.setState({ restrictAccess: false });
|
|
32
|
+
}
|
|
33
|
+
// If cookie, auth or access data is missing / mismatched,
|
|
34
|
+
// silently check auth0 session and refresh flow on success
|
|
35
|
+
if (!isFreshUser &&
|
|
36
|
+
auth !== null &&
|
|
37
|
+
access !== null &&
|
|
38
|
+
typeof session === 'object' &&
|
|
39
|
+
typeof session.sub === 'string' &&
|
|
40
|
+
session.sub === auth.idTokenPayload.sub &&
|
|
41
|
+
session.stories_hash === SessionService.generateStoriesHash(access) &&
|
|
42
|
+
session.orgs_hash === SessionService.generateOrgsHash(access)) {
|
|
43
|
+
this.propagateCreds();
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
this.doCheckSession(true);
|
|
47
|
+
}
|
|
48
|
+
};
|
|
49
|
+
/*
|
|
50
|
+
Check the auth0 session expiry
|
|
51
|
+
*/
|
|
52
|
+
componentDidUpdate = (prevProps, prevState) => {
|
|
53
|
+
const { auth } = this.props;
|
|
54
|
+
let validAccessLevel;
|
|
55
|
+
if (auth) {
|
|
56
|
+
const { idTokenPayload: { exp } } = auth;
|
|
57
|
+
const validSession = AuthService.checkExpiry(exp);
|
|
58
|
+
if (!validSession) {
|
|
59
|
+
this.props.clearCachedAuth();
|
|
60
|
+
this.props.clearCachedAccessList();
|
|
61
|
+
this.doCheckSession();
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
if (this.props.organizationId !== prevProps.organizationId) {
|
|
65
|
+
validAccessLevel = validateAccessLevel(this.props.organizationId, this.props.serviceId, this.props.access);
|
|
66
|
+
if (!this.state.restrictAccess && !validAccessLevel) {
|
|
67
|
+
this.setState({ restrictAccess: true });
|
|
68
|
+
}
|
|
69
|
+
if (this.state.restrictAccess && validAccessLevel) {
|
|
70
|
+
this.setState({ restrictAccess: false });
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
};
|
|
74
|
+
/*
|
|
75
|
+
Emit creds to React parent
|
|
76
|
+
*/
|
|
77
|
+
propagateCreds = () => {
|
|
78
|
+
const { auth, access, storyId, onAuthenticated } = this.props;
|
|
79
|
+
const activeOrgId = this.determineActiveOrganization(auth, access);
|
|
80
|
+
let activeStoryId = SessionService.getSession().story_id;
|
|
81
|
+
if (storyId) {
|
|
82
|
+
activeStoryId = storyId;
|
|
83
|
+
}
|
|
84
|
+
onAuthenticated(activeOrgId, activeStoryId);
|
|
85
|
+
if (this.state.blockRender) {
|
|
86
|
+
this.setState({ blockRender: false });
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
/*
|
|
90
|
+
Bust cached creds if exist, invoke auth failure handler
|
|
91
|
+
*/
|
|
92
|
+
handleCheckSessionFailure = (e) => {
|
|
93
|
+
this.props.clearCachedAuth();
|
|
94
|
+
this.props.clearCachedAccessList();
|
|
95
|
+
this.props.onAuthenticationFailure(e);
|
|
96
|
+
};
|
|
97
|
+
/*
|
|
98
|
+
Check auth0 session, pull Imposium access creds on success and initialize app-wrapper
|
|
99
|
+
*/
|
|
100
|
+
doCheckSession = (blockRender = false) => {
|
|
101
|
+
const { baseUrl } = this.props;
|
|
102
|
+
if (blockRender) {
|
|
103
|
+
this.setState({ blockRender: true });
|
|
104
|
+
}
|
|
105
|
+
AuthService.checkSession()
|
|
106
|
+
.then((freshIdentity) => {
|
|
107
|
+
SessionService.getAccessData(freshIdentity.idToken, baseUrl)
|
|
108
|
+
.then((freshAccess) => {
|
|
109
|
+
this.props.login(freshIdentity);
|
|
110
|
+
this.props.cacheAccessData(freshAccess);
|
|
111
|
+
SessionService.buildFreshSession(freshIdentity, freshAccess);
|
|
112
|
+
this.propagateCreds();
|
|
113
|
+
})
|
|
114
|
+
.catch((e) => {
|
|
115
|
+
console.error(e);
|
|
116
|
+
this.handleCheckSessionFailure(e);
|
|
117
|
+
});
|
|
118
|
+
})
|
|
119
|
+
.catch((e) => {
|
|
120
|
+
console.error(e);
|
|
121
|
+
this.handleCheckSessionFailure(e);
|
|
122
|
+
});
|
|
123
|
+
};
|
|
124
|
+
determineActiveOrganizationIn(auth, session, organizationIds) {
|
|
125
|
+
const { organizationId } = this.props;
|
|
126
|
+
const { idTokenPayload: { exp } } = auth;
|
|
127
|
+
if (organizationIds.length > 0) {
|
|
128
|
+
if (organizationId && organizationIds.indexOf(organizationId) > -1) {
|
|
129
|
+
return this.setActiveOrganization(organizationId, exp, session);
|
|
130
|
+
}
|
|
131
|
+
if (session &&
|
|
132
|
+
session.organization_id &&
|
|
133
|
+
organizationIds.indexOf(session.organization_id) > -1) {
|
|
134
|
+
return session.organization_id;
|
|
135
|
+
}
|
|
136
|
+
return this.setActiveOrganization(organizationIds[0], exp, session);
|
|
137
|
+
}
|
|
138
|
+
return '';
|
|
139
|
+
}
|
|
140
|
+
/*
|
|
141
|
+
Figure out what the active org should be based on app-wrapper configuration
|
|
142
|
+
*/
|
|
143
|
+
determineActiveOrganization = (auth, access) => {
|
|
144
|
+
const { serviceId } = this.props;
|
|
145
|
+
const { organizations } = access;
|
|
146
|
+
const session = SessionService.getSession();
|
|
147
|
+
const allOrgIdsFlattened = organizations.map((o) => o.id);
|
|
148
|
+
const activeOrgId = this.determineActiveOrganizationIn(auth, session, allOrgIdsFlattened);
|
|
149
|
+
const activeOrg = organizations.find((o) => o.id === activeOrgId);
|
|
150
|
+
if (activeOrg && !activeOrg.services.includes(serviceId)) {
|
|
151
|
+
this.setState({ restrictAccess: true });
|
|
152
|
+
}
|
|
153
|
+
return activeOrgId;
|
|
154
|
+
};
|
|
155
|
+
/*
|
|
156
|
+
Update session if no session exists or diff in org id
|
|
157
|
+
*/
|
|
158
|
+
setActiveOrganization = (organizationId, exp, sharedSession) => {
|
|
159
|
+
if (!sharedSession ||
|
|
160
|
+
!sharedSession.organization_id ||
|
|
161
|
+
sharedSession.organization_id !== organizationId) {
|
|
162
|
+
const activeOrg = this.props.access.organizations.find((o) => o.id === organizationId);
|
|
163
|
+
const firstStoryId = typeof activeOrg.stories[0] === 'object' ? activeOrg.stories[0].id : '';
|
|
164
|
+
SessionService.updateSession({ organization_id: organizationId, story_id: firstStoryId }, exp);
|
|
165
|
+
}
|
|
166
|
+
return organizationId;
|
|
167
|
+
};
|
|
168
|
+
render = () => {
|
|
169
|
+
const { blockRender, restrictAccess } = this.state;
|
|
170
|
+
const { children, showRequestAccess, allowUnauthenticatedRender } = this.props;
|
|
171
|
+
let innerContent;
|
|
172
|
+
if (!blockRender && restrictAccess) {
|
|
173
|
+
const showNoOrgs = this.props.access &&
|
|
174
|
+
this.props.access.organizations &&
|
|
175
|
+
this.props.access.organizations.length === 0;
|
|
176
|
+
const errorIndicator = showNoOrgs
|
|
177
|
+
? AppWrapper.NO_ORGS
|
|
178
|
+
: showRequestAccess
|
|
179
|
+
? AppWrapper.RESTRICTED_REQUEST
|
|
180
|
+
: AppWrapper.RESTRICTED_BLOCK;
|
|
181
|
+
innerContent = [
|
|
182
|
+
typeof children[0] === 'object' && children[0].type === Header && children[0],
|
|
183
|
+
errorIndicator
|
|
184
|
+
];
|
|
185
|
+
}
|
|
186
|
+
if ((!blockRender && !restrictAccess) || allowUnauthenticatedRender) {
|
|
187
|
+
innerContent = children;
|
|
188
|
+
}
|
|
189
|
+
return (React.createElement("div", { id: 'app', className: 'app' }, innerContent));
|
|
190
|
+
};
|
|
191
|
+
}
|
|
192
|
+
const mapDispatchToProps = (dispatch) => {
|
|
193
|
+
return bindActionCreators({
|
|
194
|
+
login,
|
|
195
|
+
clearCachedAuth,
|
|
196
|
+
cacheAccessData,
|
|
197
|
+
clearCachedAccessList
|
|
198
|
+
}, dispatch);
|
|
199
|
+
};
|
|
200
|
+
const mapStateToProps = (state) => {
|
|
201
|
+
return { auth: state.auth, access: state.access };
|
|
202
|
+
};
|
|
203
|
+
export default connect(mapStateToProps, mapDispatchToProps)(AppWrapper);
|
|
204
|
+
//# sourceMappingURL=AppWrapper_REMOTE_73190.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AppWrapper_REMOTE_73190.js","sourceRoot":"","sources":["../../../../src/components/app-wrapper/AppWrapper_REMOTE_73190.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import ScaleLoader from 'react-spinners/ScaleLoader';
|
|
3
|
+
import SessionService from '../../services/Session';
|
|
4
|
+
import AuthService from '../../services/Auth0';
|
|
5
|
+
import { connect } from 'react-redux';
|
|
6
|
+
import { bindActionCreators } from 'redux';
|
|
7
|
+
import { login } from '../../redux/actions/auth';
|
|
8
|
+
import { setAccessData } from '../../redux/actions/access';
|
|
9
|
+
class AuthGate extends React.PureComponent {
|
|
10
|
+
static LOADER_COLOR = '#2d8ceb';
|
|
11
|
+
constructor(p) {
|
|
12
|
+
super(p);
|
|
13
|
+
}
|
|
14
|
+
componentDidMount = () => {
|
|
15
|
+
const { auth0ClientId, auth0Hash, auth0Domain, onAuthenticated, baseUrl } = this.props;
|
|
16
|
+
AuthService.bindToClient(auth0ClientId, auth0Domain);
|
|
17
|
+
if (!auth0Hash) {
|
|
18
|
+
console.info('No hash found, redirecting to login');
|
|
19
|
+
AuthService.login();
|
|
20
|
+
}
|
|
21
|
+
else {
|
|
22
|
+
AuthService.parseIdFromHash(auth0Hash)
|
|
23
|
+
.then((freshIdentity) => {
|
|
24
|
+
// Use the cached org ID and story ID if it exists
|
|
25
|
+
const orgId = SessionService.getCachedOrgId() || null;
|
|
26
|
+
const storyId = SessionService.getCachedStoryId() || null;
|
|
27
|
+
SessionService.getAccessData(freshIdentity.accessToken, baseUrl, false, orgId)
|
|
28
|
+
.then((freshAccess) => {
|
|
29
|
+
this.props.login(freshIdentity);
|
|
30
|
+
this.props.setAccessData(freshAccess);
|
|
31
|
+
SessionService.buildFreshSession(freshIdentity, orgId, storyId);
|
|
32
|
+
onAuthenticated(storyId, orgId);
|
|
33
|
+
})
|
|
34
|
+
.catch((e) => {
|
|
35
|
+
console.error('Error getting access data, redirecting to root');
|
|
36
|
+
console.error(e);
|
|
37
|
+
onAuthenticated(null, null);
|
|
38
|
+
});
|
|
39
|
+
})
|
|
40
|
+
.catch((e) => {
|
|
41
|
+
console.error('Error parsing ID from hash, redirecting to login');
|
|
42
|
+
console.error(e);
|
|
43
|
+
AuthService.login();
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
render = () => {
|
|
48
|
+
return (React.createElement("div", { className: 'auth-gate' },
|
|
49
|
+
React.createElement(ScaleLoader, { color: AuthGate.LOADER_COLOR })));
|
|
50
|
+
};
|
|
51
|
+
}
|
|
52
|
+
const mapDispatchToProps = (dispatch) => {
|
|
53
|
+
return bindActionCreators({
|
|
54
|
+
login,
|
|
55
|
+
setAccessData
|
|
56
|
+
}, dispatch);
|
|
57
|
+
};
|
|
58
|
+
export default connect(null, mapDispatchToProps)(AuthGate);
|
|
59
|
+
//# sourceMappingURL=AuthGate.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AuthGate.js","sourceRoot":"","sources":["../../../../src/components/auth-gate/AuthGate.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { IChangeReportSection } from '../../constants/snippets';
|
|
3
|
+
interface IChangeReportTreeProps {
|
|
4
|
+
sections: IChangeReportSection[] | null;
|
|
5
|
+
defaultExpanded?: boolean;
|
|
6
|
+
emptyMessage?: string;
|
|
7
|
+
loadingMessage?: string;
|
|
8
|
+
}
|
|
9
|
+
declare const ChangeReportTree: React.FC<IChangeReportTreeProps>;
|
|
10
|
+
export default ChangeReportTree;
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import * as copy from '../../constants/copy';
|
|
3
|
+
const STATUS_LABELS = {
|
|
4
|
+
added: copy.publish.statusAdded,
|
|
5
|
+
removed: copy.publish.statusRemoved,
|
|
6
|
+
modified: copy.publish.statusModified
|
|
7
|
+
};
|
|
8
|
+
const ChangeReportNode = ({ node, defaultExpanded, depth }) => {
|
|
9
|
+
const [expanded, setExpanded] = React.useState(defaultExpanded);
|
|
10
|
+
const hasChildren = node.children && node.children.length > 0;
|
|
11
|
+
const hasValues = node.oldValue !== undefined || node.newValue !== undefined;
|
|
12
|
+
const oldDisplay = node.oldValue === null || node.oldValue === '' || node.oldValue === undefined
|
|
13
|
+
? '*empty*'
|
|
14
|
+
: node.oldValue;
|
|
15
|
+
const newDisplay = node.newValue === null || node.newValue === '' || node.newValue === undefined
|
|
16
|
+
? '*empty*'
|
|
17
|
+
: node.newValue;
|
|
18
|
+
return (React.createElement("div", { className: 'change-report-node', style: { paddingLeft: depth * 16 } },
|
|
19
|
+
React.createElement("div", { className: 'change-report-node-row' },
|
|
20
|
+
hasChildren && (React.createElement("span", { className: `change-report-toggle ${expanded ? 'change-report-toggle--expanded' : ''}`, onClick: () => setExpanded(!expanded) }, "\u25B6")),
|
|
21
|
+
!hasChildren && React.createElement("span", { className: 'change-report-toggle-placeholder' }),
|
|
22
|
+
React.createElement("span", { className: `change-report-status change-report-status--${node.status}` }, STATUS_LABELS[node.status]),
|
|
23
|
+
React.createElement("span", { className: 'change-report-label' }, node.label),
|
|
24
|
+
hasValues && (React.createElement("span", { className: 'change-report-values' },
|
|
25
|
+
React.createElement("span", { className: 'change-report-value change-report-value--old' }, oldDisplay),
|
|
26
|
+
React.createElement("span", { className: 'change-report-value-arrow' }, "\u2192"),
|
|
27
|
+
React.createElement("span", { className: 'change-report-value change-report-value--new' }, newDisplay)))),
|
|
28
|
+
hasChildren && expanded && (React.createElement("div", { className: 'change-report-children' }, node.children.map((child, i) => (React.createElement(ChangeReportNode, { key: i, node: child, defaultExpanded: defaultExpanded, depth: depth + 1 })))))));
|
|
29
|
+
};
|
|
30
|
+
const ChangeReportTree = ({ sections, defaultExpanded = true, emptyMessage = copy.publish.noChangesMessage, loadingMessage = copy.publish.loadingChangesMessage }) => {
|
|
31
|
+
if (sections === null) {
|
|
32
|
+
return (React.createElement("div", { className: 'change-report-tree change-report-tree--loading' }, loadingMessage));
|
|
33
|
+
}
|
|
34
|
+
if (sections.length === 0) {
|
|
35
|
+
return React.createElement("div", { className: 'change-report-tree change-report-tree--empty' }, emptyMessage);
|
|
36
|
+
}
|
|
37
|
+
return (React.createElement("div", { className: 'change-report-tree' }, sections.map((section, i) => (React.createElement("div", { key: i, className: 'change-report-section' },
|
|
38
|
+
React.createElement("div", { className: 'change-report-section-heading' }, section.section),
|
|
39
|
+
React.createElement("div", { className: 'change-report-section-nodes' }, section.nodes.map((node, j) => (React.createElement(ChangeReportNode, { key: j, node: node, defaultExpanded: defaultExpanded, depth: 0 })))))))));
|
|
40
|
+
};
|
|
41
|
+
export default ChangeReportTree;
|
|
42
|
+
//# sourceMappingURL=ChangeReportTree.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChangeReportTree.js","sourceRoot":"","sources":["../../../../src/components/change-report/ChangeReportTree.tsx"],"names":[],"mappings":"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"}
|
|
@@ -12,4 +12,4 @@ export const defaultDropDown = () => {
|
|
|
12
12
|
React.createElement(Button, { onClick: () => setToggle(!toggle), ref: dropdownToggleRef }, "Sample DropDown Toggle"),
|
|
13
13
|
React.createElement(ImposiumDropdown, { toggleRef: dropdownToggleRef, show: toggle, position: 'bottomright', onOutsideClick: () => setToggle(!toggle) }, "Sample")));
|
|
14
14
|
};
|
|
15
|
-
//# sourceMappingURL=
|
|
15
|
+
//# sourceMappingURL=dropdown.stories.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"
|
|
1
|
+
{"version":3,"file":"dropdown.stories.js","sourceRoot":"","sources":["../../../../src/components/dropdown/dropdown.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,MAAM,MAAM,kBAAkB,CAAC;AACtC,OAAO,gBAAgB,MAAM,YAAY,CAAC;AAE1C,eAAe;IACX,KAAK,EAAE,UAAU;IACjB,SAAS,EAAE,gBAAgB;CAC9B,CAAC;AAeF,MAAM,CAAC,MAAM,eAAe,GAAG,GAAG,EAAE;IAChC,MAAM,iBAAiB,GAAG,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IAClD,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAElD,OAAO,CACH;QACI,oBAAC,MAAM,IACH,OAAO,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,EACjC,GAAG,EAAE,iBAAiB,6BAEjB;QACT,oBAAC,gBAAgB,IACb,SAAS,EAAE,iBAAiB,EAC5B,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAC,aAAa,EACtB,cAAc,EAAE,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,aAEzB,CACpB,CACN,CAAC;AACN,CAAC,CAAC"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
import React, { useCallback, useEffect, useState } from 'react';
|
|
2
|
+
import ReactDOM from 'react-dom';
|
|
3
|
+
import Modal from '../modal/Modal';
|
|
4
|
+
import Button from '../button/Button';
|
|
5
|
+
import Section from '../section/Section';
|
|
6
|
+
import NumberField from '../number-field/NumberField';
|
|
7
|
+
export const EditGuideModal = () => {
|
|
8
|
+
const [props, setProps] = useState(null);
|
|
9
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
10
|
+
const [guide, setGuide] = useState(null);
|
|
11
|
+
const onOpen = (event) => {
|
|
12
|
+
setProps({
|
|
13
|
+
...event.detail
|
|
14
|
+
});
|
|
15
|
+
setIsOpen(true);
|
|
16
|
+
};
|
|
17
|
+
const onClose = () => setIsOpen(false);
|
|
18
|
+
useEffect(() => {
|
|
19
|
+
window.addEventListener('openeditguidemodal', onOpen);
|
|
20
|
+
return () => {
|
|
21
|
+
window.removeEventListener('openeditguidemodal', onOpen);
|
|
22
|
+
};
|
|
23
|
+
}, []);
|
|
24
|
+
useEffect(() => {
|
|
25
|
+
if (props?.guide) {
|
|
26
|
+
setGuide(props.guide);
|
|
27
|
+
}
|
|
28
|
+
}, [props?.guide]);
|
|
29
|
+
const onKeyDown = (e) => {
|
|
30
|
+
if (e.key === 'Enter') {
|
|
31
|
+
e.preventDefault();
|
|
32
|
+
onContinue(guide);
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
useEffect(() => {
|
|
36
|
+
if (isOpen) {
|
|
37
|
+
window.addEventListener('keypress', onKeyDown);
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
window.removeEventListener('keypress', onKeyDown);
|
|
41
|
+
}
|
|
42
|
+
return () => {
|
|
43
|
+
window.removeEventListener('keypress', onKeyDown);
|
|
44
|
+
};
|
|
45
|
+
}, [isOpen, onKeyDown]);
|
|
46
|
+
const onContinue = useCallback((e) => {
|
|
47
|
+
if (e) {
|
|
48
|
+
props.onContinue(e);
|
|
49
|
+
onClose();
|
|
50
|
+
}
|
|
51
|
+
}, [isOpen]);
|
|
52
|
+
const modal = isOpen && (React.createElement(Modal, { onRequestClose: onClose, style: {
|
|
53
|
+
width: '200px',
|
|
54
|
+
height: '110px',
|
|
55
|
+
top: '25%',
|
|
56
|
+
left: '55%'
|
|
57
|
+
}, isOpen: true },
|
|
58
|
+
React.createElement(Section, { title: `Edit ${props.isHorizontal ? 'Horizontal Guide' : 'Vertical Guide'}`, style: { padding: '10px' } },
|
|
59
|
+
React.createElement(NumberField, { label: 'Guide Position', labelPosition: 'top', onChange: (e) => setGuide(Number(e)), focusOnMount: true, value: guide }),
|
|
60
|
+
React.createElement(Button, { onClick: onClose, style: 'bold', color: 'secondary' }, "Cancel"),
|
|
61
|
+
React.createElement(Button, { onClick: () => onContinue(guide), style: 'bold', color: 'primary' }, "Ok"))));
|
|
62
|
+
const PortalContextComponent = () => ReactDOM.createPortal(modal, document.querySelector('#react-root'));
|
|
63
|
+
return React.createElement(PortalContextComponent, null);
|
|
64
|
+
};
|
|
65
|
+
//# sourceMappingURL=EditGuideModal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EditGuideModal.js","sourceRoot":"","sources":["../../../../src/components/edit-guide-modal/EditGuideModal.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { useCallback, useEffect, useState } from 'react';
|
|
3
|
+
import Button from '../button/Button';
|
|
4
|
+
import Modal from '../modal/Modal';
|
|
5
|
+
import Section from '../section/Section';
|
|
6
|
+
import SMPTEField from '../smpte-field/SMPTEField';
|
|
7
|
+
import TextField from '../text-field/TextField';
|
|
8
|
+
export const EditMarkerModal = () => {
|
|
9
|
+
const [label, setLabel] = useState('');
|
|
10
|
+
const [frame, setFrame] = useState(0);
|
|
11
|
+
const [props, setProps] = useState(null);
|
|
12
|
+
const [isOpen, setIsOpen] = useState(false);
|
|
13
|
+
const onOpen = (event) => {
|
|
14
|
+
setProps({
|
|
15
|
+
...event.detail
|
|
16
|
+
});
|
|
17
|
+
setIsOpen(true);
|
|
18
|
+
};
|
|
19
|
+
const onClose = () => setIsOpen(false);
|
|
20
|
+
useEffect(() => {
|
|
21
|
+
window.addEventListener('openeditmarkermodal', onOpen);
|
|
22
|
+
return () => {
|
|
23
|
+
window.removeEventListener('openeditmarkermodal', onOpen);
|
|
24
|
+
};
|
|
25
|
+
}, []);
|
|
26
|
+
const onUpdate = useCallback((e) => {
|
|
27
|
+
if (e) {
|
|
28
|
+
props.updateMarker(e);
|
|
29
|
+
setIsOpen(false);
|
|
30
|
+
}
|
|
31
|
+
}, [isOpen]);
|
|
32
|
+
const onKeyDown = (e) => {
|
|
33
|
+
if (e.key === 'Enter') {
|
|
34
|
+
e.preventDefault();
|
|
35
|
+
onUpdate({ label, frame });
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
useEffect(() => {
|
|
39
|
+
if (isOpen) {
|
|
40
|
+
window.addEventListener('keypress', onKeyDown);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
window.removeEventListener('keypress', onKeyDown);
|
|
44
|
+
}
|
|
45
|
+
return () => {
|
|
46
|
+
window.removeEventListener('keypress', onKeyDown);
|
|
47
|
+
};
|
|
48
|
+
}, [isOpen, onKeyDown]);
|
|
49
|
+
useEffect(() => {
|
|
50
|
+
if (props?.marker) {
|
|
51
|
+
setLabel(props.marker.label ? props.marker.label : '');
|
|
52
|
+
setFrame(props.marker.frame ? props.marker.frame : 0);
|
|
53
|
+
}
|
|
54
|
+
}, [props?.marker]);
|
|
55
|
+
if (!isOpen)
|
|
56
|
+
return null;
|
|
57
|
+
return (React.createElement(Modal, { onRequestClose: onClose, wrapperStyle: {
|
|
58
|
+
left: '0px',
|
|
59
|
+
width: '100%'
|
|
60
|
+
}, style: {
|
|
61
|
+
width: '200px',
|
|
62
|
+
height: '150px',
|
|
63
|
+
top: 'calc(50% - 150px)',
|
|
64
|
+
left: 'calc((100% - 200px) / 2)'
|
|
65
|
+
}, isOpen: true },
|
|
66
|
+
React.createElement(Section, { title: 'Edit Marker' },
|
|
67
|
+
React.createElement("div", { className: 'edit-marker-modal' },
|
|
68
|
+
React.createElement(TextField, { label: 'Label', labelPosition: 'top', value: label, onChange: (e) => setLabel(e) }),
|
|
69
|
+
React.createElement(SMPTEField, { label: 'Frame', labelPosition: 'top', value: frame, onChange: (e) => setFrame(e), frameRate: props?.frameRate }),
|
|
70
|
+
React.createElement(Button, { color: 'primary', style: 'bold', onClick: () => onUpdate({ label, frame }) }, "Update Marker")))));
|
|
71
|
+
};
|
|
72
|
+
//# sourceMappingURL=EditMarkerModal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EditMarkerModal.js","sourceRoot":"","sources":["../../../../src/components/edit-marker-modal/EditMarkerModal.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
interface IErrorMessagePreviewProps {
|
|
3
|
+
showMedia: boolean;
|
|
4
|
+
message: string;
|
|
5
|
+
style?: React.CSSProperties | any;
|
|
6
|
+
onRequestClose?(): void;
|
|
7
|
+
}
|
|
8
|
+
declare class ErrorMessagePreview extends React.PureComponent<IErrorMessagePreviewProps> {
|
|
9
|
+
private errorMsgNode;
|
|
10
|
+
private evtHandlers;
|
|
11
|
+
constructor(props: any);
|
|
12
|
+
private onClose;
|
|
13
|
+
render(): JSX.Element;
|
|
14
|
+
}
|
|
15
|
+
export default ErrorMessagePreview;
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import Portal from '../portal/Portal';
|
|
3
|
+
import Button from '../button/Button';
|
|
4
|
+
import { assets as copy } from '../../constants/copy';
|
|
5
|
+
import { ICON_TIMES } from '../../constants/icons';
|
|
6
|
+
class ErrorMessagePreview extends React.PureComponent {
|
|
7
|
+
errorMsgNode = null;
|
|
8
|
+
evtHandlers;
|
|
9
|
+
constructor(props) {
|
|
10
|
+
super(props);
|
|
11
|
+
this.errorMsgNode = React.createRef();
|
|
12
|
+
this.evtHandlers = {
|
|
13
|
+
onClose: (e) => this.onClose(e)
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
onClose(e) {
|
|
17
|
+
const { onRequestClose } = this.props;
|
|
18
|
+
e.stopPropagation();
|
|
19
|
+
onRequestClose();
|
|
20
|
+
}
|
|
21
|
+
render() {
|
|
22
|
+
const { showMedia, style, message } = this.props;
|
|
23
|
+
if (showMedia) {
|
|
24
|
+
return (React.createElement(Portal, { id: 'portal-root' },
|
|
25
|
+
React.createElement("div", { style: { ...style }, className: 'close-icon-preview' },
|
|
26
|
+
React.createElement(Button, { key: 'btn-filter', onClick: this.evtHandlers.onClose, size: 'large', style: 'subtle', tooltip: copy.field.tooltipFilter }, ICON_TIMES)),
|
|
27
|
+
React.createElement("p", { style: style, ref: this.errorMsgNode, className: 'asset-preview-background media-preview' }, message)));
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
return null;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
export default ErrorMessagePreview;
|
|
35
|
+
//# sourceMappingURL=ErrorMessagePreview.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ErrorMessagePreview.js","sourceRoot":"","sources":["../../../../src/components/error-message-preview/ErrorMessagePreview.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,MAAM,MAAM,kBAAkB,CAAC;AACtC,OAAO,MAAM,MAAM,kBAAkB,CAAC;AACtC,OAAO,EAAE,MAAM,IAAI,IAAI,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AASnD,MAAM,mBAAoB,SAAQ,KAAK,CAAC,aAAwC;IACpE,YAAY,GAAQ,IAAI,CAAC;IAEzB,WAAW,CAAM;IAEzB,YAAY,KAAK;QACb,KAAK,CAAC,KAAK,CAAC,CAAC;QACb,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;QACtC,IAAI,CAAC,WAAW,GAAG;YACf,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC;SAClC,CAAC;IACN,CAAC;IAEO,OAAO,CAAC,CAAC;QACb,MAAM,EAAE,cAAc,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;QACtC,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,cAAc,EAAE,CAAC;IACrB,CAAC;IAEM,MAAM;QACT,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;QACjD,IAAI,SAAS,EAAE;YACX,OAAO,CACH,oBAAC,MAAM,IAAC,EAAE,EAAC,aAAa;gBACpB,6BACI,KAAK,EAAE,EAAE,GAAG,KAAK,EAAE,EACnB,SAAS,EAAE,oBAAoB;oBAC/B,oBAAC,MAAM,IACH,GAAG,EAAC,YAAY,EAChB,OAAO,EAAE,IAAI,CAAC,WAAW,CAAC,OAAO,EACjC,IAAI,EAAE,OAAO,EACb,KAAK,EAAC,QAAQ,EACd,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa,IAChC,UAAU,CACN,CACP;gBACN,2BACI,KAAK,EAAE,KAAK,EACZ,GAAG,EAAE,IAAI,CAAC,YAAY,EACtB,SAAS,EAAC,wCAAwC,IACpD,OAAO,CAAK,CACT,CACZ,CAAC;SACL;aAAM;YACH,OAAO,IAAI,CAAC;SACf;IACL,CAAC;CACJ;AAED,eAAe,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import * as React from 'react';
|
|
2
|
+
import { useFlag } from '@innovid/feature-flags-react';
|
|
3
|
+
export const FeatureFlagWrapper = ({ children, flagName }) => {
|
|
4
|
+
const isFeatureFlagEnabled = useFlag(flagName);
|
|
5
|
+
if (isFeatureFlagEnabled) {
|
|
6
|
+
return children;
|
|
7
|
+
}
|
|
8
|
+
return React.createElement(React.Fragment, null);
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=FeatureFlagWrapper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FeatureFlagWrapper.js","sourceRoot":"","sources":["../../../../src/components/feature-flag-wrapper/FeatureFlagWrapper.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,OAAO,EAAE,MAAM,8BAA8B,CAAC;AAOvD,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,EAAC,QAAQ,EAAE,QAAQ,EAA2B,EAAC,EAAE;IAChF,MAAM,oBAAoB,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC/C,IAAG,oBAAoB,EAAE,CAAC;QACtB,OAAO,QAAQ,CAAC;IACpB,CAAC;IACD,OAAO,yCAAK,CAAC;AACjB,CAAC,CAAA"}
|