@reltio/components 1.4.2071 → 1.4.2072

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 (174) hide show
  1. package/AttributesView/AttributesView.js +1 -1
  2. package/ColumnsSettings/components/ColumnsSettingsPopup/ColumnsSettingsPopup.d.ts +2 -3
  3. package/ColumnsSettings/helpers.d.ts +3 -1
  4. package/ColumnsSettings/types.d.ts +8 -0
  5. package/CommentsContainer/CommentsContainer.js +1 -1
  6. package/ConfigureColumnsPopup/ConfigureColumnsPopup.d.ts +23 -40
  7. package/ConfigureColumnsPopup/ConfigureColumnsPopup.js +6 -26
  8. package/EditModeAttributesList/EditModeAttributesList.js +1 -1
  9. package/EditModeAttributesPager/EditModeAttributesPager.test.js +1 -1
  10. package/EditModeAttributesPager/components/AttributeRenderer/AttributeRenderer.js +1 -1
  11. package/MetadataTypesSelector/MetadataTypesSelector.d.ts +2 -1
  12. package/MetadataTypesSelector/components/SelectMetadataTypesList/SelectMetadataTypesList.d.ts +5 -6
  13. package/MoreAttributesButton/useMoreAttributesItems.d.ts +1 -1
  14. package/ReadOnlyAttributesList/ReadOnlyAttributesList.js +1 -1
  15. package/ReadOnlyAttributesPager/ReadOnlyAttributesPager.js +1 -1
  16. package/ReadOnlyAttributesView/ReadOnlyAttributesView.js +1 -1
  17. package/ScrollableTabs/ScrollableTabs.test.js +69 -19
  18. package/SearchHighlighter/SearchHighlighter.test.js +18 -7
  19. package/SelectAttributesList/SelectAttributesList.d.ts +11 -6
  20. package/SelectAttributesList/SelectAttributesList.js +5 -2
  21. package/SelectorWithOnlyOptionAutoSelect/SelectorWithOnlyOptionAutoSelect.test.js +109 -60
  22. package/SidePanelContentHeader/SidePanelContentHeader.js +2 -2
  23. package/SidePanelContentHeader/SidePanelContentHeader.test.js +104 -0
  24. package/SidePanelEmptyState/SidePanelEmptyState.js +1 -1
  25. package/SidePanelEmptyState/SidePanelEmptyState.test.js +24 -0
  26. package/SimpleAttribute/SimpleAttribute.js +1 -1
  27. package/SimpleAttribute/SimpleAttribute.test.js +155 -80
  28. package/SimpleAttributeEditor/SimpleAttributeEditor.test.js +339 -330
  29. package/SimpleAttributeEditor/useAttributeValuePermissions.js +1 -1
  30. package/SimpleDropDownSelector/SimpleDropDownSelector.test.js +86 -10
  31. package/SimpleDropDownSelector/components/DropDownPlaceholder/DropDownPlaceholder.js +1 -1
  32. package/SimpleDropDownSelector/components/DropDownValue/DropDownValue.js +1 -1
  33. package/SimpleMatchRulesBlock/SimpleMatchRulesBlock.test.js +128 -32
  34. package/SmallIconButton/SmallIconButton.test.js +98 -25
  35. package/TableWithBars/TableWithBars.test.js +98 -60
  36. package/TableWithBars/components/AttributeCellRenderer/AttributeCellRenderer.js +1 -1
  37. package/TableWithBars/components/HeadCellRenderer/HeadCellRenderer.js +1 -1
  38. package/Tags/Tags.d.ts +0 -1
  39. package/Tags/Tags.test.js +8 -7
  40. package/TransitiveMatchBlock/TransitiveMatchBlock.test.js +78 -22
  41. package/TransitiveMatchRule/TransitiveMatchRule.test.js +78 -37
  42. package/TransitiveMatchRulesTooltip/TransitiveMatchRulesTooltip.js +1 -1
  43. package/TransitiveMatchRulesTooltip/TransitiveMatchRulesTooltip.test.js +12 -18
  44. package/UploadFileButton/UploadFileButton.d.ts +2 -2
  45. package/UploadFileButton/UploadFileButton.test.js +199 -0
  46. package/UploadImageDialog/UploadImageDialog.test.js +1 -0
  47. package/UploadImageDialog/components/DividerWithText/DividerWithText.js +1 -1
  48. package/UploadImageDialog/components/ErrorSnackbar/ErrorSnackbar.test.js +80 -22
  49. package/UploadImageDialog/components/ImageByUrlField/ImageByUrlField.js +1 -1
  50. package/UploadImageDialog/components/ImageByUrlField/ImageByUrlField.test.js +162 -49
  51. package/ValueChip/ValueChip.test.js +7 -23
  52. package/VirtualGroupedList/VirtualGroupedList.d.ts +19 -31
  53. package/VirtualGroupedList/VirtualGroupedList.js +11 -36
  54. package/VirtualGroupedList/VirtualGroupedList.test.js +224 -0
  55. package/VirtualGroupedList/helpers.d.ts +7 -2
  56. package/VirtualGroupedList/helpers.js +3 -1
  57. package/VirtualGroupedList/index.d.ts +1 -1
  58. package/VirtualGroupedList/types.d.ts +10 -6
  59. package/VirtualGroupedList/useScrollToFocusItem.d.ts +8 -5
  60. package/WhiteSearchInput/{WhiteSearchInput.spec.js → WhiteSearchInput.test.js} +3 -8
  61. package/cjs/AttributesView/AttributesView.js +2 -2
  62. package/cjs/ColumnsSettings/components/ColumnsSettingsPopup/ColumnsSettingsPopup.d.ts +2 -3
  63. package/cjs/ColumnsSettings/helpers.d.ts +3 -1
  64. package/cjs/ColumnsSettings/types.d.ts +8 -0
  65. package/cjs/ColumnsSettings/types.js +2 -0
  66. package/cjs/CommentsContainer/CommentsContainer.js +1 -1
  67. package/cjs/ConfigureColumnsPopup/ConfigureColumnsPopup.d.ts +23 -40
  68. package/cjs/ConfigureColumnsPopup/ConfigureColumnsPopup.js +6 -26
  69. package/cjs/EditModeAttributesList/EditModeAttributesList.js +2 -2
  70. package/cjs/EditModeAttributesPager/EditModeAttributesPager.test.js +2 -2
  71. package/cjs/EditModeAttributesPager/components/AttributeRenderer/AttributeRenderer.js +2 -2
  72. package/cjs/MetadataTypesSelector/MetadataTypesSelector.d.ts +2 -1
  73. package/cjs/MetadataTypesSelector/components/SelectMetadataTypesList/SelectMetadataTypesList.d.ts +5 -6
  74. package/cjs/MoreAttributesButton/useMoreAttributesItems.d.ts +1 -1
  75. package/cjs/ReadOnlyAttributesList/ReadOnlyAttributesList.js +2 -2
  76. package/cjs/ReadOnlyAttributesPager/ReadOnlyAttributesPager.js +2 -2
  77. package/cjs/ReadOnlyAttributesView/ReadOnlyAttributesView.js +2 -2
  78. package/cjs/ScrollableTabs/ScrollableTabs.test.js +69 -19
  79. package/cjs/SearchHighlighter/SearchHighlighter.test.js +18 -7
  80. package/cjs/SelectAttributesList/SelectAttributesList.d.ts +11 -6
  81. package/cjs/SelectAttributesList/SelectAttributesList.js +5 -2
  82. package/cjs/SelectorWithOnlyOptionAutoSelect/SelectorWithOnlyOptionAutoSelect.test.js +109 -60
  83. package/cjs/SidePanelContentHeader/SidePanelContentHeader.js +2 -2
  84. package/cjs/SidePanelContentHeader/SidePanelContentHeader.test.js +109 -0
  85. package/cjs/SidePanelEmptyState/SidePanelEmptyState.js +1 -1
  86. package/cjs/SidePanelEmptyState/SidePanelEmptyState.test.js +29 -0
  87. package/cjs/SimpleAttribute/SimpleAttribute.js +1 -1
  88. package/cjs/SimpleAttribute/SimpleAttribute.test.js +155 -80
  89. package/cjs/SimpleAttributeEditor/SimpleAttributeEditor.test.js +338 -352
  90. package/cjs/SimpleAttributeEditor/useAttributeValuePermissions.js +2 -2
  91. package/cjs/SimpleDropDownSelector/SimpleDropDownSelector.test.js +86 -10
  92. package/cjs/SimpleDropDownSelector/components/DropDownPlaceholder/DropDownPlaceholder.js +1 -1
  93. package/cjs/SimpleDropDownSelector/components/DropDownValue/DropDownValue.js +1 -1
  94. package/cjs/SimpleMatchRulesBlock/SimpleMatchRulesBlock.test.js +127 -31
  95. package/cjs/SmallIconButton/SmallIconButton.test.js +98 -25
  96. package/cjs/TableWithBars/TableWithBars.test.js +98 -60
  97. package/cjs/TableWithBars/components/AttributeCellRenderer/AttributeCellRenderer.js +1 -1
  98. package/cjs/TableWithBars/components/HeadCellRenderer/HeadCellRenderer.js +1 -1
  99. package/cjs/Tags/Tags.d.ts +0 -1
  100. package/cjs/Tags/Tags.test.js +8 -7
  101. package/cjs/TransitiveMatchBlock/TransitiveMatchBlock.test.js +77 -21
  102. package/cjs/TransitiveMatchRule/TransitiveMatchRule.test.js +78 -37
  103. package/cjs/TransitiveMatchRulesTooltip/TransitiveMatchRulesTooltip.js +1 -1
  104. package/cjs/TransitiveMatchRulesTooltip/TransitiveMatchRulesTooltip.test.js +12 -18
  105. package/cjs/UploadFileButton/UploadFileButton.d.ts +2 -2
  106. package/cjs/UploadFileButton/UploadFileButton.test.js +204 -0
  107. package/cjs/UploadImageDialog/UploadImageDialog.test.js +1 -0
  108. package/cjs/UploadImageDialog/components/DividerWithText/DividerWithText.js +1 -1
  109. package/cjs/UploadImageDialog/components/ErrorSnackbar/ErrorSnackbar.test.js +80 -22
  110. package/cjs/UploadImageDialog/components/ImageByUrlField/ImageByUrlField.js +1 -1
  111. package/cjs/UploadImageDialog/components/ImageByUrlField/ImageByUrlField.test.js +162 -49
  112. package/cjs/ValueChip/ValueChip.test.js +7 -23
  113. package/cjs/VirtualGroupedList/VirtualGroupedList.d.ts +19 -31
  114. package/cjs/VirtualGroupedList/VirtualGroupedList.js +11 -36
  115. package/cjs/VirtualGroupedList/VirtualGroupedList.test.js +252 -0
  116. package/cjs/VirtualGroupedList/helpers.d.ts +7 -2
  117. package/cjs/VirtualGroupedList/helpers.js +3 -1
  118. package/cjs/VirtualGroupedList/index.d.ts +1 -1
  119. package/cjs/VirtualGroupedList/types.d.ts +10 -6
  120. package/cjs/VirtualGroupedList/useScrollToFocusItem.d.ts +8 -5
  121. package/cjs/WhiteSearchInput/{WhiteSearchInput.spec.js → WhiteSearchInput.test.js} +3 -8
  122. package/cjs/features/crosswalks/hooks/useAttributeActions.test.js +24 -25
  123. package/cjs/features/crosswalks/hooks/useCrosswalkActions.test.js +10 -11
  124. package/cjs/features/workflow/hooks/useChangeRequest.test.js +5 -6
  125. package/cjs/hooks/useCommentsEntitiesMap/useCommentsEntitiesMap.test.js +8 -9
  126. package/cjs/hooks/useKeyboardNavigation/useKeyboardNavigation.d.ts +9 -13
  127. package/features/crosswalks/hooks/useAttributeActions.test.js +1 -2
  128. package/features/crosswalks/hooks/useCrosswalkActions.test.js +1 -2
  129. package/features/workflow/hooks/useChangeRequest.test.js +1 -2
  130. package/hooks/useCommentsEntitiesMap/useCommentsEntitiesMap.test.js +1 -2
  131. package/hooks/useKeyboardNavigation/useKeyboardNavigation.d.ts +9 -13
  132. package/package.json +1 -1
  133. package/SidePanelContentHeader/SidePanelContentHeader.spec.js +0 -49
  134. package/SidePanelEmptyState/SidePanelEmptyState.spec.js +0 -24
  135. package/SimpleAttributeEditor/SimpleAttributeEditorWithoutPermissions.test.js +0 -103
  136. package/SimpleDropDownSelector/components/DropDownPlaceholder/DropDownPlaceholder.test.js +0 -13
  137. package/TableWithBars/components/AttributeCellRenderer/AttributeCellRenderer.test.js +0 -21
  138. package/TableWithBars/components/HeadCellRenderer/HeadCellRenderer.test.js +0 -20
  139. package/UploadFileButton/UploadFileButton.spec.js +0 -219
  140. package/UploadImageDialog/components/DividerWithText/DividerWithText.test.js +0 -9
  141. package/VirtualGroupedList/VirtualGroupedList.spec.js +0 -282
  142. package/cjs/SidePanelContentHeader/SidePanelContentHeader.spec.js +0 -54
  143. package/cjs/SidePanelEmptyState/SidePanelEmptyState.spec.d.ts +0 -1
  144. package/cjs/SidePanelEmptyState/SidePanelEmptyState.spec.js +0 -29
  145. package/cjs/SimpleAttributeEditor/SimpleAttributeEditorWithoutPermissions.test.d.ts +0 -1
  146. package/cjs/SimpleAttributeEditor/SimpleAttributeEditorWithoutPermissions.test.js +0 -108
  147. package/cjs/SimpleDropDownSelector/components/DropDownPlaceholder/DropDownPlaceholder.test.d.ts +0 -1
  148. package/cjs/SimpleDropDownSelector/components/DropDownPlaceholder/DropDownPlaceholder.test.js +0 -18
  149. package/cjs/TableWithBars/components/AttributeCellRenderer/AttributeCellRenderer.test.d.ts +0 -1
  150. package/cjs/TableWithBars/components/AttributeCellRenderer/AttributeCellRenderer.test.js +0 -26
  151. package/cjs/TableWithBars/components/HeadCellRenderer/HeadCellRenderer.test.d.ts +0 -1
  152. package/cjs/TableWithBars/components/HeadCellRenderer/HeadCellRenderer.test.js +0 -25
  153. package/cjs/UploadFileButton/UploadFileButton.spec.d.ts +0 -1
  154. package/cjs/UploadFileButton/UploadFileButton.spec.js +0 -224
  155. package/cjs/UploadImageDialog/components/DividerWithText/DividerWithText.test.d.ts +0 -1
  156. package/cjs/UploadImageDialog/components/DividerWithText/DividerWithText.test.js +0 -14
  157. package/cjs/VirtualGroupedList/VirtualGroupedList.spec.d.ts +0 -1
  158. package/cjs/VirtualGroupedList/VirtualGroupedList.spec.js +0 -287
  159. package/cjs/WhiteSearchInput/WhiteSearchInput.spec.d.ts +0 -1
  160. /package/{SidePanelContentHeader/SidePanelContentHeader.spec.d.ts → ColumnsSettings/types.js} +0 -0
  161. /package/{SidePanelEmptyState/SidePanelEmptyState.spec.d.ts → SidePanelContentHeader/SidePanelContentHeader.test.d.ts} +0 -0
  162. /package/{SimpleAttributeEditor/SimpleAttributeEditorWithoutPermissions.test.d.ts → SidePanelEmptyState/SidePanelEmptyState.test.d.ts} +0 -0
  163. /package/{SimpleDropDownSelector/components/DropDownPlaceholder/DropDownPlaceholder.test.d.ts → UploadFileButton/UploadFileButton.test.d.ts} +0 -0
  164. /package/{TableWithBars/components/AttributeCellRenderer/AttributeCellRenderer.test.d.ts → VirtualGroupedList/VirtualGroupedList.test.d.ts} +0 -0
  165. /package/{TableWithBars/components/HeadCellRenderer/HeadCellRenderer.test.d.ts → WhiteSearchInput/WhiteSearchInput.test.d.ts} +0 -0
  166. /package/{UploadFileButton/UploadFileButton.spec.d.ts → cjs/SidePanelContentHeader/SidePanelContentHeader.test.d.ts} +0 -0
  167. /package/{UploadImageDialog/components/DividerWithText/DividerWithText.test.d.ts → cjs/SidePanelEmptyState/SidePanelEmptyState.test.d.ts} +0 -0
  168. /package/{VirtualGroupedList/VirtualGroupedList.spec.d.ts → cjs/UploadFileButton/UploadFileButton.test.d.ts} +0 -0
  169. /package/{WhiteSearchInput/WhiteSearchInput.spec.d.ts → cjs/VirtualGroupedList/VirtualGroupedList.test.d.ts} +0 -0
  170. /package/cjs/{SidePanelContentHeader/SidePanelContentHeader.spec.d.ts → WhiteSearchInput/WhiteSearchInput.test.d.ts} +0 -0
  171. /package/cjs/contexts/{AllwaysVisibleAttributesContext → AlwaysVisibleAttributesContext}/index.d.ts +0 -0
  172. /package/cjs/contexts/{AllwaysVisibleAttributesContext → AlwaysVisibleAttributesContext}/index.js +0 -0
  173. /package/contexts/{AllwaysVisibleAttributesContext → AlwaysVisibleAttributesContext}/index.d.ts +0 -0
  174. /package/contexts/{AllwaysVisibleAttributesContext → AlwaysVisibleAttributesContext}/index.js +0 -0
