@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,316 @@
1
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
2
+ import { joiResolver } from "@hookform/resolvers/joi";
3
+ import { Form, FormGroup, FormSection, Icon, Loader, Stack, Text, spacing, useToast } from "@scality/core-ui";
4
+ import { convertRemToPixels } from "@scality/core-ui/dist/components/tablev2/TableUtils";
5
+ import { Box, Button, Input } from "@scality/core-ui/dist/next";
6
+ import joi from "joi";
7
+ import { useCallback, useEffect, useMemo } from "react";
8
+ import { FormProvider, useForm } from "react-hook-form";
9
+ import { useParams } from "react-router";
10
+ import { useGetBucketNotification, useSetBucketNotification } from "../../../hooks/index.js";
11
+ import { useDataBrowserNavigate } from "../../../hooks/useDataBrowserNavigate.js";
12
+ import { EventsSection } from "./EventsSection.js";
13
+ const baseSchema = joi.object({
14
+ ruleName: joi.string().required().messages({
15
+ 'string.empty': 'This field is required'
16
+ }),
17
+ queueArn: joi.string().required().pattern(/^arn:aws:sqs:[a-z0-9-]+:\d+:.+$/).messages({
18
+ 'string.empty': 'This field is required',
19
+ 'string.pattern.base': 'Must be a valid ARN (e.g., arn:aws:sqs:region:account-id:queue-name)'
20
+ }),
21
+ events: joi.array().min(1).required().messages({
22
+ 'array.min': 'At least one event must be selected'
23
+ }),
24
+ prefix: joi.string().allow('').optional(),
25
+ suffix: joi.string().allow('').optional()
26
+ });
27
+ function BucketNotificationFormPage() {
28
+ const { bucketName, ruleId } = useParams();
29
+ const navigate = useDataBrowserNavigate();
30
+ const { showToast } = useToast();
31
+ const isEditMode = !!ruleId;
32
+ const { data: existingNotificationData, status: notificationStatus, error: notificationError } = useGetBucketNotification({
33
+ Bucket: bucketName
34
+ });
35
+ const existingRule = useMemo(()=>{
36
+ if (!isEditMode || !existingNotificationData?.QueueConfigurations || !ruleId) return null;
37
+ return existingNotificationData.QueueConfigurations.find((config)=>config.Id === decodeURIComponent(ruleId));
38
+ }, [
39
+ isEditMode,
40
+ existingNotificationData,
41
+ ruleId
42
+ ]);
43
+ const existingRuleNames = useMemo(()=>existingNotificationData?.QueueConfigurations?.map((config)=>config.Id)?.filter((id)=>!!id)?.filter((id)=>!isEditMode || id !== existingRule?.Id) || [], [
44
+ existingNotificationData,
45
+ isEditMode,
46
+ existingRule
47
+ ]);
48
+ const dynamicSchema = useMemo(()=>baseSchema.keys({
49
+ ruleName: joi.string().required().invalid(...existingRuleNames).messages({
50
+ 'string.empty': 'This field is required',
51
+ 'any.invalid': 'A rule with this name already exists'
52
+ })
53
+ }), [
54
+ existingRuleNames
55
+ ]);
56
+ const methods = useForm({
57
+ resolver: joiResolver(dynamicSchema),
58
+ mode: 'onChange',
59
+ defaultValues: {
60
+ ruleName: '',
61
+ queueArn: '',
62
+ events: [],
63
+ prefix: '',
64
+ suffix: ''
65
+ }
66
+ });
67
+ const { mutate: setNotification, isPending: isSaving } = useSetBucketNotification();
68
+ const { handleSubmit, register, reset, formState: { isValid, isDirty, errors } } = methods;
69
+ useEffect(()=>{
70
+ if (isEditMode && existingRule) {
71
+ const prefixRule = existingRule.Filter?.Key?.FilterRules?.find((r)=>'prefix' === r.Name);
72
+ const suffixRule = existingRule.Filter?.Key?.FilterRules?.find((r)=>'suffix' === r.Name);
73
+ reset({
74
+ ruleName: existingRule.Id || '',
75
+ queueArn: existingRule.QueueArn || '',
76
+ events: existingRule.Events || [],
77
+ prefix: prefixRule?.Value || '',
78
+ suffix: suffixRule?.Value || ''
79
+ });
80
+ }
81
+ }, [
82
+ isEditMode,
83
+ existingRule,
84
+ reset
85
+ ]);
86
+ const handleCancel = useCallback(()=>{
87
+ navigate(`/buckets/${bucketName}?tab=notification`);
88
+ }, [
89
+ navigate,
90
+ bucketName
91
+ ]);
92
+ const onSubmit = useCallback((data)=>{
93
+ const filterRules = [
94
+ ...data.prefix ? [
95
+ {
96
+ Name: 'prefix',
97
+ Value: data.prefix
98
+ }
99
+ ] : [],
100
+ ...data.suffix ? [
101
+ {
102
+ Name: 'suffix',
103
+ Value: data.suffix
104
+ }
105
+ ] : []
106
+ ];
107
+ const wildcardPrefixes = [
108
+ 's3:ObjectCreated:',
109
+ 's3:ObjectRemoved:',
110
+ 's3:ObjectRestore:',
111
+ 's3:LifecycleExpiration:',
112
+ 's3:Replication:',
113
+ 's3:ObjectTagging:'
114
+ ];
115
+ const filteredEvents = data.events.filter((event)=>{
116
+ if (event.endsWith('*')) return true;
117
+ for (const prefix of wildcardPrefixes)if (event.startsWith(prefix)) return !data.events.includes(`${prefix}*`);
118
+ return true;
119
+ });
120
+ const newQueueConfiguration = {
121
+ Id: data.ruleName,
122
+ QueueArn: data.queueArn,
123
+ Events: filteredEvents,
124
+ ...filterRules.length > 0 && {
125
+ Filter: {
126
+ Key: {
127
+ FilterRules: filterRules
128
+ }
129
+ }
130
+ }
131
+ };
132
+ const existingConfigurations = existingNotificationData?.QueueConfigurations || [];
133
+ const updatedConfigurations = isEditMode ? existingConfigurations.map((config)=>config.Id === existingRule?.Id ? newQueueConfiguration : config) : [
134
+ ...existingConfigurations,
135
+ newQueueConfiguration
136
+ ];
137
+ setNotification({
138
+ Bucket: bucketName,
139
+ NotificationConfiguration: {
140
+ QueueConfigurations: updatedConfigurations
141
+ }
142
+ }, {
143
+ onSuccess: ()=>{
144
+ showToast({
145
+ open: true,
146
+ message: `Notification rule ${isEditMode ? 'updated' : 'created'} successfully`,
147
+ status: 'success'
148
+ });
149
+ navigate(`/buckets/${bucketName}?tab=notification`);
150
+ },
151
+ onError: (error)=>{
152
+ const errorMessage = error instanceof Error ? error.message : `Failed to ${isEditMode ? 'update' : 'create'} notification rule`;
153
+ showToast({
154
+ open: true,
155
+ message: errorMessage,
156
+ status: 'error'
157
+ });
158
+ }
159
+ });
160
+ }, [
161
+ bucketName,
162
+ setNotification,
163
+ navigate,
164
+ showToast,
165
+ existingNotificationData,
166
+ isEditMode,
167
+ existingRule
168
+ ]);
169
+ if ('pending' === notificationStatus) return /*#__PURE__*/ jsx(Loader, {
170
+ centered: true,
171
+ children: /*#__PURE__*/ jsx(Text, {
172
+ children: "Loading..."
173
+ })
174
+ });
175
+ if ('error' === notificationStatus && notificationError) {
176
+ const errorMessage = notificationError instanceof Error ? notificationError.message : 'Failed to load notification configuration';
177
+ return /*#__PURE__*/ jsx(Form, {
178
+ layout: {
179
+ kind: 'page',
180
+ title: isEditMode ? 'Edit Bucket Notification' : 'Create Bucket Notification'
181
+ },
182
+ children: /*#__PURE__*/ jsx(Box, {
183
+ display: "flex",
184
+ justifyContent: "center",
185
+ alignItems: "center",
186
+ padding: spacing.r16,
187
+ children: /*#__PURE__*/ jsx(Text, {
188
+ color: "statusCritical",
189
+ children: errorMessage
190
+ })
191
+ })
192
+ });
193
+ }
194
+ if (isEditMode && (!existingRule || !existingRule.Id)) return /*#__PURE__*/ jsx(Form, {
195
+ layout: {
196
+ kind: 'page',
197
+ title: 'Edit Bucket Notification'
198
+ },
199
+ children: /*#__PURE__*/ jsx(Box, {
200
+ display: "flex",
201
+ justifyContent: "center",
202
+ alignItems: "center",
203
+ padding: spacing.r16,
204
+ children: /*#__PURE__*/ jsx(Text, {
205
+ color: "statusCritical",
206
+ children: "Notification rule not found"
207
+ })
208
+ })
209
+ });
210
+ return /*#__PURE__*/ jsx(FormProvider, {
211
+ ...methods,
212
+ children: /*#__PURE__*/ jsxs(Form, {
213
+ layout: {
214
+ kind: 'page',
215
+ title: isEditMode ? 'Edit Bucket Notification' : 'Create Bucket Notification'
216
+ },
217
+ requireMode: "partial",
218
+ onSubmit: handleSubmit(onSubmit),
219
+ rightActions: /*#__PURE__*/ jsxs(Stack, {
220
+ gap: "r16",
221
+ children: [
222
+ /*#__PURE__*/ jsx(Button, {
223
+ id: "cancel-btn",
224
+ variant: "outline",
225
+ type: "button",
226
+ label: "Cancel",
227
+ onClick: handleCancel,
228
+ disabled: isSaving
229
+ }),
230
+ /*#__PURE__*/ jsx(Button, {
231
+ id: isEditMode ? 'save-notification-btn' : 'create-notification-btn',
232
+ type: "submit",
233
+ variant: "primary",
234
+ label: isEditMode ? 'Save' : 'Create',
235
+ icon: isEditMode ? /*#__PURE__*/ jsx(Icon, {
236
+ name: "Save"
237
+ }) : void 0,
238
+ disabled: isEditMode ? !isDirty || !isValid || isSaving : !isValid || isSaving
239
+ })
240
+ ]
241
+ }),
242
+ children: [
243
+ /*#__PURE__*/ jsx(FormSection, {
244
+ forceLabelWidth: convertRemToPixels(13),
245
+ children: /*#__PURE__*/ jsx(FormGroup, {
246
+ label: "Rule name",
247
+ id: "ruleName",
248
+ direction: "horizontal",
249
+ error: errors?.ruleName?.message,
250
+ helpErrorPosition: "bottom",
251
+ labelHelpTooltip: /*#__PURE__*/ jsx(Fragment, {}),
252
+ required: true,
253
+ content: isEditMode ? /*#__PURE__*/ jsx(Text, {
254
+ children: existingRule?.Id
255
+ }) : /*#__PURE__*/ jsx(Input, {
256
+ id: "ruleName",
257
+ ...register('ruleName')
258
+ })
259
+ })
260
+ }),
261
+ /*#__PURE__*/ jsx(EventsSection, {}),
262
+ /*#__PURE__*/ jsx(FormSection, {
263
+ forceLabelWidth: convertRemToPixels(13),
264
+ children: /*#__PURE__*/ jsx(FormGroup, {
265
+ label: "Destination Queue",
266
+ id: "queueArn",
267
+ direction: "horizontal",
268
+ error: errors?.queueArn?.message,
269
+ helpErrorPosition: "bottom",
270
+ labelHelpTooltip: /*#__PURE__*/ jsx(Fragment, {}),
271
+ required: true,
272
+ content: /*#__PURE__*/ jsx(Input, {
273
+ id: "queueArn",
274
+ placeholder: "arn:aws:sqs:us-east-1:1xx:name",
275
+ ...register('queueArn')
276
+ })
277
+ })
278
+ }),
279
+ /*#__PURE__*/ jsx(FormSection, {
280
+ title: {
281
+ name: 'Filters'
282
+ },
283
+ children: /*#__PURE__*/ jsxs(Stack, {
284
+ direction: "horizontal",
285
+ gap: "r16",
286
+ children: [
287
+ /*#__PURE__*/ jsx(FormGroup, {
288
+ label: "Prefix",
289
+ id: "prefix",
290
+ direction: "horizontal",
291
+ content: /*#__PURE__*/ jsx(Input, {
292
+ id: "prefix",
293
+ placeholder: "",
294
+ size: "2/3",
295
+ ...register('prefix')
296
+ })
297
+ }),
298
+ /*#__PURE__*/ jsx(FormGroup, {
299
+ label: "Suffix",
300
+ id: "suffix",
301
+ direction: "horizontal",
302
+ content: /*#__PURE__*/ jsx(Input, {
303
+ id: "suffix",
304
+ placeholder: "",
305
+ size: "2/3",
306
+ ...register('suffix')
307
+ })
308
+ })
309
+ ]
310
+ })
311
+ })
312
+ ]
313
+ })
314
+ });
315
+ }
316
+ export { BucketNotificationFormPage };
@@ -0,0 +1,10 @@
1
+ import type { QueueConfiguration } from '@aws-sdk/client-s3';
2
+ interface BucketNotificationListProps {
3
+ bucketName: string;
4
+ notificationRules: QueueConfiguration[];
5
+ notificationStatus?: 'idle' | 'loading' | 'error' | 'success';
6
+ onCreateRule?: () => void;
7
+ onEditRule?: (ruleId: string) => void;
8
+ }
9
+ export declare function BucketNotificationList({ bucketName, notificationRules, notificationStatus, onCreateRule, onEditRule, }: BucketNotificationListProps): import("react/jsx-runtime").JSX.Element;
10
+ export {};
@@ -0,0 +1,267 @@
1
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
2
+ import { ConstrainedText, Icon, Stack, Tooltip, spacing, useToast } from "@scality/core-ui";
3
+ import { Box, Button, Table } from "@scality/core-ui/dist/next";
4
+ import { useMemo, useState } from "react";
5
+ import { useSetBucketNotification } from "../../../hooks/bucketConfiguration.js";
6
+ import { useTableRowSelection } from "../../../hooks/useTableRowSelection.js";
7
+ import { ConfirmDeleteRuleModal } from "../../ui/ConfirmDeleteRuleModal.js";
8
+ const MAX_VISIBLE_EVENTS = 3;
9
+ function BucketNotificationList({ bucketName, notificationRules, notificationStatus, onCreateRule, onEditRule }) {
10
+ const { showToast } = useToast();
11
+ const updateNotificationMutation = useSetBucketNotification();
12
+ const [deleteModalState, setDeleteModalState] = useState({
13
+ isOpen: false,
14
+ ruleId: ''
15
+ });
16
+ const handleDeleteConfirm = ()=>{
17
+ if (!deleteModalState.ruleId) {
18
+ showToast({
19
+ open: true,
20
+ message: 'Cannot delete rule: Invalid rule ID',
21
+ status: 'error'
22
+ });
23
+ setDeleteModalState({
24
+ isOpen: false,
25
+ ruleId: ''
26
+ });
27
+ return;
28
+ }
29
+ const remainingRules = notificationRules.filter((rule)=>rule.Id !== deleteModalState.ruleId);
30
+ updateNotificationMutation.mutate({
31
+ Bucket: bucketName,
32
+ NotificationConfiguration: {
33
+ QueueConfigurations: remainingRules
34
+ }
35
+ }, {
36
+ onSuccess: ()=>{
37
+ showToast({
38
+ open: true,
39
+ message: 'Notification rule deleted successfully',
40
+ status: 'success'
41
+ });
42
+ setDeleteModalState({
43
+ isOpen: false,
44
+ ruleId: ''
45
+ });
46
+ },
47
+ onError: (error)=>{
48
+ const errorMessage = error instanceof Error ? error.message : 'Failed to delete notification rule';
49
+ showToast({
50
+ open: true,
51
+ message: errorMessage,
52
+ status: 'error'
53
+ });
54
+ setDeleteModalState({
55
+ isOpen: false,
56
+ ruleId: ''
57
+ });
58
+ }
59
+ });
60
+ };
61
+ const columns = useMemo(()=>[
62
+ {
63
+ Header: 'Rule Name',
64
+ accessor: 'ID',
65
+ id: 'id',
66
+ Cell: ({ value })=>/*#__PURE__*/ jsx(ConstrainedText, {
67
+ text: value || '-',
68
+ lineClamp: 2
69
+ }),
70
+ cellStyle: {
71
+ flex: '1',
72
+ width: 'unset'
73
+ }
74
+ },
75
+ {
76
+ Header: 'Events',
77
+ accessor: 'Events',
78
+ id: 'events',
79
+ Cell: ({ value })=>{
80
+ if (!value || 0 === value.length) return /*#__PURE__*/ jsx("span", {
81
+ children: "-"
82
+ });
83
+ const visibleEvents = value.slice(0, MAX_VISIBLE_EVENTS);
84
+ const remainingCount = value.length - MAX_VISIBLE_EVENTS;
85
+ const allEventsTooltip = /*#__PURE__*/ jsx("ul", {
86
+ style: {
87
+ margin: 0,
88
+ paddingLeft: '1.5rem'
89
+ },
90
+ children: value.map((event)=>/*#__PURE__*/ jsx("li", {
91
+ children: event
92
+ }, event))
93
+ });
94
+ return /*#__PURE__*/ jsxs(Stack, {
95
+ direction: "horizontal",
96
+ gap: "r8",
97
+ children: [
98
+ /*#__PURE__*/ jsxs(Box, {
99
+ display: "flex",
100
+ flexDirection: "column",
101
+ gap: spacing.r4,
102
+ style: {
103
+ borderLeft: '2px solid currentColor',
104
+ paddingLeft: spacing.r8,
105
+ opacity: 0.8
106
+ },
107
+ children: [
108
+ visibleEvents.map((event)=>/*#__PURE__*/ jsx("span", {
109
+ children: event
110
+ }, event)),
111
+ remainingCount > 0 && /*#__PURE__*/ jsxs("span", {
112
+ style: {
113
+ fontStyle: 'italic'
114
+ },
115
+ children: [
116
+ "+",
117
+ remainingCount,
118
+ " more"
119
+ ]
120
+ })
121
+ ]
122
+ }),
123
+ remainingCount > 0 && /*#__PURE__*/ jsx(Tooltip, {
124
+ overlay: allEventsTooltip,
125
+ placement: "top",
126
+ overlayStyle: {
127
+ maxWidth: '30rem'
128
+ },
129
+ children: /*#__PURE__*/ jsx("span", {
130
+ style: {
131
+ cursor: 'help'
132
+ },
133
+ children: /*#__PURE__*/ jsx(Icon, {
134
+ name: "Info",
135
+ size: "sm"
136
+ })
137
+ })
138
+ })
139
+ ]
140
+ });
141
+ },
142
+ cellStyle: {
143
+ width: 'unset',
144
+ flex: '2',
145
+ alignItems: 'flex-start',
146
+ paddingTop: spacing.r8,
147
+ paddingBottom: spacing.r8
148
+ }
149
+ },
150
+ {
151
+ Header: '',
152
+ accessor: 'rule',
153
+ id: 'operations',
154
+ cellStyle: {
155
+ flex: '0.5',
156
+ textAlign: 'right',
157
+ paddingRight: spacing.r16,
158
+ width: 'unset'
159
+ },
160
+ Cell: ({ value })=>{
161
+ const hasValidId = !!value.Id;
162
+ return /*#__PURE__*/ jsxs(Box, {
163
+ display: "flex",
164
+ gap: spacing.r8,
165
+ justifyContent: "flex-end",
166
+ children: [
167
+ /*#__PURE__*/ jsx(Button, {
168
+ icon: /*#__PURE__*/ jsx(Icon, {
169
+ name: "Edit"
170
+ }),
171
+ variant: "secondary",
172
+ type: "button",
173
+ disabled: !hasValidId,
174
+ onClick: (e)=>{
175
+ e.stopPropagation();
176
+ if (hasValidId) onEditRule?.(value.Id);
177
+ },
178
+ "aria-label": "Edit rule",
179
+ tooltip: {
180
+ overlay: hasValidId ? 'Edit rule' : 'Cannot edit rule without ID'
181
+ }
182
+ }),
183
+ /*#__PURE__*/ jsx(Button, {
184
+ icon: /*#__PURE__*/ jsx(Icon, {
185
+ name: "Delete"
186
+ }),
187
+ variant: "danger",
188
+ type: "button",
189
+ disabled: !hasValidId,
190
+ onClick: (e)=>{
191
+ e.stopPropagation();
192
+ if (hasValidId) setDeleteModalState({
193
+ isOpen: true,
194
+ ruleId: value.Id
195
+ });
196
+ },
197
+ "aria-label": "Delete rule",
198
+ tooltip: {
199
+ overlay: hasValidId ? 'Delete rule' : 'Cannot delete rule without ID'
200
+ }
201
+ })
202
+ ]
203
+ });
204
+ }
205
+ }
206
+ ], [
207
+ onEditRule
208
+ ]);
209
+ const tableData = useMemo(()=>notificationRules.map((rule)=>({
210
+ ID: rule.Id || '-',
211
+ Events: rule.Events || [],
212
+ rule
213
+ })), [
214
+ notificationRules
215
+ ]);
216
+ const { selectedId, onRowSelected } = useTableRowSelection(tableData);
217
+ return /*#__PURE__*/ jsxs(Fragment, {
218
+ children: [
219
+ /*#__PURE__*/ jsxs(Table, {
220
+ columns: columns,
221
+ data: tableData,
222
+ status: notificationStatus,
223
+ defaultSortingKey: "id",
224
+ entityName: {
225
+ en: {
226
+ singular: 'notification rule',
227
+ plural: 'notification rules'
228
+ }
229
+ },
230
+ children: [
231
+ /*#__PURE__*/ jsx(Box, {
232
+ display: "flex",
233
+ justifyContent: "flex-end",
234
+ padding: spacing.r16,
235
+ children: /*#__PURE__*/ jsx(Button, {
236
+ icon: /*#__PURE__*/ jsx(Icon, {
237
+ name: "Create-add"
238
+ }),
239
+ label: "Add Notification",
240
+ variant: "primary",
241
+ onClick: onCreateRule,
242
+ type: "button"
243
+ })
244
+ }),
245
+ /*#__PURE__*/ jsx(Table.SingleSelectableContent, {
246
+ rowHeight: "h64",
247
+ separationLineVariant: "backgroundLevel1",
248
+ selectedId: selectedId?.toString(),
249
+ onRowSelected: onRowSelected
250
+ })
251
+ ]
252
+ }),
253
+ /*#__PURE__*/ jsx(ConfirmDeleteRuleModal, {
254
+ isOpen: deleteModalState.isOpen,
255
+ ruleId: deleteModalState.ruleId,
256
+ ruleType: "notification",
257
+ isDeleting: updateNotificationMutation.isPending,
258
+ onConfirm: handleDeleteConfirm,
259
+ onCancel: ()=>setDeleteModalState({
260
+ isOpen: false,
261
+ ruleId: ''
262
+ })
263
+ })
264
+ ]
265
+ });
266
+ }
267
+ export { BucketNotificationList };