@imposium-hub/components 2.5.10-15 → 2.5.10-17

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 (86) hide show
  1. package/dist/cjs/components/app-wrapper/AppWrapper_BACKUP_73190.d.ts +27 -0
  2. package/dist/cjs/components/app-wrapper/AppWrapper_BACKUP_73190.js +243 -0
  3. package/dist/cjs/components/app-wrapper/AppWrapper_BACKUP_73190.js.map +1 -0
  4. package/dist/cjs/components/app-wrapper/AppWrapper_BASE_73190.d.ts +28 -0
  5. package/dist/cjs/components/app-wrapper/AppWrapper_BASE_73190.js +255 -0
  6. package/dist/cjs/components/app-wrapper/AppWrapper_BASE_73190.js.map +1 -0
  7. package/dist/cjs/components/app-wrapper/AppWrapper_LOCAL_73190.d.ts +27 -0
  8. package/dist/cjs/components/app-wrapper/AppWrapper_LOCAL_73190.js +243 -0
  9. package/dist/cjs/components/app-wrapper/AppWrapper_LOCAL_73190.js.map +1 -0
  10. package/dist/cjs/components/app-wrapper/AppWrapper_REMOTE_73190.d.ts +28 -0
  11. package/dist/cjs/components/app-wrapper/AppWrapper_REMOTE_73190.js +251 -0
  12. package/dist/cjs/components/app-wrapper/AppWrapper_REMOTE_73190.js.map +1 -0
  13. package/dist/cjs/components/confirm-modal/ConfirmModal.d.ts +8 -0
  14. package/dist/cjs/components/confirm-modal/ConfirmModal.js +18 -9
  15. package/dist/cjs/components/confirm-modal/ConfirmModal.js.map +1 -1
  16. package/dist/cjs/components/error-message-preview/ErrorMessagePreview.d.ts +15 -0
  17. package/dist/cjs/components/error-message-preview/ErrorMessagePreview.js +91 -0
  18. package/dist/cjs/components/error-message-preview/ErrorMessagePreview.js.map +1 -0
  19. package/dist/cjs/components/header/Header_BACKUP_73021.d.ts +33 -0
  20. package/dist/cjs/components/header/Header_BACKUP_73021.js +393 -0
  21. package/dist/cjs/components/header/Header_BACKUP_73021.js.map +1 -0
  22. package/dist/cjs/components/header/Header_BASE_73021.d.ts +29 -0
  23. package/dist/cjs/components/header/Header_BASE_73021.js +376 -0
  24. package/dist/cjs/components/header/Header_BASE_73021.js.map +1 -0
  25. package/dist/cjs/components/header/Header_LOCAL_73021.d.ts +33 -0
  26. package/dist/cjs/components/header/Header_LOCAL_73021.js +382 -0
  27. package/dist/cjs/components/header/Header_LOCAL_73021.js.map +1 -0
  28. package/dist/cjs/components/header/Header_REMOTE_73021.d.ts +30 -0
  29. package/dist/cjs/components/header/Header_REMOTE_73021.js +386 -0
  30. package/dist/cjs/components/header/Header_REMOTE_73021.js.map +1 -0
  31. package/dist/cjs/components/story-previewer/StoryPreviewer.js +2 -1
  32. package/dist/cjs/components/story-previewer/StoryPreviewer.js.map +1 -1
  33. package/dist/cjs/components/tabs/Tabs.d.ts +4 -1
  34. package/dist/cjs/components/tabs/Tabs.stories.d.ts +3 -1
  35. package/dist/cjs/index.d.ts +2 -2
  36. package/dist/cjs/index.js.map +1 -1
  37. package/dist/esm/components/app-wrapper/AppWrapper_BACKUP_73190.d.ts +27 -0
  38. package/dist/esm/components/app-wrapper/AppWrapper_BACKUP_73190.js +194 -0
  39. package/dist/esm/components/app-wrapper/AppWrapper_BACKUP_73190.js.map +1 -0
  40. package/dist/esm/components/app-wrapper/AppWrapper_BASE_73190.d.ts +28 -0
  41. package/dist/esm/components/app-wrapper/AppWrapper_BASE_73190.js +208 -0
  42. package/dist/esm/components/app-wrapper/AppWrapper_BASE_73190.js.map +1 -0
  43. package/dist/esm/components/app-wrapper/AppWrapper_LOCAL_73190.d.ts +27 -0
  44. package/dist/esm/components/app-wrapper/AppWrapper_LOCAL_73190.js +194 -0
  45. package/dist/esm/components/app-wrapper/AppWrapper_LOCAL_73190.js.map +1 -0
  46. package/dist/esm/components/app-wrapper/AppWrapper_REMOTE_73190.d.ts +28 -0
  47. package/dist/esm/components/app-wrapper/AppWrapper_REMOTE_73190.js +204 -0
  48. package/dist/esm/components/app-wrapper/AppWrapper_REMOTE_73190.js.map +1 -0
  49. package/dist/esm/components/confirm-modal/ConfirmModal.d.ts +8 -0
  50. package/dist/esm/components/confirm-modal/ConfirmModal.js +18 -9
  51. package/dist/esm/components/confirm-modal/ConfirmModal.js.map +1 -1
  52. package/dist/esm/components/error-message-preview/ErrorMessagePreview.d.ts +15 -0
  53. package/dist/esm/components/error-message-preview/ErrorMessagePreview.js +35 -0
  54. package/dist/esm/components/error-message-preview/ErrorMessagePreview.js.map +1 -0
  55. package/dist/esm/components/header/Header_BACKUP_73021.d.ts +33 -0
  56. package/dist/esm/components/header/Header_BACKUP_73021.js +336 -0
  57. package/dist/esm/components/header/Header_BACKUP_73021.js.map +1 -0
  58. package/dist/esm/components/header/Header_BASE_73021.d.ts +29 -0
  59. package/dist/esm/components/header/Header_BASE_73021.js +322 -0
  60. package/dist/esm/components/header/Header_BASE_73021.js.map +1 -0
  61. package/dist/esm/components/header/Header_LOCAL_73021.d.ts +33 -0
  62. package/dist/esm/components/header/Header_LOCAL_73021.js +328 -0
  63. package/dist/esm/components/header/Header_LOCAL_73021.js.map +1 -0
  64. package/dist/esm/components/header/Header_REMOTE_73021.d.ts +30 -0
  65. package/dist/esm/components/header/Header_REMOTE_73021.js +329 -0
  66. package/dist/esm/components/header/Header_REMOTE_73021.js.map +1 -0
  67. package/dist/esm/components/story-previewer/StoryPreviewer.js +2 -1
  68. package/dist/esm/components/story-previewer/StoryPreviewer.js.map +1 -1
  69. package/dist/esm/index.d.ts +2 -2
  70. package/dist/esm/index.js.map +1 -1
  71. package/package.json +1 -1
  72. package/src/components/confirm-modal/ConfirmModal.tsx +22 -15
  73. package/src/components/story-previewer/StoryPreviewer.tsx +2 -3
  74. package/src/index.ts +3 -2
  75. package/dist/cjs/components/assets/AssetsTableAssetIdCell.d.ts +0 -2
  76. package/dist/cjs/components/assets/AssetsTableAssetIdCell.js +0 -56
  77. package/dist/cjs/components/assets/AssetsTableAssetIdCell.js.map +0 -1
  78. package/dist/cjs/components/assets/AssetsTableAssetIdFilter.d.ts +0 -2
  79. package/dist/cjs/components/assets/AssetsTableAssetIdFilter.js +0 -94
  80. package/dist/cjs/components/assets/AssetsTableAssetIdFilter.js.map +0 -1
  81. package/dist/esm/components/assets/AssetsTableAssetIdCell.d.ts +0 -2
  82. package/dist/esm/components/assets/AssetsTableAssetIdCell.js +0 -31
  83. package/dist/esm/components/assets/AssetsTableAssetIdCell.js.map +0 -1
  84. package/dist/esm/components/assets/AssetsTableAssetIdFilter.d.ts +0 -2
  85. package/dist/esm/components/assets/AssetsTableAssetIdFilter.js +0 -20
  86. package/dist/esm/components/assets/AssetsTableAssetIdFilter.js.map +0 -1
