synapse-react-client 3.0.19 → 3.0.22

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 (89) 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/ErrorPage.js +1 -1
  9. package/dist/containers/ErrorPage.js.map +1 -1
  10. package/dist/containers/FullWidthAlert.js +4 -3
  11. package/dist/containers/FullWidthAlert.js.map +1 -1
  12. package/dist/containers/IconSvg.d.ts +1 -1
  13. package/dist/containers/IconSvg.js +2 -0
  14. package/dist/containers/IconSvg.js.map +1 -1
  15. package/dist/containers/Login.d.ts +1 -1
  16. package/dist/containers/Login.js +1 -1
  17. package/dist/containers/QueryWrapper.js +10 -11
  18. package/dist/containers/QueryWrapper.js.map +1 -1
  19. package/dist/containers/SqlEditor.d.ts +6 -2
  20. package/dist/containers/SqlEditor.js +16 -9
  21. package/dist/containers/SqlEditor.js.map +1 -1
  22. package/dist/containers/SynapseNavDrawer.js +2 -2
  23. package/dist/containers/SynapseNavDrawer.js.map +1 -1
  24. package/dist/containers/UserOrTeamBadge.js +8 -25
  25. package/dist/containers/UserOrTeamBadge.js.map +1 -1
  26. package/dist/containers/UserSearchBoxV2.d.ts +13 -0
  27. package/dist/containers/UserSearchBoxV2.js +91 -0
  28. package/dist/containers/UserSearchBoxV2.js.map +1 -0
  29. package/dist/containers/dataaccess/AccessRequirementDashboard.d.ts +6 -0
  30. package/dist/containers/dataaccess/AccessRequirementDashboard.js +130 -0
  31. package/dist/containers/dataaccess/AccessRequirementDashboard.js.map +1 -0
  32. package/dist/containers/dataaccess/AccessRequirementTable.d.ts +10 -0
  33. package/dist/containers/dataaccess/AccessRequirementTable.js +89 -0
  34. package/dist/containers/dataaccess/AccessRequirementTable.js.map +1 -0
  35. package/dist/containers/dataaccess/ReviewerDashboard.d.ts +9 -0
  36. package/dist/containers/dataaccess/ReviewerDashboard.js +82 -0
  37. package/dist/containers/dataaccess/ReviewerDashboard.js.map +1 -0
  38. package/dist/containers/dataaccess/SubmissionPage.d.ts +11 -0
  39. package/dist/containers/dataaccess/SubmissionPage.js +176 -0
  40. package/dist/containers/dataaccess/SubmissionPage.js.map +1 -0
  41. package/dist/containers/synapse_table_functions/SynapseTableCell.js +4 -2
  42. package/dist/containers/synapse_table_functions/SynapseTableCell.js.map +1 -1
  43. package/dist/containers/table/SynapseTable.js +1 -1
  44. package/dist/style/abstracts/_mixins.scss +13 -8
  45. package/dist/style/components/_global-alert.scss +1 -1
  46. package/dist/style/components/_governance-dashboard.scss +29 -0
  47. package/dist/style/components/_submission-page.scss +1 -4
  48. package/dist/style/main.css +117 -28
  49. package/dist/umd/synapse-react-client.development.css +112 -28
  50. package/dist/umd/synapse-react-client.development.css.map +2 -2
  51. package/dist/umd/synapse-react-client.development.js +3307 -1832
  52. package/dist/umd/synapse-react-client.development.js.map +3 -3
  53. package/dist/umd/synapse-react-client.production.min.css +1 -1
  54. package/dist/umd/synapse-react-client.production.min.js +90 -90
  55. package/dist/umd.index.d.ts +4 -1
  56. package/dist/umd.index.js +7 -1
  57. package/dist/umd.index.js.map +1 -1
  58. package/dist/utils/SynapseClient.d.ts +6 -3
  59. package/dist/utils/SynapseClient.js +14 -3
  60. package/dist/utils/SynapseClient.js.map +1 -1
  61. package/dist/utils/SynapseConstants.d.ts +2 -1
  62. package/dist/utils/SynapseConstants.js +3 -2
  63. package/dist/utils/SynapseConstants.js.map +1 -1
  64. package/dist/utils/functions/getEndpoint.d.ts +1 -2
  65. package/dist/utils/hooks/SynapseAPI/dataaccess/useAccessSubmission.d.ts +5 -0
  66. package/dist/utils/hooks/SynapseAPI/dataaccess/useAccessSubmission.js +21 -0
  67. package/dist/utils/hooks/SynapseAPI/dataaccess/useAccessSubmission.js.map +1 -0
  68. package/dist/utils/hooks/SynapseAPI/dataaccess/useGetDataAccessSubmission.d.ts +5 -0
  69. package/dist/utils/hooks/SynapseAPI/dataaccess/useGetDataAccessSubmission.js +11 -0
  70. package/dist/utils/hooks/SynapseAPI/dataaccess/useGetDataAccessSubmission.js.map +1 -0
  71. package/dist/utils/hooks/SynapseAPI/entity/useEntity.d.ts +5 -0
  72. package/dist/utils/hooks/SynapseAPI/entity/useGetQueryResultBundle.js +5 -2
  73. package/dist/utils/hooks/SynapseAPI/entity/useGetQueryResultBundle.js.map +1 -1
  74. package/dist/utils/hooks/SynapseAPI/useUserBundle.d.ts +2 -1
  75. package/dist/utils/hooks/SynapseAPI/useUserBundle.js +17 -2
  76. package/dist/utils/hooks/SynapseAPI/useUserBundle.js.map +1 -1
  77. package/dist/utils/hooks/SynapseAPI/useUserGroupHeader.d.ts +5 -0
  78. package/dist/utils/hooks/SynapseAPI/useUserGroupHeader.js +28 -0
  79. package/dist/utils/hooks/SynapseAPI/useUserGroupHeader.js.map +1 -0
  80. package/dist/utils/hooks/useDebouncedEffect.d.ts +9 -0
  81. package/dist/utils/hooks/useDebouncedEffect.js +21 -0
  82. package/dist/utils/hooks/useDebouncedEffect.js.map +1 -0
  83. package/dist/utils/hooks/useGetInfoFromIds.d.ts +6 -0
  84. package/dist/utils/hooks/useGetInfoFromIds.js +6 -2
  85. package/dist/utils/hooks/useGetInfoFromIds.js.map +1 -1
  86. package/dist/utils/synapseTypes/AccessRequirement/Submission.d.ts +52 -0
  87. package/dist/utils/synapseTypes/AccessRequirement/Submission.js +3 -0
  88. package/dist/utils/synapseTypes/AccessRequirement/Submission.js.map +1 -0
  89. package/package.json +2 -2