@@ -10,89 +10,162 @@ var __assign = (this && this.__assign) || function () {
10
10
  };
11
11
  return __assign.apply(this, arguments);
12
12
  };
13
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
14
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
15
+ return new (P || (P = Promise))(function (resolve, reject) {
16
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
17
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
18
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
19
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
20
+ });
21
+ };
22
+ var __generator = (this && this.__generator) || function (thisArg, body) {
23
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
24
+ return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
25
+ function verb(n) { return function (v) { return step([n, v]); }; }
26
+ function step(op) {
27
+ if (f) throw new TypeError("Generator is already executing.");
28
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
29
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
30
+ if (y = 0, t) op = [op[0] & 2, t.value];
31
+ switch (op[0]) {
32
+ case 0: case 1: t = op; break;
33
+ case 4: _.label++; return { value: op[1], done: false };
34
+ case 5: _.label++; y = op[1]; op = [0]; continue;
35
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
36
+ default:
37
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
38
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
39
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
40
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
41
+ if (t[2]) _.ops.pop();
42
+ _.trys.pop(); continue;
43
+ }
44
+ op = body.call(thisArg, _);
45
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
46
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
+ }
48
+ };
13
49
  var __importDefault = (this && this.__importDefault) || function (mod) {
14
50
  return (mod && mod.__esModule) ? mod : { "default": mod };
15
51
  };
