@scality/data-browser-library 1.0.0-preview.8 → 1.0.1

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 (303) hide show
  1. package/dist/components/DataBrowserUI.d.ts +12 -0
  2. package/dist/components/DataBrowserUI.js +99 -0
  3. package/dist/components/Editor.d.ts +1 -1
  4. package/dist/components/Editor.js +3 -3
  5. package/dist/components/__tests__/BucketAccessor.test.js +214 -0
  6. package/dist/components/__tests__/BucketCorsPage.test.d.ts +1 -0
  7. package/dist/components/__tests__/BucketCorsPage.test.js +263 -0
  8. package/dist/components/__tests__/BucketCreate.test.d.ts +1 -0
  9. package/dist/components/__tests__/BucketCreate.test.js +574 -0
  10. package/dist/components/__tests__/BucketDetails.test.d.ts +1 -0
  11. package/dist/components/__tests__/BucketDetails.test.js +421 -0
  12. package/dist/components/__tests__/BucketLifecycleFormPage.test.d.ts +14 -0
  13. package/dist/components/__tests__/BucketLifecycleFormPage.test.js +618 -0
  14. package/dist/components/__tests__/BucketLifecycleList.test.d.ts +1 -0
  15. package/dist/components/__tests__/BucketLifecycleList.test.js +325 -0
  16. package/dist/components/__tests__/BucketList.test.js +495 -81
  17. package/dist/components/__tests__/BucketNotificationFormPage.test.d.ts +1 -0
  18. package/dist/components/__tests__/BucketNotificationFormPage.test.js +348 -0
  19. package/dist/components/__tests__/BucketNotificationList.test.d.ts +1 -0
  20. package/dist/components/__tests__/BucketNotificationList.test.js +379 -0
  21. package/dist/components/__tests__/BucketOverview.test.js +484 -179
  22. package/dist/components/__tests__/BucketPolicyPage.test.js +151 -99
  23. package/dist/components/__tests__/BucketReplicationFormPage.test.d.ts +16 -0
  24. package/dist/components/__tests__/BucketReplicationFormPage.test.js +1757 -0
  25. package/dist/components/__tests__/BucketReplicationList.test.d.ts +1 -0
  26. package/dist/components/__tests__/BucketReplicationList.test.js +344 -0
  27. package/dist/components/__tests__/CreateFolderButton.test.js +56 -56
  28. package/dist/components/__tests__/DeleteBucketButton.test.js +64 -64
  29. package/dist/components/__tests__/DeleteBucketConfigRuleButton.test.d.ts +1 -0
  30. package/dist/components/__tests__/DeleteBucketConfigRuleButton.test.js +196 -0
  31. package/dist/components/__tests__/DeleteObjectButton.test.js +64 -64
  32. package/dist/components/__tests__/EmptyBucketButton.test.d.ts +1 -0
  33. package/dist/components/__tests__/EmptyBucketButton.test.js +302 -0
  34. package/dist/components/__tests__/MetadataSearch.test.js +65 -65
  35. package/dist/components/__tests__/ObjectList.test.js +741 -240
  36. package/dist/components/__tests__/UploadButton.test.js +45 -45
  37. package/dist/components/breadcrumb/Breadcrumb.d.ts +6 -0
  38. package/dist/components/breadcrumb/Breadcrumb.js +37 -0
  39. package/dist/components/breadcrumb/DataBrowserBreadcrumb.d.ts +1 -0
  40. package/dist/components/breadcrumb/DataBrowserBreadcrumb.js +10 -0
  41. package/dist/components/breadcrumb/__tests__/Breadcrumb.test.d.ts +1 -0
  42. package/dist/components/breadcrumb/__tests__/Breadcrumb.test.js +196 -0
  43. package/dist/components/breadcrumb/__tests__/DataBrowserBreadcrumb.test.d.ts +1 -0
  44. package/dist/components/breadcrumb/__tests__/DataBrowserBreadcrumb.test.js +153 -0
  45. package/dist/components/breadcrumb/__tests__/useBreadcrumbPaths.test.d.ts +1 -0
  46. package/dist/components/breadcrumb/__tests__/useBreadcrumbPaths.test.js +134 -0
  47. package/dist/components/breadcrumb/index.d.ts +8 -0
  48. package/dist/components/breadcrumb/index.js +4 -0
  49. package/dist/components/breadcrumb/useBreadcrumbPaths.d.ts +2 -0
  50. package/dist/components/breadcrumb/useBreadcrumbPaths.js +82 -0
  51. package/dist/components/buckets/BucketAccessor.d.ts +2 -0
  52. package/dist/components/buckets/BucketAccessor.js +125 -0
  53. package/dist/components/buckets/BucketConfigEditButton.d.ts +8 -0
  54. package/dist/components/buckets/{BucketPolicyButton.js → BucketConfigEditButton.js} +9 -5
  55. package/dist/components/buckets/BucketCorsPage.d.ts +1 -0
  56. package/dist/components/buckets/BucketCorsPage.js +234 -0
  57. package/dist/components/buckets/BucketCreate.d.ts +50 -0
  58. package/dist/components/buckets/BucketCreate.js +279 -0
  59. package/dist/components/buckets/BucketDetails.d.ts +42 -0
  60. package/dist/components/buckets/BucketDetails.js +256 -40
  61. package/dist/components/buckets/BucketLifecycleFormPage.d.ts +15 -0
  62. package/dist/components/buckets/BucketLifecycleFormPage.js +1086 -0
  63. package/dist/components/buckets/BucketLifecycleList.d.ts +10 -0
  64. package/dist/components/buckets/BucketLifecycleList.js +270 -0
  65. package/dist/components/buckets/BucketList.d.ts +6 -4
  66. package/dist/components/buckets/BucketList.js +161 -94
  67. package/dist/components/buckets/BucketLocation.js +4 -4
  68. package/dist/components/buckets/BucketOverview.d.ts +86 -5
  69. package/dist/components/buckets/BucketOverview.js +481 -192
  70. package/dist/components/buckets/BucketPage.js +44 -22
  71. package/dist/components/buckets/BucketPolicyPage.js +155 -127
  72. package/dist/components/buckets/BucketReplicationFormPage.d.ts +1 -0
  73. package/dist/components/buckets/BucketReplicationFormPage.js +835 -0
  74. package/dist/components/buckets/BucketReplicationList.d.ts +11 -0
  75. package/dist/components/buckets/BucketReplicationList.js +189 -0
  76. package/dist/components/buckets/BucketVersioning.d.ts +4 -0
  77. package/dist/components/buckets/BucketVersioning.js +76 -0
  78. package/dist/components/buckets/DeleteBucketButton.js +8 -8
  79. package/dist/components/buckets/DeleteBucketConfigRuleButton.d.ts +18 -0
  80. package/dist/components/buckets/DeleteBucketConfigRuleButton.js +53 -0
  81. package/dist/components/buckets/EmptyBucketButton.d.ts +5 -0
  82. package/dist/components/buckets/EmptyBucketButton.js +232 -0
  83. package/dist/components/buckets/EmptyBucketSummary.d.ts +9 -0
  84. package/dist/components/buckets/EmptyBucketSummary.js +60 -0
  85. package/dist/components/buckets/EmptyBucketSummaryList.d.ts +13 -0
  86. package/dist/components/buckets/EmptyBucketSummaryList.js +140 -0
  87. package/dist/components/buckets/__tests__/BucketVersioning.test.d.ts +1 -0
  88. package/dist/components/buckets/__tests__/BucketVersioning.test.js +163 -0
  89. package/dist/components/buckets/notifications/BucketNotificationFormPage.d.ts +1 -0
  90. package/dist/components/buckets/notifications/BucketNotificationFormPage.js +316 -0
  91. package/dist/components/buckets/notifications/BucketNotificationList.d.ts +10 -0
  92. package/dist/components/buckets/notifications/BucketNotificationList.js +267 -0
  93. package/dist/components/buckets/notifications/EventsSection.js +145 -29
  94. package/dist/components/buckets/notifications/__tests__/events.test.d.ts +1 -0
  95. package/dist/components/buckets/notifications/__tests__/events.test.js +56 -0
  96. package/dist/components/buckets/notifications/events.d.ts +71 -7
  97. package/dist/components/buckets/notifications/events.js +98 -16
  98. package/dist/components/index.d.ts +27 -13
  99. package/dist/components/index.js +20 -6
  100. package/dist/components/layouts/ArrowNavigation.d.ts +3 -0
  101. package/dist/components/layouts/ArrowNavigation.js +28 -0
  102. package/dist/components/layouts/BrowserPageLayout.d.ts +5 -1
  103. package/dist/components/layouts/BrowserPageLayout.js +10 -5
  104. package/dist/components/objects/CreateFolderButton.d.ts +2 -2
  105. package/dist/components/objects/CreateFolderButton.js +12 -12
  106. package/dist/components/objects/DeleteObjectButton.d.ts +1 -1
  107. package/dist/components/objects/DeleteObjectButton.js +19 -21
  108. package/dist/components/objects/GetPresignedUrlButton.d.ts +7 -0
  109. package/dist/components/objects/GetPresignedUrlButton.js +255 -0
  110. package/dist/components/objects/ObjectDetails/ObjectMetadata.d.ts +2 -2
  111. package/dist/components/objects/ObjectDetails/ObjectMetadata.js +263 -230
  112. package/dist/components/objects/ObjectDetails/ObjectSummary.d.ts +2 -2
  113. package/dist/components/objects/ObjectDetails/ObjectSummary.js +540 -138
  114. package/dist/components/objects/ObjectDetails/ObjectTags.d.ts +2 -2
  115. package/dist/components/objects/ObjectDetails/ObjectTags.js +95 -123
  116. package/dist/components/objects/ObjectDetails/__tests__/ObjectDetails.test.d.ts +1 -0
  117. package/dist/components/objects/ObjectDetails/__tests__/ObjectDetails.test.js +516 -0
  118. package/dist/components/objects/ObjectDetails/__tests__/ObjectSummary.test.d.ts +1 -0
  119. package/dist/components/objects/ObjectDetails/__tests__/ObjectSummary.test.js +1064 -0
  120. package/dist/components/objects/ObjectDetails/index.d.ts +18 -2
  121. package/dist/components/objects/ObjectDetails/index.js +152 -40
  122. package/dist/components/objects/ObjectList.d.ts +12 -10
  123. package/dist/components/objects/ObjectList.js +590 -263
  124. package/dist/components/objects/ObjectLock/EditRetentionButton.d.ts +4 -0
  125. package/dist/components/objects/ObjectLock/EditRetentionButton.js +32 -0
  126. package/dist/components/objects/ObjectLock/ObjectLockRetentionSettings.d.ts +3 -0
  127. package/dist/components/objects/ObjectLock/ObjectLockRetentionSettings.js +211 -0
  128. package/dist/components/objects/ObjectLock/ObjectLockSettings.d.ts +9 -0
  129. package/dist/components/objects/ObjectLock/ObjectLockSettings.js +159 -0
  130. package/dist/components/objects/ObjectLock/ObjectLockSettingsUtils.d.ts +8 -0
  131. package/dist/components/objects/ObjectLock/ObjectLockSettingsUtils.js +39 -0
  132. package/dist/components/objects/ObjectLock/__tests__/EditRetentionButton.test.d.ts +1 -0
  133. package/dist/components/objects/ObjectLock/__tests__/EditRetentionButton.test.js +204 -0
  134. package/dist/components/objects/ObjectLock/__tests__/ObjectLockSettings.test.d.ts +1 -0
  135. package/dist/components/objects/ObjectLock/__tests__/ObjectLockSettings.test.js +374 -0
  136. package/dist/components/objects/ObjectPage.js +12 -8
  137. package/dist/components/objects/UploadButton.d.ts +3 -3
  138. package/dist/components/objects/UploadButton.js +10 -10
  139. package/dist/components/objects/__tests__/GetPresignedUrlButton.test.d.ts +1 -0
  140. package/dist/components/objects/__tests__/GetPresignedUrlButton.test.js +531 -0
  141. package/dist/components/providers/DataBrowserProvider.d.ts +23 -12
  142. package/dist/components/providers/DataBrowserProvider.js +60 -38
  143. package/dist/components/providers/QueryProvider.d.ts +9 -0
  144. package/dist/components/providers/QueryProvider.js +21 -0
  145. package/dist/components/search/MetadataSearch.js +29 -28
  146. package/dist/components/search/SearchHints.js +1 -1
  147. package/dist/components/ui/ArrayFieldActions.d.ts +36 -0
  148. package/dist/components/ui/ArrayFieldActions.js +43 -0
  149. package/dist/components/ui/ConfirmDeleteRuleModal.d.ts +16 -0
  150. package/dist/components/ui/ConfirmDeleteRuleModal.js +48 -0
  151. package/dist/components/ui/DeleteObjectModalContent.d.ts +1 -1
  152. package/dist/components/ui/DeleteObjectModalContent.js +12 -12
  153. package/dist/components/ui/FilterFormSection.d.ts +44 -0
  154. package/dist/components/ui/FilterFormSection.js +159 -0
  155. package/dist/components/ui/Search.elements.d.ts +2 -2
  156. package/dist/components/ui/Search.elements.js +7 -7
  157. package/dist/components/ui/Table.elements.d.ts +2 -1
  158. package/dist/components/ui/Table.elements.js +18 -12
  159. package/dist/config/__tests__/factory.test.d.ts +1 -0
  160. package/dist/config/__tests__/factory.test.js +311 -0
  161. package/dist/config/factory.d.ts +14 -49
  162. package/dist/config/factory.js +23 -68
  163. package/dist/config/types.d.ts +212 -34
  164. package/dist/contexts/DataBrowserUICustomizationContext.d.ts +27 -0
  165. package/dist/contexts/DataBrowserUICustomizationContext.js +13 -0
  166. package/dist/hooks/__tests__/useAccessibleBuckets.test.d.ts +1 -0
  167. package/dist/hooks/__tests__/useAccessibleBuckets.test.js +145 -0
  168. package/dist/hooks/__tests__/useISVBucketDetection.test.d.ts +1 -0
  169. package/dist/hooks/__tests__/useISVBucketDetection.test.js +188 -0
  170. package/dist/hooks/__tests__/useIsBucketEmpty.test.js +27 -27
  171. package/dist/hooks/__tests__/useLoginMutation.test.d.ts +1 -0
  172. package/dist/hooks/__tests__/useLoginMutation.test.js +194 -0
  173. package/dist/hooks/bucketConfiguration.d.ts +8 -1
  174. package/dist/hooks/bucketConfiguration.js +52 -51
  175. package/dist/hooks/bucketOperations.d.ts +10 -1
  176. package/dist/hooks/bucketOperations.js +10 -9
  177. package/dist/hooks/factories/__tests__/useCreateS3FunctionMutationHook.test.js +80 -80
  178. package/dist/hooks/factories/__tests__/useCreateS3InfiniteQueryHook.test.js +80 -80
  179. package/dist/hooks/factories/__tests__/useCreateS3LoginHook.test.js +44 -44
  180. package/dist/hooks/factories/__tests__/useCreateS3MutationHook.test.js +63 -63
  181. package/dist/hooks/factories/__tests__/useCreateS3QueryHook.test.js +95 -52
  182. package/dist/hooks/factories/index.d.ts +4 -4
  183. package/dist/hooks/factories/index.js +2 -2
  184. package/dist/hooks/factories/useCreateS3InfiniteQueryHook.d.ts +2 -2
  185. package/dist/hooks/factories/useCreateS3InfiniteQueryHook.js +16 -13
  186. package/dist/hooks/factories/useCreateS3LoginHook.d.ts +2 -2
  187. package/dist/hooks/factories/useCreateS3LoginHook.js +1 -1
  188. package/dist/hooks/factories/useCreateS3MutationHook.d.ts +3 -3
  189. package/dist/hooks/factories/useCreateS3MutationHook.js +7 -2
  190. package/dist/hooks/factories/useCreateS3QueryHook.d.ts +2 -2
  191. package/dist/hooks/factories/useCreateS3QueryHook.js +29 -3
  192. package/dist/hooks/index.d.ts +19 -8
  193. package/dist/hooks/index.js +16 -5
  194. package/dist/hooks/loginOperations.d.ts +1 -1
  195. package/dist/hooks/loginOperations.js +1 -1
  196. package/dist/hooks/objectOperations.d.ts +2 -2
  197. package/dist/hooks/objectOperations.js +50 -49
  198. package/dist/hooks/presignedOperations.d.ts +4 -4
  199. package/dist/hooks/presignedOperations.js +5 -5
  200. package/dist/hooks/useAccessibleBuckets.d.ts +11 -0
  201. package/dist/hooks/useAccessibleBuckets.js +115 -0
  202. package/dist/hooks/useBatchObjectLegalHold.d.ts +11 -0
  203. package/dist/hooks/useBatchObjectLegalHold.js +48 -0
  204. package/dist/hooks/useBucketConfigEditor.d.ts +31 -0
  205. package/dist/hooks/useBucketConfigEditor.js +82 -0
  206. package/dist/hooks/useDataBrowserNavigate.d.ts +28 -0
  207. package/dist/hooks/useDataBrowserNavigate.js +24 -0
  208. package/dist/hooks/useDeleteBucketConfigRule.d.ts +26 -0
  209. package/dist/hooks/useDeleteBucketConfigRule.js +46 -0
  210. package/dist/hooks/useEmptyBucket.d.ts +27 -0
  211. package/dist/hooks/useEmptyBucket.js +116 -0
  212. package/dist/hooks/useFeatures.d.ts +7 -0
  213. package/dist/hooks/useFeatures.js +8 -0
  214. package/dist/hooks/useISVBucketDetection.d.ts +15 -0
  215. package/dist/hooks/useISVBucketDetection.js +27 -0
  216. package/dist/hooks/useIsBucketEmpty.js +4 -4
  217. package/dist/hooks/useLimitedAccessFlow.d.ts +48 -0
  218. package/dist/hooks/useLimitedAccessFlow.js +23 -0
  219. package/dist/hooks/useS3Client.d.ts +6 -0
  220. package/dist/hooks/useS3Client.js +3 -2
  221. package/dist/hooks/useS3ConfigSwitch.d.ts +11 -0
  222. package/dist/hooks/useS3ConfigSwitch.js +37 -0
  223. package/dist/hooks/useSupportedNotificationEvents.d.ts +6 -0
  224. package/dist/hooks/useSupportedNotificationEvents.js +8 -0
  225. package/dist/hooks/useTableRowSelection.d.ts +9 -0
  226. package/dist/hooks/useTableRowSelection.js +45 -0
  227. package/dist/index.d.ts +6 -6
  228. package/dist/index.js +2 -2
  229. package/dist/schemas/bucketPolicySchema.json +3 -13
  230. package/dist/test/msw/handlers/deleteBucket.d.ts +1 -1
  231. package/dist/test/msw/handlers/deleteBucket.js +20 -10
  232. package/dist/test/msw/handlers/getBucketAcl.d.ts +1 -1
  233. package/dist/test/msw/handlers/getBucketAcl.js +29 -17
  234. package/dist/test/msw/handlers/getBucketLocation.d.ts +1 -1
  235. package/dist/test/msw/handlers/getBucketLocation.js +29 -15
  236. package/dist/test/msw/handlers/getBucketPolicy.d.ts +1 -1
  237. package/dist/test/msw/handlers/getBucketPolicy.js +52 -32
  238. package/dist/test/msw/handlers/headObject.d.ts +1 -1
  239. package/dist/test/msw/handlers/headObject.js +31 -13
  240. package/dist/test/msw/handlers/listBuckets.d.ts +1 -1
  241. package/dist/test/msw/handlers/listBuckets.js +5 -3
  242. package/dist/test/msw/handlers/listObjectVersions.d.ts +1 -1
  243. package/dist/test/msw/handlers/listObjectVersions.js +38 -26
  244. package/dist/test/msw/handlers/listObjects.d.ts +1 -1
  245. package/dist/test/msw/handlers/listObjects.js +35 -23
  246. package/dist/test/msw/handlers/objectLegalHold.d.ts +1 -1
  247. package/dist/test/msw/handlers/objectLegalHold.js +32 -17
  248. package/dist/test/msw/handlers/objectRetention.d.ts +1 -1
  249. package/dist/test/msw/handlers/objectRetention.js +31 -17
  250. package/dist/test/msw/handlers/putBucketAcl.d.ts +1 -1
  251. package/dist/test/msw/handlers/putBucketAcl.js +29 -14
  252. package/dist/test/msw/handlers/putObject.d.ts +1 -1
  253. package/dist/test/msw/handlers/putObject.js +27 -12
  254. package/dist/test/msw/handlers.d.ts +3 -3
  255. package/dist/test/msw/handlers.js +77 -54
  256. package/dist/test/msw/index.d.ts +2 -2
  257. package/dist/test/msw/index.js +1 -1
  258. package/dist/test/msw/server.d.ts +1 -1
  259. package/dist/test/msw/server.js +1 -1
  260. package/dist/test/msw/utils.js +2 -2
  261. package/dist/test/setup.d.ts +1 -1
  262. package/dist/test/setup.js +13 -30
  263. package/dist/test/testUtils.d.ts +170 -36
  264. package/dist/test/testUtils.js +229 -116
  265. package/dist/test/utils/errorHandling.test.js +146 -108
  266. package/dist/types/index.d.ts +49 -36
  267. package/dist/types/monaco.d.ts +13 -0
  268. package/dist/types/monaco.js +0 -0
  269. package/dist/utils/__tests__/proxyMiddleware.test.d.ts +1 -0
  270. package/dist/utils/__tests__/proxyMiddleware.test.js +579 -0
  271. package/dist/utils/__tests__/s3Client.test.d.ts +1 -0
  272. package/dist/utils/__tests__/s3Client.test.js +340 -0
  273. package/dist/utils/__tests__/s3ConfigIdentifier.test.d.ts +1 -0
  274. package/dist/utils/__tests__/s3ConfigIdentifier.test.js +437 -0
  275. package/dist/utils/constants.d.ts +22 -0
  276. package/dist/utils/constants.js +19 -0
  277. package/dist/utils/deletion/index.d.ts +2 -2
  278. package/dist/utils/deletion/index.js +1 -1
  279. package/dist/utils/deletion/messages.d.ts +1 -1
  280. package/dist/utils/deletion/messages.js +4 -4
  281. package/dist/utils/errorHandling.d.ts +12 -3
  282. package/dist/utils/errorHandling.js +12 -7
  283. package/dist/utils/hooks.js +8 -8
  284. package/dist/utils/index.d.ts +5 -2
  285. package/dist/utils/index.js +5 -1
  286. package/dist/utils/proxyMiddleware.d.ts +32 -13
  287. package/dist/utils/proxyMiddleware.js +90 -36
  288. package/dist/utils/s3Client.d.ts +14 -4
  289. package/dist/utils/s3Client.js +5 -26
  290. package/dist/utils/s3ConfigIdentifier.d.ts +79 -0
  291. package/dist/utils/s3ConfigIdentifier.js +57 -0
  292. package/dist/utils/s3RuleUtils.d.ts +53 -0
  293. package/dist/utils/s3RuleUtils.js +101 -0
  294. package/package.json +10 -8
  295. package/dist/components/__tests__/BucketNotificationCreatePage.test.js +0 -316
  296. package/dist/components/buckets/BucketPolicyButton.d.ts +0 -7
  297. package/dist/components/buckets/notifications/BucketNotificationCreatePage.d.ts +0 -1
  298. package/dist/components/buckets/notifications/BucketNotificationCreatePage.js +0 -234
  299. package/dist/hooks/useLoginMutation.d.ts +0 -21
  300. package/dist/hooks/useLoginMutation.js +0 -9
  301. package/dist/utils/useFeatures.d.ts +0 -1
  302. package/dist/utils/useFeatures.js +0 -7
  303. /package/dist/components/__tests__/{BucketNotificationCreatePage.test.d.ts → BucketAccessor.test.d.ts} +0 -0