@@ -3,13 +3,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  var tslib_1 = require("tslib");
4
4
  var lab_1 = require("@material-ui/lab");
5
5
  var react_1 = (0, tslib_1.__importStar)(require("react"));
6
- var utils_1 = require("../utils");
6
+ var useUserGroupHeader_1 = require("../utils/hooks/SynapseAPI/useUserGroupHeader");
7
7
  var SynapseConstants_1 = require("../utils/SynapseConstants");
8
8
  var SynapseContext_1 = require("../utils/SynapseContext");
9
9
  var TeamBadge_1 = (0, tslib_1.__importDefault)(require("./TeamBadge"));
10
10
  var UserCard_1 = (0, tslib_1.__importDefault)(require("./UserCard"));
11
11
  function UserOrTeamBadge(props) {
12
- var isMounted = true;
13
12
  var principalId = props.principalId;
14
13
  var disableHref = props.disableHref, showFullName = props.showFullName, providedUserGroupHeader = props.userGroupHeader;
15
14
  if (principalId == null) {
@@ -17,36 +16,20 @@ function UserOrTeamBadge(props) {
17
16
  }
18
17
  var accessToken = (0, SynapseContext_1.useSynapseContext)().accessToken;
19
18
  var _a = (0, react_1.useState)(providedUserGroupHeader), userGroupHeader = _a[0], setUserGroupHeader = _a[1];
19
+ var fetchedUserGroupHeader = (0, useUserGroupHeader_1.useGetUserGroupHeader)((principalId !== null && principalId !== void 0 ? principalId : '').toString(), {
20
+ enabled: !providedUserGroupHeader,
21
+ }).data;
20
22
  (0, react_1.useEffect)(function () {
21
- function getUserGroupHeader() {
22
- return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
23
- var headers;
24
- return (0, tslib_1.__generator)(this, function (_a) {
25
- switch (_a.label) {
26
- case 0: return [4 /*yield*/, utils_1.SynapseClient.getGroupHeadersBatch([principalId.toString()], accessToken)];
27
- case 1:
28
- headers = _a.sent();
29
- if (isMounted) {
30
- setUserGroupHeader(headers.children[0]);
31
- }
32
- return [2 /*return*/];
33
- }
34
- });
35
- });
23
+ if (principalId && userGroupHeader == undefined && fetchedUserGroupHeader) {
24
+ setUserGroupHeader(fetchedUserGroupHeader);
36
25
  }
37
- if (principalId && userGroupHeader == undefined) {
38
- getUserGroupHeader();
39
- }
40
- return function () {
41
- isMounted = false;
42
- };
43
- }, [accessToken, principalId, userGroupHeader]);
26
+ }, [accessToken, principalId, userGroupHeader, fetchedUserGroupHeader]);
44
27
  if (principalId == null && providedUserGroupHeader == null) {
45
28
  console.error('Expected one of principalId or userGroupHeader to be defined but both were null or undefined');
46
29
  return react_1.default.createElement(react_1.default.Fragment, null);
47
30
  }