16
52
  Object.defineProperty(exports, "__esModule", { value: true });
17
53
  var react_1 = __importDefault(require("react"));
18
- var enzyme_1 = require("enzyme");
19
- var ramda_1 = require("ramda");
20
- var mdm_sdk_1 = require("@reltio/mdm-sdk");
21
- var DataTypeValue_1 = require("../DataTypeValue");
22
- var SimpleAttribute_1 = require("./SimpleAttribute");
54
+ var react_2 = require("@testing-library/react");
55
+ var user_event_1 = __importDefault(require("@testing-library/user-event"));
23
56
  var classnames_1 = require("../constants/classnames");
24
- var CommentsContainer_1 = require("../CommentsContainer");
25
57
  var HistoryAppearanceContext_1 = require("../contexts/HistoryAppearanceContext");
26
- var PivotingTooltip_1 = require("../PivotingTooltip");
27
58
  var HighlightedValuesContext_1 = require("../contexts/HighlightedValuesContext");
59
+ var PivotingAttributeContext_1 = require("../contexts/PivotingAttributeContext");
60
+ var SimpleAttribute_1 = require("./SimpleAttribute");
61
+ var CollaborationContext_1 = require("../contexts/CollaborationContext");
28
62
  describe('SimpleAttribute tests', function () {
29
- var historyDiff = {
30
- appearance: { testAttributeUri: 'INSERT_ATTRIBUTE' },
31
- attributes: {},
32
- roles: [],
33
- tags: []
63
+ var defaultProps = {
64
+ attributeType: { type: 'String', name: 'Name', uri: 'URI' },
65
+ attributeValue: { value: '123', uri: 'entities/16U21B8f/attributes/Name/2sAfjGOIh' }
66
+ };
67
+ var defaultCollaborationContextValue = {
68
+ commentsMap: {},
69
+ currentComment: null
70
+ };
71
+ var defaultContextValues = {
72
+ collaboration: defaultCollaborationContextValue,
73
+ pivotingAttribute: undefined,
74
+ highlightedValues: {
75
+ highlightedValuesUris: [],
76
+ highlightedClassName: 'test'
77
+ },
78
+ historyDiff: {}
79
+ };
80
+ var setUp = function (props, contextValues) {
81
+ if (props === void 0) { props = {}; }
82
+ if (contextValues === void 0) { contextValues = {}; }
83
+ var user = user_event_1.default.setup();
84
+ var _a = __assign(__assign({}, defaultContextValues), contextValues), pivotingAttribute = _a.pivotingAttribute, highlightedValues = _a.highlightedValues, historyDiff = _a.historyDiff, collaboration = _a.collaboration;
85
+ var Providers = function (_a) {
86
+ var children = _a.children;
87
+ return (react_1.default.createElement(CollaborationContext_1.CollaborationContext.Provider, { value: collaboration },
88
+ react_1.default.createElement(PivotingAttributeContext_1.PivotingAttributeContext.Provider, { value: pivotingAttribute },
89
+ react_1.default.createElement(HighlightedValuesContext_1.HighlightedValuesContext.Provider, { value: highlightedValues },
90
+ react_1.default.createElement(HistoryAppearanceContext_1.HistoryDiffContext.Provider, { value: historyDiff }, children)))));
91
+ };
92
+ return __assign({ user: user }, (0, react_2.render)(react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, __assign({}, defaultProps, props)), { wrapper: Providers }));
34
93
  };
35
94
  it('should render DataTypeValue', function () {
36
- var attrType = { type: 'String', name: 'Name', uri: 'URI' };
95
+ var attributeType = { type: 'String', name: 'Name', uri: 'URI' };
37
96
  var attributeValue = { value: '123', uri: 'entities/16U21B8f/attributes/Name/2sAfjGOIh' };
38
- var component = (0, enzyme_1.shallow)(react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attrType, attributeValue: attributeValue }));
39
- var dataTypeValue = component.find(DataTypeValue_1.DataTypeValue);
40
- expect(dataTypeValue.length).toBe(1);
41
- expect(dataTypeValue.prop('value')).toEqual(attributeValue.value);
42
- expect(dataTypeValue.prop('dataTypeDefinition')).toEqual({ type: 'String', uri: 'URI', name: 'Name' });
97
+ setUp({ attributeType: attributeType, attributeValue: attributeValue });
98
+ expect(react_2.screen.getByTestId('reltio-attribute-value')).toHaveTextContent('123');
43
99
  });