@@ -0,0 +1,10 @@
1
+ import type { LifecycleRule } from '@aws-sdk/client-s3';
2
+ interface BucketLifecycleListProps {
3
+ bucketName: string;
4
+ lifecycleRules: LifecycleRule[];
5
+ lifecycleStatus?: 'idle' | 'loading' | 'error' | 'success';
6
+ onCreateRule?: () => void;
7
+ onEditRule?: (ruleId: string) => void;
8
+ }
9
+ export declare function BucketLifecycleList({ bucketName, lifecycleRules, lifecycleStatus, onCreateRule, onEditRule, }: BucketLifecycleListProps): import("react/jsx-runtime").JSX.Element;
10
+ export {};
@@ -0,0 +1,270 @@
1
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
2
+ import { ConstrainedText, FormattedDateTime, Icon, Stack, Tooltip, Wrap, spacing } from "@scality/core-ui";
3
+ import { Box, Button, Table } from "@scality/core-ui/dist/next";
4
+ import { useMemo } from "react";
5
+ import { useDeleteBucketLifecycle, useSetBucketLifecycle } from "../../hooks/bucketConfiguration.js";
6
+ import { useTableRowSelection } from "../../hooks/useTableRowSelection.js";
7
+ import { DeleteBucketConfigRuleButton } from "./DeleteBucketConfigRuleButton.js";
8
+ const pluralizeDays = (days)=>1 === days ? `${days} day` : `${days} days`;
9
+ const formatActions = (rule)=>{
10
+ const actions = [];
11
+ if (rule.Expiration) {
12
+ if (rule.Expiration.Days) actions.push({
13
+ text: `Expire current (${pluralizeDays(rule.Expiration.Days)})`,
14
+ description: `Expire current versions of objects after ${pluralizeDays(rule.Expiration.Days)}`
15
+ });
16
+ else if (rule.Expiration.Date) actions.push({
17
+ text: 'Expire current',
18
+ description: 'Expire current versions of objects on date',
19
+ date: rule.Expiration.Date
20
+ });
21
+ else if (rule.Expiration.ExpiredObjectDeleteMarker) actions.push({
22
+ text: 'Delete expired markers',
23
+ description: 'Delete expired object delete markers'
24
+ });
25
+ }
26
+ if (rule.NoncurrentVersionExpiration?.NoncurrentDays) {
27
+ const keepText = rule.NoncurrentVersionExpiration.NewerNoncurrentVersions ? `, keep ${rule.NoncurrentVersionExpiration.NewerNoncurrentVersions}` : '';
28
+ const keepDescription = rule.NoncurrentVersionExpiration.NewerNoncurrentVersions ? `, keep ${rule.NoncurrentVersionExpiration.NewerNoncurrentVersions} newest versions` : '';
29
+ actions.push({
30
+ text: `Expire noncurrent (${pluralizeDays(rule.NoncurrentVersionExpiration.NoncurrentDays)}${keepText})`,
31
+ description: `Permanently delete noncurrent versions of objects after ${pluralizeDays(rule.NoncurrentVersionExpiration.NoncurrentDays)}${keepDescription}`
32
+ });
33
+ }
34
+ if (rule.Transitions && rule.Transitions.length > 0) rule.Transitions.forEach((transition)=>{
35
+ if (transition.Days) actions.push({
36
+ text: `Transition current (${pluralizeDays(transition.Days)})`,
37
+ description: `Transition current versions of objects after ${pluralizeDays(transition.Days)}`
38
+ });
39
+ else if (transition.Date) actions.push({
40
+ text: 'Transition current',
41
+ description: 'Transition current versions of objects on date',
42
+ date: transition.Date
43
+ });
44
+ });
45
+ if (rule.NoncurrentVersionTransitions && rule.NoncurrentVersionTransitions.length > 0) rule.NoncurrentVersionTransitions.forEach((transition)=>{
46
+ if (transition.NoncurrentDays) {
47
+ const keepText = transition.NewerNoncurrentVersions ? `, keep ${transition.NewerNoncurrentVersions}` : '';
48
+ const keepDescription = transition.NewerNoncurrentVersions ? `, keep ${transition.NewerNoncurrentVersions} newest versions` : '';
49
+ actions.push({
50
+ text: `Transition noncurrent (${pluralizeDays(transition.NoncurrentDays)}${keepText})`,
51
+ description: `Transition noncurrent versions of objects after ${pluralizeDays(transition.NoncurrentDays)}${keepDescription}`
52
+ });
53
+ }
54
+ });
55
+ if (rule.AbortIncompleteMultipartUpload?.DaysAfterInitiation) actions.push({
56
+ text: `Abort Incomplete MPU (${pluralizeDays(rule.AbortIncompleteMultipartUpload.DaysAfterInitiation)})`,
57
+ description: `Abort incomplete multipart uploads after ${pluralizeDays(rule.AbortIncompleteMultipartUpload.DaysAfterInitiation)}`
58
+ });
59
+ return actions.length > 0 ? actions : [
60
+ {
61
+ text: '-',
62
+ description: '-'
63
+ }
64
+ ];
65
+ };
66
+ function BucketLifecycleList({ bucketName, lifecycleRules, lifecycleStatus, onCreateRule, onEditRule }) {
67
+ const updateLifecycleMutation = useSetBucketLifecycle();
68
+ const deleteLifecycleMutation = useDeleteBucketLifecycle();
69
+ const columns = useMemo(()=>[
70
+ {
71
+ Header: 'Rule ID',
72
+ accessor: 'ID',
73
+ id: 'id',
74
+ Cell: ({ value })=>/*#__PURE__*/ jsx(ConstrainedText, {
75
+ text: value || '-',
76
+ lineClamp: 2
77
+ }),
78
+ cellStyle: {
79
+ flex: '1',
80
+ width: 'unset'
81
+ }
82
+ },
83
+ {
84
+ Header: 'Status',
85
+ accessor: 'Status',
86
+ id: 'status',
87
+ Cell: ({ value })=>{
88
+ const statusText = 'Enabled' === value ? 'Active' : 'Disabled' === value ? 'Inactive' : value;
89
+ return /*#__PURE__*/ jsx("span", {
90
+ children: statusText || '-'
91
+ });
92
+ },
93
+ cellStyle: {
94
+ width: 'unset',
95
+ flex: '0.5'
96
+ }
97
+ },
98
+ {
99
+ Header: 'Actions',
100
+ accessor: 'Actions',
101
+ id: 'actions',
102
+ Cell: ({ value })=>{
103
+ if (!value || 0 === value.length || 1 === value.length && '-' === value[0].text) return /*#__PURE__*/ jsx("span", {
104
+ children: "-"
105
+ });
106
+ const firstAction = value[0];
107
+ const remainingCount = value.length - 1;
108
+ const renderWithDate = (text, date)=>{
109
+ if (date) return /*#__PURE__*/ jsxs(Fragment, {
110
+ children: [
111
+ text,
112
+ " (",
113
+ /*#__PURE__*/ jsx(FormattedDateTime, {
114
+ format: "date",
115
+ value: 'string' == typeof date ? new Date(date) : date
116
+ }),
117
+ ")"
118
+ ]
119
+ });
120
+ return text;
121
+ };
122
+ const renderAction = (action)=>renderWithDate(action.text, action.date);
123
+ const renderDescription = (action)=>renderWithDate(action.description, action.date);
124
+ const multiActionTooltip = /*#__PURE__*/ jsx("ul", {
125
+ style: {
126
+ margin: 0,
127
+ paddingLeft: '1.5rem'
128
+ },
129
+ children: value.map((action, index)=>/*#__PURE__*/ jsx("li", {
130
+ children: renderDescription(action)
131
+ }, index))
132
+ });
133
+ if (value.length > 1) return /*#__PURE__*/ jsxs(Stack, {
134
+ gap: "r4",
135
+ direction: "horizontal",
136
+ children: [
137
+ /*#__PURE__*/ jsxs("span", {
138
+ children: [
139
+ renderAction(firstAction),
140
+ ", +",
141
+ remainingCount
142
+ ]
143
+ }),
144
+ /*#__PURE__*/ jsx(Tooltip, {
145
+ overlay: multiActionTooltip,
146
+ placement: "top",
147
+ overlayStyle: {
148
+ maxWidth: '30rem'
149
+ },
150
+ children: /*#__PURE__*/ jsx("span", {
151
+ style: {
152
+ cursor: 'help'
153
+ },
154
+ children: /*#__PURE__*/ jsx(Icon, {
155
+ name: "Info",
156
+ size: "sm"
157
+ })
158
+ })
159
+ })
160
+ ]
161
+ });
162
+ return /*#__PURE__*/ jsx("span", {
163
+ children: renderAction(firstAction)
164
+ });
165
+ },
166
+ cellStyle: {
167
+ width: 'unset',
168
+ flex: '1.5'
169
+ }
170
+ },
171
+ {
172
+ Header: '',
173
+ accessor: 'ID',
174
+ id: 'operations',
175
+ cellStyle: {
176
+ flex: '0.5',
177
+ textAlign: 'right',
178
+ paddingRight: spacing.r16,
179
+ width: 'unset'
180
+ },
181
+ Cell: ({ value })=>/*#__PURE__*/ jsxs(Box, {
182
+ display: "flex",
183
+ gap: spacing.r8,
184
+ justifyContent: "flex-end",
185
+ children: [
186
+ /*#__PURE__*/ jsx(Button, {
187
+ icon: /*#__PURE__*/ jsx(Icon, {
188
+ name: "Edit"
189
+ }),
190
+ variant: "secondary",
191
+ type: "button",
192
+ onClick: (e)=>{
193
+ e.stopPropagation();
194
+ onEditRule?.(value);
195
+ },
196
+ "aria-label": "Edit rule",
197
+ tooltip: {
198
+ overlay: 'Edit rule'
199
+ }
200
+ }),
201
+ /*#__PURE__*/ jsx(DeleteBucketConfigRuleButton, {
202
+ bucketName: bucketName,
203
+ ruleId: value,
204
+ rules: lifecycleRules,
205
+ ruleType: "lifecycle",
206
+ updateMutation: updateLifecycleMutation,
207
+ deleteMutation: deleteLifecycleMutation,
208
+ buildUpdateInput: (remainingRules)=>({
209
+ LifecycleConfiguration: {
210
+ Rules: remainingRules
211
+ }
212
+ }),
213
+ successMessage: "Lifecycle rule deleted successfully",
214
+ errorMessage: "Failed to delete lifecycle rule"
215
+ })
216
+ ]
217
+ })
218
+ }
219
+ ], [
220
+ bucketName,
221
+ lifecycleRules,
222
+ onEditRule
223
+ ]);
224
+ const tableData = useMemo(()=>lifecycleRules.map((rule)=>({
225
+ ID: rule.ID || '-',
226
+ Status: rule.Status || 'Disabled',
227
+ Actions: formatActions(rule),
228
+ rule
229
+ })), [
230
+ lifecycleRules
231
+ ]);
232
+ const { selectedId, onRowSelected } = useTableRowSelection(tableData);
233
+ return /*#__PURE__*/ jsxs(Table, {
234
+ columns: columns,
235
+ data: tableData,
236
+ status: lifecycleStatus,
237
+ defaultSortingKey: "id",
238
+ entityName: {
239
+ en: {
240
+ singular: 'lifecycle rule',
241
+ plural: 'lifecycle rules'
242
+ }
243
+ },
244
+ children: [
245
+ /*#__PURE__*/ jsx(Wrap, {
246
+ padding: spacing.r16,
247
+ children: /*#__PURE__*/ jsx(Box, {
248
+ display: "flex",
249
+ justifyContent: "flex-end",
250
+ children: /*#__PURE__*/ jsx(Button, {
251
+ icon: /*#__PURE__*/ jsx(Icon, {
252
+ name: "Create-add"
253
+ }),
254
+ label: "Create Rule",
255
+ variant: "primary",
256
+ onClick: onCreateRule,
257
+ type: "button"
258
+ })
259
+ })
260
+ }),
261
+ /*#__PURE__*/ jsx(Table.SingleSelectableContent, {
262
+ rowHeight: "h48",
263
+ separationLineVariant: "backgroundLevel1",
264
+ selectedId: selectedId?.toString(),
265
+ onRowSelected: onRowSelected
266
+ })
267
+ ]
268
+ });
269
+ }
270
+ export { BucketLifecycleList };
@@ -1,12 +1,14 @@
1
- import type { Bucket } from "@aws-sdk/client-s3";
1
+ import type { Bucket } from '@aws-sdk/client-s3';
2
2
  interface BucketListProps {
3
3
  buckets: Bucket[];
4
- bucketStatus?: "idle" | "loading" | "error" | "success";
4
+ bucketStatus?: 'idle' | 'loading' | 'error' | 'success';
5
5
  selectedBucketName?: string | null;
6
6
  onBucketSelect?: (bucketName: string) => void;
7
7
  onCreateBucket?: () => void;
8
8
  onNavigateToBucket?: (bucketName: string) => void;
9
- renderBucketLocation?: (bucketName: string) => React.ReactNode;
10
9
  }