48
31
  else if (userGroupHeader === undefined) {
49
- return react_1.default.createElement(lab_1.Skeleton, { width: 150 });
32
+ return react_1.default.createElement(lab_1.Skeleton, { width: 125, height: 30 });
50
33
  }
51
34
  else if (userGroupHeader.isIndividual) {
52
35
  return (react_1.default.createElement(UserCard_1.default, { ownerId: principalId.toString(), size: SynapseConstants_1.SMALL_USER_CARD, disableLink: disableHref, showFullName: showFullName }));
@@ -1 +1 @@
1
- {"version":3,"file":"UserOrTeamBadge.js","sourceRoot":"","sources":["../../src/lib/containers/UserOrTeamBadge.tsx"],"names":[],"mappings":";;;AAAA,wCAA2C;AAC3C,0DAAkD;AAClD,kCAAwC;AACxC,8DAA2D;AAC3D,0DAA2D;AAE3D,uEAAmC;AACnC,qEAAiC;AAWjC,SAAwB,eAAe,CAAC,KAA2B;IACjE,IAAI,SAAS,GAAG,IAAI,CAAA;IACpB,IAAI,WAAW,GAAG,KAAK,CAAC,WAAW,CAAA;IAEjC,IAAA,WAAW,GAGT,KAAK,YAHI,EACX,YAAY,GAEV,KAAK,aAFK,EACK,uBAAuB,GACtC,KAAK,gBADiC,CACjC;IAET,IAAI,WAAW,IAAI,IAAI,EAAE;QACvB,WAAW,GAAG,uBAAuB,aAAvB,uBAAuB,uBAAvB,uBAAuB,CAAE,OAAO,CAAA;KAC/C;IAEO,IAAA,WAAW,GAAK,IAAA,kCAAiB,GAAE,YAAxB,CAAwB;IACrC,IAAA,KAAwC,IAAA,gBAAQ,EAEpD,uBAAuB,CAAC,EAFnB,eAAe,QAAA,EAAE,kBAAkB,QAEhB,CAAA;IAE1B,IAAA,iBAAS,EAAC;QACR,SAAe,kBAAkB;;;;;gCACf,qBAAM,qBAAa,CAAC,oBAAoB,CACtD,CAAC,WAAY,CAAC,QAAQ,EAAE,CAAC,EACzB,WAAW,CACZ,EAAA;;4BAHK,OAAO,GAAG,SAGf;4BACD,IAAI,SAAS,EAAE;gCACb,kBAAkB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAA;6BACxC;;;;;SACF;QACD,IAAI,WAAW,IAAI,eAAe,IAAI,SAAS,EAAE;YAC/C,kBAAkB,EAAE,CAAA;SACrB;QACD,OAAO;YACL,SAAS,GAAG,KAAK,CAAA;QACnB,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,WAAW,EAAE,WAAW,EAAE,eAAe,CAAC,CAAC,CAAA;IAE/C,IAAI,WAAW,IAAI,IAAI,IAAI,uBAAuB,IAAI,IAAI,EAAE;QAC1D,OAAO,CAAC,KAAK,CACX,8FAA8F,CAC/F,CAAA;QACD,OAAO,6DAAK,CAAA;KACb;SAAM,IAAI,eAAe,KAAK,SAAS,EAAE;QACxC,OAAO,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,GAAI,CAAA;KAChC;SAAM,IAAI,eAAe,CAAC,YAAY,EAAE;QACvC,OAAO,CACL,8BAAC,kBAAQ,IACP,OAAO,EAAE,WAAY,CAAC,QAAQ,EAAE,EAChC,IAAI,EAAE,kCAAe,EACrB,WAAW,EAAE,WAAW,EACxB,YAAY,EAAE,YAAY,GAC1B,CACH,CAAA;KACF;SAAM;QACL,OAAO,CACL,8BAAC,mBAAS,IACR,MAAM,EAAE,WAAY,EACpB,QAAQ,EAAE,eAAe,CAAC,QAAQ,EAClC,WAAW,EAAE,WAAW,GACxB,CACH,CAAA;KACF;AACH,CAAC;AA7DD,kCA6DC"}
1
+ {"version":3,"file":"UserOrTeamBadge.js","sourceRoot":"","sources":["../../src/lib/containers/UserOrTeamBadge.tsx"],"names":[],"mappings":";;;AAAA,wCAA2C;AAC3C,0DAAkD;AAClD,mFAAoF;AACpF,8DAA2D;AAC3D,0DAA2D;AAE3D,uEAAmC;AACnC,qEAAiC;AAWjC,SAAwB,eAAe,CAAC,KAA2B;IACjE,IAAI,WAAW,GAAG,KAAK,CAAC,WAAW,CAAA;IAEjC,IAAA,WAAW,GAGT,KAAK,YAHI,EACX,YAAY,GAEV,KAAK,aAFK,EACK,uBAAuB,GACtC,KAAK,gBADiC,CACjC;IAET,IAAI,WAAW,IAAI,IAAI,EAAE;QACvB,WAAW,GAAG,uBAAuB,aAAvB,uBAAuB,uBAAvB,uBAAuB,CAAE,OAAO,CAAA;KAC/C;IAEO,IAAA,WAAW,GAAK,IAAA,kCAAiB,GAAE,YAAxB,CAAwB;IACrC,IAAA,KAAwC,IAAA,gBAAQ,EAEpD,uBAAuB,CAAC,EAFnB,eAAe,QAAA,EAAE,kBAAkB,QAEhB,CAAA;IAElB,IAAM,sBAAsB,GAAK,IAAA,0CAAqB,EAC5D,CAAC,WAAW,aAAX,WAAW,cAAX,WAAW,GAAI,EAAE,CAAC,CAAC,QAAQ,EAAE,EAC9B;QACE,OAAO,EAAE,CAAC,uBAAuB;KAClC,CACF,KALmC,CAKnC;IAED,IAAA,iBAAS,EAAC;QACR,IAAI,WAAW,IAAI,eAAe,IAAI,SAAS,IAAI,sBAAsB,EAAE;YACzE,kBAAkB,CAAC,sBAAsB,CAAC,CAAA;SAC3C;IACH,CAAC,EAAE,CAAC,WAAW,EAAE,WAAW,EAAE,eAAe,EAAE,sBAAsB,CAAC,CAAC,CAAA;IAEvE,IAAI,WAAW,IAAI,IAAI,IAAI,uBAAuB,IAAI,IAAI,EAAE;QAC1D,OAAO,CAAC,KAAK,CACX,8FAA8F,CAC/F,CAAA;QACD,OAAO,6DAAK,CAAA;KACb;SAAM,IAAI,eAAe,KAAK,SAAS,EAAE;QACxC,OAAO,8BAAC,cAAQ,IAAC,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,EAAE,GAAI,CAAA;KAC5C;SAAM,IAAI,eAAe,CAAC,YAAY,EAAE;QACvC,OAAO,CACL,8BAAC,kBAAQ,IACP,OAAO,EAAE,WAAY,CAAC,QAAQ,EAAE,EAChC,IAAI,EAAE,kCAAe,EACrB,WAAW,EAAE,WAAW,EACxB,YAAY,EAAE,YAAY,GAC1B,CACH,CAAA;KACF;SAAM;QACL,OAAO,CACL,8BAAC,mBAAS,IACR,MAAM,EAAE,WAAY,EACpB,QAAQ,EAAE,eAAe,CAAC,QAAQ,EAClC,WAAW,EAAE,WAAW,GACxB,CACH,CAAA;KACF;AACH,CAAC;AAvDD,kCAuDC"}
@@ -0,0 +1,13 @@
1
+ import * as React from 'react';
2
+ import { UserGroupHeader } from '../utils/synapseTypes';
3
+ import { TYPE_FILTER } from '../utils/synapseTypes/UserGroupHeader';
4
+ export declare type UserSearchBoxProps = {
5
+ htmlId?: string;
6
+ defaultValue?: string;
7
+ onChange?: (principalId: string | null, header: UserGroupHeader | null) => void;
8
+ typeFilter?: TYPE_FILTER;
9
+ filterPredicate?: (item: UserGroupHeader) => boolean;
10
+ placeholder?: string;
11
+ };
12
+ declare const UserSearchBoxV2: React.FC<UserSearchBoxProps>;
13
+ export default UserSearchBoxV2;
@@ -0,0 +1,91 @@
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 React = (0, tslib_1.__importStar)(require("react"));
6
+ var react_select_1 = require("react-select");
7
+ var async_1 = (0, tslib_1.__importDefault)(require("react-select/async"));
8
+ var utils_1 = require("../utils");
9
+ var useGetInfoFromIds_1 = (0, tslib_1.__importDefault)(require("../utils/hooks/useGetInfoFromIds"));
10
+ var UserOrTeamBadge_1 = (0, tslib_1.__importDefault)(require("./UserOrTeamBadge"));
11
+ var customSelectComponents = {
12
+ Control: function (props) {
13
+ var _a;
14
+ return (React.createElement(react_select_1.components.Control, (0, tslib_1.__assign)({}, props, { className: "form-control " + ((_a = props.className) !== null && _a !== void 0 ? _a : '') })));
15
+ },
16
+ SingleValue: function (props) {
17
+ var data = props.data;
18
+ return (React.createElement("div", (0, tslib_1.__assign)({}, props),
19
+ React.createElement(UserOrTeamBadge_1.default, { userGroupHeader: data.header, disableHref: true, showFullName: true })));
20
+ },
21
+ Option: function (props) {
22
+ var data = props.data, selectOption = props.selectOption;
23
+ return (React.createElement("div", (0, tslib_1.__assign)({}, props, { key: data.id, onClick: function () { return selectOption(data); }, style: { padding: '5px 10px' } }),
24
+ React.createElement(UserOrTeamBadge_1.default, { userGroupHeader: data.header, disableHref: true, showFullName: true })));
25
+ },
26
+ };
27
+ var UserSearchBoxV2 = function (props) {
28
+ var htmlId = props.htmlId, _a = props.defaultValue, defaultValue = _a === void 0 ? null : _a, onChange = props.onChange, filterPredicate = props.filterPredicate, typeFilter = props.typeFilter, placeholder = props.placeholder;
29
+ var _b = (0, useGetInfoFromIds_1.default)({
30
+ ids: defaultValue ? [defaultValue] : [],
31
+ type: 'USER_PROFILE',
32
+ })[0], defaultUserGroupHeader = _b === void 0 ? undefined : _b;
33
+ function loadOptions(inputValue) {
34
+ var _a, _b;
35
+ return (0, tslib_1.__awaiter)(this, void 0, void 0, function () {
36
+ var data;
37
+ return (0, tslib_1.__generator)(this, function (_c) {
38
+ switch (_c.label) {
39
+ case 0:
40
+ data = undefined;
41
+ if (!!data) return [3 /*break*/, 2];
42
+ return [4 /*yield*/, utils_1.SynapseClient.getUserGroupHeaders(inputValue, typeFilter)];
43
+ case 1:
44
+ data = (_a = (_c.sent())) === null || _a === void 0 ? void 0 : _a.children;
45
+ _c.label = 2;
46
+ case 2:
47
+ if (filterPredicate) {
48
+ data = data.filter(filterPredicate);
49
+ }
50
+ // Map the AR(s) to options for the select input component
51
+ return [2 /*return*/, ((_b = data === null || data === void 0 ? void 0 : data.map(function (item) { return ({
52
+ id: item.ownerId.toString(),
53
+ value: item.ownerId.toString(),
54
+ label: item.userName,
55
+ header: item,
56
+ }); })) !== null && _b !== void 0 ? _b : [])];
57
+ }
58
+ });
59
+ });
60
+ }
61
+ if (defaultValue && defaultUserGroupHeader == null) {
62
+ return React.createElement(lab_1.Skeleton, { width: "100%" });
63
+ }
64
+ return (React.createElement(async_1.default, { className: "bootstrap-4-backport", defaultValue: defaultValue
65
+ ? {
66
+ id: defaultValue,
67
+ value: defaultValue,
68
+ label: defaultUserGroupHeader.userName,
69
+ header: defaultUserGroupHeader,
70
+ }
71
+ : undefined, defaultOptions: defaultValue
72
+ ? [
73
+ {
74
+ id: defaultValue,
75
+ value: defaultValue,
76
+ label: defaultUserGroupHeader.userName,
77
+ header: defaultUserGroupHeader,
78
+ },
79
+ ]
80
+ : false, id: htmlId, cacheOptions: true, isClearable: true, styles: {
81
+ // Bootstrap's form-control class overrides the display value, manually set to flex (the default without Bootstrap)
82
+ control: function (styles) { return ((0, tslib_1.__assign)((0, tslib_1.__assign)({}, styles), { display: 'flex !important' })); },
83
+ }, components: customSelectComponents, loadOptions: loadOptions, onChange: function (option) {
84
+ var _a, _b;
85
+ if (onChange) {
86
+ onChange((_a = option === null || option === void 0 ? void 0 : option.id) !== null && _a !== void 0 ? _a : null, (_b = option === null || option === void 0 ? void 0 : option.header) !== null && _b !== void 0 ? _b : null);
87
+ }
88
+ }, placeholder: placeholder }));
89
+ };
90
+ exports.default = UserSearchBoxV2;
91
+ //# sourceMappingURL=UserSearchBoxV2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UserSearchBoxV2.js","sourceRoot":"","sources":["../../src/lib/containers/UserSearchBoxV2.tsx"],"names":[],"mappings":"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"}
@@ -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":"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"}
@@ -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":"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"}
@@ -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;