44
- it('should provide correct props DataTypeValue if attribute is lookup', function () {
45
- var attrType = { type: 'String', dependentLookupCode: 'Code', name: 'Name', uri: 'URI', access: ['READ'] };
100
+ it('should render lookup correctly', function () {
101
+ var attributeType = { type: 'String', dependentLookupCode: 'Code', name: 'Name', uri: 'URI', access: ['READ'] };
46
102
  var attributeValue = {
47
- value: '123',
48
- lookupCode: '12',
49
- rawLookupCode: '34',
103
+ value: 'India',
104
+ lookupCode: 'IN',
105
+ rawLookupCode: 'IND',
50
106
  uri: 'entities/16U21B8f/attributes/Name/2sAfjGOIh'
51
107
  };
52
- var component = (0, enzyme_1.shallow)(react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attrType, attributeValue: attributeValue }));
53
- var dataTypeValue = component.find(DataTypeValue_1.DataTypeValue);
54
- expect(dataTypeValue.length).toBe(1);
55
- expect(dataTypeValue.prop('value')).toEqual((0, ramda_1.pick)(['value', 'lookupCode'], attributeValue));
56
- expect(dataTypeValue.prop('dataTypeDefinition')).toEqual(__assign({ access: ['READ'], type: 'String', dependentLookupCode: 'Code', uri: 'URI', name: 'Name' }, { type: mdm_sdk_1.DataTypes.TYPE_DEPENDENT_LOOKUP }));
57
- });
58
- it('should render CommentsContainer inside COMMENTS_CONTAINER_VISIBILITY_AREA with correct uri', function () {
59
- var attrType = { type: 'String', name: 'Name', uri: 'uri1' };
60
- var attributeValue = { value: '123', uri: 'entities/uri1/attributes/ABCD' };
61
- var component = (0, enzyme_1.shallow)(react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attrType, attributeValue: attributeValue }));
62
- var commentsContainer = component.find(".".concat(classnames_1.COMMENTS_CONTAINER_VISIBILITY_AREA)).find(CommentsContainer_1.CommentsContainer);
63
- expect(commentsContainer.length).toBe(1);
64
- expect(commentsContainer.prop('uri')).toBe(attributeValue.uri);
65
- expect(commentsContainer.prop('relatedObjectUris')).toEqual(['entities/uri1']);
66
- expect(commentsContainer.prop('objectType')).toBe(mdm_sdk_1.CollaborationObjectTypes.ENTITY_ATTRIBUTE);
108
+ setUp({ attributeType: attributeType, attributeValue: attributeValue });
109
+ expect(react_2.screen.getByTestId('reltio-attribute-value')).toHaveTextContent('India (IN)');
67
110
  });
