@truedat/core 4.29.1 → 4.29.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,11 @@
1
1
  # Changelog
2
2
 
3
+ ## [4.29.5] 2021-10-05
4
+
5
+ ### Changed
6
+
7
+ - [TD-4111] Extract grant routes
8
+
3
9
  ## [4.28.6] 2021-09-20
4
10
 
5
11
  ### Added
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@truedat/core",
3
- "version": "4.29.1",
3
+ "version": "4.29.5",
4
4
  "description": "Truedat Web Core",
5
5
  "sideEffects": false,
6
6
  "jsnext:main": "src/index.js",
@@ -103,5 +103,5 @@
103
103
  "react-dom": ">= 16.8.6 < 17",
104
104
  "semantic-ui-react": ">= 0.88.2 < 2.1"
105
105
  },
106
- "gitHead": "bd33b4258962a80b10ffedf9d222272cd3babaf0"
106
+ "gitHead": "7fbbe4e02679ab067e73c2941db7ceefce36a5d2"
107
107
  }
@@ -6,16 +6,10 @@ import {
6
6
  SYSTEMS,
7
7
  STRUCTURE_TAGS,
8
8
  STRUCTURE_TYPES,
9
- MY_GRANTS,
10
- GRANTS,
11
9
  } from "../routes";
12
10
  import Submenu from "./Submenu";
13
11
 
14
- const items = [
15
- { name: "structures", routes: [STRUCTURES, SYSTEMS] },
16
- { name: "my_grants", routes: [MY_GRANTS] },
17
- { name: "grants", routes: [GRANTS] },
18
- ];
12
+ const items = [{ name: "structures", routes: [STRUCTURES, SYSTEMS] }];
19
13
 
