@scality/data-browser-library 1.0.0-preview.13 → 1.0.0-preview.15

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 (206) hide show
  1. package/dist/components/DataBrowserUI.d.ts +15 -8
  2. package/dist/components/DataBrowserUI.js +79 -55
  3. package/dist/components/Editor.d.ts +1 -1
  4. package/dist/components/Editor.js +3 -3
  5. package/dist/components/__tests__/BucketCreate.test.js +102 -102
  6. package/dist/components/__tests__/BucketDetails.test.js +121 -122
  7. package/dist/components/__tests__/BucketLifecycleFormPage.test.js +177 -177
  8. package/dist/components/__tests__/BucketLifecycleList.test.js +85 -85
  9. package/dist/components/__tests__/BucketList.test.js +175 -176
  10. package/dist/components/__tests__/BucketNotificationCreatePage.test.js +84 -84
  11. package/dist/components/__tests__/BucketOverview.test.js +256 -200
  12. package/dist/components/__tests__/BucketPolicyPage.test.js +62 -62
  13. package/dist/components/__tests__/BucketReplicationFormPage.test.js +542 -542
  14. package/dist/components/__tests__/BucketReplicationList.test.js +106 -106
  15. package/dist/components/__tests__/CreateFolderButton.test.js +56 -56
  16. package/dist/components/__tests__/DeleteBucketButton.test.js +62 -62
  17. package/dist/components/__tests__/DeleteBucketConfigRuleButton.test.js +47 -47
  18. package/dist/components/__tests__/DeleteObjectButton.test.js +63 -63
  19. package/dist/components/__tests__/EmptyBucketButton.test.js +56 -56
  20. package/dist/components/__tests__/MetadataSearch.test.js +65 -65
  21. package/dist/components/__tests__/ObjectList.test.js +251 -250
  22. package/dist/components/__tests__/UploadButton.test.js +45 -45
  23. package/dist/components/buckets/BucketCreate.d.ts +2 -2
  24. package/dist/components/buckets/BucketCreate.js +41 -41
  25. package/dist/components/buckets/BucketDetails.d.ts +2 -2
  26. package/dist/components/buckets/BucketDetails.js +48 -36
  27. package/dist/components/buckets/BucketLifecycleFormPage.js +161 -160
  28. package/dist/components/buckets/BucketLifecycleList.d.ts +2 -2
  29. package/dist/components/buckets/BucketLifecycleList.js +46 -46
  30. package/dist/components/buckets/BucketList.d.ts +2 -2
  31. package/dist/components/buckets/BucketList.js +28 -27
  32. package/dist/components/buckets/BucketLocation.js +3 -3
  33. package/dist/components/buckets/BucketOverview.d.ts +1 -1
  34. package/dist/components/buckets/BucketOverview.js +62 -62
  35. package/dist/components/buckets/BucketPage.js +19 -11
  36. package/dist/components/buckets/BucketPolicyButton.js +2 -2
  37. package/dist/components/buckets/BucketPolicyPage.js +27 -25
  38. package/dist/components/buckets/BucketReplicationFormPage.js +133 -132
  39. package/dist/components/buckets/BucketReplicationList.d.ts +2 -2
  40. package/dist/components/buckets/BucketReplicationList.js +41 -41
  41. package/dist/components/buckets/BucketVersioning.js +11 -11
  42. package/dist/components/buckets/DeleteBucketButton.js +5 -5
  43. package/dist/components/buckets/DeleteBucketConfigRuleButton.d.ts +2 -2
  44. package/dist/components/buckets/DeleteBucketConfigRuleButton.js +1 -1
  45. package/dist/components/buckets/EmptyBucketButton.js +19 -19
  46. package/dist/components/buckets/EmptyBucketSummary.d.ts +1 -1
  47. package/dist/components/buckets/EmptyBucketSummary.js +1 -1
  48. package/dist/components/buckets/EmptyBucketSummaryList.js +22 -22
  49. package/dist/components/buckets/__tests__/BucketVersioning.test.js +45 -45
  50. package/dist/components/buckets/notifications/BucketNotificationCreatePage.js +34 -33
  51. package/dist/components/buckets/notifications/EventsSection.js +144 -28
  52. package/dist/components/buckets/notifications/__tests__/events.test.d.ts +1 -0
  53. package/dist/components/buckets/notifications/__tests__/events.test.js +56 -0
  54. package/dist/components/buckets/notifications/events.d.ts +71 -7
  55. package/dist/components/buckets/notifications/events.js +98 -16
  56. package/dist/components/index.d.ts +23 -22
  57. package/dist/components/index.js +3 -2
  58. package/dist/components/layouts/ArrowNavigation.d.ts +1 -2
  59. package/dist/components/layouts/ArrowNavigation.js +3 -3
  60. package/dist/components/layouts/BrowserPageLayout.d.ts +2 -3
  61. package/dist/components/layouts/BrowserPageLayout.js +1 -1
  62. package/dist/components/objects/CreateFolderButton.d.ts +2 -2
  63. package/dist/components/objects/CreateFolderButton.js +9 -9
  64. package/dist/components/objects/DeleteObjectButton.d.ts +1 -1
  65. package/dist/components/objects/DeleteObjectButton.js +20 -20
  66. package/dist/components/objects/ObjectDetails/ObjectMetadata.d.ts +1 -1
  67. package/dist/components/objects/ObjectDetails/ObjectMetadata.js +56 -56
  68. package/dist/components/objects/ObjectDetails/ObjectSummary.d.ts +1 -1
  69. package/dist/components/objects/ObjectDetails/ObjectSummary.js +39 -39
  70. package/dist/components/objects/ObjectDetails/ObjectTags.d.ts +1 -1
  71. package/dist/components/objects/ObjectDetails/ObjectTags.js +25 -25
  72. package/dist/components/objects/ObjectDetails/__tests__/ObjectDetails.test.js +119 -119
  73. package/dist/components/objects/ObjectDetails/__tests__/ObjectSummary.test.js +211 -211
  74. package/dist/components/objects/ObjectDetails/index.d.ts +1 -1
  75. package/dist/components/objects/ObjectDetails/index.js +30 -30
  76. package/dist/components/objects/ObjectList.d.ts +5 -5
  77. package/dist/components/objects/ObjectList.js +112 -111
  78. package/dist/components/objects/ObjectLock/EditRetentionButton.js +3 -3
  79. package/dist/components/objects/ObjectLock/ObjectLockRetentionSettings.js +14 -14
  80. package/dist/components/objects/ObjectLock/ObjectLockSettings.d.ts +1 -1
  81. package/dist/components/objects/ObjectLock/ObjectLockSettings.js +29 -28
  82. package/dist/components/objects/ObjectLock/ObjectLockSettingsUtils.d.ts +1 -1
  83. package/dist/components/objects/ObjectLock/ObjectLockSettingsUtils.js +6 -6
  84. package/dist/components/objects/ObjectLock/__tests__/EditRetentionButton.test.js +50 -50
  85. package/dist/components/objects/ObjectLock/__tests__/ObjectLockSettings.test.js +77 -77
  86. package/dist/components/objects/ObjectPage.js +5 -4
  87. package/dist/components/objects/UploadButton.d.ts +3 -3
  88. package/dist/components/objects/UploadButton.js +5 -5
  89. package/dist/components/providers/DataBrowserProvider.d.ts +15 -4
  90. package/dist/components/providers/DataBrowserProvider.js +33 -11
  91. package/dist/components/search/MetadataSearch.js +26 -25
  92. package/dist/components/search/SearchHints.js +1 -1
  93. package/dist/components/ui/ArrayFieldActions.js +4 -4
  94. package/dist/components/ui/ConfirmDeleteRuleModal.d.ts +1 -1
  95. package/dist/components/ui/ConfirmDeleteRuleModal.js +1 -1
  96. package/dist/components/ui/DeleteObjectModalContent.d.ts +1 -1
  97. package/dist/components/ui/DeleteObjectModalContent.js +12 -12
  98. package/dist/components/ui/FilterFormSection.d.ts +2 -2
  99. package/dist/components/ui/FilterFormSection.js +29 -29
  100. package/dist/components/ui/Search.elements.d.ts +1 -1
  101. package/dist/components/ui/Search.elements.js +7 -7
  102. package/dist/components/ui/Table.elements.js +5 -5
  103. package/dist/config/factory.d.ts +23 -10
  104. package/dist/config/factory.js +22 -7
  105. package/dist/config/types.d.ts +20 -3
  106. package/dist/contexts/DataBrowserUICustomizationContext.d.ts +2 -2
  107. package/dist/hooks/__tests__/useISVBucketDetection.test.js +41 -41
  108. package/dist/hooks/__tests__/useIsBucketEmpty.test.js +25 -25
  109. package/dist/hooks/bucketConfiguration.d.ts +1 -1
  110. package/dist/hooks/bucketConfiguration.js +48 -48
  111. package/dist/hooks/bucketOperations.d.ts +1 -1
  112. package/dist/hooks/bucketOperations.js +6 -6
  113. package/dist/hooks/factories/__tests__/useCreateS3FunctionMutationHook.test.js +78 -78
  114. package/dist/hooks/factories/__tests__/useCreateS3InfiniteQueryHook.test.js +78 -78
  115. package/dist/hooks/factories/__tests__/useCreateS3LoginHook.test.js +42 -42
  116. package/dist/hooks/factories/__tests__/useCreateS3MutationHook.test.js +61 -61
  117. package/dist/hooks/factories/__tests__/useCreateS3QueryHook.test.js +63 -63
  118. package/dist/hooks/factories/index.d.ts +4 -4
  119. package/dist/hooks/factories/useCreateS3InfiniteQueryHook.d.ts +2 -2
  120. package/dist/hooks/factories/useCreateS3InfiniteQueryHook.js +15 -12
  121. package/dist/hooks/factories/useCreateS3LoginHook.d.ts +2 -2
  122. package/dist/hooks/factories/useCreateS3MutationHook.d.ts +3 -3
  123. package/dist/hooks/factories/useCreateS3MutationHook.js +6 -1
  124. package/dist/hooks/factories/useCreateS3QueryHook.d.ts +2 -2
  125. package/dist/hooks/factories/useCreateS3QueryHook.js +8 -5
  126. package/dist/hooks/index.d.ts +14 -13
  127. package/dist/hooks/index.js +2 -1
  128. package/dist/hooks/loginOperations.d.ts +1 -1
  129. package/dist/hooks/loginOperations.js +1 -1
  130. package/dist/hooks/objectOperations.d.ts +2 -2
  131. package/dist/hooks/objectOperations.js +49 -49
  132. package/dist/hooks/presignedOperations.d.ts +2 -2
  133. package/dist/hooks/presignedOperations.js +3 -3
  134. package/dist/hooks/useBatchObjectLegalHold.js +7 -4
  135. package/dist/hooks/useDataBrowserNavigate.d.ts +14 -0
  136. package/dist/hooks/useDataBrowserNavigate.js +24 -0
  137. package/dist/hooks/useDeleteBucketConfigRule.d.ts +2 -2
  138. package/dist/hooks/useDeleteBucketConfigRule.js +4 -4
  139. package/dist/hooks/useEmptyBucket.js +10 -10
  140. package/dist/hooks/useISVBucketDetection.js +3 -3
  141. package/dist/hooks/useIsBucketEmpty.js +4 -4
  142. package/dist/hooks/useLoginMutation.d.ts +1 -1
  143. package/dist/hooks/useLoginMutation.js +1 -1
  144. package/dist/hooks/useS3Client.d.ts +5 -0
  145. package/dist/hooks/useS3Client.js +3 -2
  146. package/dist/hooks/useS3ConfigSwitch.d.ts +11 -0
  147. package/dist/hooks/useS3ConfigSwitch.js +37 -0
  148. package/dist/index.d.ts +6 -6
  149. package/dist/test/msw/handlers/deleteBucket.d.ts +1 -1
  150. package/dist/test/msw/handlers/deleteBucket.js +20 -10
  151. package/dist/test/msw/handlers/getBucketAcl.d.ts +1 -1
  152. package/dist/test/msw/handlers/getBucketAcl.js +29 -17
  153. package/dist/test/msw/handlers/getBucketLocation.d.ts +1 -1
  154. package/dist/test/msw/handlers/getBucketLocation.js +29 -15
  155. package/dist/test/msw/handlers/getBucketPolicy.d.ts +1 -1
  156. package/dist/test/msw/handlers/getBucketPolicy.js +52 -32
  157. package/dist/test/msw/handlers/headObject.d.ts +1 -1
  158. package/dist/test/msw/handlers/headObject.js +31 -13
  159. package/dist/test/msw/handlers/listBuckets.d.ts +1 -1
  160. package/dist/test/msw/handlers/listBuckets.js +5 -3
  161. package/dist/test/msw/handlers/listObjectVersions.d.ts +1 -1
  162. package/dist/test/msw/handlers/listObjectVersions.js +38 -26
  163. package/dist/test/msw/handlers/listObjects.d.ts +1 -1
  164. package/dist/test/msw/handlers/listObjects.js +35 -23
  165. package/dist/test/msw/handlers/objectLegalHold.d.ts +1 -1
  166. package/dist/test/msw/handlers/objectLegalHold.js +31 -16
  167. package/dist/test/msw/handlers/objectRetention.d.ts +1 -1
  168. package/dist/test/msw/handlers/objectRetention.js +31 -17
  169. package/dist/test/msw/handlers/putBucketAcl.d.ts +1 -1
  170. package/dist/test/msw/handlers/putBucketAcl.js +29 -14
  171. package/dist/test/msw/handlers/putObject.d.ts +1 -1
  172. package/dist/test/msw/handlers/putObject.js +27 -12
  173. package/dist/test/msw/handlers.d.ts +3 -3
  174. package/dist/test/msw/handlers.js +72 -49
  175. package/dist/test/msw/index.d.ts +2 -2
  176. package/dist/test/msw/server.d.ts +1 -1
  177. package/dist/test/msw/server.js +1 -1
  178. package/dist/test/msw/utils.js +2 -2
  179. package/dist/test/setup.d.ts +1 -1
  180. package/dist/test/setup.js +19 -19
  181. package/dist/test/testUtils.d.ts +9 -15
  182. package/dist/test/testUtils.js +78 -92
  183. package/dist/test/utils/errorHandling.test.js +119 -119
  184. package/dist/types/index.d.ts +6 -31
  185. package/dist/utils/__tests__/s3ConfigIdentifier.test.d.ts +1 -0
  186. package/dist/utils/__tests__/s3ConfigIdentifier.test.js +429 -0
  187. package/dist/utils/constants.js +8 -8
  188. package/dist/utils/deletion/index.d.ts +2 -2
  189. package/dist/utils/deletion/messages.d.ts +1 -1
  190. package/dist/utils/deletion/messages.js +4 -4
  191. package/dist/utils/errorHandling.d.ts +3 -3
  192. package/dist/utils/errorHandling.js +6 -6
  193. package/dist/utils/hooks.js +8 -8
  194. package/dist/utils/index.d.ts +5 -4
  195. package/dist/utils/index.js +2 -0
  196. package/dist/utils/proxyMiddleware.d.ts +1 -1
  197. package/dist/utils/proxyMiddleware.js +6 -11
  198. package/dist/utils/s3Client.d.ts +2 -2
  199. package/dist/utils/s3Client.js +1 -1
  200. package/dist/utils/s3ConfigIdentifier.d.ts +68 -0
  201. package/dist/utils/s3ConfigIdentifier.js +55 -0
  202. package/dist/utils/s3RuleUtils.d.ts +5 -5
  203. package/dist/utils/s3RuleUtils.js +17 -17
  204. package/dist/utils/useSupportedNotificationEvents.d.ts +6 -0
  205. package/dist/utils/useSupportedNotificationEvents.js +7 -0
  206. package/package.json +2 -2