68
111
  it('should not render CommentsContainer if "inlined" prop is true', function () {
69
- var attrType = { type: 'String', name: 'Name', uri: 'uri1' };
112
+ var attributeType = { type: 'String', name: 'Name', uri: 'uri1' };
70
113
  var attributeValue = { value: '123', uri: 'uri1' };
71
- var component = (0, enzyme_1.shallow)(react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attrType, attributeValue: attributeValue, inlined: true }));
72
- expect(component.find(".".concat(classnames_1.COMMENTS_CONTAINER_VISIBILITY_AREA)).find(CommentsContainer_1.CommentsContainer).length).toBe(0);
73
- expect(component.find(CommentsContainer_1.CommentsContainer).length).toBe(0);
114
+ setUp({ attributeType: attributeType, attributeValue: attributeValue, inlined: true });
115
+ expect(react_2.screen.queryByTestId('comments-container-visibility-area')).not.toBeInTheDocument();
74
116
  });
75
117
  it('should provide history className', function () {
76
118
  var attrType = { type: 'String', name: 'Name', uri: 'testAttributeUri' };
77
119
  var attributeValue = { value: '123', uri: 'testAttributeUri' };
78
- var component = (0, enzyme_1.mount)(react_1.default.createElement(HistoryAppearanceContext_1.HistoryDiffContext.Provider, { value: historyDiff },
79
- react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attrType, attributeValue: attributeValue })));
80
- expect(component.find('.insertAttribute')).toHaveLength(1);
81
- });
82
- it('should render PivotingTooltip with history', function () {
83
- var attrType = { type: 'String', name: 'Name', uri: 'testAttributeUri' };
84
- var attributeValue = { value: '123', uri: 'entities/16U21B8f/attributes/Name/2sAfjGOIh' };
85
- var component = (0, enzyme_1.mount)(react_1.default.createElement(HistoryAppearanceContext_1.HistoryDiffContext.Provider, { value: historyDiff },
86
- react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attrType, attributeValue: attributeValue })));
87
- expect(component.find(PivotingTooltip_1.PivotingTooltip)).toHaveLength(1);
120
+ var historyDiff = {
121
+ appearance: { testAttributeUri: 'INSERT_ATTRIBUTE' },
122
+ attributes: {},
123
+ roles: [],
124
+ tags: []
125
+ };
126
+ setUp({ attributeType: attrType, attributeValue: attributeValue }, { historyDiff: historyDiff });
127
+ expect(react_2.screen.getByTestId('reltio-attribute-value')).toHaveClass('insertAttribute');
88
128
  });