11
- export declare function BucketList({ buckets, bucketStatus, selectedBucketName, onBucketSelect, onCreateBucket, onNavigateToBucket, renderBucketLocation, }: BucketListProps): import("react/jsx-runtime").JSX.Element;
10
+ export declare function BucketList({ buckets, bucketStatus, selectedBucketName, onBucketSelect, onCreateBucket, onNavigateToBucket, }: BucketListProps): import("react/jsx-runtime").JSX.Element;
11
+ export declare namespace BucketList {
12
+ var displayName: string;
13
+ }
12
14
  export {};
@@ -1,97 +1,169 @@
1
1
  import { jsx, jsxs } from "react/jsx-runtime";
2
2
  import { ConstrainedText, FormattedDateTime, Icon, Link, Wrap, spacing } from "@scality/core-ui";
3
3
  import { Box, Button, Table } from "@scality/core-ui/dist/next";
4
- import { useMemo } from "react";
5
- const SEARCH_QUERY_PARAM = "search";
6
- function BucketList({ buckets, bucketStatus, selectedBucketName, onBucketSelect, onCreateBucket, onNavigateToBucket, renderBucketLocation }) {
7
- const columns = useMemo(()=>[
8
- {
9
- Header: "Bucket Name",
10
- accessor: "Name",
11
- id: "name",
12
- Cell: ({ value, row })=>{
13
- const name = value || row.original?.Name;
14
- if (!name) return /*#__PURE__*/ jsx("span", {
15
- children: "-"
16
- });
17
- return /*#__PURE__*/ jsx(ConstrainedText, {
18
- text: /*#__PURE__*/ jsx(Link, {
19
- onClick: (e)=>{
20
- e.stopPropagation();
21
- onNavigateToBucket?.(name);
22
- },
23
- children: name
24
- }),
25
- lineClamp: 2
26
- });
27
- },
28
- cellStyle: {
29
- flex: "1",
30
- width: "unset"
31
- }
32
- },
33
- {
34
- Header: "Storage Location",
35
- accessor: "Name",
36
- id: "location",
37
- Cell ({ value }) {
38
- return renderBucketLocation ? renderBucketLocation(value) : /*#__PURE__*/ jsx("span", {
39
- children: "-"
40
- });
41
- },
42
- cellStyle: {
43
- width: "unset",
44
- flex: "1.2"
45
- }
46
- },
47
- {
48
- Header: "Created on",
49
- accessor: "CreationDate",
50
- id: "date",
51
- cellStyle: {
52
- flex: "1",
53
- textAlign: "right",
54
- paddingRight: spacing.r16,
55
- width: "unset"
56
- },
57
- Cell: ({ value, row })=>{
58
- const date = value || row.original?.CreationDate;
59
- if (!date) return /*#__PURE__*/ jsx("span", {
60
- children: "-"
61
- });
62
- return /*#__PURE__*/ jsx(FormattedDateTime, {
63
- format: "date-time-second",
64
- value: new Date(date)
65
- });
66
- }
67
- }
68
- ], [
4
+ import { Fragment, useCallback, useMemo } from "react";
5
+ import { useDataBrowserUICustomization } from "../../contexts/DataBrowserUICustomizationContext.js";
6
+ import { BucketLocation } from "./BucketLocation.js";
7
+ const SEARCH_QUERY_PARAM = 'search';
8
+ const LOCATION_COLUMN_FLEX = '1.2';
9
+ const createBucketNameColumn = (onNavigateToBucket)=>({
10
+ Header: 'Bucket Name',
11
+ accessor: 'Name',
12
+ id: 'name',
13
+ Cell: ({ value })=>{
14
+ if (!value) return /*#__PURE__*/ jsx("span", {
15
+ children: "-"
16
+ });
17
+ return /*#__PURE__*/ jsx(ConstrainedText, {
18
+ text: /*#__PURE__*/ jsx(Link, {
19
+ onClick: (e)=>{
20
+ e.stopPropagation();
21
+ onNavigateToBucket?.(value);
22
+ },
23
+ children: value
24
+ }),
25
+ lineClamp: 2
26
+ });
27
+ },
28
+ cellStyle: {
29
+ flex: '1',
30
+ width: 'unset'
31
+ }
32
+ });
33
+ const createLocationColumn = ()=>({
34
+ Header: 'Storage Location',
35
+ accessor: 'Name',
36
+ id: 'location',
37
+ Cell: ({ value })=>{
38
+ if (!value) return /*#__PURE__*/ jsx("span", {
39
+ children: "-"
40
+ });
41
+ return /*#__PURE__*/ jsx(BucketLocation, {
42
+ bucketName: value
43
+ });
44
+ },
45
+ cellStyle: {
46
+ width: 'unset',
47
+ flex: LOCATION_COLUMN_FLEX
48
+ }
49
+ });
50
+ const createDateColumn = ()=>({
51
+ Header: 'Created on',
52
+ accessor: 'CreationDate',
53
+ id: 'date',
54
+ cellStyle: {
55
+ flex: '1',
56
+ textAlign: 'right',
57
+ paddingRight: spacing.r16,
58
+ width: 'unset'
59
+ },
60
+ Cell: ({ value })=>{
61
+ if (!value) return /*#__PURE__*/ jsx("span", {
62
+ children: "-"
63
+ });
64
+ return /*#__PURE__*/ jsx(FormattedDateTime, {
65
+ format: "date-time-second",
66
+ value: new Date(value)
67
+ });
68
+ }
69
+ });
70
+ const buildCustomColumn = (columnConfig)=>({
71
+ Header: columnConfig.header,
72
+ id: String(columnConfig.id),
73
+ Cell: ({ row })=>{
74
+ const RenderComponent = columnConfig.render;
75
+ return /*#__PURE__*/ jsx(RenderComponent, {
76
+ data: row.original
77
+ });
78
+ },
79
+ cellStyle: {
80
+ width: columnConfig.width ?? 'unset',
81
+ flex: columnConfig.width ? void 0 : '1',
82
+ ...columnConfig.cellStyle
83
+ }
84
+ });
85
+ function createOverrideMap(customItems) {
86
+ return new Map(customItems.filter((item)=>item.id).map((item)=>[
87
+ String(item.id),
88
+ item
89
+ ]));
90
+ }
91
+ function BucketList({ buckets, bucketStatus, selectedBucketName, onBucketSelect, onCreateBucket, onNavigateToBucket }) {
92
+ const { extraBucketListColumns, extraBucketListActions } = useDataBrowserUICustomization();
93
+ const columns = useMemo(()=>{
94
+ const defaultColumnsMap = {
95
+ name: createBucketNameColumn(onNavigateToBucket),
96
+ location: createLocationColumn(),
97
+ date: createDateColumn()
98
+ };
99
+ const customColumns = (extraBucketListColumns || []).map((config)=>buildCustomColumn(config));
100
+ const customColumnsMap = createOverrideMap(customColumns);
101
+ const getColumn = (id)=>customColumnsMap.get(id) || defaultColumnsMap[id];
102
+ const extraColumns = customColumns.filter((col)=>col.id && !(col.id in defaultColumnsMap));
103
+ return [
104
+ getColumn('name'),
105
+ getColumn('location'),
106
+ ...extraColumns,
107
+ getColumn('date')
108
+ ];
109
+ }, [
69
110
  onNavigateToBucket,
70
- renderBucketLocation
71
- ]);
72
- const tableData = useMemo(()=>buckets.map(({ Name, CreationDate, ...bucket })=>({
73
- Name,
74
- CreationDate,
75
- ...bucket
76
- })), [
77
- buckets
111
+ extraBucketListColumns
78
112
  ]);
79
113
  const selectedId = useMemo(()=>{
80
- if (buckets && selectedBucketName) return buckets.findIndex((bucket)=>bucket.Name === selectedBucketName);
81
- return null;
114
+ if (!buckets || !selectedBucketName) return;
115
+ const index = buckets.findIndex((bucket)=>bucket.Name === selectedBucketName);
116
+ return index >= 0 ? String(index) : void 0;
82
117
  }, [
83
118
  selectedBucketName,
84
119
  buckets
85
120
  ]);
121
+ const actions = useMemo(()=>{
122
+ const defaultActionsMap = {
123
+ createBucket: {
124
+ id: 'createBucket',
125
+ render: ()=>/*#__PURE__*/ jsx(Button, {
126
+ icon: /*#__PURE__*/ jsx(Icon, {
127
+ name: "Create-add"
128
+ }),
129
+ label: "Create Bucket",
130
+ variant: "primary",
131
+ onClick: onCreateBucket,
132
+ type: "submit"
133
+ })
134
+ }
135
+ };
136
+ const customActions = (extraBucketListActions || []).map((config)=>({
137
+ id: config.id,
138
+ render: config.render
139
+ }));
140
+ const customActionsMap = createOverrideMap(customActions);
141
+ const getAction = (id)=>customActionsMap.get(id) || defaultActionsMap[id];
142
+ const extraActions = customActions.filter((action)=>!(action.id in defaultActionsMap));
143
+ return [
144
+ getAction('createBucket'),
145
+ ...extraActions
146
+ ];
147
+ }, [
148
+ onCreateBucket,
149
+ extraBucketListActions
150
+ ]);
151
+ const handleRowSelected = useCallback((row)=>{
152
+ const isSelected = selectedBucketName === row.original.Name;
153
+ if (!isSelected && row.original.Name) onBucketSelect?.(row.original.Name);
154
+ }, [
155
+ selectedBucketName,
156
+ onBucketSelect
157
+ ]);
86
158
  return /*#__PURE__*/ jsxs(Table, {
87
159
  columns: columns,
88
- data: tableData,
160
+ data: buckets,
89
161
  status: bucketStatus,
90
162
  defaultSortingKey: "CreationDate",
91
163
  entityName: {
92
164
  en: {
93
- singular: "bucket",
94
- plural: "buckets"
165
+ singular: 'bucket',
166
+ plural: 'buckets'
95
167
  }
96
168
  },
97
169
  children: [
@@ -108,29 +180,24 @@ function BucketList({ buckets, bucketStatus, selectedBucketName, onBucketSelect,
108
180
  })
109
181
  }),
110
182
  /*#__PURE__*/ jsx(Box, {
111
- gap: "r16",
112
- children: /*#__PURE__*/ jsx(Button, {
113
- icon: /*#__PURE__*/ jsx(Icon, {
114
- name: "Create-add"
115
- }),
116
- label: "Create Bucket",
117
- variant: "primary",
118
- onClick: onCreateBucket,
119
- type: "submit"
120
- })
183
+ display: "flex",
184
+ gap: spacing.r16,
185
+ alignItems: "center",
186
+ children: actions.map((action)=>/*#__PURE__*/ jsx(Fragment, {
187
+ children: action.render()
188
+ }, action.id))
121
189
  })
122
190
  ]
123
191
  }),
124
192
  /*#__PURE__*/ jsx(Table.SingleSelectableContent, {
125
193
  rowHeight: "h40",
126
- selectedId: selectedId?.toString(),
127
- onRowSelected: (row)=>{
128
- const isSelected = selectedBucketName === row.original.Name;
129
- if (!isSelected && row.original.Name) onBucketSelect?.(row.original.Name);
130
- },
131
- separationLineVariant: "backgroundLevel1"
194
+ selectedId: selectedId,
195
+ onRowSelected: handleRowSelected,
196
+ separationLineVariant: "backgroundLevel1",
197
+ autoScrollToSelected: true
132
198
  })
133
199
  ]
134
200
  });
135
201
  }
202
+ BucketList.displayName = 'BucketList';
136
203
  export { BucketList };
@@ -1,16 +1,16 @@
1
1
  import { jsx } from "react/jsx-runtime";
2
- import { useGetBucketLocation } from "../../hooks/index.js";
3
2
  import { Loader } from "@scality/core-ui";
3
+ import { useGetBucketLocation } from "../../hooks/index.js";
4
4
  const BucketLocation = ({ bucketName })=>{
5
5
  const { data: bucketLocation, status } = useGetBucketLocation({
6
6
  Bucket: bucketName
7
7
  });
8
- if ("pending" === status) return /*#__PURE__*/ jsx(Loader, {});
9
- if ("error" === status) return /*#__PURE__*/ jsx("div", {
8
+ if ('pending' === status) return /*#__PURE__*/ jsx(Loader, {});
9
+ if ('error' === status) return /*#__PURE__*/ jsx("div", {
10
10
  children: "Error"
11
11
  });
12
12
  return /*#__PURE__*/ jsx("div", {
13
- children: bucketLocation?.LocationConstraint || "us-east-1"
13
+ children: bucketLocation?.LocationConstraint || 'us-east-1'
14
14
  });
15
15
  };
16
16
  export { BucketLocation };