@@ -1,11 +1,11 @@
1
1
  import * as __WEBPACK_EXTERNAL_MODULE__index_js_95fdb65a__ from "../index.js";
2
2
  import { jsx } from "react/jsx-runtime";
3
3
  import { cleanup, render, screen } from "@testing-library/react";
4
- import { MemoryRouter, Route, Routes } from "react-router-dom";
4
+ import { MemoryRouter, Route, Routes } from "react-router";
5
5
  import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
6
6
  import { DataBrowserUICustomizationProvider } from "../../../../contexts/DataBrowserUICustomizationContext.js";
7
7
  var __webpack_modules__ = {
8
- "../index": function(module) {
8
+ "..": function(module) {
9
9
  module.exports = __WEBPACK_EXTERNAL_MODULE__index_js_95fdb65a__;
10
10
  }
11
11
  };
@@ -19,57 +19,57 @@ function __webpack_require__(moduleId) {
19
19
  __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
20
20
  return module.exports;
21
21
  }
22
- var external_index_js_ = __webpack_require__("../index");
23
- jest.mock("../ObjectSummary", ()=>({
22
+ var external_index_js_ = __webpack_require__("..");
23
+ jest.mock('../ObjectSummary', ()=>({
24
24
  ObjectSummary: ()=>/*#__PURE__*/ jsx("div", {
25
25
  "data-testid": "object-summary",
26
26
  children: "ObjectSummary"
27
27
  })
28
28
  }));
29
- jest.mock("../ObjectMetadata", ()=>({
29
+ jest.mock('../ObjectMetadata', ()=>({
30
30
  ObjectMetadata: ()=>/*#__PURE__*/ jsx("div", {
31
31
  "data-testid": "object-metadata",
32
32
  children: "ObjectMetadata"
33
33
  })
34
34
  }));
35
- jest.mock("../ObjectTags", ()=>({
35
+ jest.mock('../ObjectTags', ()=>({
36
36
  ObjectTags: ()=>/*#__PURE__*/ jsx("div", {
37
37
  "data-testid": "object-tags",
38
38
  children: "ObjectTags"
39
39
  })
40
40
  }));
41
41
  const createMockObjectItem = (overrides)=>({
42
- Key: "test-object.txt",
43
- LastModified: new Date("2024-01-01"),
42
+ Key: 'test-object.txt',
43
+ LastModified: new Date('2024-01-01'),
44
44
  Size: 1024,
45
- type: "object",
46
- displayName: "test-object.txt",
45
+ type: 'object',
46
+ displayName: 'test-object.txt',
47
47
  ...overrides
48
48
  });
49
49
  const createMockVersionItem = ()=>({
50
- Key: "test-object.txt",
51
- VersionId: "version-123",
52
- LastModified: new Date("2024-01-01"),
50
+ Key: 'test-object.txt',
51
+ VersionId: 'version-123',
52
+ LastModified: new Date('2024-01-01'),
53
53
  Size: 1024,
54
- type: "version",
55
- displayName: "test-object.txt",
54
+ type: 'version',
55
+ displayName: 'test-object.txt',
56
56
  IsLatest: true
57
57
  });
58
58
  const createMockFolderItem = ()=>({
59
- Key: "test-folder/",
60
- type: "folder",
61
- displayName: "test-folder/"
59
+ Key: 'test-folder/',
60
+ type: 'folder',
61
+ displayName: 'test-folder/'
62
62
  });
63
63
  const createMockDeleteMarkerItem = ()=>({
64
- Key: "deleted-object.txt",
65
- VersionId: "delete-marker-123",
66
- LastModified: new Date("2024-01-01"),
67
- type: "deleteMarker",
68
- displayName: "deleted-object.txt",
64
+ Key: 'deleted-object.txt',
65
+ VersionId: 'delete-marker-123',
66
+ LastModified: new Date('2024-01-01'),
67
+ type: 'deleteMarker',
68
+ displayName: 'deleted-object.txt',
69
69
  IsLatest: true,
70
70
  isDeleteMarker: true
71
71
  });
72
- const renderWithProviders = (ui, { initialRoute = "/buckets/test-bucket/objects", customizationConfig = {} } = {})=>{
72
+ const renderWithProviders = (ui, { initialRoute = '/buckets/test-bucket/objects', customizationConfig = {} } = {})=>{
73
73
  const queryClient = new QueryClient({
74
74
  defaultOptions: {
75
75
  queries: {
@@ -98,78 +98,78 @@ const renderWithProviders = (ui, { initialRoute = "/buckets/test-bucket/objects"
98
98
  })
99
99
  }));
100
100
  };
101
- describe("ObjectDetails", ()=>{
102
- describe("Default Tabs", ()=>{
103
- it("should render three default tabs", ()=>{
101
+ describe('ObjectDetails', ()=>{
102
+ describe('Default Tabs', ()=>{
103
+ it('should render three default tabs', ()=>{
104
104
  const item = createMockObjectItem();
105
105
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
106
106
  item: item
107
107
  }));
108
- expect(screen.getByRole("tab", {
108
+ expect(screen.getByRole('tab', {
109
109
  name: /summary/i
110
110
  })).toBeInTheDocument();
111
- expect(screen.getByRole("tab", {
111
+ expect(screen.getByRole('tab', {
112
112
  name: /metadata/i
113
113
  })).toBeInTheDocument();
114
- expect(screen.getByRole("tab", {
114
+ expect(screen.getByRole('tab', {
115
115
  name: /tags/i
116
116
  })).toBeInTheDocument();
117
117
  });
118
- it("should render Summary tab content by default", ()=>{
118
+ it('should render Summary tab content by default', ()=>{
119
119
  const item = createMockObjectItem();
120
120
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
121
121
  item: item
122
122
  }));
123
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
123
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
124
124
  });
125
- it("should render child components when valid item is provided", ()=>{
125
+ it('should render child components when valid item is provided', ()=>{
126
126
  const item = createMockObjectItem({
127
- Key: "my-file.txt"
127
+ Key: 'my-file.txt'
128
128
  });
129
129
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
130
130
  item: item
131
131
  }));
132
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
132
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
133
133
  });
134
134
  });
135
- describe("Version ID handling", ()=>{
136
- it("should pass versionId when item is a version", ()=>{
135
+ describe('Version ID handling', ()=>{
136
+ it('should pass versionId when item is a version', ()=>{
137
137
  const versionItem = createMockVersionItem();
138
138
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
139
139
  item: versionItem
140
140
  }));
141
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
141
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
142
142
  });
143
- it("should not pass versionId for regular objects", ()=>{
143
+ it('should not pass versionId for regular objects', ()=>{
144
144
  const item = createMockObjectItem();
145
145
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
146
146
  item: item
147
147
  }));
148
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
148
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
149
149
  });
150
150
  });
151
- describe("Placeholder States", ()=>{
152
- it("should show placeholder when no item is selected", ()=>{
151
+ describe('Placeholder States', ()=>{
152
+ it('should show placeholder when no item is selected', ()=>{
153
153
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
154
154
  item: null
155
155
  }));
156
156
  expect(screen.getByText(/select an object to view details/i)).toBeInTheDocument();
157
157
  });
158
- it("should show placeholder for folder items", ()=>{
158
+ it('should show placeholder for folder items', ()=>{
159
159
  const folderItem = createMockFolderItem();
160
160
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
161
161
  item: folderItem
162
162
  }));
163
163
  expect(screen.getByText(/a "folder" is selected/i)).toBeInTheDocument();
164
164
  });
165
- it("should show placeholder for delete marker items", ()=>{
165
+ it('should show placeholder for delete marker items', ()=>{
166
166
  const deleteMarkerItem = createMockDeleteMarkerItem();
167
167
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
168
168
  item: deleteMarkerItem
169
169
  }));
170
170
  expect(screen.getByText(/a "delete marker" is selected/i)).toBeInTheDocument();
171
171
  });
172
- it("should show placeholder when item has no Key", ()=>{
172
+ it('should show placeholder when item has no Key', ()=>{
173
173
  const item = createMockObjectItem({
174
174
  Key: void 0
175
175
  });
@@ -178,38 +178,38 @@ describe("ObjectDetails", ()=>{
178
178
  }));
179
179
  expect(screen.getByText(/select an object to view details/i)).toBeInTheDocument();
180
180
  });
181
- it("should show placeholder when item has empty Key", ()=>{
181
+ it('should show placeholder when item has empty Key', ()=>{
182
182
  const item = createMockObjectItem({
183
- Key: ""
183
+ Key: ''
184
184
  });
185
185
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
186
186
  item: item
187
187
  }));
188
188
  expect(screen.getByText(/select an object to view details/i)).toBeInTheDocument();
189
189
  });
190
- it("should render tabs even in placeholder state", ()=>{
190
+ it('should render tabs even in placeholder state', ()=>{
191
191
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
192
192
  item: null
193
193
  }));
194
- expect(screen.getByRole("tab", {
194
+ expect(screen.getByRole('tab', {
195
195
  name: /summary/i
196
196
  })).toBeInTheDocument();
197
- expect(screen.getByRole("tab", {
197
+ expect(screen.getByRole('tab', {
198
198
  name: /metadata/i
199
199
  })).toBeInTheDocument();
200
- expect(screen.getByRole("tab", {
200
+ expect(screen.getByRole('tab', {
201
201
  name: /tags/i
202
202
  })).toBeInTheDocument();
203
203
  });
204
204
  });
205
- describe("Custom Tabs", ()=>{
206
- it("should render extra custom tabs", ()=>{
205
+ describe('Custom Tabs', ()=>{
206
+ it('should render extra custom tabs', ()=>{
207
207
  const item = createMockObjectItem();
208
208
  const customConfig = {
209
209
  extraObjectTabs: [
210
210
  {
211
- id: "custom-tab",
212
- title: "Custom Tab",
211
+ id: 'custom-tab',
212
+ title: 'Custom Tab',
213
213
  render: ()=>/*#__PURE__*/ jsx("div", {
214
214
  "data-testid": "custom-tab-content",
215
215
  children: "Custom Content"
@@ -222,17 +222,17 @@ describe("ObjectDetails", ()=>{
222
222
  }), {
223
223
  customizationConfig: customConfig
224
224
  });
225
- expect(screen.getByRole("tab", {
225
+ expect(screen.getByRole('tab', {
226
226
  name: /custom tab/i
227
227
  })).toBeInTheDocument();
228
228
  });
229
- it("should render custom tab in tab list", ()=>{
229
+ it('should render custom tab in tab list', ()=>{
230
230
  const item = createMockObjectItem();
231
231
  const customConfig = {
232
232
  extraObjectTabs: [
233
233
  {
234
- id: "versions",
235
- title: "Versions",
234
+ id: 'versions',
235
+ title: 'Versions',
236
236
  render: ()=>/*#__PURE__*/ jsx("div", {
237
237
  "data-testid": "versions-tab",
238
238
  children: "Version History"
@@ -245,18 +245,18 @@ describe("ObjectDetails", ()=>{
245
245
  }), {
246
246
  customizationConfig: customConfig
247
247
  });
248
- const versionsTab = screen.getByRole("tab", {
248
+ const versionsTab = screen.getByRole('tab', {
249
249
  name: /versions/i
250
250
  });
251
251
  expect(versionsTab).toBeInTheDocument();
252
252
  });
253
- it("should replace default tabs when custom tab has same ID", ()=>{
253
+ it('should replace default tabs when custom tab has same ID', ()=>{
254
254
  const item = createMockObjectItem();
255
255
  const customConfig = {
256
256
  extraObjectTabs: [
257
257
  {
258
- id: "summary",
259
- title: "Custom Summary",
258
+ id: 'summary',
259
+ title: 'Custom Summary',
260
260
  render: ()=>/*#__PURE__*/ jsx("div", {
261
261
  "data-testid": "custom-summary",
262
262
  children: "Custom Summary Content"
@@ -269,34 +269,34 @@ describe("ObjectDetails", ()=>{
269
269
  }), {
270
270
  customizationConfig: customConfig
271
271
  });
272
- expect(screen.getByRole("tab", {
272
+ expect(screen.getByRole('tab', {
273
273
  name: /custom summary/i
274
274
  })).toBeInTheDocument();
275
- expect(screen.queryByRole("tab", {
275
+ expect(screen.queryByRole('tab', {
276
276
  name: /^summary$/i
277
277
  })).not.toBeInTheDocument();
278
278
  });
279
- it("should support multiple custom tabs", ()=>{
279
+ it('should support multiple custom tabs', ()=>{
280
280
  const item = createMockObjectItem();
281
281
  const customConfig = {
282
282
  extraObjectTabs: [
283
283
  {
284
- id: "versions",
285
- title: "Versions",
284
+ id: 'versions',
285
+ title: 'Versions',
286
286
  render: ()=>/*#__PURE__*/ jsx("div", {
287
287
  children: "Versions"
288
288
  })
289
289
  },
290
290
  {
291
- id: "permissions",
292
- title: "Permissions",
291
+ id: 'permissions',
292
+ title: 'Permissions',
293
293
  render: ()=>/*#__PURE__*/ jsx("div", {
294
294
  children: "Permissions"
295
295
  })
296
296
  },
297
297
  {
298
- id: "activity",
299
- title: "Activity",
298
+ id: 'activity',
299
+ title: 'Activity',
300
300
  render: ()=>/*#__PURE__*/ jsx("div", {
301
301
  children: "Activity"
302
302
  })
@@ -308,23 +308,23 @@ describe("ObjectDetails", ()=>{
308
308
  }), {
309
309
  customizationConfig: customConfig
310
310
  });
311
- expect(screen.getByRole("tab", {
311
+ expect(screen.getByRole('tab', {
312
312
  name: /versions/i
313
313
  })).toBeInTheDocument();
314
- expect(screen.getByRole("tab", {
314
+ expect(screen.getByRole('tab', {
315
315
  name: /permissions/i
316
316
  })).toBeInTheDocument();
317
- expect(screen.getByRole("tab", {
317
+ expect(screen.getByRole('tab', {
318
318
  name: /activity/i
319
319
  })).toBeInTheDocument();
320
320
  });
321
- it("should support withoutPadding option for custom tabs", ()=>{
321
+ it('should support withoutPadding option for custom tabs', ()=>{
322
322
  const item = createMockObjectItem();
323
323
  const customConfig = {
324
324
  extraObjectTabs: [
325
325
  {
326
- id: "full-width",
327
- title: "Full Width",
326
+ id: 'full-width',
327
+ title: 'Full Width',
328
328
  withoutPadding: true,
329
329
  render: ()=>/*#__PURE__*/ jsx("div", {
330
330
  "data-testid": "full-width-content",
@@ -338,36 +338,36 @@ describe("ObjectDetails", ()=>{
338
338
  }), {
339
339
  customizationConfig: customConfig
340
340
  });
341
- expect(screen.getByRole("tab", {
341
+ expect(screen.getByRole('tab', {
342
342
  name: /full width/i
343
343
  })).toBeInTheDocument();
344
344
  });
345
345
  });
346
- describe("Tab Ordering", ()=>{
347
- it("should maintain default tab order", ()=>{
346
+ describe('Tab Ordering', ()=>{
347
+ it('should maintain default tab order', ()=>{
348
348
  const item = createMockObjectItem();
349
349
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
350
350
  item: item
351
351
  }));
352
- const tabs = screen.getAllByRole("tab");
352
+ const tabs = screen.getAllByRole('tab');
353
353
  expect(tabs[0]).toHaveTextContent(/summary/i);
354
354
  expect(tabs[1]).toHaveTextContent(/metadata/i);
355
355
  expect(tabs[2]).toHaveTextContent(/tags/i);
356
356
  });
357
- it("should append custom tabs after default tabs", ()=>{
357
+ it('should append custom tabs after default tabs', ()=>{
358
358
  const item = createMockObjectItem();
359
359
  const customConfig = {
360
360
  extraObjectTabs: [
361
361
  {
362
- id: "custom1",
363
- title: "Custom 1",
362
+ id: 'custom1',
363
+ title: 'Custom 1',
364
364
  render: ()=>/*#__PURE__*/ jsx("div", {
365
365
  children: "Custom 1"
366
366
  })
367
367
  },
368
368
  {
369
- id: "custom2",
370
- title: "Custom 2",
369
+ id: 'custom2',
370
+ title: 'Custom 2',
371
371
  render: ()=>/*#__PURE__*/ jsx("div", {
372
372
  children: "Custom 2"
373
373
  })
@@ -379,7 +379,7 @@ describe("ObjectDetails", ()=>{
379
379
  }), {
380
380
  customizationConfig: customConfig
381
381
  });
382
- const tabs = screen.getAllByRole("tab");
382
+ const tabs = screen.getAllByRole('tab');
383
383
  expect(tabs[0]).toHaveTextContent(/summary/i);
384
384
  expect(tabs[1]).toHaveTextContent(/metadata/i);
385
385
  expect(tabs[2]).toHaveTextContent(/tags/i);
@@ -387,18 +387,18 @@ describe("ObjectDetails", ()=>{
387
387
  expect(tabs[4]).toHaveTextContent(/custom 2/i);
388
388
  });
389
389
  });
390
- describe("Context Provider", ()=>{
391
- it("should render child components when context is provided", ()=>{
390
+ describe('Context Provider', ()=>{
391
+ it('should render child components when context is provided', ()=>{
392
392
  const item = createMockObjectItem({
393
- Key: "test-file.txt"
393
+ Key: 'test-file.txt'
394
394
  });
395
395
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
396
396
  item: item
397
397
  }));
398
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
398
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
399
399
  });
400
- it("should throw error when useObjectDetailsContext is used outside provider", ()=>{
401
- const { useObjectDetailsContext } = __webpack_require__("../index");
400
+ it('should throw error when useObjectDetailsContext is used outside provider', ()=>{
401
+ const { useObjectDetailsContext } = __webpack_require__("..");
402
402
  const TestComponent = ()=>{
403
403
  useObjectDetailsContext();
404
404
  return null;
@@ -410,21 +410,21 @@ describe("ObjectDetails", ()=>{
410
410
  client: new QueryClient(),
411
411
  children: /*#__PURE__*/ jsx(TestComponent, {})
412
412
  }));
413
- }).toThrow("ObjectDetails components must be used within ObjectDetails");
413
+ }).toThrow('ObjectDetails components must be used within ObjectDetails');
414
414
  console.error = originalError;
415
415
  });
416
- it("should provide correct context values to nested components", ()=>{
416
+ it('should provide correct context values to nested components', ()=>{
417
417
  const item = createMockObjectItem({
418
- Key: "context-test.txt"
418
+ Key: 'context-test.txt'
419
419
  });
420
420
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
421
421
  item: item
422
422
  }));
423
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
423
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
424
424
  });
425
425
  });
426
- describe("Edge Cases", ()=>{
427
- it("should handle missing bucketName in route", ()=>{
426
+ describe('Edge Cases', ()=>{
427
+ it('should handle missing bucketName in route', ()=>{
428
428
  const item = createMockObjectItem();
429
429
  const queryClient = new QueryClient();
430
430
  render(/*#__PURE__*/ jsx(QueryClientProvider, {
@@ -433,7 +433,7 @@ describe("ObjectDetails", ()=>{
433
433
  config: {},
434
434
  children: /*#__PURE__*/ jsx(MemoryRouter, {
435
435
  initialEntries: [
436
- "/invalid-route"
436
+ '/invalid-route'
437
437
  ],
438
438
  children: /*#__PURE__*/ jsx(Routes, {
439
439
  children: /*#__PURE__*/ jsx(Route, {
@@ -448,69 +448,69 @@ describe("ObjectDetails", ()=>{
448
448
  }));
449
449
  expect(screen.getByText(/select an object to view details/i)).toBeInTheDocument();
450
450
  });
451
- it("should handle item type changes", ()=>{
451
+ it('should handle item type changes', ()=>{
452
452
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
453
453
  item: createMockObjectItem()
454
454
  }));
455
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
455
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
456
456
  cleanup();
457
457
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
458
458
  item: createMockFolderItem()
459
459
  }));
460
460
  expect(screen.getByText(/a "folder" is selected/i)).toBeInTheDocument();
461
461
  });
462
- it("should memoize tabs content efficiently", ()=>{
462
+ it('should memoize tabs content efficiently', ()=>{
463
463
  const item = createMockObjectItem();
464
464
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
465
465
  item: item
466
466
  }));
467
- screen.getByTestId("object-summary");
467
+ screen.getByTestId('object-summary');
468
468
  cleanup();
469
469
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
470
470
  item: item
471
471
  }));
472
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
472
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
473
473
  });
474
474
  });
475
- describe("Performance", ()=>{
476
- it("should not recreate context value unnecessarily", ()=>{
475
+ describe('Performance', ()=>{
476
+ it('should not recreate context value unnecessarily', ()=>{
477
477
  const item = createMockObjectItem({
478
- Key: "same-key.txt"
478
+ Key: 'same-key.txt'
479
479
  });
480
480
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
481
481
  item: item
482
482
  }));
483
- screen.getByTestId("object-summary");
483
+ screen.getByTestId('object-summary');
484
484
  cleanup();
485
485
  const sameKeyItem = createMockObjectItem({
486
- Key: "same-key.txt"
486
+ Key: 'same-key.txt'
487
487
  });
488
488
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
489
489
  item: sameKeyItem
490
490
  }));
491
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
491
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
492
492
  });
493
- it("should handle rapid item changes", ()=>{
493
+ it('should handle rapid item changes', ()=>{
494
494
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
495
495
  item: createMockObjectItem({
496
- Key: "file1.txt"
496
+ Key: 'file1.txt'
497
497
  })
498
498
  }));
499
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
499
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
500
500
  cleanup();
501
501
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
502
502
  item: createMockObjectItem({
503
- Key: "file2.txt"
503
+ Key: 'file2.txt'
504
504
  })
505
505
  }));
506
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
506
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
507
507
  cleanup();
508
508
  renderWithProviders(/*#__PURE__*/ jsx(external_index_js_.ObjectDetails, {
509
509
  item: createMockObjectItem({
510
- Key: "file3.txt"
510
+ Key: 'file3.txt'
511
511
  })
512
512
  }));
513
- expect(screen.getByTestId("object-summary")).toBeInTheDocument();
513
+ expect(screen.getByTestId('object-summary')).toBeInTheDocument();
514
514
  });
515
515
  });
516
516
  });