129
+ it('should render PivotingTooltip with history', function () { return __awaiter(void 0, void 0, void 0, function () {
130
+ var attrType, attributeValue, historyDiff, pivotingAttribute;
131
+ return __generator(this, function (_a) {
132
+ attrType = { type: 'String', name: 'Name', uri: 'testAttributeUri' };
133
+ attributeValue = { value: '123', uri: 'entities/16U21B8f/attributes/Name/2sAfjGOIh' };
134
+ historyDiff = {
135
+ appearance: { testAttributeUri: 'INSERT_ATTRIBUTE' },
136
+ attributes: {},
137
+ roles: [],
138
+ tags: []
139
+ };
140
+ pivotingAttribute = [{ uri: 'testAttributeUri' }];
141
+ setUp({ attributeType: attrType, attributeValue: attributeValue }, { historyDiff: historyDiff, pivotingAttribute: pivotingAttribute });
142
+ expect(react_2.screen.getByTestId('SvgPivotingIcon')).toBeInTheDocument();
143
+ expect(react_2.screen.getByRole('link')).toHaveTextContent('123');
144
+ return [2 /*return*/];
145
+ });
146
+ }); });
89
147
  it('should render PivotingTooltip without history', function () {
90
- var attrType = { type: 'String', name: 'Name', uri: 'testAttributeUri' };
148
+ var attributeType = { type: 'String', name: 'Name', uri: 'testAttributeUri' };
91
149
  var attributeValue = { value: '123', uri: 'entities/16U21B8f/attributes/Name/2sAfjGOIh' };
92
- var component = (0, enzyme_1.mount)(react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attrType, attributeValue: attributeValue }));
93
- expect(component.find(PivotingTooltip_1.PivotingTooltip)).toHaveLength(1);
150
+ var pivotingAttribute = [{ uri: 'testAttributeUri' }];
151
+ setUp({ attributeType: attributeType, attributeValue: attributeValue }, { historyDiff: {}, pivotingAttribute: pivotingAttribute });
152
+ expect(react_2.screen.getByTestId('SvgPivotingIcon')).toBeInTheDocument();
153
+ expect(react_2.screen.getByRole('link')).toHaveTextContent('123');
94
154
  });
