@truedat/dq 4.37.1 → 4.37.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.
Files changed (30) hide show
  1. package/CHANGELOG.md +26 -0
  2. package/package.json +4 -4
  3. package/src/components/ExecutionDetails.js +17 -9
  4. package/src/components/ImplementationsRoutes.js +4 -0
  5. package/src/components/RuleEventRow.js +47 -0
  6. package/src/components/RuleEvents.js +31 -0
  7. package/src/components/RuleImplementationSelectedFilters.js +23 -1
  8. package/src/components/RuleRoutes.js +26 -2
  9. package/src/components/RuleSelectedFilters.js +21 -1
  10. package/src/components/RuleTabs.js +16 -2
  11. package/src/components/RulesRoutes.js +13 -1
  12. package/src/components/__tests__/ExecutionDetails.spec.js +31 -24
  13. package/src/components/__tests__/RuleEventRow.spec.js +33 -0
  14. package/src/components/__tests__/RuleEvents.spec.js +64 -0
  15. package/src/components/__tests__/RuleRoutes.spec.js +23 -0
  16. package/src/components/__tests__/__snapshots__/ExecutionDetails.spec.js.snap +2 -5
  17. package/src/components/__tests__/__snapshots__/RuleEventRow.spec.js.snap +38 -0
  18. package/src/components/__tests__/__snapshots__/RuleEvents.spec.js.snap +78 -0
  19. package/src/components/__tests__/__snapshots__/RuleRoutes.spec.js.snap +3 -0
  20. package/src/messages/en.js +6 -0
  21. package/src/messages/es.js +9 -0
  22. package/src/reducers/__tests__/ruleActiveFilters.spec.js +19 -7
  23. package/src/reducers/__tests__/ruleImplementationActiveFilters.spec.js +19 -7
  24. package/src/reducers/index.js +2 -0
  25. package/src/reducers/ruleActiveFilters.js +5 -0
  26. package/src/reducers/ruleImplementationActiveFilters.js +7 -0
  27. package/src/reducers/ruleImplementationFilters.js +1 -1
  28. package/src/reducers/ruleImplementationFiltersLoading.js +14 -0
  29. package/src/selectors/__tests__/getParsedEvents.spec.js +173 -0
  30. package/src/selectors/getParsedEvents.js +55 -0
@@ -1,6 +1,6 @@
1
1
  // Jest Snapshot v1, https://goo.gl/fbAQLP
2
2
 
3
- exports[`<ExecutionDetetails> matches the lastest snapshot 1`] = `
3
+ exports[`<ExecutionDetails> matches the lastest snapshot 1`] = `
4
4
  <div>
5
5
  <table
6
6
  class="ui table implementation-results medium"
@@ -47,7 +47,6 @@ exports[`<ExecutionDetetails> matches the lastest snapshot 1`] = `
47
47
  class=""
48
48
  >
49
49
  Date
50
-
51
50
  </td>
52
51
  <td
53
52
  class=""
@@ -60,7 +59,6 @@ exports[`<ExecutionDetetails> matches the lastest snapshot 1`] = `
60
59
  class=""
61
60
  >
62
61
  Records
63
-
64
62
  </td>
65
63
  <td
66
64
  class=""
@@ -73,7 +71,6 @@ exports[`<ExecutionDetetails> matches the lastest snapshot 1`] = `
73
71
  class=""
74
72
  >
75
73
  Errors
76
-
77
74
  </td>
78
75
  <td
79
76
  class=""
@@ -116,7 +113,7 @@ exports[`<ExecutionDetetails> matches the lastest snapshot 1`] = `
116
113
  </div>
