synapse-react-client 3.0.19 → 3.0.20

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 (78) hide show
  1. package/dist/containers/AccessRequestSubmissionTable.d.ts +14 -0
  2. package/dist/containers/AccessRequestSubmissionTable.js +90 -0
  3. package/dist/containers/AccessRequestSubmissionTable.js.map +1 -0
  4. package/dist/containers/EntityIdList.js +8 -5
  5. package/dist/containers/EntityIdList.js.map +1 -1
  6. package/dist/containers/EntityLink.js +3 -4
  7. package/dist/containers/EntityLink.js.map +1 -1
  8. package/dist/containers/FullWidthAlert.js +4 -3
  9. package/dist/containers/FullWidthAlert.js.map +1 -1
  10. package/dist/containers/IconSvg.d.ts +1 -1
  11. package/dist/containers/IconSvg.js +2 -0
  12. package/dist/containers/IconSvg.js.map +1 -1
  13. package/dist/containers/SqlEditor.d.ts +6 -2
  14. package/dist/containers/SqlEditor.js +16 -9
  15. package/dist/containers/SqlEditor.js.map +1 -1
  16. package/dist/containers/SynapseNavDrawer.js +1 -1
  17. package/dist/containers/SynapseNavDrawer.js.map +1 -1
  18. package/dist/containers/UserOrTeamBadge.js +8 -25
  19. package/dist/containers/UserOrTeamBadge.js.map +1 -1
  20. package/dist/containers/UserSearchBoxV2.d.ts +13 -0
  21. package/dist/containers/UserSearchBoxV2.js +91 -0
  22. package/dist/containers/UserSearchBoxV2.js.map +1 -0
  23. package/dist/containers/dataaccess/AccessRequirementDashboard.d.ts +6 -0
  24. package/dist/containers/dataaccess/AccessRequirementDashboard.js +130 -0
  25. package/dist/containers/dataaccess/AccessRequirementDashboard.js.map +1 -0
  26. package/dist/containers/dataaccess/AccessRequirementTable.d.ts +10 -0
  27. package/dist/containers/dataaccess/AccessRequirementTable.js +89 -0
  28. package/dist/containers/dataaccess/AccessRequirementTable.js.map +1 -0
  29. package/dist/containers/dataaccess/ReviewerDashboard.d.ts +9 -0
  30. package/dist/containers/dataaccess/ReviewerDashboard.js +82 -0
  31. package/dist/containers/dataaccess/ReviewerDashboard.js.map +1 -0
  32. package/dist/containers/dataaccess/SubmissionPage.d.ts +11 -0
  33. package/dist/containers/dataaccess/SubmissionPage.js +176 -0
  34. package/dist/containers/dataaccess/SubmissionPage.js.map +1 -0
  35. package/dist/containers/synapse_table_functions/SynapseTableCell.js +4 -2
  36. package/dist/containers/synapse_table_functions/SynapseTableCell.js.map +1 -1
  37. package/dist/style/abstracts/_mixins.scss +13 -8
  38. package/dist/style/components/_global-alert.scss +1 -1
  39. package/dist/style/components/_governance-dashboard.scss +29 -0
  40. package/dist/style/components/_submission-page.scss +1 -4
  41. package/dist/style/main.css +117 -28
  42. package/dist/umd/synapse-react-client.development.css +112 -28
  43. package/dist/umd/synapse-react-client.development.css.map +2 -2
  44. package/dist/umd/synapse-react-client.development.js +2884 -1717
  45. package/dist/umd/synapse-react-client.development.js.map +3 -3
  46. package/dist/umd/synapse-react-client.production.min.css +1 -1
  47. package/dist/umd/synapse-react-client.production.min.js +96 -96
  48. package/dist/umd.index.d.ts +2 -0
  49. package/dist/umd.index.js +2 -0
  50. package/dist/umd.index.js.map +1 -1
  51. package/dist/utils/SynapseClient.d.ts +4 -2
  52. package/dist/utils/SynapseClient.js +8 -2
  53. package/dist/utils/SynapseClient.js.map +1 -1
  54. package/dist/utils/SynapseConstants.d.ts +1 -1
  55. package/dist/utils/SynapseConstants.js +1 -1
  56. package/dist/utils/SynapseConstants.js.map +1 -1
  57. package/dist/utils/hooks/SynapseAPI/dataaccess/useAccessSubmission.d.ts +5 -0
  58. package/dist/utils/hooks/SynapseAPI/dataaccess/useAccessSubmission.js +21 -0
  59. package/dist/utils/hooks/SynapseAPI/dataaccess/useAccessSubmission.js.map +1 -0
  60. package/dist/utils/hooks/SynapseAPI/dataaccess/useGetDataAccessSubmission.d.ts +5 -0
  61. package/dist/utils/hooks/SynapseAPI/dataaccess/useGetDataAccessSubmission.js +11 -0
  62. package/dist/utils/hooks/SynapseAPI/dataaccess/useGetDataAccessSubmission.js.map +1 -0
  63. package/dist/utils/hooks/SynapseAPI/useUserBundle.d.ts +2 -1
  64. package/dist/utils/hooks/SynapseAPI/useUserBundle.js +17 -2
  65. package/dist/utils/hooks/SynapseAPI/useUserBundle.js.map +1 -1
  66. package/dist/utils/hooks/SynapseAPI/useUserGroupHeader.d.ts +5 -0
  67. package/dist/utils/hooks/SynapseAPI/useUserGroupHeader.js +28 -0
  68. package/dist/utils/hooks/SynapseAPI/useUserGroupHeader.js.map +1 -0
  69. package/dist/utils/hooks/useDebouncedEffect.d.ts +9 -0
  70. package/dist/utils/hooks/useDebouncedEffect.js +21 -0
  71. package/dist/utils/hooks/useDebouncedEffect.js.map +1 -0
  72. package/dist/utils/hooks/useGetInfoFromIds.d.ts +6 -0
  73. package/dist/utils/hooks/useGetInfoFromIds.js +6 -2
  74. package/dist/utils/hooks/useGetInfoFromIds.js.map +1 -1
  75. package/dist/utils/synapseTypes/AccessRequirement/Submission.d.ts +52 -0
  76. package/dist/utils/synapseTypes/AccessRequirement/Submission.js +3 -0
  77. package/dist/utils/synapseTypes/AccessRequirement/Submission.js.map +1 -0
  78. package/package.json +1 -1