95
- it('should set correct props for CommentsContainer component if we have entity attribute', function () {
155
+ it('should render comments correctly for entity type', function () {
156
+ var attributeType = { type: 'String', name: 'Name', uri: 'uri1' };
157
+ var attributeValue = { value: '123', uri: 'entities/uri1/attributes/ABCD' };
158
+ var commentsMap = {
159
+ 'entities/uri1/attributes/ABCD': [{ commentId: 'commentId', status: 'open', replies: 0 }]
160
+ };
161
+ setUp({ attributeType: attributeType, attributeValue: attributeValue }, { collaboration: __assign(__assign({}, defaultCollaborationContextValue), { commentsMap: commentsMap }) });
162
+ expect(react_2.screen.getByTestId('comments-container-visibility-area')).toHaveClass(classnames_1.COMMENTS_CONTAINER_VISIBILITY_AREA);
163
+ expect(react_2.screen.getByText('123')).toBeInTheDocument();
164
+ expect(react_2.screen.getByTestId('comments-container')).toBeInTheDocument();
165
+ expect(react_2.screen.getByTestId('SvgAddComment')).toBeInTheDocument();
166
+ expect(react_2.screen.getByTestId('reltio-comment-button')).toBeInTheDocument();
167
+ });
168
+ it('should render comments correctly for relation type', function () {
96
169
  var attributeType = {
97
170
  uri: 'configuration/relationTypes/HCPtoHCP/attributes/AffiliationStatus',
98
171
  type: 'String',
@@ -105,49 +178,51 @@ describe('SimpleAttribute tests', function () {
105
178
  value: 'Active',
106
179
  ov: true
107
180
  };
108
- var component = (0, enzyme_1.shallow)(react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attributeType, attributeValue: attributeValue }));
109
- var commentsContainer = component.find(CommentsContainer_1.CommentsContainer);
110
- expect(commentsContainer.prop('relatedObjectUris')).toEqual(['relations/12rMNliU']);
111
- expect(commentsContainer.prop('objectType')).toBe(mdm_sdk_1.CollaborationObjectTypes.RELATION_ATTRIBUTE);
112
- component.setProps({
113
- attributeValue: __assign(__assign({}, attributeValue), { uri: 'entities/sIeHttl/attributes/Reference/r123/Simple/u123' })
114
- });
115
- commentsContainer = component.find(CommentsContainer_1.CommentsContainer);
116
- expect(commentsContainer.prop('relatedObjectUris')).toEqual(['entities/sIeHttl']);
117
- expect(commentsContainer.prop('objectType')).toBe(mdm_sdk_1.CollaborationObjectTypes.ENTITY_ATTRIBUTE);
181
+ var commentsMap = {
182
+ 'relations/12rMNliU/attributes/AffiliationSubType/3e6txxgYJ': [
183
+ { commentId: 'commentId', status: 'open', replies: 0 }
184
+ ]
185
+ };
186
+ setUp({ attributeType: attributeType, attributeValue: attributeValue }, { collaboration: __assign(__assign({}, defaultCollaborationContextValue), { commentsMap: commentsMap }) });
187
+ expect(react_2.screen.getByTestId('comments-container-visibility-area')).toHaveClass(classnames_1.COMMENTS_CONTAINER_VISIBILITY_AREA);
188
+ expect(react_2.screen.getByTestId('comments-container')).toBeInTheDocument();
189
+ expect(react_2.screen.getByTestId('SvgAddComment')).toBeInTheDocument();
190
+ expect(react_2.screen.getByTestId('reltio-comment-button')).toBeInTheDocument();
118
191
  });
119
192
  it('should render highlighted label', function () {
120
193
  var attributeType = { type: 'String', name: 'Name', uri: 'testAttributeUri', label: 'Affiliation Status' };
121
194
  var attributeValue = { value: '123', uri: 'entities/16U21B8f/attributes/Name/2sAfjGOIh' };
122
- var highlightedValuesContextValues = {
195
+ var highlightedValues = {
123
196
  highlightedValuesUris: [attributeValue.uri],
124
197
  highlightedClassName: 'hlClassName'
125
198
  };
126
- var component = (0, enzyme_1.mount)(react_1.default.createElement(HighlightedValuesContext_1.HighlightedValuesContext.Provider, { value: highlightedValuesContextValues },
127
- react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attributeType, attributeValue: attributeValue })));
128
- expect(component.find('div.root').hasClass('hlClassName')).toBeTruthy();
199
+ setUp({ attributeType: attributeType, attributeValue: attributeValue }, { highlightedValues: highlightedValues });
200
+ var container = react_2.screen.getByTestId('comments-container-visibility-area');
201
+ expect(container).toHaveClass('hlClassName');
202
+ expect(container).toHaveTextContent('123');
129
203
  });
130
204
  it('should render label without highlights', function () {
131
205
  var attributeType = { type: 'String', name: 'Name', uri: 'testAttributeUri', label: 'Affiliation Status' };
132
206
  var attributeValue = { value: '123', uri: 'entities/16U21B8f/attributes/Name/2sAfjGOIh' };
133
- var highlightedValuesContextValues = {
207
+ var highlightedValues = {
134
208
  highlightedValuesUris: ['testAttributeUr'],
135
209
  highlightedClassName: 'hlClassName'
136
210
  };
137
- var component = (0, enzyme_1.mount)(react_1.default.createElement(HighlightedValuesContext_1.HighlightedValuesContext.Provider, { value: highlightedValuesContextValues },
138
- react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attributeType, attributeValue: attributeValue })));
139
- expect(component.hasClass('hlClassName')).toBeFalsy();
211
+ setUp({ attributeType: attributeType, attributeValue: attributeValue }, { highlightedValues: highlightedValues });
212
+ var container = react_2.screen.getByTestId('comments-container-visibility-area');
213
+ expect(container).not.toHaveClass('hlClassName');
214
+ expect(container).toHaveTextContent('123');
140
215
  });