@@ -0,0 +1,194 @@
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 { validateAccessLevel } from '../../Util';
10
+ import { setAccessData } from '../../redux/actions/access';
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 { auth0ClientId, auth0Domain } = this.props;
24
+ AuthService.bindToClient(auth0ClientId, auth0Domain);
25
+ const validAccessLevel = validateAccessLevel(this.props.organizationId, this.props.serviceId, this.props.access);
26
+ if (!this.state.restrictAccess && !validAccessLevel) {
27
+ this.setState({ restrictAccess: true });
28
+ }
29
+ if (this.state.restrictAccess && validAccessLevel) {
30
+ this.setState({ restrictAccess: false });
31
+ }
32
+ // Always check the session
33
+ this.doCheckSession(true);
34
+ };
35
+ /*
36
+ Check the auth0 session expiry
37
+ */
38
+ componentDidUpdate = (prevProps, prevState) => {
39
+ const { auth } = this.props;
40
+ let validAccessLevel;
41
+ if (auth) {
42
+ const { idTokenPayload: { exp } } = auth;
43
+ const validSession = AuthService.checkExpiry(exp);
44
+ if (!validSession) {
45
+ this.props.clearCachedAuth();
46
+ this.doCheckSession();
47
+ }
48
+ }
49
+ if (this.props.organizationId !== prevProps.organizationId ||
50
+ this.props.access !== prevProps.access) {
51
+ validAccessLevel = validateAccessLevel(this.props.organizationId, this.props.serviceId, this.props.access);
52
+ if (!this.state.restrictAccess && !validAccessLevel) {
53
+ this.setState({ restrictAccess: true });
54
+ }
55
+ if (this.state.restrictAccess && validAccessLevel) {
56
+ this.setState({ restrictAccess: false });
57
+ }
58
+ }
59
+ };
60
+ /*
61
+ Emit creds to React parent
62
+ */
63
+ propagateCreds = (freshAccess, freshIdentity) => {
64
+ const { storyId, organizationId, onAuthenticated } = this.props;
65
+ let initialStoryId = storyId;
66
+ let initialOrganizationId = organizationId;
67
+ const firstOrg = freshAccess.organizations[0];
68
+ const getIDsFromSession = () => {
69
+ const session = SessionService.getSession();
70
+ if (session && session.story_id && session.organization_id) {
71
+ const org = freshAccess.organizations.find((o) => o.id === session.organization_id);
72
+ if (org) {
73
+ const story = org.stories.find((s) => s.id === session.story_id);
74
+ if (story) {
75
+ return { orgId: org.id, storyId: story.id };
76
+ }
77
+ }
78
+ }
79
+ return null;
80
+ };
81
+ // If the org ID is not provided, but the storyID is provided, find the org ID if we can, if not, use the first org ID found and we'll show the story not found interface
82
+ if (!initialOrganizationId && initialStoryId) {
83
+ const org = freshAccess.organizations.find((o) => o.stories.find((s) => s.id === initialStoryId));
84
+ if (org) {
85
+ initialOrganizationId = org.id;
86
+ }
87
+ else {
88
+ initialOrganizationId = firstOrg.id;
89
+ }
90
+ }
91
+ if (!initialStoryId) {
92
+ // If storyID is not provided, try to use the one from the previous session
93
+ const sessionIds = getIDsFromSession();
94
+ if (sessionIds) {
95
+ initialOrganizationId = sessionIds.orgId;
96
+ initialStoryId = sessionIds.storyId;
97
+ }
98
+ else {
99
+ // If that doesn't work - default to the first org & story
100
+ const story = firstOrg.stories[0];
101
+ initialOrganizationId = firstOrg.id;
102
+ initialStoryId = story.id;
103
+ }
104
+ }
105
+ SessionService.buildFreshSession(freshIdentity, initialOrganizationId, initialStoryId);
106
+ onAuthenticated(initialOrganizationId, initialStoryId);
107
+ if (this.state.blockRender) {
108
+ this.setState({ blockRender: false });
109
+ }
110
+ };
111
+ /*
112
+ Bust cached creds if exist, invoke auth failure handler
113
+ */
114
+ handleCheckSessionFailure = (e) => {
115
+ if (this.props.storyId) {
116
+ SessionService.cacheStoryId(this.props.storyId);
117
+ }
118
+ else {
119
+ SessionService.clearCachedStoryId();
120
+ }
121
+ if (this.props.organizationId) {
122
+ SessionService.cacheOrgId(this.props.organizationId);
123
+ }
124
+ else {
125
+ SessionService.clearCachedOrgId();
126
+ }
127
+ this.props.clearCachedAuth();
128
+ this.props.onAuthenticationFailure(e);
129
+ };
130
+ /*
131
+ Check auth0 session, pull Imposium access creds on success and initialize app-wrapper
132
+ */
133
+ doCheckSession = (blockRender = false) => {
134
+ const { baseUrl } = this.props;
135
+ if (blockRender) {
136
+ this.setState({ blockRender: true });
137
+ }
138
+ AuthService.checkSession()
139
+ .then((freshIdentity) => {
140
+ const orgId = this.props.organizationId
141
+ ? this.props.organizationId
142
+ : SessionService.getCachedOrgId();
143
+ SessionService.getAccessData(freshIdentity.idToken, baseUrl, false, orgId)
144
+ .then((freshAccess) => {
145
+ this.props.setAccessData(freshAccess);
146
+ this.props.login(freshIdentity);
147
+ this.propagateCreds(freshAccess, freshIdentity);
148
+ })
149
+ .catch((e) => {
150
+ console.error(e);
151
+ this.handleCheckSessionFailure(e);
152
+ });
153
+ })
154
+ .catch((e) => {
155
+ console.error(e);
156
+ this.handleCheckSessionFailure(e);
157
+ });
158
+ };
159
+ render = () => {
160
+ const { blockRender, restrictAccess } = this.state;
161
+ const { children, showRequestAccess, allowUnauthenticatedRender } = this.props;
162
+ let innerContent;
163
+ if (!blockRender && restrictAccess) {
164
+ const showNoOrgs = this.props.access &&
165
+ this.props.access.organizations &&
166
+ this.props.access.organizations.length === 0;
167
+ const errorIndicator = showNoOrgs
168
+ ? AppWrapper.NO_ORGS
169
+ : showRequestAccess
170
+ ? AppWrapper.RESTRICTED_REQUEST
171
+ : AppWrapper.RESTRICTED_BLOCK;
172
+ innerContent = [
173
+ typeof children[0] === 'object' && children[0].type === Header && children[0],
174
+ errorIndicator
175
+ ];
176
+ }
177
+ if ((!blockRender && !restrictAccess) || allowUnauthenticatedRender) {
178
+ innerContent = children;
179
+ }
180
+ return (React.createElement("div", { id: 'app', className: 'app' }, innerContent));
181
+ };
182
+ }
183
+ const mapDispatchToProps = (dispatch) => {
184
+ return bindActionCreators({
185
+ login,
186
+ setAccessData,
187
+ clearCachedAuth
188
+ }, dispatch);
189
+ };
190
+ const mapStateToProps = (state) => {
191
+ return { auth: state.auth, access: state.access };
192
+ };
193
+ export default connect(mapStateToProps, mapDispatchToProps)(AppWrapper);
194
+ //# sourceMappingURL=AppWrapper_LOCAL_73190.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AppWrapper_LOCAL_73190.js","sourceRoot":"","sources":["../../../../src/components/app-wrapper/AppWrapper_LOCAL_73190.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,28 @@
1
+ import * as React from 'react';
2
+ import { IIdentity } from '../../services/Auth0';
3
+ export interface IAppWrapperProps {
4
+ children: React.ReactChildren;
5
+ auth0Domain: string;
6
+ auth0ClientId: string;
7
+ organizationId: string;
8
+ baseUrl: string;
9
+ storyId?: string;
10
+ serviceId: number;
11
+ access: any;
12
+ auth: any;
13
+ isFreshUser: boolean;
14
+ allowUnauthenticatedRender: boolean;
15
+ onAuthenticated: (activeOrgId: string, activeStoryId: string) => any;
16
+ onAuthenticationFailure: (e: Error) => any;
17
+ showRequestAccess?: boolean;
18
+ login: (id: IIdentity) => any;
19
+ clearCachedAuth: () => any;
20
+ cacheAccessData: (accessData: any) => any;
21
+ clearCachedAccessList: () => any;
22
+ }
23
+ export interface IAppWrapperState {
24
+ blockRender: boolean;
25
+ restrictAccess: boolean;
26
+ }
27
+ declare const _default: any;
28
+ export default _default;
@@ -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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"}
@@ -1,2 +1,10 @@
1
1
  import React from 'react';