@@ -0,0 +1,6 @@
1
+ /// <reference types="react" />
2
+ export declare type AccessRequirementDashboardProps = {
3
+ onCreateNewAccessRequirementClicked?: () => void;
4
+ };
5
+ export declare function AccessRequirementDashboard(props: AccessRequirementDashboardProps): JSX.Element;
6
+ export default AccessRequirementDashboard;
@@ -0,0 +1,130 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AccessRequirementDashboard = void 0;
4
+ var tslib_1 = require("tslib");
5
+ var lodash_es_1 = require("lodash-es");
6
+ var react_1 = (0, tslib_1.__importStar)(require("react"));
7
+ var react_bootstrap_1 = require("react-bootstrap");
8
+ var react_router_dom_1 = require("react-router-dom");
9
+ var useDebouncedEffect_1 = require("../../utils/hooks/useDebouncedEffect");
10
+ var synapseTypes_1 = require("../../utils/synapseTypes");
11
+ var EntityFinderModal_1 = require("../entity_finder/EntityFinderModal");
12
+ var EntityTree_1 = require("../entity_finder/tree/EntityTree");
13
+ var IconSvg_1 = (0, tslib_1.__importDefault)(require("../IconSvg"));
14
+ var UserSearchBoxV2_1 = (0, tslib_1.__importDefault)(require("../UserSearchBoxV2"));
15
+ var AccessRequirementTable_1 = require("./AccessRequirementTable");
16
+ function AccessRequirementDashboard(props) {
17
+ // Amount of time to wait after an input value changes before sending a new request
18
+ var INPUT_CHANGE_DEBOUNCE_DELAY_MS = 500;
19
+ var onCreateNewAccessRequirementClicked = props.onCreateNewAccessRequirementClicked;
20
+ var location = (0, react_router_dom_1.useLocation)();
21
+ var history = (0, react_router_dom_1.useHistory)();
22
+ var _a = (0, react_1.useState)(''), nameContains = _a[0], setNameContains = _a[1];
23
+ var _b = (0, react_1.useState)(undefined), relatedProjectId = _b[0], setRelatedProjectId = _b[1];
24
+ var _c = (0, react_1.useState)(undefined), reviewerId = _c[0], setReviewerId = _c[1];
25
+ (0, react_1.useEffect)(function () {
26
+ function initializeFromSearchParams() {
27
+ var _a, _b, _c;
28
+ var initialParams = new URLSearchParams(location.search);
29
+ setNameContains((_a = initialParams.get('nameContains')) !== null && _a !== void 0 ? _a : '');
30
+ setRelatedProjectId((_b = initialParams.get('relatedProjectId')) !== null && _b !== void 0 ? _b : undefined);
31
+ setReviewerId((_c = initialParams.get('reviewerId')) !== null && _c !== void 0 ? _c : undefined);
32
+ }
33
+ initializeFromSearchParams();
34
+ }, [location.search]);
35
+ var _d = (0, react_1.useState)(false), showEntityFinder = _d[0], setShowEntityFinder = _d[1];
36
+ var _e = (0, react_1.useState)({
37
+ nameContains: nameContains,
38
+ relatedProjectId: relatedProjectId,
39
+ reviewerId: reviewerId,
40
+ onCreateNewAccessRequirementClicked: onCreateNewAccessRequirementClicked,
41
+ }), tableProps = _e[0], setTableProps = _e[1];
42
+ /**
43
+ * When an input changes, update the props passed to the table and update the search params.
44
+ *
45
+ * Debounced to prevent firing many queries while the user is entering text.
46
+ */
47
+ (0, useDebouncedEffect_1.useDebouncedEffect)(function () {
48
+ function updateQueryParams(nameContains, relatedProjectId, reviewerId) {
49
+ // Don't include undefined/empty parameters
50
+ var params = (0, lodash_es_1.omitBy)({
51
+ nameContains: nameContains,
52
+ relatedProjectId: relatedProjectId,
53
+ reviewerId: reviewerId,
54
+ }, function (item) { return item === undefined || item === ''; });
55
+ // Add the new params to the URL
56
+ // Replace history because intuitively, the user has not navigated to a new page
57
+ var paramsObject = new URLSearchParams(params);
58
+ history.replace({
59
+ pathname: location.pathname,
60
+ search: paramsObject.toString(),
61
+ });
62
+ }
63
+ setTableProps({
64
+ nameContains: nameContains,
65
+ relatedProjectId: relatedProjectId,
66
+ reviewerId: reviewerId,
67
+ onCreateNewAccessRequirementClicked: onCreateNewAccessRequirementClicked,
68
+ });
69
+ updateQueryParams(nameContains, relatedProjectId, reviewerId);
70
+ }, [
71
+ nameContains,
72
+ relatedProjectId,
73
+ reviewerId,
74
+ onCreateNewAccessRequirementClicked,
75
+ history,
76
+ location,
77
+ ], INPUT_CHANGE_DEBOUNCE_DELAY_MS);
78
+ var onReviewerChange = (0, react_1.useCallback)(function (selected) {
79
+ if (selected) {
80
+ setReviewerId(selected);
81
+ }
82
+ else {
83
+ setReviewerId(undefined);
84
+ }
85
+ }, []);
86
+ return (react_1.default.createElement("div", { className: "AccessRequirementDashboard bootstrap-4-backport" },
87
+ react_1.default.createElement(EntityFinderModal_1.EntityFinderModal, { configuration: {
88
+ initialScope: EntityTree_1.FinderScope.ALL_PROJECTS,
89
+ initialContainer: null,
90
+ selectMultiple: false,
91
+ selectableTypes: [synapseTypes_1.EntityType.PROJECT],
92
+ }, show: showEntityFinder, onClose: function () {
93
+ setShowEntityFinder(false);
94
+ }, onCancel: function () {
95
+ setShowEntityFinder(false);
96
+ }, title: 'Select Project to Filter Access Requirements', promptCopy: 'Select a project to find Access Requirements that are associated with that project. Access Requirements will be found if the Access Requirement is applied to the project, or if it is applied to any item inside the project.', onConfirm: function (selected) {
97
+ setRelatedProjectId(selected[0].targetId);
98
+ setShowEntityFinder(false);
99
+ }, confirmButtonCopy: 'Select' }),
100
+ react_1.default.createElement("div", { className: "InputPanel" },
101
+ react_1.default.createElement("div", null,
102
+ react_1.default.createElement(react_bootstrap_1.FormLabel, { htmlFor: "ar-name-filter" }, "Filter by Access Requirement Name"),
103
+ react_1.default.createElement(react_bootstrap_1.InputGroup, null,
104
+ react_1.default.createElement(react_bootstrap_1.FormControl, { id: "ar-name-filter", type: "text", placeholder: "Search for an Access Requirement Name", value: nameContains, onChange: function (e) {
105
+ setNameContains(e.target.value);
106
+ } }),
107
+ react_1.default.createElement(IconSvg_1.default, { options: { icon: 'searchOutlined' } }))),
108
+ react_1.default.createElement("div", null,
109
+ react_1.default.createElement(react_bootstrap_1.FormLabel, { htmlFor: "project-id-filter" }, "Filter by Project"),
110
+ react_1.default.createElement("div", { className: "ProjectIdInputGroup" },
111
+ react_1.default.createElement(react_bootstrap_1.FormControl, { id: "project-id-filter", type: "text", placeholder: "Enter a project SynID", value: relatedProjectId, onChange: function (e) {
112
+ var newValue = e.target.value;
113
+ if (newValue === '') {
114
+ setRelatedProjectId(undefined);
115
+ }
116
+ else {
117
+ setRelatedProjectId(newValue);
118
+ }
119
+ } }),
120
+ react_1.default.createElement(react_bootstrap_1.Button, { variant: "outline", onClick: function () {
121
+ setShowEntityFinder(true);
122
+ } }, "Browse"))),
123
+ react_1.default.createElement("div", null,
124
+ react_1.default.createElement(react_bootstrap_1.FormLabel, { htmlFor: "reviewer-filter" }, "Filter by Reviewer"),
125
+ react_1.default.createElement(UserSearchBoxV2_1.default, { htmlId: "reviewer-filter", placeholder: "Search for a username or team name", defaultValue: reviewerId, onChange: onReviewerChange }))),
126
+ react_1.default.createElement(AccessRequirementTable_1.AccessRequirementTable, (0, tslib_1.__assign)({}, tableProps))));
127
+ }
128
+ exports.AccessRequirementDashboard = AccessRequirementDashboard;
129
+ exports.default = AccessRequirementDashboard;
130
+ //# sourceMappingURL=AccessRequirementDashboard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AccessRequirementDashboard.js","sourceRoot":"","sources":["../../../src/lib/containers/dataaccess/AccessRequirementDashboard.tsx"],"names":[],"mappings":";;;;AAAA,uCAAkC;AAClC,0DAA+D;AAC/D,mDAA4E;AAC5E,qDAA0D;AAC1D,2EAAyE;AACzE,yDAAqD;AACrD,wEAAsE;AACtE,+DAA8D;AAC9D,oEAAgC;AAChC,oFAAgD;AAChD,mEAGiC;AAMjC,SAAgB,0BAA0B,CACxC,KAAsC;IAEtC,mFAAmF;IACnF,IAAM,8BAA8B,GAAG,GAAG,CAAA;IAElC,IAAA,mCAAmC,GAAK,KAAK,oCAAV,CAAU;IAErD,IAAM,QAAQ,GAAG,IAAA,8BAAW,GAAE,CAAA;IAC9B,IAAM,OAAO,GAAG,IAAA,6BAAU,GAAE,CAAA;IAEtB,IAAA,KAAkC,IAAA,gBAAQ,EAAS,EAAE,CAAC,EAArD,YAAY,QAAA,EAAE,eAAe,QAAwB,CAAA;IACtD,IAAA,KAA0C,IAAA,gBAAQ,EACtD,SAAS,CACV,EAFM,gBAAgB,QAAA,EAAE,mBAAmB,QAE3C,CAAA;IACK,IAAA,KAA8B,IAAA,gBAAQ,EAAqB,SAAS,CAAC,EAApE,UAAU,QAAA,EAAE,aAAa,QAA2C,CAAA;IAE3E,IAAA,iBAAS,EAAC;QACR,SAAS,0BAA0B;;YACjC,IAAM,aAAa,GAAG,IAAI,eAAe,CAAC,QAAQ,CAAC,MAAgB,CAAC,CAAA;YACpE,eAAe,CAAC,MAAA,aAAa,CAAC,GAAG,CAAC,cAAc,CAAC,mCAAI,EAAE,CAAC,CAAA;YACxD,mBAAmB,CAAC,MAAA,aAAa,CAAC,GAAG,CAAC,kBAAkB,CAAC,mCAAI,SAAS,CAAC,CAAA;YACvE,aAAa,CAAC,MAAA,aAAa,CAAC,GAAG,CAAC,YAAY,CAAC,mCAAI,SAAS,CAAC,CAAA;QAC7D,CAAC;QACD,0BAA0B,EAAE,CAAA;IAC9B,CAAC,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAA;IAEf,IAAA,KAA0C,IAAA,gBAAQ,EAAC,KAAK,CAAC,EAAxD,gBAAgB,QAAA,EAAE,mBAAmB,QAAmB,CAAA;IAEzD,IAAA,KAA8B,IAAA,gBAAQ,EAA8B;QACxE,YAAY,cAAA;QACZ,gBAAgB,kBAAA;QAChB,UAAU,YAAA;QACV,mCAAmC,qCAAA;KACpC,CAAC,EALK,UAAU,QAAA,EAAE,aAAa,QAK9B,CAAA;IAEF;;;;OAIG;IACH,IAAA,uCAAkB,EAChB;QACE,SAAS,iBAAiB,CACxB,YAAgC,EAChC,gBAAoC,EACpC,UAA8B;YAE9B,2CAA2C;YAC3C,IAAM,MAAM,GAAG,IAAA,kBAAM,EACnB;gBACE,YAAY,cAAA;gBACZ,gBAAgB,kBAAA;gBAChB,UAAU,YAAA;aACX,EACD,UAAA,IAAI,IAAI,OAAA,IAAI,KAAK,SAAS,IAAI,IAAI,KAAK,EAAE,EAAjC,CAAiC,CAChB,CAAA;YAE3B,gCAAgC;YAChC,gFAAgF;YAChF,IAAM,YAAY,GAAG,IAAI,eAAe,CAAC,MAAM,CAAC,CAAA;YAChD,OAAO,CAAC,OAAO,CAAC;gBACd,QAAQ,EAAE,QAAQ,CAAC,QAAQ;gBAC3B,MAAM,EAAE,YAAY,CAAC,QAAQ,EAAE;aAChC,CAAC,CAAA;QACJ,CAAC;QAED,aAAa,CAAC;YACZ,YAAY,cAAA;YACZ,gBAAgB,kBAAA;YAChB,UAAU,YAAA;YACV,mCAAmC,qCAAA;SACpC,CAAC,CAAA;QACF,iBAAiB,CAAC,YAAY,EAAE,gBAAgB,EAAE,UAAU,CAAC,CAAA;IAC/D,CAAC,EACD;QACE,YAAY;QACZ,gBAAgB;QAChB,UAAU;QACV,mCAAmC;QACnC,OAAO;QACP,QAAQ;KACT,EACD,8BAA8B,CAC/B,CAAA;IAED,IAAM,gBAAgB,GAAG,IAAA,mBAAW,EAAC,UAAC,QAAuB;QAC3D,IAAI,QAAQ,EAAE;YACZ,aAAa,CAAC,QAAQ,CAAC,CAAA;SACxB;aAAM;YACL,aAAa,CAAC,SAAS,CAAC,CAAA;SACzB;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,OAAO,CACL,uCAAK,SAAS,EAAC,iDAAiD;QAC9D,8BAAC,qCAAiB,IAChB,aAAa,EAAE;gBACb,YAAY,EAAE,wBAAW,CAAC,YAAY;gBACtC,gBAAgB,EAAE,IAAI;gBACtB,cAAc,EAAE,KAAK;gBACrB,eAAe,EAAE,CAAC,yBAAU,CAAC,OAAO,CAAC;aACtC,EACD,IAAI,EAAE,gBAAgB,EACtB,OAAO,EAAE;gBACP,mBAAmB,CAAC,KAAK,CAAC,CAAA;YAC5B,CAAC,EACD,QAAQ,EAAE;gBACR,mBAAmB,CAAC,KAAK,CAAC,CAAA;YAC5B,CAAC,EACD,KAAK,EAAE,8CAA8C,EACrD,UAAU,EACR,gOAAgO,EAElO,SAAS,EAAE,UAAA,QAAQ;gBACjB,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAA;gBACzC,mBAAmB,CAAC,KAAK,CAAC,CAAA;YAC5B,CAAC,EACD,iBAAiB,EAAE,QAAQ,GAC3B;QACF,uCAAK,SAAS,EAAC,YAAY;YACzB;gBACE,8BAAC,2BAAS,IAAC,OAAO,EAAC,gBAAgB,wCAEvB;gBAEZ,8BAAC,4BAAU;oBACT,8BAAC,6BAAW,IACV,EAAE,EAAC,gBAAgB,EACnB,IAAI,EAAC,MAAM,EACX,WAAW,EAAC,uCAAuC,EACnD,KAAK,EAAE,YAAY,EACnB,QAAQ,EAAE,UAAA,CAAC;4BACT,eAAe,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;wBACjC,CAAC,GACD;oBACF,8BAAC,iBAAO,IAAC,OAAO,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE,GAAI,CACrC,CACT;YACN;gBACE,8BAAC,2BAAS,IAAC,OAAO,EAAC,mBAAmB,wBAA8B;gBACpE,uCAAK,SAAS,EAAC,qBAAqB;oBAClC,8BAAC,6BAAW,IACV,EAAE,EAAC,mBAAmB,EACtB,IAAI,EAAC,MAAM,EACX,WAAW,EAAC,uBAAuB,EACnC,KAAK,EAAE,gBAAgB,EACvB,QAAQ,EAAE,UAAA,CAAC;4BACT,IAAM,QAAQ,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAA;4BAC/B,IAAI,QAAQ,KAAK,EAAE,EAAE;gCACnB,mBAAmB,CAAC,SAAS,CAAC,CAAA;6BAC/B;iCAAM;gCACL,mBAAmB,CAAC,QAAQ,CAAC,CAAA;6BAC9B;wBACH,CAAC,GACD;oBACF,8BAAC,wBAAM,IACL,OAAO,EAAC,SAAS,EACjB,OAAO,EAAE;4BACP,mBAAmB,CAAC,IAAI,CAAC,CAAA;wBAC3B,CAAC,aAGM,CACL,CACF;YACN;gBACE,8BAAC,2BAAS,IAAC,OAAO,EAAC,iBAAiB,yBAA+B;gBACnE,8BAAC,yBAAe,IACd,MAAM,EAAC,iBAAiB,EACxB,WAAW,EAAC,oCAAoC,EAChD,YAAY,EAAE,UAAU,EACxB,QAAQ,EAAE,gBAAgB,GAC1B,CACE,CACF;QACN,8BAAC,+CAAsB,4BAAK,UAAU,EAAI,CACtC,CACP,CAAA;AACH,CAAC;AAnLD,gEAmLC;AAED,kBAAe,0BAA0B,CAAA"}
@@ -0,0 +1,10 @@
1
+ /// <reference types="react" />
2
+ import { ACCESS_TYPE } from '../../utils/synapseTypes';
3
+ export declare type AccessRequirementTableProps = {
4
+ nameContains?: string;
5
+ relatedProjectId?: string;
6
+ reviewerId?: string;
7
+ accessType?: ACCESS_TYPE;
8
+ onCreateNewAccessRequirementClicked?: () => void;
9
+ };
10
+ export declare function AccessRequirementTable(props: AccessRequirementTableProps): JSX.Element;
@@ -0,0 +1,89 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AccessRequirementTable = void 0;
4
+ var tslib_1 = require("tslib");
5
+ var moment_1 = (0, tslib_1.__importDefault)(require("moment"));
6
+ var react_1 = (0, tslib_1.__importStar)(require("react"));
7
+ var react_bootstrap_1 = require("react-bootstrap");
8
+ var Sort_1 = (0, tslib_1.__importDefault)(require("../../assets/icons/Sort"));
9
+ var DateFormatter_1 = require("../../utils/functions/DateFormatter");
10
+ var getEndpoint_1 = require("../../utils/functions/getEndpoint");
11
+ var useGetAccessRequirement_1 = require("../../utils/hooks/SynapseAPI/dataaccess/useGetAccessRequirement");
12
+ var SynapseConstants_1 = require("../../utils/SynapseConstants");
13
+ var Typography_1 = (0, tslib_1.__importDefault)(require("../../utils/typography/Typography"));
14
+ var EntityLink_1 = require("../EntityLink");
15
+ var IconSvg_1 = (0, tslib_1.__importDefault)(require("../IconSvg"));
16
+ var LoadingScreen_1 = require("../LoadingScreen");
17
+ var UserOrTeamBadge_1 = (0, tslib_1.__importDefault)(require("../UserOrTeamBadge"));
18
+ function AccessRequirementTable(props) {
19
+ var _a;
20
+ var nameContains = props.nameContains, relatedProjectId = props.relatedProjectId, reviewerId = props.reviewerId, accessType = props.accessType, onCreateNewAccessRequirementClicked = props.onCreateNewAccessRequirementClicked;
21
+ var _b = (0, react_1.useState)({
22
+ field: 'CREATED_ON',
23
+ direction: 'DESC',
24
+ }), sort = _b[0], setSort = _b[1];
25
+ var searchRequest = (0, react_1.useMemo)(function () { return ({
26
+ nameContains: nameContains,
27
+ relatedProjectId: relatedProjectId,
28
+ reviewerId: reviewerId,
29
+ accessType: accessType,
30
+ sort: [sort],
31
+ }); }, [nameContains, relatedProjectId, reviewerId, accessType, sort]);
32
+ var _c = (0, useGetAccessRequirement_1.useSearchAccessRequirementsInfinite)(searchRequest), data = _c.data, hasNextPage = _c.hasNextPage, fetchNextPage = _c.fetchNextPage, isLoading = _c.isLoading;
33
+ var accessRequirements = (_a = data === null || data === void 0 ? void 0 : data.pages.flatMap(function (page) { return page.results; })) !== null && _a !== void 0 ? _a : [];
34
+ var onSort = function (field) {
35
+ if (sort.field === field) {
36
+ setSort({ field: field, direction: sort.direction === 'DESC' ? 'ASC' : 'DESC' });
37
+ }
38
+ else {
39
+ setSort({ field: field, direction: 'DESC' });
40
+ }
41
+ };
42
+ return (react_1.default.createElement("div", { className: "bootstrap-4-backport" },
43
+ react_1.default.createElement("div", { className: "SRC-split" },
44
+ react_1.default.createElement(Typography_1.default, { variant: "headline3", style: { marginBottom: 0 } }, "Access Requirements"),
45
+ onCreateNewAccessRequirementClicked && (react_1.default.createElement(react_bootstrap_1.Button, { variant: 'outline', onClick: onCreateNewAccessRequirementClicked },
46
+ react_1.default.createElement(IconSvg_1.default, { options: { icon: 'favTwoTone', padding: 'right' } }),
47
+ "New Access Requirement"))),
48
+ react_1.default.createElement("div", { className: "AccessRequirementsTable" },
49
+ react_1.default.createElement(react_bootstrap_1.Table, { striped: true, borderless: true, bordered: false },
50
+ react_1.default.createElement("thead", { className: "access-requirements-header" },
51
+ react_1.default.createElement("tr", null,
52
+ react_1.default.createElement("th", null, "AR ID"),
53
+ react_1.default.createElement("th", null,
54
+ react_1.default.createElement("span", { className: "SRC-split" },
55
+ react_1.default.createElement("span", null, "Access Requirement Name"),
56
+ react_1.default.createElement(Sort_1.default, { role: "button", onClick: function () { return onSort('NAME'); }, "aria-label": "Sort by Name", active: sort.field === 'NAME', direction: sort.field === 'NAME' ? sort.direction : 'DESC' }))),
57
+ react_1.default.createElement("th", null, "Related to Projects"),
58
+ react_1.default.createElement("th", null, "Reviewer"),
59
+ react_1.default.createElement("th", null, "Last Modified"),
60
+ react_1.default.createElement("th", null,
61
+ react_1.default.createElement("span", { className: "SRC-split" },
62
+ react_1.default.createElement("span", null, "Created On"),
63
+ react_1.default.createElement(Sort_1.default, { role: "button", onClick: function () { return onSort('CREATED_ON'); }, active: sort.field === 'CREATED_ON', "aria-label": "Sort by Created On", direction: sort.field === 'CREATED_ON' ? sort.direction : 'DESC' }))))),
64
+ react_1.default.createElement("tbody", null, accessRequirements.map(function (ar) {
65
+ return (react_1.default.createElement("tr", { key: ar.id },
66
+ react_1.default.createElement("td", null,
67
+ react_1.default.createElement("a", { href: getEndpoint_1.PRODUCTION_ENDPOINT_CONFIG.PORTAL + "#!AccessRequirement:AR_ID=" + ar.id }, ar.id)),
68
+ react_1.default.createElement("td", null, ar.name),
69
+ react_1.default.createElement("td", null, ar.relatedProjectIds.map(function (projectId) { return (react_1.default.createElement(react_1.default.Fragment, { key: projectId },
70
+ react_1.default.createElement(EntityLink_1.EntityLink, { entity: projectId }),
71
+ ' ',
72
+ react_1.default.createElement("span", { className: "InlineLabel" },
73
+ "(",
74
+ projectId,
75
+ ")"),
76
+ react_1.default.createElement("br", null))); })),
77
+ react_1.default.createElement("td", null, ar.reviewerIds.length === 0 ? (react_1.default.createElement(UserOrTeamBadge_1.default, { principalId: SynapseConstants_1.ACT_TEAM_ID })) : (ar.reviewerIds.map(function (reviewerId) { return (react_1.default.createElement(UserOrTeamBadge_1.default, { key: reviewerId, principalId: reviewerId })); }))),
78
+ react_1.default.createElement("td", null, (0, DateFormatter_1.formatDate)((0, moment_1.default)(ar.modifiedOn))),
79
+ react_1.default.createElement("td", null, (0, DateFormatter_1.formatDate)((0, moment_1.default)(ar.createdOn)))));
80
+ }))),
81
+ isLoading && (react_1.default.createElement("div", { className: "SRC-center-text" },
82
+ react_1.default.createElement(LoadingScreen_1.SynapseSpinner, { size: 40 }))),
83
+ !isLoading && accessRequirements.length === 0 && (react_1.default.createElement(Typography_1.default, { className: "SRC-center-text", variant: "body1" }, "No Results")),
84
+ !hasNextPage ? (react_1.default.createElement(react_1.default.Fragment, null)) : (react_1.default.createElement(react_bootstrap_1.Button, { variant: "outline", onClick: function () {
85
+ fetchNextPage();
86
+ } }, "Show More")))));
87
+ }
88
+ exports.AccessRequirementTable = AccessRequirementTable;
89
+ //# sourceMappingURL=AccessRequirementTable.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AccessRequirementTable.js","sourceRoot":"","sources":["../../../src/lib/containers/dataaccess/AccessRequirementTable.tsx"],"names":[],"mappings":";;;;AAAA,+DAA2B;AAC3B,0DAAgD;AAChD,mDAA+C;AAC/C,8EAA8C;AAC9C,qEAAgE;AAChE,iEAA8E;AAC9E,2GAAqH;AACrH,iEAA0D;AAM1D,8FAA0D;AAC1D,4CAA0C;AAC1C,oEAAgC;AAChC,kDAAiD;AACjD,oFAAgD;AAUhD,SAAgB,sBAAsB,CAAC,KAAkC;;IAErE,IAAA,YAAY,GAKV,KAAK,aALK,EACZ,gBAAgB,GAId,KAAK,iBAJS,EAChB,UAAU,GAGR,KAAK,WAHG,EACV,UAAU,GAER,KAAK,WAFG,EACV,mCAAmC,GACjC,KAAK,oCAD4B,CAC5B;IAEH,IAAA,KAAkB,IAAA,gBAAQ,EAA8B;QAC5D,KAAK,EAAE,YAAY;QACnB,SAAS,EAAE,MAAM;KAClB,CAAC,EAHK,IAAI,QAAA,EAAE,OAAO,QAGlB,CAAA;IAEF,IAAM,aAAa,GACjB,IAAA,eAAO,EACL,cAAM,OAAA,CAAC;QACL,YAAY,cAAA;QACZ,gBAAgB,kBAAA;QAChB,UAAU,YAAA;QACV,UAAU,YAAA;QACV,IAAI,EAAE,CAAC,IAAI,CAAC;KACb,CAAC,EANI,CAMJ,EACF,CAAC,YAAY,EAAE,gBAAgB,EAAE,UAAU,EAAE,UAAU,EAAE,IAAI,CAAC,CAC/D,CAAA;IAEG,IAAA,KACJ,IAAA,6DAAmC,EAAC,aAAa,CAAC,EAD5C,IAAI,UAAA,EAAE,WAAW,iBAAA,EAAE,aAAa,mBAAA,EAAE,SAAS,eACC,CAAA;IAEpD,IAAM,kBAAkB,GAAG,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,KAAK,CAAC,OAAO,CAAC,UAAA,IAAI,IAAI,OAAA,IAAI,CAAC,OAAO,EAAZ,CAAY,CAAC,mCAAI,EAAE,CAAA;IAC1E,IAAM,MAAM,GAAG,UAAC,KAA2C;QACzD,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE;YACxB,OAAO,CAAC,EAAE,KAAK,OAAA,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,KAAK,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAA;SAC1E;aAAM;YACL,OAAO,CAAC,EAAE,KAAK,OAAA,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC,CAAA;SACtC;IACH,CAAC,CAAA;IAED,OAAO,CACL,uCAAK,SAAS,EAAC,sBAAsB;QACnC,uCAAK,SAAS,EAAC,WAAW;YACxB,8BAAC,oBAAU,IAAC,OAAO,EAAC,WAAW,EAAC,KAAK,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,0BAE7C;YACZ,mCAAmC,IAAI,CACtC,8BAAC,wBAAM,IACL,OAAO,EAAE,SAAS,EAClB,OAAO,EAAE,mCAAmC;gBAE5C,8BAAC,iBAAO,IAAC,OAAO,EAAE,EAAE,IAAI,EAAE,YAAY,EAAE,OAAO,EAAE,OAAO,EAAE,GAAI;yCAEvD,CACV,CACG;QAEN,uCAAK,SAAS,EAAC,yBAAyB;YACtC,8BAAC,uBAAK,IAAC,OAAO,QAAC,UAAU,QAAC,QAAQ,EAAE,KAAK;gBACvC,yCAAO,SAAS,EAAC,4BAA4B;oBAC3C;wBACE,kDAAc;wBACd;4BACE,wCAAM,SAAS,EAAC,WAAW;gCACzB,sEAAoC;gCACpC,8BAAC,cAAQ,IACP,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,cAAM,OAAA,MAAM,CAAC,MAAM,CAAC,EAAd,CAAc,gBAClB,cAAc,EACzB,MAAM,EAAE,IAAI,CAAC,KAAK,KAAK,MAAM,EAC7B,SAAS,EAAE,IAAI,CAAC,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,GAC1D,CACG,CACJ;wBACL,gEAA4B;wBAC5B,qDAAiB;wBACjB,0DAAsB;wBACtB;4BACE,wCAAM,SAAS,EAAC,WAAW;gCACzB,yDAAuB;gCACvB,8BAAC,cAAQ,IACP,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,cAAM,OAAA,MAAM,CAAC,YAAY,CAAC,EAApB,CAAoB,EACnC,MAAM,EAAE,IAAI,CAAC,KAAK,KAAK,YAAY,gBACxB,oBAAoB,EAC/B,SAAS,EACP,IAAI,CAAC,KAAK,KAAK,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,GAEvD,CACG,CACJ,CACF,CACC;gBACR,6CACG,kBAAkB,CAAC,GAAG,CAAC,UAAA,EAAE;oBACxB,OAAO,CACL,sCAAI,GAAG,EAAE,EAAE,CAAC,EAAE;wBACZ;4BACE,qCACE,IAAI,EAAK,wCAA0B,CAAC,MAAM,kCAA6B,EAAE,CAAC,EAAI,IAE7E,EAAE,CAAC,EAAE,CACJ,CACD;wBACL,0CAAK,EAAE,CAAC,IAAI,CAAM;wBAClB,0CACG,EAAE,CAAC,iBAAiB,CAAC,GAAG,CAAC,UAAA,SAAS,IAAI,OAAA,CACrC,8BAAC,eAAK,CAAC,QAAQ,IAAC,GAAG,EAAE,SAAS;4BAC5B,8BAAC,uBAAU,IAAC,MAAM,EAAE,SAAS,GAAI;4BAAC,GAAG;4BACrC,wCAAM,SAAS,EAAC,aAAa;;gCAAG,SAAS;oCAAS;4BAClD,yCAAM,CACS,CAClB,EANsC,CAMtC,CAAC,CACC;wBACL,0CACG,EAAE,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAC7B,8BAAC,yBAAe,IAAC,WAAW,EAAE,8BAAW,GAAI,CAC9C,CAAC,CAAC,CAAC,CACF,EAAE,CAAC,WAAW,CAAC,GAAG,CAAC,UAAA,UAAU,IAAI,OAAA,CAC/B,8BAAC,yBAAe,IACd,GAAG,EAAE,UAAU,EACf,WAAW,EAAE,UAAU,GACvB,CACH,EALgC,CAKhC,CAAC,CACH,CACE;wBACL,0CAAK,IAAA,0BAAU,EAAC,IAAA,gBAAM,EAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAM;wBAC5C,0CAAK,IAAA,0BAAU,EAAC,IAAA,gBAAM,EAAC,EAAE,CAAC,SAAS,CAAC,CAAC,CAAM,CACxC,CACN,CAAA;gBACH,CAAC,CAAC,CACI,CACF;YACP,SAAS,IAAI,CACZ,uCAAK,SAAS,EAAC,iBAAiB;gBAC9B,8BAAC,8BAAc,IAAC,IAAI,EAAE,EAAE,GAAI,CACxB,CACP;YACA,CAAC,SAAS,IAAI,kBAAkB,CAAC,MAAM,KAAK,CAAC,IAAI,CAChD,8BAAC,oBAAU,IAAC,SAAS,EAAC,iBAAiB,EAAC,OAAO,EAAC,OAAO,iBAE1C,CACd;YACA,CAAC,WAAW,CAAC,CAAC,CAAC,CACd,6DAAK,CACN,CAAC,CAAC,CAAC,CACF,8BAAC,wBAAM,IACL,OAAO,EAAC,SAAS,EACjB,OAAO,EAAE;oBACP,aAAa,EAAE,CAAA;gBACjB,CAAC,gBAGM,CACV,CACG,CACF,CACP,CAAA;AACH,CAAC;AA5JD,wDA4JC"}
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ declare type ReviewerDashboardProps = {
3
+ /** Used to determine the base path for the component. Default is #!DataAccessManagement:default */
4
+ routerBaseName?: string;
5
+ /** If true use a MemoryRouter, which prevents the browser URL from updating. For demo purposes only. */
6
+ useMemoryRouter?: boolean;
7
+ };
8
+ export declare function ReviewerDashboard(props: ReviewerDashboardProps): JSX.Element;
9
+ export default ReviewerDashboard;
@@ -0,0 +1,82 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ReviewerDashboard = void 0;
4
+ var tslib_1 = require("tslib");
5
+ var react_1 = (0, tslib_1.__importStar)(require("react"));
6
+ var react_router_dom_1 = require("react-router-dom");
7
+ var useUserBundle_1 = require("../../utils/hooks/SynapseAPI/useUserBundle");
8
+ var synapseTypes_1 = require("../../utils/synapseTypes");
9
+ var Typography_1 = (0, tslib_1.__importDefault)(require("../../utils/typography/Typography"));
10
+ var AccessRequestSubmissionTable_1 = require("../AccessRequestSubmissionTable");
11
+ var IconSvg_1 = (0, tslib_1.__importDefault)(require("../IconSvg"));
12
+ var LoadingScreen_1 = require("../LoadingScreen");
13
+ var AccessRequirementDashboard_1 = require("./AccessRequirementDashboard");
14
+ var SubmissionPage_1 = (0, tslib_1.__importDefault)(require("./SubmissionPage"));
15
+ function LinkTab(props) {
16
+ var href = props.href, children = props.children, icon = props.icon;
17
+ return (react_1.default.createElement(react_router_dom_1.NavLink, { className: "Tab", role: "tab", to: href },
18
+ react_1.default.createElement(IconSvg_1.default, { options: {
19
+ icon: icon,
20
+ padding: 'right',
21
+ } }),
22
+ react_1.default.createElement(Typography_1.default, { variant: "buttonLink" }, children)));
23
+ }
24
+ function ReviewerDashboard(props) {
25
+ var _a = props.routerBaseName, routerBaseName = _a === void 0 ? '#!DataAccessManagement:default' : _a, _b = props.useMemoryRouter, useMemoryRouter = _b === void 0 ? false : _b;
26
+ var _c = (0, useUserBundle_1.useGetCurrentUserBundle)(), userBundle = _c.data, isLoading = _c.isLoading;
27
+ var hasActPermissions = userBundle === null || userBundle === void 0 ? void 0 : userBundle.isACTMember;
28
+ var hasReviewerPermissions = (userBundle === null || userBundle === void 0 ? void 0 : userBundle.isACTMember) || (userBundle === null || userBundle === void 0 ? void 0 : userBundle.isARReviewer);
29
+ var Router = (0, react_1.useCallback)(function (props) {
30
+ if (useMemoryRouter) {
31
+ return react_1.default.createElement(react_router_dom_1.MemoryRouter, (0, tslib_1.__assign)({}, props));
32
+ }
33
+ else {
34
+ return react_1.default.createElement(react_router_dom_1.BrowserRouter, (0, tslib_1.__assign)({}, props));
35
+ }
36
+ }, [useMemoryRouter]);
37
+ if (isLoading) {
38
+ return react_1.default.createElement(LoadingScreen_1.SynapseSpinner, { size: 50 });
39
+ }
40
+ return (react_1.default.createElement(Router, { basename: routerBaseName },
41
+ react_1.default.createElement("div", { className: "ReviewerDashboard" },
42
+ react_1.default.createElement("div", { className: "Tabs", role: "tablist" },
43
+ hasActPermissions && (react_1.default.createElement(LinkTab, { href: "/AccessRequirements", icon: "accessClosed" }, "Access Requirements")),
44
+ hasReviewerPermissions && (react_1.default.createElement(LinkTab, { href: "/Submissions", icon: "discussion" }, "Submissions")),
45
+ hasActPermissions && (react_1.default.createElement(LinkTab, { href: "/UserAccessHistory", icon: "history" }, "User Access History"))),
46
+ react_1.default.createElement("div", { className: "TabContentContainer" },
47
+ react_1.default.createElement(react_router_dom_1.Switch, null,
48
+ hasActPermissions && (react_1.default.createElement(react_router_dom_1.Route, { path: "/AccessRequirements" },
49
+ react_1.default.createElement(AccessRequirementDashboard_1.AccessRequirementDashboard, null))),
50
+ hasReviewerPermissions && (react_1.default.createElement(react_1.default.Fragment, null,
51
+ react_1.default.createElement(react_router_dom_1.Route, { exact: true, path: "/Submissions" },
52
+ react_1.default.createElement(Typography_1.default, { variant: "headline1" }, "Inputs coming soon!"),
53
+ react_1.default.createElement(AccessRequestSubmissionTable_1.AccessRequestSubmissionTable, { showSubmitter: true, showStatus: false, showRequestors: true, submissionState: synapseTypes_1.SubmissionState.SUBMITTED })),
54
+ react_1.default.createElement(react_router_dom_1.Route, { path: "/Submissions/:id" },
55
+ react_1.default.createElement(SubmissionPageRouteRenderer, null)))),
56
+ hasActPermissions && (react_1.default.createElement(react_router_dom_1.Route, { path: "/UserAccessHistory" },
57
+ react_1.default.createElement(Typography_1.default, { variant: "headline1" }, "Coming soon!"))))))));
58
+ }
59
+ exports.ReviewerDashboard = ReviewerDashboard;
60
+ function SubmissionPageRouteRenderer() {
61
+ var id = (0, react_router_dom_1.useParams)().id;
62
+ return (react_1.default.createElement(react_1.default.Fragment, null,
63
+ react_1.default.createElement("div", { className: "Breadcrumb" },
64
+ react_1.default.createElement(Typography_1.default, { variant: "breadcrumb1" },
65
+ react_1.default.createElement(IconSvg_1.default, { options: {
66
+ icon: 'accessManagement',
67
+ } }),
68
+ react_1.default.createElement(IconSvg_1.default, { options: {
69
+ icon: 'chevronRight',
70
+ } }),
71
+ react_1.default.createElement(react_router_dom_1.Link, { to: "/Submissions" },
72
+ react_1.default.createElement("span", null, "Submissions")),
73
+ react_1.default.createElement(IconSvg_1.default, { options: {
74
+ icon: 'chevronRight',
75
+ } }),
76
+ react_1.default.createElement("span", null, id))),
77
+ react_1.default.createElement(SubmissionPage_1.default, { submissionId: id, onRejectClicked: function () {
78
+ throw new Error('Function not implemented.');
79
+ } })));
80
+ }
81
+ exports.default = ReviewerDashboard;
82
+ //# sourceMappingURL=ReviewerDashboard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ReviewerDashboard.js","sourceRoot":"","sources":["../../../src/lib/containers/dataaccess/ReviewerDashboard.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ /// <reference types="react" />
2
+ export declare type SubmissionPageProps = {
3
+ /** The ID of the submission to view */
4
+ submissionId: string | number;
5
+ /** Invoked when a reviewer clicks "Reject". Note that the web request to reject the submission is not sent. We do this to continue using the existing rejection dialog written in SWC */
6
+ onRejectClicked: () => void;
7
+ };
8
+ /**
9
+ * Page for a Data Access Submission that a designated reviewer can view, and choose to approve or reject.
10
+ */
11
+ export default function SubmissionPage(props: SubmissionPageProps): JSX.Element;
@@ -0,0 +1,176 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ var tslib_1 = require("tslib");
4
+ var lab_1 = require("@material-ui/lab");
5
+ var lodash_es_1 = require("lodash-es");
6
+ var moment_1 = (0, tslib_1.__importDefault)(require("moment"));
7
+ var react_1 = (0, tslib_1.__importStar)(require("react"));
8
+ var react_bootstrap_1 = require("react-bootstrap");
9
+ var react_error_boundary_1 = require("react-error-boundary");
10
+ var utils_1 = require("../../utils");
11
+ var DateFormatter_1 = require("../../utils/functions/DateFormatter");
12
+ var useGetAccessRequirement_1 = (0, tslib_1.__importStar)(require("../../utils/hooks/SynapseAPI/dataaccess/useGetAccessRequirement"));
13
+ var useGetDataAccessSubmission_1 = (0, tslib_1.__importDefault)(require("../../utils/hooks/SynapseAPI/dataaccess/useGetDataAccessSubmission"));
14
+ var SynapseConstants_1 = require("../../utils/SynapseConstants");
15
+ var SynapseContext_1 = require("../../utils/SynapseContext");
16
+ var synapseTypes_1 = require("../../utils/synapseTypes");
17
+ var Typography_1 = (0, tslib_1.__importDefault)(require("../../utils/typography/Typography"));
18
+ var MarkdownSynapse_1 = (0, tslib_1.__importDefault)(require("../MarkdownSynapse"));
19
+ var WarningModal_1 = (0, tslib_1.__importDefault)(require("../synapse_form_wrapper/WarningModal"));
20
+ var UserCard_1 = (0, tslib_1.__importDefault)(require("../UserCard"));
21
+ var UserOrTeamBadge_1 = (0, tslib_1.__importDefault)(require("../UserOrTeamBadge"));
22
+ var FileHandleLink_1 = require("../widgets/FileHandleLink");
23
+ function DataAccessSubmissionFileHandleLink(props) {
24
+ var submissionId = props.submissionId, fileHandleId = props.fileHandleId;
25
+ var fileHandleAssociation = react_1.default.useMemo(function () { return ({
26
+ fileHandleId: fileHandleId,
27
+ associateObjectId: submissionId,
28
+ associateObjectType: synapseTypes_1.FileHandleAssociateType.DataAccessSubmissionAttachment,
29
+ }); }, [fileHandleId, submissionId]);
30
+ return (react_1.default.createElement(FileHandleLink_1.FileHandleLink, { key: fileHandleId, showDownloadIcon: true, fileHandleAssociation: fileHandleAssociation }));
31
+ }
32
+ function ApproveConfirmationModal(props) {
33
+ return (react_1.default.createElement(WarningModal_1.default, { show: props.show, title: "Approve Request?", modalBody: react_1.default.createElement(react_1.default.Fragment, null,
34
+ react_1.default.createElement(Typography_1.default, { variant: "body1" }, "Approving the request will grant access to controlled data."),
35
+ react_1.default.createElement(Typography_1.default, { variant: "body1" }, "In addition, the user will receive an email notification alerting them that the request has been granted.")), onConfirm: props.onConfirm, onConfirmCallbackArgs: [], onCancel: props.onCancel, confirmButtonText: "Approve" }));
36
+ }
37
+ /**
38
+ * Page for a Data Access Submission that a designated reviewer can view, and choose to approve or reject.
39
+ */
40
+ function SubmissionPage(props) {
41
+ var _this = this;
42
+ var _a;
43
+ var submissionId = props.submissionId, onRejectClicked = props.onRejectClicked;
44
+ var handleError = (0, react_error_boundary_1.useErrorHandler)();
45
+ var accessToken = (0, SynapseContext_1.useSynapseContext)().accessToken;
46
+ var _b = (0, useGetDataAccessSubmission_1.default)(submissionId, { useErrorBoundary: true }), submission = _b.data, refetch = _b.refetch;
47
+ var accessRequirement = (0, useGetAccessRequirement_1.default)(parseInt(submission === null || submission === void 0 ? void 0 : submission.accessRequirementId), { enabled: !!submission }).data;
48
+ var acl = (0, useGetAccessRequirement_1.useGetAccessRequirementACL)(submission === null || submission === void 0 ? void 0 : submission.accessRequirementId, { enabled: !!submission, useErrorBoundary: true }).data;
49
+ var wikiPageKey = (0, useGetAccessRequirement_1.useGetAccessRequirementWikiPageKey)(submission === null || submission === void 0 ? void 0 : submission.accessRequirementId, { enabled: !!submission, useErrorBoundary: true }).data;
50
+ var _c = (0, react_1.useState)(false), showApprovalConfirmation = _c[0], setShowApprovalConfirmation = _c[1];
51
+ function approveSubmission() {
52
+ var _a;
53
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
54
+ return (0, tslib_1.__generator)(this, function (_b) {
55
+ switch (_b.label) {
56
+ case 0: return [4 /*yield*/, utils_1.SynapseClient.updateSubmissionStatus({
57
+ submissionId: (_a = submission === null || submission === void 0 ? void 0 : submission.id) !== null && _a !== void 0 ? _a : '',
58
+ newState: synapseTypes_1.SubmissionState.APPROVED,
59
+ }, accessToken)];
60
+ case 1: return [2 /*return*/, _b.sent()];
61
+ }
62
+ });
63
+ });
64
+ }
65
+ return (react_1.default.createElement("div", { className: "SubmissionPage" },
66
+ react_1.default.createElement(ApproveConfirmationModal, { show: showApprovalConfirmation, onCancel: function () {
67
+ setShowApprovalConfirmation(false);
68
+ }, onConfirm: function () { return (0, tslib_1.__awaiter)(_this, void 0, void 0, function () {
69
+ var e_1;
70
+ return (0, tslib_1.__generator)(this, function (_a) {
71
+ switch (_a.label) {
72
+ case 0:
73
+ _a.trys.push([0, 2, , 3]);
74
+ return [4 /*yield*/, approveSubmission()];
75
+ case 1:
76
+ _a.sent();
77
+ return [3 /*break*/, 3];
78
+ case 2:
79
+ e_1 = _a.sent();
80
+ handleError(e_1);
81
+ return [3 /*break*/, 3];
82
+ case 3:
83
+ setShowApprovalConfirmation(false);
84
+ refetch();
85
+ return [2 /*return*/];
86
+ }
87
+ });
88
+ }); } }),
89
+ react_1.default.createElement("div", { className: "SubmissionSummary" },
90
+ react_1.default.createElement(Typography_1.default, { variant: "dataFieldKey" }, "Status"),
91
+ react_1.default.createElement(Typography_1.default, { variant: "headline3" }, submission ? submission.state : react_1.default.createElement(lab_1.Skeleton, { width: 100 })),
92
+ react_1.default.createElement("br", null),
93
+ submission ? (submission.state === 'SUBMITTED' && (react_1.default.createElement("div", { className: "bootstrap-4-backport ButtonContainer" },
94
+ react_1.default.createElement(react_bootstrap_1.Button, { onClick: function () {
95
+ setShowApprovalConfirmation(true);
96
+ }, variant: "success" }, "Approve"),
97
+ react_1.default.createElement(react_bootstrap_1.Button, { onClick: onRejectClicked, variant: "danger" }, "Reject")))) : (react_1.default.createElement(lab_1.Skeleton, { width: 200 })),
98
+ react_1.default.createElement(Typography_1.default, { variant: "dataFieldKey" }, "Access Requirement Name"),
99
+ react_1.default.createElement(Typography_1.default, { variant: "smallText1" }, (_a = accessRequirement === null || accessRequirement === void 0 ? void 0 : accessRequirement.name) !== null && _a !== void 0 ? _a : react_1.default.createElement(lab_1.Skeleton, { width: 100 })),
100
+ react_1.default.createElement("br", null),
101
+ react_1.default.createElement(Typography_1.default, { variant: "dataFieldKey" }, "Assigned Reviewer"),
102
+ react_1.default.createElement(Typography_1.default, { variant: "smallText1" }, acl !== undefined ? (acl !== null ? (acl.resourceAccess.map(function (ra) {
103
+ return (react_1.default.createElement(UserOrTeamBadge_1.default, { key: ra.principalId, principalId: ra.principalId }));
104
+ })) : (react_1.default.createElement(UserOrTeamBadge_1.default, { principalId: SynapseConstants_1.ACT_TEAM_ID }))) : (react_1.default.createElement(lab_1.Skeleton, { width: 100 }))),
105
+ react_1.default.createElement("br", null),
106
+ react_1.default.createElement(Typography_1.default, { variant: "dataFieldKey" }, "Conditions"),
107
+ accessRequirement ? (react_1.default.createElement(Typography_1.default, { variant: "smallText1" },
108
+ react_1.default.createElement("ul", null,
109
+ react_1.default.createElement("li", null,
110
+ "Expiration period:",
111
+ ' ',
112
+ moment_1.default
113
+ .duration(accessRequirement.expirationPeriod, 'milliseconds')
114
+ .asDays(),
115
+ ' ',
116
+ "day(s)",
117
+ accessRequirement.expirationPeriod === 0 && ' (no expiration)'),
118
+ accessRequirement.isCertifiedUserRequired && (react_1.default.createElement("li", null, "User must be Certified")),
119
+ accessRequirement.isValidatedProfileRequired && (react_1.default.createElement("li", null, "User Profile must be Validated")),
120
+ accessRequirement.isDUCRequired && react_1.default.createElement("li", null, "DUC is required"),
121
+ accessRequirement.isIDURequired && react_1.default.createElement("li", null, "IDU is required"),
122
+ accessRequirement.isIDUPublic && (react_1.default.createElement("li", null, "IDU will be made public")),
123
+ accessRequirement.isIRBApprovalRequired && (react_1.default.createElement("li", null, "IRB Approval is required")),
124
+ accessRequirement.areOtherAttachmentsRequired && (react_1.default.createElement("li", null, "Other attachments are required"))))) : (react_1.default.createElement(lab_1.Skeleton, { width: 100 })),
125
+ react_1.default.createElement("br", null),
126
+ react_1.default.createElement("div", { className: "SubmissionSummaryGrid" },
127
+ react_1.default.createElement(Typography_1.default, { variant: "dataFieldKey" }, "Submitted By"),
128
+ react_1.default.createElement(Typography_1.default, { variant: "smallText1" }, submission ? (react_1.default.createElement(UserCard_1.default, { size: 'SMALL USER CARD', ownerId: submission.submittedBy })) : (react_1.default.createElement(lab_1.Skeleton, { width: 100 }))),
129
+ react_1.default.createElement(Typography_1.default, { variant: "dataFieldKey" }, "Submitted On"),
130
+ react_1.default.createElement(Typography_1.default, { variant: "smallText1" }, submission ? ((0, DateFormatter_1.formatDate)((0, moment_1.default)(submission.submittedOn))) : (react_1.default.createElement(lab_1.Skeleton, { width: 100 }))),
131
+ react_1.default.createElement(Typography_1.default, { variant: "dataFieldKey" }, "Modified By"),
132
+ react_1.default.createElement(Typography_1.default, { variant: "smallText1" }, submission ? (react_1.default.createElement(UserCard_1.default, { size: 'SMALL USER CARD', ownerId: submission.modifiedBy })) : (react_1.default.createElement(lab_1.Skeleton, { width: 100 }))),
133
+ react_1.default.createElement(Typography_1.default, { variant: "dataFieldKey" }, "Modified On"),
134
+ react_1.default.createElement(Typography_1.default, { variant: "smallText1" }, submission ? ((0, DateFormatter_1.formatDate)((0, moment_1.default)(submission.modifiedOn))) : (react_1.default.createElement(lab_1.Skeleton, { width: 100 }))),
135
+ react_1.default.createElement(Typography_1.default, { className: "Key", variant: "dataFieldKey" },
136
+ "Data Requesters", "" + (submission ? " (" + submission.accessorChanges.length + ")" : '')),
137
+ submission ? (submission.accessorChanges.map(function (accessorChange) { return (react_1.default.createElement(react_1.default.Fragment, { key: accessorChange.userId },
138
+ react_1.default.createElement(Typography_1.default, { className: "Key DataAccessor", variant: "smallText1" },
139
+ react_1.default.createElement("span", { style: { whiteSpace: 'nowrap' } },
140
+ react_1.default.createElement(UserCard_1.default, { key: accessorChange.userId, size: "SMALL USER CARD", ownerId: accessorChange.userId }))),
141
+ react_1.default.createElement(Typography_1.default, { className: "Value DataAccessor", variant: "smallText1" }, (0, lodash_es_1.upperFirst)((0, lodash_es_1.toLower)(accessorChange.type.substring(0, accessorChange.type.indexOf('_'))))))); })) : (react_1.default.createElement(lab_1.Skeleton, { width: 100 })),
142
+ react_1.default.createElement(Typography_1.default, { className: "Key", variant: "dataFieldKey" }, "Institution"),
143
+ react_1.default.createElement(Typography_1.default, { className: "Value", variant: "smallText1" }, submission ? (submission.researchProjectSnapshot.institution) : (react_1.default.createElement(lab_1.Skeleton, { width: 100 }))),
144
+ react_1.default.createElement(Typography_1.default, { className: "Key", variant: "dataFieldKey" }, "Project Lead"),
145
+ react_1.default.createElement(Typography_1.default, { className: "Value", variant: "smallText1" }, submission ? (submission.researchProjectSnapshot.projectLead) : (react_1.default.createElement(lab_1.Skeleton, { width: 100 }))))),
146
+ react_1.default.createElement("div", { className: "SubmissionRightPane" },
147
+ react_1.default.createElement("div", { className: "AccessRequirementWikiContainer" },
148
+ react_1.default.createElement("div", { className: "AccessRequirementWikiContent" },
149
+ react_1.default.createElement(Typography_1.default, { variant: "headline1" }, "Access Requirement"),
150
+ react_1.default.createElement("hr", null),
151
+ react_1.default.createElement(MarkdownSynapse_1.default, { wikiId: wikiPageKey === null || wikiPageKey === void 0 ? void 0 : wikiPageKey.wikiPageId, ownerId: wikiPageKey === null || wikiPageKey === void 0 ? void 0 : wikiPageKey.ownerObjectId, objectType: wikiPageKey === null || wikiPageKey === void 0 ? void 0 : wikiPageKey.ownerObjectType }))),
152
+ react_1.default.createElement("div", null,
153
+ (submission === null || submission === void 0 ? void 0 : submission.rejectedReason) && (react_1.default.createElement(react_1.default.Fragment, null,
154
+ react_1.default.createElement(Typography_1.default, { variant: "headline1" }, "Reason for rejection given by reviewer"),
155
+ react_1.default.createElement("hr", null),
156
+ react_1.default.createElement(Typography_1.default, { variant: "body1", style: { whiteSpace: 'pre-line' } }, submission.rejectedReason))),
157
+ react_1.default.createElement(Typography_1.default, { variant: "headline1" }, "Contents of the Access Request"),
158
+ react_1.default.createElement("hr", null),
159
+ (submission === null || submission === void 0 ? void 0 : submission.researchProjectSnapshot.intendedDataUseStatement) && (react_1.default.createElement(react_1.default.Fragment, null,
160
+ react_1.default.createElement(Typography_1.default, { variant: "headline2" }, "Intended Data Use Statement"),
161
+ react_1.default.createElement(Typography_1.default, { variant: "body1", style: { whiteSpace: 'pre-line' } }, submission.researchProjectSnapshot.intendedDataUseStatement))),
162
+ react_1.default.createElement(Typography_1.default, { variant: "headline2" }, "Documents"),
163
+ (submission === null || submission === void 0 ? void 0 : submission.ducFileHandleId) && (react_1.default.createElement(react_1.default.Fragment, null,
164
+ react_1.default.createElement(Typography_1.default, { variant: "smallText2" }, "Data Use Certificate (DUC)"),
165
+ react_1.default.createElement(DataAccessSubmissionFileHandleLink, { submissionId: submission.id, fileHandleId: submission.ducFileHandleId }))),
166
+ (submission === null || submission === void 0 ? void 0 : submission.irbFileHandleId) && (react_1.default.createElement(react_1.default.Fragment, null,
167
+ react_1.default.createElement(Typography_1.default, { variant: "smallText2" }, "IRB Approval Letter"),
168
+ react_1.default.createElement(DataAccessSubmissionFileHandleLink, { submissionId: submission.id, fileHandleId: submission.irbFileHandleId }))),
169
+ (submission === null || submission === void 0 ? void 0 : submission.attachments) && (react_1.default.createElement(react_1.default.Fragment, null,
170
+ react_1.default.createElement(Typography_1.default, { variant: "smallText2" }, "Other Attachments"),
171
+ submission.attachments.map(function (fileHandleId) { return (react_1.default.createElement(react_1.default.Fragment, null,
172
+ react_1.default.createElement(DataAccessSubmissionFileHandleLink, { key: fileHandleId, submissionId: submission.id, fileHandleId: fileHandleId }),
173
+ react_1.default.createElement("br", null))); })))))));
174
+ }
175
+ exports.default = SubmissionPage;
176
+ //# sourceMappingURL=SubmissionPage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SubmissionPage.js","sourceRoot":"","sources":["../../../src/lib/containers/dataaccess/SubmissionPage.tsx"],"names":[],"mappings":";;;AAAA,wCAA2C;AAC3C,uCAA+C;AAC/C,+DAA2B;AAC3B,0DAAuC;AACvC,mDAAwC;AACxC,6DAAsD;AACtD,qCAA2C;AAC3C,qEAAgE;AAChE,sIAGwE;AACxE,+IAA2G;AAC3G,iEAA0D;AAC1D,6DAA8D;AAC9D,yDAIiC;AACjC,8FAA0D;AAC1D,oFAAgD;AAChD,mGAE6C;AAC7C,sEAAkC;AAClC,oFAAgD;AAChD,4DAA0D;AAS1D,SAAS,kCAAkC,CAAC,KAG3C;IACS,IAAA,YAAY,GAAmB,KAAK,aAAxB,EAAE,YAAY,GAAK,KAAK,aAAV,CAAU;IAC5C,IAAM,qBAAqB,GAAG,eAAK,CAAC,OAAO,CACzC,cAAM,OAAA,CAAC;QACL,YAAY,EAAE,YAAY;QAC1B,iBAAiB,EAAE,YAAY;QAC/B,mBAAmB,EACjB,sCAAuB,CAAC,8BAA8B;KACzD,CAAC,EALI,CAKJ,EACF,CAAC,YAAY,EAAE,YAAY,CAAC,CAC7B,CAAA;IACD,OAAO,CACL,8BAAC,+BAAc,IACb,GAAG,EAAE,YAAY,EACjB,gBAAgB,EAAE,IAAI,EACtB,qBAAqB,EAAE,qBAAqB,GAC5C,CACH,CAAA;AACH,CAAC;AAED,SAAS,wBAAwB,CAC/B,KAAiE;IAEjE,OAAO,CACL,8BAAC,sBAAY,IACX,IAAI,EAAE,KAAK,CAAC,IAAI,EAChB,KAAK,EAAC,kBAAkB,EACxB,SAAS,EACP;YACE,8BAAC,oBAAU,IAAC,OAAO,EAAC,OAAO,kEAEd;YACb,8BAAC,oBAAU,IAAC,OAAO,EAAC,OAAO,gHAGd,CACZ,EAEL,SAAS,EAAE,KAAK,CAAC,SAAS,EAC1B,qBAAqB,EAAE,EAAE,EACzB,QAAQ,EAAE,KAAK,CAAC,QAAQ,EACxB,iBAAiB,EAAC,SAAS,GAC3B,CACH,CAAA;AACH,CAAC;AAED;;GAEG;AACH,SAAwB,cAAc,CAAC,KAA0B;IAAjE,iBAuTC;;IAtTS,IAAA,YAAY,GAAsB,KAAK,aAA3B,EAAE,eAAe,GAAK,KAAK,gBAAV,CAAU;IAE/C,IAAM,WAAW,GAAG,IAAA,sCAAe,GAAE,CAAA;IAC7B,IAAA,WAAW,GAAK,IAAA,kCAAiB,GAAE,YAAxB,CAAwB;IACrC,IAAA,KAAgC,IAAA,oCAA0B,EAC9D,YAAY,EACZ,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAC3B,EAHa,UAAU,UAAA,EAAE,OAAO,aAGhC,CAAA;IAEO,IAAM,iBAAiB,GAC7B,IAAA,iCAAuB,EACrB,QAAQ,CAAC,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,mBAAoB,CAAC,EAC1C,EAAE,OAAO,EAAE,CAAC,CAAC,UAAU,EAAE,CAC1B,KAJ4B,CAI5B;IAEK,IAAM,GAAG,GAAK,IAAA,oDAA0B,EAC9C,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,mBAAoB,EAChC,EAAE,OAAO,EAAE,CAAC,CAAC,UAAU,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAClD,KAHgB,CAGhB;IACO,IAAM,WAAW,GAAK,IAAA,4DAAkC,EAC9D,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,mBAAoB,EAChC,EAAE,OAAO,EAAE,CAAC,CAAC,UAAU,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAClD,KAHwB,CAGxB;IAEK,IAAA,KACJ,IAAA,gBAAQ,EAAC,KAAK,CAAC,EADV,wBAAwB,QAAA,EAAE,2BAA2B,QAC3C,CAAA;IAEjB,SAAe,iBAAiB;;;;;4BACvB,qBAAM,qBAAa,CAAC,sBAAsB,CAC/C;4BACE,YAAY,EAAE,MAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,EAAE,mCAAI,EAAE;4BAClC,QAAQ,EAAE,8BAAe,CAAC,QAAQ;yBACnC,EACD,WAAW,CACZ,EAAA;4BAND,sBAAO,SAMN,EAAA;;;;KACF;IAED,OAAO,CACL,uCAAK,SAAS,EAAC,gBAAgB;QAC7B,8BAAC,wBAAwB,IACvB,IAAI,EAAE,wBAAwB,EAC9B,QAAQ,EAAE;gBACR,2BAA2B,CAAC,KAAK,CAAC,CAAA;YACpC,CAAC,EACD,SAAS,EAAE;;;;;;4BAEP,qBAAM,iBAAiB,EAAE,EAAA;;4BAAzB,SAAyB,CAAA;;;;4BAEzB,WAAW,CAAC,GAAC,CAAC,CAAA;;;4BAEhB,2BAA2B,CAAC,KAAK,CAAC,CAAA;4BAClC,OAAO,EAAE,CAAA;;;;iBACV,GACD;QACF,uCAAK,SAAS,EAAC,mBAAmB;YAChC,8BAAC,oBAAU,IAAC,OAAO,EAAC,cAAc,aAAoB;YACtD,8BAAC,oBAAU,IAAC,OAAO,EAAC,WAAW,IAC5B,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CAC9C;YACb,yCAAM;YACL,UAAU,CAAC,CAAC,CAAC,CACZ,UAAU,CAAC,KAAK,KAAK,WAAW,IAAI,CAClC,uCAAK,SAAS,EAAC,sCAAsC;gBACnD,8BAAC,wBAAM,IACL,OAAO,EAAE;wBACP,2BAA2B,CAAC,IAAI,CAAC,CAAA;oBACnC,CAAC,EACD,OAAO,EAAC,SAAS,cAGV;gBACT,8BAAC,wBAAM,IAAC,OAAO,EAAE,eAAe,EAAE,OAAO,EAAC,QAAQ,aAEzC,CACL,CACP,CACF,CAAC,CAAC,CAAC,CACF,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CACzB;YACD,8BAAC,oBAAU,IAAC,OAAO,EAAC,cAAc,8BAAqC;YACvE,8BAAC,oBAAU,IAAC,OAAO,EAAC,YAAY,IAC7B,MAAA,iBAAiB,aAAjB,iBAAiB,uBAAjB,iBAAiB,CAAE,IAAI,mCAAI,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CACzC;YACb,yCAAM;YACN,8BAAC,oBAAU,IAAC,OAAO,EAAC,cAAc,wBAA+B;YACjE,8BAAC,oBAAU,IAAC,OAAO,EAAC,YAAY,IAC7B,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,CACnB,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,CACb,GAAG,CAAC,cAAc,CAAC,GAAG,CAAC,UAAA,EAAE;gBACvB,OAAO,CACL,8BAAC,yBAAe,IACd,GAAG,EAAE,EAAE,CAAC,WAAW,EACnB,WAAW,EAAE,EAAE,CAAC,WAAW,GAC3B,CACH,CAAA;YACH,CAAC,CAAC,CACH,CAAC,CAAC,CAAC,CACF,8BAAC,yBAAe,IAAC,WAAW,EAAE,8BAAW,GAAI,CAC9C,CACF,CAAC,CAAC,CAAC,CACF,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CACzB,CACU;YACb,yCAAM;YACN,8BAAC,oBAAU,IAAC,OAAO,EAAC,cAAc,iBAAwB;YACzD,iBAAiB,CAAC,CAAC,CAAC,CACnB,8BAAC,oBAAU,IAAC,OAAO,EAAC,YAAY;gBAC9B;oBACE;;wBACqB,GAAG;wBACrB,gBAAM;6BACJ,QAAQ,CAAC,iBAAiB,CAAC,gBAAgB,EAAE,cAAc,CAAC;6BAC5D,MAAM,EAAE;wBAAE,GAAG;;wBAEf,iBAAiB,CAAC,gBAAgB,KAAK,CAAC,IAAI,kBAAkB,CAC5D;oBAEJ,iBAAiB,CAAC,uBAAuB,IAAI,CAC5C,mEAA+B,CAChC;oBACA,iBAAiB,CAAC,0BAA0B,IAAI,CAC/C,2EAAuC,CACxC;oBACA,iBAAiB,CAAC,aAAa,IAAI,4DAAwB;oBAC3D,iBAAiB,CAAC,aAAa,IAAI,4DAAwB;oBAC3D,iBAAiB,CAAC,WAAW,IAAI,CAChC,oEAAgC,CACjC;oBACA,iBAAiB,CAAC,qBAAqB,IAAI,CAC1C,qEAAiC,CAClC;oBACA,iBAAiB,CAAC,2BAA2B,IAAI,CAChD,2EAAuC,CACxC,CACE,CACM,CACd,CAAC,CAAC,CAAC,CACF,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CACzB;YACD,yCAAM;YACN,uCAAK,SAAS,EAAC,uBAAuB;gBACpC,8BAAC,oBAAU,IAAC,OAAO,EAAC,cAAc,mBAA0B;gBAC5D,8BAAC,oBAAU,IAAC,OAAO,EAAC,YAAY,IAC7B,UAAU,CAAC,CAAC,CAAC,CACZ,8BAAC,kBAAQ,IACP,IAAI,EAAE,iBAAiB,EACvB,OAAO,EAAE,UAAU,CAAC,WAAW,GAC/B,CACH,CAAC,CAAC,CAAC,CACF,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CACzB,CACU;gBACb,8BAAC,oBAAU,IAAC,OAAO,EAAC,cAAc,mBAA0B;gBAC5D,8BAAC,oBAAU,IAAC,OAAO,EAAC,YAAY,IAC7B,UAAU,CAAC,CAAC,CAAC,CACZ,IAAA,0BAAU,EAAC,IAAA,gBAAM,EAAC,UAAU,CAAC,WAAW,CAAC,CAAC,CAC3C,CAAC,CAAC,CAAC,CACF,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CACzB,CACU;gBACb,8BAAC,oBAAU,IAAC,OAAO,EAAC,cAAc,kBAAyB;gBAC3D,8BAAC,oBAAU,IAAC,OAAO,EAAC,YAAY,IAC7B,UAAU,CAAC,CAAC,CAAC,CACZ,8BAAC,kBAAQ,IACP,IAAI,EAAE,iBAAiB,EACvB,OAAO,EAAE,UAAU,CAAC,UAAU,GAC9B,CACH,CAAC,CAAC,CAAC,CACF,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CACzB,CACU;gBACb,8BAAC,oBAAU,IAAC,OAAO,EAAC,cAAc,kBAAyB;gBAC3D,8BAAC,oBAAU,IAAC,OAAO,EAAC,YAAY,IAC7B,UAAU,CAAC,CAAC,CAAC,CACZ,IAAA,0BAAU,EAAC,IAAA,gBAAM,EAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAC1C,CAAC,CAAC,CAAC,CACF,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CACzB,CACU;gBACb,8BAAC,oBAAU,IAAC,SAAS,EAAC,KAAK,EAAC,OAAO,EAAC,cAAc;uCAE/C,MAAG,UAAU,CAAC,CAAC,CAAC,OAAK,UAAU,CAAC,eAAe,CAAC,MAAM,MAAG,CAAC,CAAC,CAAC,EAAE,CAAE,CACtD;gBACZ,UAAU,CAAC,CAAC,CAAC,CACZ,UAAU,CAAC,eAAe,CAAC,GAAG,CAAC,UAAA,cAAc,IAAI,OAAA,CAC/C,8BAAC,eAAK,CAAC,QAAQ,IAAC,GAAG,EAAE,cAAc,CAAC,MAAM;oBACxC,8BAAC,oBAAU,IAAC,SAAS,EAAC,kBAAkB,EAAC,OAAO,EAAC,YAAY;wBAC3D,wCAAM,KAAK,EAAE,EAAE,UAAU,EAAE,QAAQ,EAAE;4BACnC,8BAAC,kBAAQ,IACP,GAAG,EAAE,cAAc,CAAC,MAAM,EAC1B,IAAI,EAAC,iBAAiB,EACtB,OAAO,EAAE,cAAc,CAAC,MAAM,GAC9B,CACG,CACI;oBACb,8BAAC,oBAAU,IAAC,SAAS,EAAC,oBAAoB,EAAC,OAAO,EAAC,YAAY,IAC5D,IAAA,sBAAU,EACT,IAAA,mBAAO,EACL,cAAc,CAAC,IAAI,CAAC,SAAS,CAC3B,CAAC,EACD,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CACjC,CACF,CACF,CACU,CACE,CAClB,EAtBgD,CAsBhD,CAAC,CACH,CAAC,CAAC,CAAC,CACF,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CACzB;gBACD,8BAAC,oBAAU,IAAC,SAAS,EAAC,KAAK,EAAC,OAAO,EAAC,cAAc,kBAErC;gBACb,8BAAC,oBAAU,IAAC,SAAS,EAAC,OAAO,EAAC,OAAO,EAAC,YAAY,IAC/C,UAAU,CAAC,CAAC,CAAC,CACZ,UAAU,CAAC,uBAAuB,CAAC,WAAW,CAC/C,CAAC,CAAC,CAAC,CACF,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CACzB,CACU;gBACb,8BAAC,oBAAU,IAAC,SAAS,EAAC,KAAK,EAAC,OAAO,EAAC,cAAc,mBAErC;gBACb,8BAAC,oBAAU,IAAC,SAAS,EAAC,OAAO,EAAC,OAAO,EAAC,YAAY,IAC/C,UAAU,CAAC,CAAC,CAAC,CACZ,UAAU,CAAC,uBAAuB,CAAC,WAAW,CAC/C,CAAC,CAAC,CAAC,CACF,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CACzB,CACU,CACT,CACF;QACN,uCAAK,SAAS,EAAC,qBAAqB;YAClC,uCAAK,SAAS,EAAC,gCAAgC;gBAC7C,uCAAK,SAAS,EAAC,8BAA8B;oBAC3C,8BAAC,oBAAU,IAAC,OAAO,EAAC,WAAW,yBAAgC;oBAC/D,yCAAM;oBACN,8BAAC,yBAAe,IACd,MAAM,EAAE,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,UAAU,EAC/B,OAAO,EAAE,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,aAAa,EACnC,UAAU,EAAE,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,eAAe,GACxC,CACE,CACF;YACN;gBACG,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,cAAc,KAAI,CAC7B;oBACE,8BAAC,oBAAU,IAAC,OAAO,EAAC,WAAW,6CAElB;oBACb,yCAAM;oBACN,8BAAC,oBAAU,IAAC,OAAO,EAAC,OAAO,EAAC,KAAK,EAAE,EAAE,UAAU,EAAE,UAAU,EAAE,IAC1D,UAAU,CAAC,cAAc,CACf,CACZ,CACJ;gBACD,8BAAC,oBAAU,IAAC,OAAO,EAAC,WAAW,qCAElB;gBACb,yCAAM;gBACL,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,uBAAuB,CAAC,wBAAwB,KAAI,CAC/D;oBACE,8BAAC,oBAAU,IAAC,OAAO,EAAC,WAAW,kCAElB;oBACb,8BAAC,oBAAU,IAAC,OAAO,EAAC,OAAO,EAAC,KAAK,EAAE,EAAE,UAAU,EAAE,UAAU,EAAE,IAC1D,UAAU,CAAC,uBAAuB,CAAC,wBAAwB,CACjD,CACZ,CACJ;gBACD,8BAAC,oBAAU,IAAC,OAAO,EAAC,WAAW,gBAAuB;gBACrD,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,eAAe,KAAI,CAC9B;oBACE,8BAAC,oBAAU,IAAC,OAAO,EAAC,YAAY,iCAEnB;oBACb,8BAAC,kCAAkC,IACjC,YAAY,EAAE,UAAU,CAAC,EAAE,EAC3B,YAAY,EAAE,UAAU,CAAC,eAAe,GACxC,CACD,CACJ;gBACA,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,eAAe,KAAI,CAC9B;oBACE,8BAAC,oBAAU,IAAC,OAAO,EAAC,YAAY,0BAAiC;oBACjE,8BAAC,kCAAkC,IACjC,YAAY,EAAE,UAAU,CAAC,EAAE,EAC3B,YAAY,EAAE,UAAU,CAAC,eAAe,GACxC,CACD,CACJ;gBACA,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,WAAW,KAAI,CAC1B;oBACE,8BAAC,oBAAU,IAAC,OAAO,EAAC,YAAY,wBAA+B;oBAC9D,UAAU,CAAC,WAAW,CAAC,GAAG,CAAC,UAAA,YAAY,IAAI,OAAA,CAC1C;wBACE,8BAAC,kCAAkC,IACjC,GAAG,EAAE,YAAY,EACjB,YAAY,EAAE,UAAU,CAAC,EAAE,EAC3B,YAAY,EAAE,YAAY,GAC1B;wBACF,yCAAM,CACL,CACJ,EAT2C,CAS3C,CAAC,CACD,CACJ,CACG,CACF,CACF,CACP,CAAA;AACH,CAAC;AAvTD,iCAuTC"}
@@ -44,13 +44,15 @@ var SynapseTableCell = function (_a) {
44
44
  rowVersionNumber) {
45
45
  var synId = "syn" + rowId.toString();
46
46
  if (Object.prototype.hasOwnProperty.call(mapEntityIdToHeader, synId)) {
47
- return (react_1.default.createElement(EntityLink_1.EntityLink, { entity: mapEntityIdToHeader[synId], versionNumber: rowVersionNumber, className: "" + isBold, showIcon: false, displayTextField: columnName }));
47
+ return (react_1.default.createElement("p", null,
48
+ react_1.default.createElement(EntityLink_1.EntityLink, { entity: mapEntityIdToHeader[synId], versionNumber: rowVersionNumber, className: "" + isBold, showIcon: false, displayTextField: columnName })));
48
49
  }
49
50
  }
50
51
  switch (columnType) {
51
52
  case synapseTypes_1.ColumnType.ENTITYID:
52
53
  if (Object.prototype.hasOwnProperty.call(mapEntityIdToHeader, columnValue)) {
53
- return (react_1.default.createElement(EntityLink_1.EntityLink, { entity: mapEntityIdToHeader[columnValue], className: "" + isBold, displayTextField: 'name' }));
54
+ return (react_1.default.createElement("p", null,
55
+ react_1.default.createElement(EntityLink_1.EntityLink, { entity: mapEntityIdToHeader[columnValue], className: "" + isBold, displayTextField: 'name' })));
54
56
  }
55
57
  break;
56
58
  case synapseTypes_1.ColumnType.DATE_LIST: {