141
216
  it('should add ovFalse style if inlined is true', function () {
142
- var attrType = { type: 'String', name: 'Name', uri: 'uri1' };
217
+ var attributeType = { type: 'String', name: 'Name', uri: 'uri1' };
143
218
  var attributeValue = { value: '123', uri: 'uri1', ov: false };
144
- var component = (0, enzyme_1.shallow)(react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attrType, attributeValue: attributeValue, inlined: true }));
145
- expect(component.find('span').hasClass('ovFalse')).toBe(true);
219
+ setUp({ attributeType: attributeType, attributeValue: attributeValue, inlined: true });
220
+ expect(react_2.screen.getByTestId('reltio-attribute-value')).toHaveClass('ovFalse');
146
221
  });
147
222
  it('should add ovFalse style if inlined is false', function () {
148
- var attrType = { type: 'String', name: 'Name', uri: 'uri1' };
223
+ var attributeType = { type: 'String', name: 'Name', uri: 'uri1' };
149
224
  var attributeValue = { value: '123', uri: 'uri1', ov: false };
150
- var component = (0, enzyme_1.shallow)(react_1.default.createElement(SimpleAttribute_1.SimpleAttribute, { attributeType: attrType, attributeValue: attributeValue }));
151
- expect(component.find('span').hasClass('ovFalse')).toBe(true);
225
+ setUp({ attributeType: attributeType, attributeValue: attributeValue, inlined: false });
226
+ expect(react_2.screen.getByTestId('reltio-attribute-value')).toHaveClass('ovFalse');
152
227
  });
153
228
  });