2
+ export interface IConfirmModalProps {
3
+ onYes: () => void;
4
+ onNo?: () => void;
5
+ title: string;
6
+ yesLabel?: string;
7
+ noLabel?: string;
8
+ showCancel?: boolean;
9
+ }
2
10
  export declare const ConfirmModal: () => React.JSX.Element;
@@ -13,21 +13,30 @@ export const ConfirmModal = () => {
13
13
  });
14
14
  setIsOpen(true);
15
15
  };
16
- const onClose = () => {
16
+ const onYesHandler = () => {
17
+ props.onYes();
17
18
  setIsOpen(false);
18
19
  };
20
+ const onYes = useCallback(() => onYesHandler(), [isOpen]);
21
+ const onNo = useCallback(() => {
22
+ if (props.onNo) {
23
+ props.onNo();
24
+ setIsOpen(false);
25
+ }
26
+ else {
27
+ setIsOpen(false);
28
+ }
29
+ }, [isOpen]);
19
30
  const onKeyDown = useCallback((e) => {
20
31
  if (e.key === 'Enter') {
21
32
  e.preventDefault();
22
- props.onYes(e);
33
+ onYesHandler();
23
34
  }
24
35
  }, [isOpen]);
25
36
  useEffect(() => {
26
37
  window.addEventListener('openconfirmmodal', onOpen);
27
- window.addEventListener('closeconfirmmodal', onClose);
28
38
  return () => {
29
39
  window.removeEventListener('openconfirmmodal', onOpen);
30
- window.removeEventListener('closeconfirmmodal', onClose);
31
40
  };
32
41
  }, []);
33
42
  useEffect(() => {
@@ -44,7 +53,7 @@ export const ConfirmModal = () => {
44
53
  const { cancel, yes, no } = copy;
45
54
  const noLabel = props?.noLabel ? props.noLabel : no;
46
55
  const yesLabel = props?.yesLabel ? props.yesLabel : yes;
47
- const modal = isOpen && (React.createElement(Modal, { onRequestClose: onClose, wrapperStyle: {
56
+ const modal = isOpen && (React.createElement(Modal, { onRequestClose: onNo, wrapperStyle: {
48
57
  left: '0px',
49
58
  width: '100%'
50
59
  }, style: {
@@ -54,12 +63,12 @@ export const ConfirmModal = () => {
54
63
  left: 'calc((100% - 400px) / 2)'
55
64
  }, isOpen: true },
56
65
  React.createElement(Section, null,
57
- React.createElement("div", { className: 'confirm-modal', onKeyDown: (e) => console.log('onKeyDown', e) },
66
+ React.createElement("div", { className: 'confirm-modal' },
58
67
  React.createElement("p", null, props.title),
59
68
  React.createElement("div", { className: 'confirm-buttons' },
60
- props.showCancel ? (React.createElement(Button, { onClick: props.onClose, size: 'large', color: 'default' }, cancel)) : null,
61
- React.createElement(Button, { onClick: props.onNo, size: 'large', color: 'default' }, noLabel),
62
- React.createElement(Button, { onClick: props.onYes, size: 'large', style: 'bold', color: 'primary' }, yesLabel))))));
69
+ props.showCancel ? (React.createElement(Button, { onClick: onNo, size: 'large', color: 'default' }, cancel)) : null,
70
+ React.createElement(Button, { onClick: onNo, size: 'large', color: 'default' }, noLabel),
71
+ React.createElement(Button, { onClick: onYes, size: 'large', style: 'bold', color: 'primary' }, yesLabel))))));
63
72
  const PortalContextComponent = () => ReactDOM.createPortal(modal, document.querySelector('#react-root'));
64
73
  return React.createElement(PortalContextComponent, null);
65
74
  };
@@ -1 +1 @@
1
- {"version":3,"file":"ConfirmModal.js","sourceRoot":"","sources":["../../../../src/components/confirm-modal/ConfirmModal.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"ConfirmModal.js","sourceRoot":"","sources":["../../../../src/components/confirm-modal/ConfirmModal.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAChE,OAAO,QAAQ,MAAM,WAAW,CAAC;AACjC,OAAO,KAAK,MAAM,gBAAgB,CAAC;AACnC,OAAO,MAAM,MAAM,kBAAkB,CAAC;AACtC,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,OAAO,MAAM,oBAAoB,CAAC;AAWzC,MAAM,CAAC,MAAM,YAAY,GAAG,GAAG,EAAE;IAC7B,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAqB,IAAI,CAAC,CAAC;IAC7D,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAC;IAErD,MAAM,MAAM,GAAG,CAAC,KAAK,EAAE,EAAE;QACrB,QAAQ,CAAC;YACL,GAAG,KAAK,CAAC,MAAM;SAClB,CAAC,CAAC;QACH,SAAS,CAAC,IAAI,CAAC,CAAC;IACpB,CAAC,CAAC;IAEF,MAAM,YAAY,GAAG,GAAG,EAAE;QACtB,KAAK,CAAC,KAAK,EAAE,CAAC;QACd,SAAS,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC,CAAC;IAEF,MAAM,KAAK,GAAG,WAAW,CAAC,GAAG,EAAE,CAAC,YAAY,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAE1D,MAAM,IAAI,GAAG,WAAW,CAAC,GAAG,EAAE;QAC1B,IAAI,KAAK,CAAC,IAAI,EAAE,CAAC;YACb,KAAK,CAAC,IAAI,EAAE,CAAC;YACb,SAAS,CAAC,KAAK,CAAC,CAAC;QACrB,CAAC;aAAM,CAAC;YACJ,SAAS,CAAC,KAAK,CAAC,CAAC;QACrB,CAAC;IACL,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;IAEb,MAAM,SAAS,GAAG,WAAW,CACzB,CAAC,CAAC,EAAE,EAAE;QACF,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;YACpB,CAAC,CAAC,cAAc,EAAE,CAAC;YACnB,YAAY,EAAE,CAAC;QACnB,CAAC;IACL,CAAC,EACD,CAAC,MAAM,CAAC,CACX,CAAC;IAEF,SAAS,CAAC,GAAG,EAAE;QACX,MAAM,CAAC,gBAAgB,CAAC,kBAAkB,EAAE,MAAM,CAAC,CAAC;QACpD,OAAO,GAAG,EAAE;YACR,MAAM,CAAC,mBAAmB,CAAC,kBAAkB,EAAE,MAAM,CAAC,CAAC;QAC3D,CAAC,CAAC;IACN,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,SAAS,CAAC,GAAG,EAAE;QACX,IAAI,MAAM,EAAE,CAAC;YACT,QAAQ,CAAC,gBAAgB,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;QACrD,CAAC;aAAM,CAAC;YACJ,QAAQ,CAAC,mBAAmB,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;QACxD,CAAC;QACD,OAAO,GAAG,EAAE;YACR,QAAQ,CAAC,mBAAmB,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC;QACxD,CAAC,CAAC;IACN,CAAC,EAAE,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;IAExB,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,EAAE,EAAE,GAAG,IAAI,CAAC;IACjC,MAAM,OAAO,GAAG,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;IACpD,MAAM,QAAQ,GAAG,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,GAAG,CAAC;IAExD,MAAM,KAAK,GAAG,MAAM,IAAI,CACpB,oBAAC,KAAK,IACF,cAAc,EAAE,IAAI,EACpB,YAAY,EAAE;YACV,IAAI,EAAE,KAAK;YACX,KAAK,EAAE,MAAM;SAChB,EACD,KAAK,EAAE;YACH,KAAK,EAAE,OAAO;YACd,MAAM,EAAE,KAAK;YACb,GAAG,EAAE,mBAAmB;YACxB,IAAI,EAAE,0BAA0B;SACnC,EACD,MAAM,EAAE,IAAI;QACZ,oBAAC,OAAO;YACJ,6BAAK,SAAS,EAAC,eAAe;gBAC1B,+BAAI,KAAK,CAAC,KAAK,CAAK;gBACpB,6BAAK,SAAS,EAAC,iBAAiB;oBAC3B,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAChB,oBAAC,MAAM,IACH,OAAO,EAAE,IAAI,EACb,IAAI,EAAC,OAAO,EACZ,KAAK,EAAC,SAAS,IACd,MAAM,CACF,CACZ,CAAC,CAAC,CAAC,IAAI;oBACR,oBAAC,MAAM,IACH,OAAO,EAAE,IAAI,EACb,IAAI,EAAC,OAAO,EACZ,KAAK,EAAC,SAAS,IACd,OAAO,CACH;oBACT,oBAAC,MAAM,IACH,OAAO,EAAE,KAAK,EACd,IAAI,EAAC,OAAO,EACZ,KAAK,EAAC,MAAM,EACZ,KAAK,EAAC,SAAS,IACd,QAAQ,CACJ,CACP,CACJ,CACA,CACN,CACX,CAAC;IAEF,MAAM,sBAAsB,GAAG,GAAG,EAAE,CAChC,QAAQ,CAAC,YAAY,CAAC,KAAK,EAAE,QAAQ,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC,CAAC;IAExE,OAAO,oBAAC,sBAAsB,OAAG,CAAC;AACtC,CAAC,CAAC"}
@@ -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,33 @@
1
+ export interface IHeaderProps {
2
+ email?: string;
3
+ activeOrganization: string;
4
+ activeStory?: string;
5
+ hideStoryPicker?: boolean;
6
+ hideOrgPicker?: boolean;
7
+ onOrganizationChange?: (orgId: any) => any;
8
+ onStoryChange?: (story: any) => any;
9
+ logout: (...args: any[]) => any;
10
+ additionalButtons?: any[];
11
+ auth: any;
12
+ story: any;
13
+ baseUrl: any;
14
+ hideDocs?: boolean;
15
+ showFTLogo?: boolean;
16
+ }
17
+ export interface IHeaderState {
18
+ inactiveOrganizations: any[];
19
+ servicesByOrganization: any[];
20
+ activeServiceBlob: any;
21
+ activeOrganizationBlob: any;
22
+ showAccountDropdown: boolean;
23
+ showStoriesDropdown: boolean;
24
+ showServiceDropdown: boolean;
25
+ dropdownToggleColor: string;
26
+ activeFirstChar: string;
27
+ order: string;
28
+ orderDirection: string;
29
+ accessData: any;
30
+ dataLoading: boolean;
31
+ }
32
+ declare const _default: any;
33
+ export default _default;