20
14
  const adminItems = [
21
15
  { name: "structure_types", routes: [STRUCTURE_TYPES] },
@@ -0,0 +1,18 @@
1
+ import React from "react";
2
+ import { useAuthorized } from "../hooks";
3
+ import { MY_GRANTS, GRANTS, MY_GRANT_REQUESTS } from "../routes";
4
+ import Submenu from "./Submenu";
5
+
6
+ const items = [
7
+ { name: "my_grants", routes: [MY_GRANTS] },
8
+ { name: "grants", routes: [GRANTS] },
9
+ // { name: "grant_requests", routes: [GRANT_REQUESTS] },
10
+ { name: "my_grant_requests", routes: [MY_GRANT_REQUESTS] },
11
+ ];
12
+
13
+ export const GrantMenu = () => {
14
+ const authorized = useAuthorized("data_dictionary");
15
+ return authorized ? <Submenu items={items} icon="key" name="grants" /> : null;
16
+ };
17
+
18
+ export default GrantMenu;
@@ -12,10 +12,11 @@ import QualityMenu from "./QualityMenu";
12
12
  import SearchMenu from "./SearchMenu";
13
13
  import SidebarToggle from "./SidebarToggle";
14
14
  import TaxonomyMenu from "./TaxonomyMenu";
15
+ import GrantMenu from "./GrantMenu";
15
16
  import MembersMenu from "./MembersMenu";
16
17
 
17
18
  export const SideMenu = ({ children, animation = "push", inverted }) => {
18
- const sidebarVisible = useSelector(state => state.sidebarVisible);
19
+ const sidebarVisible = useSelector((state) => state.sidebarVisible);
19
20
 
20
21
  const width = sidebarVisible ? null : "very thin";
21
22
 
@@ -33,6 +34,7 @@ export const SideMenu = ({ children, animation = "push", inverted }) => {
33
34
  <SearchMenu />
34
35
  <GlossaryMenu />
35
36
  <CatalogMenu />
37
+ <GrantMenu />
36
38
  <QualityMenu />
37
39
  <LineageMenu />
38
40
  <IngestMenu />
@@ -50,7 +52,7 @@ export const SideMenu = ({ children, animation = "push", inverted }) => {
50
52
  SideMenu.propTypes = {
51
53
  animation: PropTypes.string,
52
54
  children: PropTypes.node,
53
- inverted: PropTypes.bool
55
+ inverted: PropTypes.bool,
54
56
  };
55
57
 
56
58
  export default SideMenu;
@@ -4,7 +4,7 @@ import { CatalogMenu } from "../CatalogMenu";
4
4
 
5
5
  jest.mock("../../hooks", () => ({
6
6
  useActiveRoutes: jest.fn(() => true),
7
- useAuthorized: jest.fn(() => true)
7
+ useAuthorized: jest.fn(() => true),
8
8
  }));
9
9
 
10
10
  describe("<CatalogMenu />", () => {
@@ -0,0 +1,15 @@
1
+ import React from "react";
2
+ import { shallow } from "enzyme";
3
+ import { GrantMenu } from "../GrantMenu";
4
+
5
+ jest.mock("../../hooks", () => ({
6
+ useActiveRoutes: jest.fn(() => true),
7
+ useAuthorized: jest.fn(() => true),
8
+ }));
9
+
10
+ describe("<GrantMenu />", () => {
11
+ it("matches the latest snapshot", () => {
12
+ const wrapper = shallow(<GrantMenu />);
13
+ expect(wrapper).toMatchSnapshot();
14
+ });
15
+ });
@@ -12,18 +12,6 @@ exports[`<CatalogMenu /> matches the latest snapshot 1`] = `
12
12
  "/systems",
13
13
  ],
14
14
  },
15
- Object {
16
- "name": "my_grants",
17
- "routes": Array [
18
- "/my_grants",
19
- ],
20
- },
21
- Object {
22
- "name": "grants",
23
- "routes": Array [
24
- "/grants",
25
- ],
26
- },
27
15
  Object {
28
16
  "name": "structure_types",
29
17
  "routes": Array [
@@ -0,0 +1,30 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`<GrantMenu /> matches the latest snapshot 1`] = `
4
+ <Submenu
5
+ icon="key"
6
+ items={
7
+ Array [
8
+ Object {
9
+ "name": "my_grants",
10
+ "routes": Array [
11
+ "/my_grants",
12
+ ],
13
+ },
14
+ Object {
15
+ "name": "grants",
16
+ "routes": Array [
17
+ "/grants",
18
+ ],
19
+ },
20
+ Object {
21
+ "name": "my_grant_requests",
22
+ "routes": Array [
23
+ "/my_grant_requests",
24
+ ],
25
+ },
26
+ ]
27
+ }
28
+ name="grants"
29
+ />
30
+ `;
@@ -15,6 +15,7 @@ exports[`<SideMenu /> matches the latest snapshot 1`] = `
15
15
  <SearchMenu />
16
16
  <GlossaryMenu />
17
17
  <CatalogMenu />
18
+ <GrantMenu />
18
19
  <QualityMenu />
19
20
  <LineageMenu />
20
21
  <IngestMenu />
@@ -73,13 +73,15 @@ export default {
73
73
  "sidemenu.configurations": "Configuration",
74
74
  "sidemenu.dashboard": "Dashboard",
75
75
  "sidemenu.glossary": "Glossary",
76
+ "sidemenu.grant_requests": "Grant Requests",
76
77
  "sidemenu.grants": "Grants",
77
78
  "sidemenu.hide": "Collapse sidebar",
78
79
  "sidemenu.ingests": "Data Requests",
79
80
  "sidemenu.implementations": "Implementations",
80
81
  "sidemenu.jobs": "Jobs",
81
82
  "sidemenu.lineage": "Lineage Analysis",
82
- "sidemenu.my_grants": "My grants",
83
+ "sidemenu.my_grant_requests": "My Grant Requests",
84
+ "sidemenu.my_grants": "My Grants",
83
85
  "sidemenu.quality": "Data Quality",
84
86
  "sidemenu.quality_dashboard": "Quality Dashboard",
85
87
  "sidemenu.roles": "Roles",
@@ -76,6 +76,7 @@ export default {
76
76
  "sidemenu.configurations": "Configuración",
77
77
  "sidemenu.dashboard": "Dashboard",
78
78
  "sidemenu.glossary": "Glosario",
79
+ "sidemenu.grant_requests": "Peticiones de Accesos",
79
80
  "sidemenu.grants": "Accesos",
80
81
  "sidemenu.hide": "Ocultar",
81
82
  "sidemenu.implementations": "Implementaciones",
@@ -83,6 +84,7 @@ export default {
83
84
  "sidemenu.jobs": "Jobs",
84
85
  "sidemenu.lineage": "Linaje",
85
86
  "sidemenu.my_grants": "Mis accesos",
87
+ "sidemenu.my_grant_requests": "Mis Peticiones de Accesos",
86
88
  "sidemenu.quality": "Calidad",
87
89
  "sidemenu.quality_dashboard": "Dashboard de Calidad",
88
90
  "sidemenu.roles": "Roles",
package/src/routes.js CHANGED
@@ -40,6 +40,9 @@ export const DOMAIN_MEMBERS = "/domains/:id/members";
40
40
  export const DOMAIN_MEMBERS_NEW = "/domains/:id/members/new";
41
41
  export const DOMAIN_NEW = "/domains/:id/new";
42
42
  export const EXECUTION_GROUP = "/executionGroups/:id";
43
+ export const GRANT_REQUESTS = "/grant_requests";
44
+ export const GRANT_REQUEST = "/grant_requests/:id";
45
+
43
46
  export const GRANTS = "/grants";
44
47
  export const GRANTS_REQUESTS_CHECKOUT = "/grants_requests/checkout";
45
48
  export const GRAPH = "/graphs/:id";
@@ -67,6 +70,7 @@ export const INGEST_RELATIONS_STRUCTURES_NEW =
67
70
  export const JOB = "/jobs/:id";
68
71
  export const JOBS = "/jobs";
69
72
  export const LOGIN = "/login";
73
+ export const MY_GRANT_REQUESTS = "/my_grant_requests";
70
74
  export const MY_GRANTS = "/my_grants";
71
75
  export const PASSWORD = "/password";
72
76
  export const PROFILE_EXECUTION =
@@ -182,6 +186,8 @@ const routes = {
182
186
  DOMAINS_SEARCH,
183
187
  DOMAINS,
184
188
  EXECUTION_GROUP,
189
+ GRANT_REQUEST,
190
+ GRANT_REQUESTS,
185
191
  GRANTS,
186
192
  GRANTS_REQUESTS_CHECKOUT,
187
193
  GRAPH,
@@ -207,6 +213,7 @@ const routes = {
207
213
  JOB,
208
214
  JOBS,
209
215
  LOGIN,
216
+ MY_GRANT_REQUESTS,
210
217
  MY_GRANTS,
211
218
  PASSWORD,
212
219
  PROFILE_EXECUTION,