117
114
  `;
118
115
 
119
- exports[`<ExecutionDetetails> without details 1`] = `
116
+ exports[`<ExecutionDetails> without details 1`] = `
120
117
  <div>
121
118
  <div
122
119
  class="ui message"
@@ -0,0 +1,38 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`<RuleEventsRow /> matches the latest snapshot 1`] = `
4
+ <div>
5
+ <div
6
+ class="event"
7
+ >
8
+ <div
9
+ class="content"
10
+ >
11
+ <div
12
+ class="summary"
13
+ >
14
+ <a
15
+ class="user"
16
+ >
17
+ some.user@domain.tld
18
+ </a>
19
+
20
+ <div
21
+ class="date"
22
+ >
23
+ <time
24
+ datetime="1631777792848"
25
+ >
26
+ 2021-09-16 07:36
27
+ </time>
28
+ </div>
29
+ </div>
30
+ <div
31
+ class="text extra"
32
+ >
33
+ Field field1 changed to: "new value"
34
+ </div>
35
+ </div>
36
+ </div>
37
+ </div>
38
+ `;
@@ -0,0 +1,78 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`<RuleEvents /> matches the latest snapshot 1`] = `
4
+ <div>
5
+ <div
6
+ class="ui bottom attached segment"
7
+ >
8
+ <div
9
+ class="ui small feed"
10
+ >
11
+ <div
12
+ class="event"
13
+ >
14
+ <div
15
+ class="content"
16
+ >
17
+ <div
18
+ class="summary"
19
+ >
20
+ <a
21
+ class="user"
22
+ >
23
+ some.user@domain.tld
24
+ </a>
25
+
26
+ <div
27
+ class="date"
28
+ >
29
+ <time
30
+ datetime="1631777792848"
31
+ >
32
+ 2021-09-16 07:36
33
+ </time>
34
+ </div>
35
+ </div>
36
+ <div
37
+ class="text extra"
38
+ >
39
+ Field domain_id changed to: 140
40
+ </div>
41
+ </div>
42
+ </div>
43
+ <div
44
+ class="event"
45
+ >
46
+ <div
47
+ class="content"
48
+ >
49
+ <div
50
+ class="summary"
51
+ >
52
+ <a
53
+ class="user"
54
+ >
55
+ some.user
56
+ </a>
57
+
58
+ <div
59
+ class="date"
60
+ >
61
+ <time
62
+ datetime="1631784663061"
63
+ >
64
+ 2021-09-16 09:31
65
+ </time>
66
+ </div>
67
+ </div>
68
+ <div
69
+ class="text extra"
70
+ >
71
+ Field domain_id changed to: 168
72
+ </div>
73
+ </div>
74
+ </div>
75
+ </div>
76
+ </div>
77
+ </div>
78
+ `;
@@ -0,0 +1,3 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`<RuleRoutes> matches the lastest snapshot 1`] = `<div />`;
@@ -132,6 +132,7 @@ export default {
132
132
  "All rule implementations should be removed",
133
133
  "rule.error.rule_name_bc_id.unique_constraint":
134
134
  "Duplicated rule name. Edit name or associated business concept.",
135
+
135
136
  "rule.form.accordion.select": "Select",
136
137
  "rule.form.concept.label": "Concept",
137
138
  "ruleImplementation.form.tooltip.deviation.goal":
@@ -541,6 +542,10 @@ export default {
541
542
  "rules.actions.upload.confirmation.header": "Confirm bulk upload",
542
543
  "rules.actions.upload.tooltip": "Upload Rules",
543
544
  "rules.crumbs.top": "Rules",
545
+ "rules.events.action_created": "Rule created",
546
+ "rules.events.action_changed": "Field {0} changed: {1}",
547
+ "rules.events.action_changed_to": "Field {0} changed to: {1}",
548
+ "rules.events.action_updated": "Rule updated",
544
549
  "rules.retrieved.results": "{count} rules found",
545
550
  "rules.search.placeholder": "Search rules...",
546
551
  "rules.searching": "Searching...",
@@ -557,6 +562,7 @@ export default {
557
562
  "structureFields.dropdown.placeholder": "Fields",
558
563
  "summary.link.and": "and",
559
564
  "tabs.dq.rule": "Rule",
565
+ "tabs.dq.rule.audit": "Audit",
560
566
  "tabs.dq.ruleImplementation": "Implementation",
561
567
  "tabs.dq.ruleImplementation.audit": "Audit",
562
568
  "tabs.dq.ruleImplementation.details": "Details",
@@ -556,6 +556,14 @@ export default {
556
556
  "rules.actions.upload.confirmation.header": "Subir ficheros de reglas",
557
557
  "rules.actions.upload.tooltip": "Subir reglas",
558
558
  "rules.crumbs.top": "Reglas",
559
+ "rules.events.action_created": "Regla creada",
560
+ "rules.events.action_changed": "Campo {0} actualizado: {1}",
561
+ "rules.events.action_changed_to": "Campo {0} actualizado a {1}",
562
+ "rules.events.action_updated": "Regla actualizada",
563
+ "ruleImplementations.events.action_created": "Implementación creada en regla: {0}",
564
+ "ruleImplementations.events.action_changed": "Campo {0} actualizado a {1}",
565
+ "ruleImplementations.events.action_deprecated": "Implementación archivada",
566
+ "ruleImplementations.events.action_moved": "Implementación movida a la regla: {0}",
559
567
  "rules.retrieved.results": "{count} reglas encontradas",
560
568
  "rules.search.placeholder": "Buscar reglas...",
561
569
  "rules.searching": "Buscando...",
@@ -573,6 +581,7 @@ export default {
573
581
  "structureFields.dropdown.placeholder": "Campos",
574
582
  "summary.link.and": "y",
575
583
  "tabs.dq.rule": "Regla",
584
+ "tabs.dq.rule.audit": "Auditoría",
576
585
  "tabs.dq.ruleImplementation.audit": "Auditoría",
577
586
  "tabs.dq.ruleImplementation.details": "Detalles",
578
587
  "tabs.dq.ruleImplementation.results": "Resultados",
@@ -1,10 +1,11 @@
1
+ import { applyUserSearchFilter } from "@truedat/dd/routines";
1
2
  import { initialState } from "../ruleActiveFilters";
2
3
  import {
3
4
  addRuleFilter,
4
5
  closeRuleFilter,
5
6
  removeRuleFilter,
6
7
  resetRuleFilters,
7
- toggleRuleFilterValue
8
+ toggleRuleFilterValue,
8
9
  } from "../../routines";
9
10
  import { ruleActiveFilters } from "..";
10
11
 
@@ -21,11 +22,22 @@ describe("reducers: ruleActiveFilters", () => {
21
22
  expect(
22
23
  ruleActiveFilters(fooState, {
23
24
  type: addRuleFilter.TRIGGER,
24
- payload
25
+ payload,
25
26
  })
26
27
  ).toEqual({ ...fooState, baz: [] });
27
28
  });
28
29
 
30
+ it("should handle the applyUserSearchFilter.TRIGGER action", () => {
31
+ const filters = { country: ["Sp"] };
32
+ const payload = { userFilter: { filters }, scope: "rule" };
33
+ expect(
34
+ ruleActiveFilters(fooState, {
35
+ type: applyUserSearchFilter.TRIGGER,
36
+ payload,
37
+ })
38
+ ).toEqual({ ...filters });
39
+ });
40
+
29
41
  it("should handle the closeRuleFilter.TRIGGER action", () => {
30
42
  const foo = ["foo1"];
31
43
  const bar = [];
@@ -34,7 +46,7 @@ describe("reducers: ruleActiveFilters", () => {
34
46
  expect(
35
47
  ruleActiveFilters(state, {
36
48
  type: closeRuleFilter.TRIGGER,
37
- payload
49
+ payload,
38
50
  })
39
51
  ).toEqual({ foo });
40
52
  });
@@ -47,7 +59,7 @@ describe("reducers: ruleActiveFilters", () => {
47
59
  expect(
48
60
  ruleActiveFilters(state, {
49
61
  type: removeRuleFilter.TRIGGER,
50
- payload
62
+ payload,
51
63
  })
52
64
  ).toEqual({ bar });
53
65
  });
@@ -55,7 +67,7 @@ describe("reducers: ruleActiveFilters", () => {
55
67
  it("should handle the resetRuleFilters.TRIGGER action", () => {
56
68
  expect(
57
69
  ruleActiveFilters(fooState, {
58
- type: resetRuleFilters.TRIGGER
70
+ type: resetRuleFilters.TRIGGER,
59
71
  })
60
72
  ).toEqual(initialState);
61
73
  });
@@ -63,7 +75,7 @@ describe("reducers: ruleActiveFilters", () => {
63
75
  it("should handle the resetRuleFilters.TRIGGER action when execution filter exists", () => {
64
76
  expect(
65
77
  ruleActiveFilters(fooState, {
66
- type: resetRuleFilters.TRIGGER
78
+ type: resetRuleFilters.TRIGGER,
67
79
  })
68
80
  ).toEqual(initialState);
69
81
  });
@@ -76,7 +88,7 @@ describe("reducers: ruleActiveFilters", () => {
76
88
  expect(
77
89
  ruleActiveFilters(state, {
78
90
  type: toggleRuleFilterValue.TRIGGER,
79
- payload
91
+ payload,
80
92
  })
81
93
  ).toEqual({ foo: ["foo1", "foo3"], bar });
82
94
  });
@@ -1,10 +1,11 @@
1
+ import { applyUserSearchFilter } from "@truedat/dd/routines";
1
2
  import { initialState } from "../ruleImplementationActiveFilters";
2
3
  import {
3
4
  addImplementationFilter,
4
5
  closeImplementationFilter,
5
6
  removeImplementationFilter,
6
7
  resetImplementationFilters,
7
- toggleImplementationFilterValue
8
+ toggleImplementationFilterValue,
8
9
  } from "../../routines";
9
10
  import { ruleImplementationActiveFilters } from "..";
10
11
 
@@ -17,13 +18,24 @@ describe("reducers: ruleImplementationActiveFilters", () => {
17
18
  );
18
19
  });
19
20
 
21
+ it("should handle the applyUserSearchFilter.TRIGGER action", () => {
22
+ const filters = { country: ["Sp"] };
23
+ const payload = { userFilter: { filters }, scope: "rule_implementation" };
24
+ expect(
25
+ ruleImplementationActiveFilters(fooState, {
26
+ type: applyUserSearchFilter.TRIGGER,
27
+ payload,
28
+ })
29
+ ).toEqual({ ...filters });
30
+ });
31
+
20
32
  it("should handle the addImplementationFilter.TRIGGER action", () => {
21
33
  const filter = "baz";
22
34
  const payload = { filter };
23
35
  expect(
24
36
  ruleImplementationActiveFilters(fooState, {
25
37
  type: addImplementationFilter.TRIGGER,
26
- payload
38
+ payload,
27
39
  })
28
40
  ).toEqual({ ...fooState, baz: [] });
29
41
  });
@@ -36,7 +48,7 @@ describe("reducers: ruleImplementationActiveFilters", () => {
36
48
  expect(
37
49
  ruleImplementationActiveFilters(state, {
38
50
  type: closeImplementationFilter.TRIGGER,
39
- payload
51
+ payload,
40
52
  })
41
53
  ).toEqual({ foo });
42
54
  });
@@ -49,7 +61,7 @@ describe("reducers: ruleImplementationActiveFilters", () => {
49
61
  expect(
50
62
  ruleImplementationActiveFilters(state, {
51
63
  type: removeImplementationFilter.TRIGGER,
52
- payload
64
+ payload,
53
65
  })
54
66
  ).toEqual({ bar });
55
67
  });
@@ -57,7 +69,7 @@ describe("reducers: ruleImplementationActiveFilters", () => {
57
69
  it("should handle the resetImplementationFilters.TRIGGER action", () => {
58
70
  expect(
59
71
  ruleImplementationActiveFilters(fooState, {
60
- type: resetImplementationFilters.TRIGGER
72
+ type: resetImplementationFilters.TRIGGER,
61
73
  })
62
74
  ).toEqual(initialState);
63
75
  });
@@ -67,7 +79,7 @@ describe("reducers: ruleImplementationActiveFilters", () => {
67
79
  ruleImplementationActiveFilters(
68
80
  { ...fooState, executable: [true] },
69
81
  {
70
- type: resetImplementationFilters.TRIGGER
82
+ type: resetImplementationFilters.TRIGGER,
71
83
  }
72
84
  )
73
85
  ).toEqual({ executable: [true] });
@@ -81,7 +93,7 @@ describe("reducers: ruleImplementationActiveFilters", () => {
81
93
  expect(
82
94
  ruleImplementationActiveFilters(state, {
83
95
  type: toggleImplementationFilterValue.TRIGGER,
84
- payload
96
+ payload,
85
97
  })
86
98
  ).toEqual({ foo: ["foo1", "foo3"], bar });
87
99
  });
@@ -17,6 +17,7 @@ import { ruleImplementation } from "./ruleImplementation";
17
17
  import { ruleImplementationCount } from "./ruleImplementationCount";
18
18
  import { ruleImplementationCreating } from "./ruleImplementationCreating";
19
19
  import { ruleImplementationFilters } from "./ruleImplementationFilters";
20
+ import { ruleImplementationFiltersLoading } from "./ruleImplementationFiltersLoading";
20
21
  import { ruleImplementationLoading } from "./ruleImplementationLoading";
21
22
  import { ruleImplementationQuery } from "./ruleImplementationQuery";
22
23
  import { ruleImplementationRaw } from "./ruleImplementationRaw";
@@ -64,6 +65,7 @@ export {
64
65
  ruleImplementationCount,
65
66
  ruleImplementationCreating,
66
67
  ruleImplementationFilters,
68
+ ruleImplementationFiltersLoading,
67
69
  ruleImplementationLoading,
68
70
  ruleImplementationQuery,
69
71
  ruleImplementationRaw,
@@ -1,4 +1,5 @@
1
1
  import _ from "lodash/fp";
2
+ import { applyUserSearchFilter } from "@truedat/dd/routines";
2
3
  import {
3
4
  addRuleFilter,
4
5
  closeRuleFilter,
@@ -15,6 +16,10 @@ export const ruleActiveFilters = (state = initialState, { type, payload }) => {
15
16
  const { filter } = payload;
16
17
  return { ...state, [filter]: [] };
17
18
  }
19
+ case applyUserSearchFilter.TRIGGER: {
20
+ const { userFilter, scope } = payload;
21
+ return scope === "rule" ? _.prop("filters")(userFilter) : state;
22
+ }
18
23
  case closeRuleFilter.TRIGGER: {
19
24
  const { filter } = payload;
20
25
  const values = _.propOr([], filter)(state);
@@ -1,4 +1,5 @@
1
1
  import _ from "lodash/fp";
2
+ import { applyUserSearchFilter } from "@truedat/dd/routines";
2
3
  import {
3
4
  addImplementationFilter,
4
5
  closeImplementationFilter,
@@ -18,6 +19,12 @@ export const ruleImplementationActiveFilters = (
18
19
  const { filter } = payload;
19
20
  return { ...state, [filter]: [] };
20
21
  }
22
+ case applyUserSearchFilter.TRIGGER: {
23
+ const { userFilter, scope } = payload;
24
+ return scope === "rule_implementation"
25
+ ? _.prop("filters")(userFilter)
26
+ : state;
27
+ }
21
28
  case closeImplementationFilter.TRIGGER: {
22
29
  const { filter } = payload;
23
30
  const values = _.propOr([], filter)(state);
@@ -1,7 +1,7 @@
1
1
  import _ from "lodash/fp";
2
2
  import {
3
3
  clearImplementationFilters,
4
- fetchImplementationFilters
4
+ fetchImplementationFilters,
5
5
  } from "../routines";
6
6
 
7
7
  const initialState = {};
@@ -0,0 +1,14 @@
1
+ import { fetchImplementationFilters } from "../routines";
2
+
3
+ const ruleImplementationFiltersLoading = (state = false, { type }) => {
4
+ switch (type) {
5
+ case fetchImplementationFilters.REQUEST:
6
+ return true;
7
+ case fetchImplementationFilters.FULFILL:
8
+ return false;
9
+ default:
10
+ return state;
11
+ }
12
+ };
13
+
14
+ export { ruleImplementationFiltersLoading };
@@ -0,0 +1,173 @@
1
+ import { getParsedEvents } from "..";
2
+
3
+ describe("selectors: getParsedEvents", () => {
4
+ const events = [
5
+ {
6
+ id: 52351,
7
+ service: "td_dd",
8
+ resource_id: 777,
9
+ resource_type: "rule",
10
+ event: "rule_created",
11
+ payload: {
12
+ active: true,
13
+ content: {
14
+ added: {
15
+ data_owner: null,
16
+ proyecto: ["P1"],
17
+ },
18
+ },
19
+ description: {},
20
+ df_name: "dq_default_template",
21
+ domain_id: 2,
22
+ goal: 20,
23
+ minimum: 80,
24
+ name: "des01",
25
+ result_type: "deviation",
26
+ updated_by: 398,
27
+ },
28
+ user_id: 398,
29
+ user_name: null,
30
+ user: {
31
+ email: "some.user@domain.tld",
32
+ full_name: "Some User",
33
+ id: 398,
34
+ user_name: "some.user@domain.tld",
35
+ },
36
+ ts: "2021-08-12T12:11:26.908147Z",
37
+ },
38
+
39
+ {
40
+ id: 100217,
41
+ service: "td_dd",
42
+ resource_id: 777,
43
+ resource_type: "rule",
44
+ event: "rule_updated",
45
+ payload: {
46
+ domain_id: 140,
47
+ },
48
+ user_id: 142,
49
+ user_name: null,
50
+ user: {
51
+ email: "some.user@domain.tld",
52
+ full_name: "Some User",
53
+ id: 142,
54
+ user_name: "some.user@domain.tld",
55
+ },
56
+ ts: "2021-09-16T07:36:32.848603Z",
57
+ },
58
+ {
59
+ id: 100435,
60
+ service: "td_dd",
61
+ resource_id: 777,
62
+ resource_type: "rule",
63
+ event: "rule_updated",
64
+ payload: {
65
+ description: {
66
+ document: {
67
+ data: {},
68
+ nodes: [
69
+ {
70
+ data: {},
71
+ nodes: [
72
+ {
73
+ marks: [],
74
+ object: "text",
75
+ text: "Añadimos descripción a la regla",
76
+ },
77
+ ],
78
+ object: "block",
79
+ type: "paragraph",
80
+ },
81
+ ],
82
+ object: "document",
83
+ },
84
+ object: "value",
85
+ },
86
+ updated_by: 171,
87
+ },
88
+ user_id: 171,
89
+ user_name: null,
90
+ user: {
91
+ email: "some.user@domain.tld",
92
+ full_name: "Some User",
93
+ id: 171,
94
+ user_name: "some.user",
95
+ },
96
+ ts: "2021-09-16T09:30:52.317357Z",
97
+ },
98
+ {
99
+ id: 177692,
100
+ service: "td_dd",
101
+ resource_id: 777,
102
+ resource_type: "rule",
103
+ event: "rule_updated",
104
+ payload: {
105
+ content: {
106
+ changed: {
107
+ data_stew: null,
108
+ principle: "Validez",
109
+ scheduler: "",
110
+ tags: "et",
111
+ },
112
+ removed: {
113
+ data_owner: null,
114
+ proyecto: ["P1"],
115
+ },
116
+ },
117
+ df_name: "quality_template",
118
+ updated_by: 426,
119
+ },
120
+ user_id: 426,
121
+ user_name: null,
122
+ user: {
123
+ email: "some.user@domain.tld",
124
+ full_name: "Some User",
125
+ id: 426,
126
+ user_name: "some.user",
127
+ },
128
+ ts: "2021-10-20T07:56:45.891087Z",
129
+ },
130
+ ];
131
+
132
+ const parsed = [
133
+ {
134
+ ...events[0],
135
+ payload: [{ field: "des01", action: "created" }],
136
+ },
137
+ {
138
+ ...events[1],
139
+ payload: [{ field: "domain_id", action: "changed", value: 140 }],
140
+ },
141
+ {
142
+ ...events[2],
143
+ payload: [
144
+ {
145
+ field: "description",
146
+ action: "changed",
147
+ value: "Añadimos descripción a la regla",
148
+ },
149
+ ],
150
+ },
151
+ {
152
+ ...events[3],
153
+ payload: [
154
+ { field: "df_name", action: "changed", value: "quality_template" },
155
+ { action: "changed", field: "data_stew", value: null },
156
+ { action: "changed", field: "principle", value: "Validez" },
157
+ { action: "changed", field: "scheduler", value: "" },
158
+ { action: "changed", field: "tags", value: "et" },
159
+ ],
160
+ },
161
+ ];
162
+
163
+ it("should return all the events with the new payload", () => {
164
+ const res = getParsedEvents({ events });
165
+ expect(res).toEqual(parsed);
166
+ });
167
+
168
+ it("should return empty array when we have no elements", () => {
169
+ const res = getParsedEvents({ events: [] });
170
+ expect(res).toHaveLength(0);
171
+ expect(res).toEqual(expect.arrayContaining([]));
172
+ });
173
+ });
@@ -8,6 +8,24 @@ const getEvents = ({ events }) => {
8
8
  const transformFieldFormat = (field) =>
9
9
  _.isBoolean(field) ? _.toString(field) : field;
10
10
 
11
+ const findDeep = (obj, key) =>
12
+ _.has(key, obj)
13
+ ? obj[key]
14
+ : _.flatten(
15
+ _.map((v) => (typeof v == "object" ? findDeep(v, key) : []), obj)
16
+ );
17
+
18
+ const transformRulePayloadFormat = (payload, field) => {
19
+ switch (field) {
20
+ case "content":
21
+ return payload.content;
22
+ case "description":
23
+ return _.first(findDeep(payload.description, "text"));
24
+ default:
25
+ return payload[field];
26
+ }
27
+ };
28
+
11
29
  const getParsedEvents = createSelector([getEvents], (events) => {
12
30
  return _.map((d) => {
13
31
  switch (d.event) {
@@ -68,6 +86,43 @@ const getParsedEvents = createSelector([getEvents], (events) => {
68
86
  }))
69
87
  )(d),
70
88
  };
89
+ case "rule_created":
90
+ return {
91
+ ...d,
92
+ payload: [
93
+ {
94
+ field: _.path("payload.name")(d),
95
+ action: "created",
96
+ },
97
+ ],
98
+ };
99
+
100
+ case "rule_updated":
101
+ const content = _.flow(
102
+ _.getOr({}, "payload.content.changed"),
103
+ _.toPairs,
104
+ _.map(([field, value]) => ({
105
+ field,
106
+ value,
107
+ action: "changed",
108
+ }))
109
+ )(d);
110
+ return {
111
+ ...d,
112
+ payload: [
113
+ ..._.flow(
114
+ _.path("payload"),
115
+ _.omit(["updated_by", "content"]),
116
+ _.keys,
117
+ _.map((field) => ({
118
+ field: field,
119
+ action: "changed",
120
+ value: transformRulePayloadFormat(d.payload, field),
121
+ }))
122
+ )(d),
123
+ ...content,
124
+ ],
125
+ };
71
126
 
72
127
  default:
73
128
  return {