@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.
Files changed (234) hide show
  1. package/dist/cjs/components/app-wrapper/AppWrapper.d.ts +1 -0
  2. package/dist/cjs/components/app-wrapper/AppWrapper.js +1 -1
  3. package/dist/cjs/components/app-wrapper/AppWrapper.js.map +1 -1
  4. package/dist/cjs/components/app-wrapper/AppWrapperV2.d.ts +26 -0
  5. package/dist/cjs/components/app-wrapper/AppWrapperV2.js +266 -0
  6. package/dist/cjs/components/app-wrapper/AppWrapperV2.js.map +1 -0
  7. package/dist/cjs/components/app-wrapper/AppWrapperV3.d.ts +19 -0
  8. package/dist/cjs/components/app-wrapper/AppWrapperV3.js +195 -0
  9. package/dist/cjs/components/app-wrapper/AppWrapperV3.js.map +1 -0
  10. package/dist/cjs/components/app-wrapper/AppWrapper_BACKUP_73190.d.ts +27 -0
  11. package/dist/cjs/components/app-wrapper/AppWrapper_BACKUP_73190.js +243 -0
  12. package/dist/cjs/components/app-wrapper/AppWrapper_BACKUP_73190.js.map +1 -0
  13. package/dist/cjs/components/app-wrapper/AppWrapper_BASE_73190.d.ts +28 -0
  14. package/dist/cjs/components/app-wrapper/AppWrapper_BASE_73190.js +255 -0
  15. package/dist/cjs/components/app-wrapper/AppWrapper_BASE_73190.js.map +1 -0
  16. package/dist/cjs/components/app-wrapper/AppWrapper_LOCAL_73190.d.ts +27 -0
  17. package/dist/cjs/components/app-wrapper/AppWrapper_LOCAL_73190.js +243 -0
  18. package/dist/cjs/components/app-wrapper/AppWrapper_LOCAL_73190.js.map +1 -0
  19. package/dist/cjs/components/app-wrapper/AppWrapper_REMOTE_73190.d.ts +28 -0
  20. package/dist/cjs/components/app-wrapper/AppWrapper_REMOTE_73190.js +251 -0
  21. package/dist/cjs/components/app-wrapper/AppWrapper_REMOTE_73190.js.map +1 -0
  22. package/dist/cjs/components/auth-gate/AuthGate.d.ts +2 -0
  23. package/dist/cjs/components/auth-gate/AuthGate.js +105 -0
  24. package/dist/cjs/components/auth-gate/AuthGate.js.map +1 -0
  25. package/dist/cjs/components/change-report/ChangeReportTree.d.ts +10 -0
  26. package/dist/cjs/components/change-report/ChangeReportTree.js +95 -0
  27. package/dist/cjs/components/change-report/ChangeReportTree.js.map +1 -0
  28. package/dist/cjs/components/dropdown/{Dropdown.stories.js → dropdown.stories.js} +1 -1
  29. package/dist/cjs/components/dropdown/{Dropdown.stories.js.map → dropdown.stories.js.map} +1 -1
  30. package/dist/cjs/components/edit-guide-modal/EditGuideModal.d.ts +8 -0
  31. package/dist/cjs/components/edit-guide-modal/EditGuideModal.js +132 -0
  32. package/dist/cjs/components/edit-guide-modal/EditGuideModal.js.map +1 -0
  33. package/dist/cjs/components/edit-marker-modal/EditMarkerModal.d.ts +8 -0
  34. package/dist/cjs/components/edit-marker-modal/EditMarkerModal.js +104 -0
  35. package/dist/cjs/components/edit-marker-modal/EditMarkerModal.js.map +1 -0
  36. package/dist/cjs/components/error-message-preview/ErrorMessagePreview.d.ts +15 -0
  37. package/dist/cjs/components/error-message-preview/ErrorMessagePreview.js +91 -0
  38. package/dist/cjs/components/error-message-preview/ErrorMessagePreview.js.map +1 -0
  39. package/dist/cjs/components/feature-flag-wrapper/FeatureFlagWrapper.d.ts +7 -0
  40. package/dist/cjs/components/feature-flag-wrapper/FeatureFlagWrapper.js +48 -0
  41. package/dist/cjs/components/feature-flag-wrapper/FeatureFlagWrapper.js.map +1 -0
  42. package/dist/cjs/components/header/Header_BACKUP_73021.d.ts +33 -0
  43. package/dist/cjs/components/header/Header_BACKUP_73021.js +393 -0
  44. package/dist/cjs/components/header/Header_BACKUP_73021.js.map +1 -0
  45. package/dist/cjs/components/header/Header_BASE_73021.d.ts +29 -0
  46. package/dist/cjs/components/header/Header_BASE_73021.js +376 -0
  47. package/dist/cjs/components/header/Header_BASE_73021.js.map +1 -0
  48. package/dist/cjs/components/header/Header_LOCAL_73021.d.ts +33 -0
  49. package/dist/cjs/components/header/Header_LOCAL_73021.js +382 -0
  50. package/dist/cjs/components/header/Header_LOCAL_73021.js.map +1 -0
  51. package/dist/cjs/components/header/Header_REMOTE_73021.d.ts +30 -0
  52. package/dist/cjs/components/header/Header_REMOTE_73021.js +386 -0
  53. package/dist/cjs/components/header/Header_REMOTE_73021.js.map +1 -0
  54. package/dist/cjs/components/header/StoryDropdown.d.ts +6 -0
  55. package/dist/cjs/components/header/StoryDropdown.js +111 -0
  56. package/dist/cjs/components/header/StoryDropdown.js.map +1 -0
  57. package/dist/cjs/components/number-field/NumberField.d.ts +2 -2
  58. package/dist/cjs/components/number-field/NumberField.js +4 -7
  59. package/dist/cjs/components/number-field/NumberField.js.map +1 -1
  60. package/dist/cjs/components/publish-wizard/PublishWizard.d.ts +4 -3
  61. package/dist/cjs/components/publish-wizard/PublishWizard.js +104 -38
  62. package/dist/cjs/components/publish-wizard/PublishWizard.js.map +1 -1
  63. package/dist/cjs/components/replace-files-modal/ReplaceFilesModal.d.ts +11 -0
  64. package/dist/cjs/components/replace-files-modal/ReplaceFilesModal.js +213 -0
  65. package/dist/cjs/components/replace-files-modal/ReplaceFilesModal.js.map +1 -0
  66. package/dist/cjs/components/service-icon/ServiceIcon.test.d.ts +0 -0
  67. package/dist/cjs/components/service-icon/ServiceIcon.test.js +1 -0
  68. package/dist/cjs/components/service-icon/ServiceIcon.test.js.map +1 -0
  69. package/dist/cjs/components/tag/Tag.test.d.ts +0 -0
  70. package/dist/cjs/components/tag/Tag.test.js +1 -0
  71. package/dist/cjs/components/tag/Tag.test.js.map +1 -0
  72. package/dist/cjs/constants/copy.d.ts +9 -0
  73. package/dist/cjs/constants/copy.js +13 -2
  74. package/dist/cjs/constants/copy.js.map +1 -1
  75. package/dist/cjs/constants/snippets.d.ts +18 -0
  76. package/dist/cjs/constants/snippets.js +3 -0
  77. package/dist/cjs/constants/snippets.js.map +1 -0
  78. package/dist/cjs/index.d.ts +3 -1
  79. package/dist/cjs/index.js +3 -1
  80. package/dist/cjs/index.js.map +1 -1
  81. package/dist/cjs/redux/actions/auth.d.ts +9 -0
  82. package/dist/cjs/redux/actions/auth.js +30 -0
  83. package/dist/cjs/redux/actions/auth.js.map +1 -0
  84. package/dist/cjs/redux/reducers/auth.d.ts +3 -0
  85. package/dist/cjs/redux/reducers/auth.js +67 -0
  86. package/dist/cjs/redux/reducers/auth.js.map +1 -0
  87. package/dist/cjs/services/API.d.ts +2 -0
  88. package/dist/cjs/services/API.js +6 -0
  89. package/dist/cjs/services/API.js.map +1 -1
  90. package/dist/cjs/services/Auth0.d.ts +18 -0
  91. package/dist/cjs/services/Auth0.js +102 -0
  92. package/dist/cjs/services/Auth0.js.map +1 -0
  93. package/dist/cjs/services/Session.d.ts +26 -0
  94. package/dist/cjs/services/Session.js +155 -0
  95. package/dist/cjs/services/Session.js.map +1 -0
  96. package/dist/esm/components/app-wrapper/AppWrapper.d.ts +1 -0
  97. package/dist/esm/components/app-wrapper/AppWrapper.js +1 -1
  98. package/dist/esm/components/app-wrapper/AppWrapper.js.map +1 -1
  99. package/dist/esm/components/app-wrapper/AppWrapperV2.d.ts +26 -0
  100. package/dist/esm/components/app-wrapper/AppWrapperV2.js +142 -0
  101. package/dist/esm/components/app-wrapper/AppWrapperV2.js.map +1 -0
  102. package/dist/esm/components/app-wrapper/AppWrapperV3.d.ts +19 -0
  103. package/dist/esm/components/app-wrapper/AppWrapperV3.js +88 -0
  104. package/dist/esm/components/app-wrapper/AppWrapperV3.js.map +1 -0
  105. package/dist/esm/components/app-wrapper/AppWrapper_BACKUP_73190.d.ts +27 -0
  106. package/dist/esm/components/app-wrapper/AppWrapper_BACKUP_73190.js +194 -0
  107. package/dist/esm/components/app-wrapper/AppWrapper_BACKUP_73190.js.map +1 -0
  108. package/dist/esm/components/app-wrapper/AppWrapper_BASE_73190.d.ts +28 -0
  109. package/dist/esm/components/app-wrapper/AppWrapper_BASE_73190.js +208 -0
  110. package/dist/esm/components/app-wrapper/AppWrapper_BASE_73190.js.map +1 -0
  111. package/dist/esm/components/app-wrapper/AppWrapper_LOCAL_73190.d.ts +27 -0
  112. package/dist/esm/components/app-wrapper/AppWrapper_LOCAL_73190.js +194 -0
  113. package/dist/esm/components/app-wrapper/AppWrapper_LOCAL_73190.js.map +1 -0
  114. package/dist/esm/components/app-wrapper/AppWrapper_REMOTE_73190.d.ts +28 -0
  115. package/dist/esm/components/app-wrapper/AppWrapper_REMOTE_73190.js +204 -0
  116. package/dist/esm/components/app-wrapper/AppWrapper_REMOTE_73190.js.map +1 -0
  117. package/dist/esm/components/auth-gate/AuthGate.d.ts +2 -0
  118. package/dist/esm/components/auth-gate/AuthGate.js +59 -0
  119. package/dist/esm/components/auth-gate/AuthGate.js.map +1 -0
  120. package/dist/esm/components/change-report/ChangeReportTree.d.ts +10 -0
  121. package/dist/esm/components/change-report/ChangeReportTree.js +42 -0
  122. package/dist/esm/components/change-report/ChangeReportTree.js.map +1 -0
  123. package/dist/esm/components/dropdown/{Dropdown.stories.js → dropdown.stories.js} +1 -1
  124. package/dist/esm/components/dropdown/{Dropdown.stories.js.map → dropdown.stories.js.map} +1 -1
  125. package/dist/esm/components/edit-guide-modal/EditGuideModal.d.ts +8 -0
  126. package/dist/esm/components/edit-guide-modal/EditGuideModal.js +65 -0
  127. package/dist/esm/components/edit-guide-modal/EditGuideModal.js.map +1 -0
  128. package/dist/esm/components/edit-marker-modal/EditMarkerModal.d.ts +8 -0
  129. package/dist/esm/components/edit-marker-modal/EditMarkerModal.js +72 -0
  130. package/dist/esm/components/edit-marker-modal/EditMarkerModal.js.map +1 -0
  131. package/dist/esm/components/error-message-preview/ErrorMessagePreview.d.ts +15 -0
  132. package/dist/esm/components/error-message-preview/ErrorMessagePreview.js +35 -0
  133. package/dist/esm/components/error-message-preview/ErrorMessagePreview.js.map +1 -0
  134. package/dist/esm/components/feature-flag-wrapper/FeatureFlagWrapper.d.ts +7 -0
  135. package/dist/esm/components/feature-flag-wrapper/FeatureFlagWrapper.js +10 -0
  136. package/dist/esm/components/feature-flag-wrapper/FeatureFlagWrapper.js.map +1 -0
  137. package/dist/esm/components/header/Header_BACKUP_73021.d.ts +33 -0
  138. package/dist/esm/components/header/Header_BACKUP_73021.js +336 -0
  139. package/dist/esm/components/header/Header_BACKUP_73021.js.map +1 -0
  140. package/dist/esm/components/header/Header_BASE_73021.d.ts +29 -0
  141. package/dist/esm/components/header/Header_BASE_73021.js +322 -0
  142. package/dist/esm/components/header/Header_BASE_73021.js.map +1 -0
  143. package/dist/esm/components/header/Header_LOCAL_73021.d.ts +33 -0
  144. package/dist/esm/components/header/Header_LOCAL_73021.js +328 -0
  145. package/dist/esm/components/header/Header_LOCAL_73021.js.map +1 -0
  146. package/dist/esm/components/header/Header_REMOTE_73021.d.ts +30 -0
  147. package/dist/esm/components/header/Header_REMOTE_73021.js +329 -0
  148. package/dist/esm/components/header/Header_REMOTE_73021.js.map +1 -0
  149. package/dist/esm/components/header/StoryDropdown.d.ts +6 -0
  150. package/dist/esm/components/header/StoryDropdown.js +82 -0
  151. package/dist/esm/components/header/StoryDropdown.js.map +1 -0
  152. package/dist/esm/components/number-field/NumberField.d.ts +2 -2
  153. package/dist/esm/components/number-field/NumberField.js +4 -5
  154. package/dist/esm/components/number-field/NumberField.js.map +1 -1
  155. package/dist/esm/components/publish-wizard/PublishWizard.d.ts +4 -3
  156. package/dist/esm/components/publish-wizard/PublishWizard.js +92 -38
  157. package/dist/esm/components/publish-wizard/PublishWizard.js.map +1 -1
  158. package/dist/esm/components/replace-files-modal/ReplaceFilesModal.d.ts +11 -0
  159. package/dist/esm/components/replace-files-modal/ReplaceFilesModal.js +141 -0
  160. package/dist/esm/components/replace-files-modal/ReplaceFilesModal.js.map +1 -0
  161. package/dist/esm/components/service-icon/ServiceIcon.test.d.ts +0 -0
  162. package/dist/esm/components/service-icon/ServiceIcon.test.js +1 -0
  163. package/dist/esm/components/service-icon/ServiceIcon.test.js.map +1 -0
  164. package/dist/esm/components/tag/Tag.test.d.ts +0 -0
  165. package/dist/esm/components/tag/Tag.test.js +1 -0
  166. package/dist/esm/components/tag/Tag.test.js.map +1 -0
  167. package/dist/esm/constants/copy.d.ts +9 -0
  168. package/dist/esm/constants/copy.js +13 -2
  169. package/dist/esm/constants/copy.js.map +1 -1
  170. package/dist/esm/constants/snippets.d.ts +18 -0
  171. package/dist/esm/constants/snippets.js +2 -0
  172. package/dist/esm/constants/snippets.js.map +1 -0
  173. package/dist/esm/index.d.ts +3 -1
  174. package/dist/esm/index.js +2 -1
  175. package/dist/esm/index.js.map +1 -1
  176. package/dist/esm/redux/actions/auth.d.ts +9 -0
  177. package/dist/esm/redux/actions/auth.js +25 -0
  178. package/dist/esm/redux/actions/auth.js.map +1 -0
  179. package/dist/esm/redux/reducers/auth.d.ts +3 -0
  180. package/dist/esm/redux/reducers/auth.js +27 -0
  181. package/dist/esm/redux/reducers/auth.js.map +1 -0
  182. package/dist/esm/services/API.d.ts +2 -0
  183. package/dist/esm/services/API.js +6 -0
  184. package/dist/esm/services/API.js.map +1 -1
  185. package/dist/esm/services/Auth0.d.ts +18 -0
  186. package/dist/esm/services/Auth0.js +68 -0
  187. package/dist/esm/services/Auth0.js.map +1 -0
  188. package/dist/esm/services/Session.d.ts +26 -0
  189. package/dist/esm/services/Session.js +107 -0
  190. package/dist/esm/services/Session.js.map +1 -0
  191. package/dist/styles.css +127 -0
  192. package/dist/styles.less +152 -0
  193. package/less/components/change-report.less +115 -0
  194. package/less/components/publish-wizard.less +36 -0
  195. package/less/entry.less +1 -0
  196. package/package.json +6 -17
  197. package/src/components/app-wrapper/AppWrapper.tsx +6 -1
  198. package/src/components/change-report/ChangeReportTree.tsx +125 -0
  199. package/src/components/number-field/NumberField.tsx +9 -15
  200. package/src/components/publish-wizard/PublishWizard.tsx +144 -45
  201. package/src/components/service-icon/ServiceIcon.test.tsx +0 -0
  202. package/src/components/tag/Tag.test.tsx +0 -0
  203. package/src/constants/copy.ts +16 -2
  204. package/src/constants/snippets.ts +25 -0
  205. package/src/index.ts +7 -1
  206. package/src/services/API.ts +8 -0
  207. package/tsconfig.json +1 -1
  208. package/src/components/advanced-number-field/AdvancedNumberField.test.tsx +0 -724
  209. package/src/components/anchor-field/AnchorField.test.tsx +0 -130
  210. package/src/components/asset-details/AssetDetails.test.tsx +0 -494
  211. package/src/components/assets/AssetField.test.tsx +0 -449
  212. package/src/components/assets/AssetsTableAssetIdCell.test.tsx +0 -142
  213. package/src/components/assets/AssetsTableAssetIdFilter.test.tsx +0 -95
  214. package/src/components/assets/AssetsTableComplexTagCell.test.tsx +0 -161
  215. package/src/components/assets/AssetsTableDateCell.test.tsx +0 -106
  216. package/src/components/assets/AssetsTableDropzone.test.tsx +0 -132
  217. package/src/components/assets/AssetsTableDurationCell.test.tsx +0 -119
  218. package/src/components/assets/AssetsTableGlobalCell.test.tsx +0 -46
  219. package/src/components/assets/AssetsTableNameCell.test.tsx +0 -166
  220. package/src/components/assets/AssetsTableNameFilter.test.tsx +0 -95
  221. package/src/components/assets/AssetsTablePreviewCell.test.tsx +0 -191
  222. package/src/components/assets/AssetsTableRateCell.test.tsx +0 -87
  223. package/src/components/assets/AssetsTableSelectCell.test.tsx +0 -156
  224. package/src/components/assets/AssetsTableSelectFilter.test.tsx +0 -119
  225. package/src/components/assets/AssetsTableStatusCell.test.tsx +0 -60
  226. package/src/components/number-field/NumberField.test.tsx +0 -383
  227. package/src/components/text-field/TextField.test.tsx +0 -988
  228. package/src/test/setup.ts +0 -91
  229. package/src/test/utils.tsx +0 -44
  230. package/tsconfig.eslint.json +0 -8
  231. package/vitest.config.ts +0 -31
  232. /package/dist/cjs/components/dropdown/{Dropdown.stories.d.ts → dropdown.stories.d.ts} +0 -0
  233. /package/dist/esm/components/dropdown/{Dropdown.stories.d.ts → dropdown.stories.d.ts} +0 -0
  234. /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,2 @@
1
+ declare const _default: any;
2
+ export default _default;
@@ -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=Dropdown.stories.js.map
15
+ //# sourceMappingURL=dropdown.stories.js.map
@@ -1 +1 @@
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"}
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,8 @@
1
+ import React from 'react';
2
+ export interface IEditGuideModalProps {
3
+ guide: number;
4
+ onClose: () => any;
5
+ onContinue: (e: any) => any;
6
+ isHorizontal: boolean;
7
+ }
8
+ export declare const EditGuideModal: () => React.JSX.Element;
@@ -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,8 @@
1
+ import React from 'react';
2
+ export interface IEditMarkerModalProps {
3
+ index: number;
4
+ updateMarker: (marker: any) => void;
5
+ marker: any;
6
+ frameRate: number;
7
+ }
8
+ export declare const EditMarkerModal: () => React.JSX.Element;
@@ -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,7 @@
1
+ import * as React from 'react';
2
+ interface IFeatureFlagWrapperProps {
3
+ children: React.ReactNode;
4
+ flagName: string;
5
+ }
6
+ export declare const FeatureFlagWrapper: ({ children, flagName }: IFeatureFlagWrapperProps) => React.ReactNode;
7
+ export {};
@@ -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"}