@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
@@ -1,209 +1,498 @@
1
1
  import { jsx, jsxs } from "react/jsx-runtime";
2
- import { ConstrainedText, Icon, Loader, spacing } from "@scality/core-ui";
2
+ import { ConstrainedText, Icon, Loader, Stack, spacing } from "@scality/core-ui";
3
3
  import { Box, Button } from "@scality/core-ui/dist/next";
4
- import "react";
4
+ import { createContext, memo, useContext, useMemo } from "react";
5
+ import { useDataBrowserUICustomization } from "../../contexts/DataBrowserUICustomizationContext.js";
5
6
  import { useGetBucketAcl, useGetBucketCors, useGetBucketObjectLockConfiguration, useGetBucketPolicy, useGetBucketVersioning } from "../../hooks/index.js";
6
- import { useDataBrowserContext } from "../providers/DataBrowserProvider.js";
7
- import { Body, Group, GroupContent, GroupName, Key, Row, Table, TableContainer, Value } from "../ui/Table.elements.js";
7
+ import { isNotFoundError } from "../../utils/errorHandling.js";
8
+ import { EditRetentionButton } from "../objects/ObjectLock/EditRetentionButton.js";
9
+ import { useDataBrowserConfig } from "../providers/DataBrowserProvider.js";
10
+ import { Body, Group, GroupContent, GroupName, GroupValues, Key, Row, Table, TableContainer, Value } from "../ui/Table.elements.js";
11
+ import { BucketConfigEditButton } from "./BucketConfigEditButton.js";
8
12
  import { BucketLocation } from "./BucketLocation.js";
9
- import { BucketPolicyButton } from "./BucketPolicyButton.js";
10
- const BucketOverview = ({ bucketName, onEmptyBucket, onDeleteBucket, onEditPolicy, renderDeleteButton, renderEmptyButton, isEmptyBucketDisabled = true, isDeleteBucketDisabled = false })=>{
11
- const { getS3Config } = useDataBrowserContext();
12
- const config = getS3Config();
13
+ const ERROR_NO_SUCH_BUCKET_POLICY = 'NoSuchBucketPolicy';
14
+ const DEFAULT_PUBLIC_ACL_URI = 'http://acs.amazonaws.com/groups/global/AllUsers';
15
+ const STATUS_PENDING = 'pending';
16
+ const STATUS_ERROR = 'error';
17
+ const VERSIONING_STATUS_ENABLED = 'Enabled';
18
+ const OBJECT_LOCK_ENABLED = 'Enabled';
19
+ const ErrorField = ()=>/*#__PURE__*/ jsxs(Stack, {
20
+ direction: "horizontal",
21
+ children: [
22
+ /*#__PURE__*/ jsx(Icon, {
23
+ name: "Exclamation-circle",
24
+ color: "statusWarning"
25
+ }),
26
+ " Error"
27
+ ]
28
+ });
29
+ const resolveFieldValue = (bucketName, config)=>{
30
+ if (void 0 !== config.slotOverride) return config.slotOverride;
31
+ if (config.renderOverride) return config.renderOverride(bucketName);
32
+ return config.defaultValue;
33
+ };
34
+ const buildCustomField = (fieldConfig, entityName)=>{
35
+ const RenderComponent = fieldConfig.render;
36
+ return {
37
+ id: fieldConfig.id,
38
+ label: fieldConfig.label || fieldConfig.id,
39
+ value: /*#__PURE__*/ jsx(RenderComponent, {
40
+ entityName: entityName
41
+ })
42
+ };
43
+ };
44
+ const mergeFieldsWithExtras = (defaultFields, extraFieldConfigs, entityName, fieldOrder)=>{
45
+ const fieldsMap = {
46
+ ...defaultFields
47
+ };
48
+ const extraFields = [];
49
+ extraFieldConfigs?.forEach((fieldConfig)=>{
50
+ const fieldItem = buildCustomField(fieldConfig, entityName);
51
+ if (fieldsMap[fieldConfig.id]) fieldsMap[fieldConfig.id] = fieldItem;
52
+ else extraFields.push(fieldItem);
53
+ });
54
+ return [
55
+ ...fieldOrder.map((key)=>fieldsMap[key]),
56
+ ...extraFields
57
+ ];
58
+ };
59
+ const createNameField = (bucketName, nameField, renderName)=>({
60
+ id: 'name',
61
+ label: 'Name',
62
+ value: resolveFieldValue(bucketName, {
63
+ slotOverride: nameField,
64
+ renderOverride: renderName,
65
+ defaultValue: /*#__PURE__*/ jsx(ConstrainedText, {
66
+ text: bucketName,
67
+ lineClamp: 2
68
+ })
69
+ })
70
+ });
71
+ const createVersioningField = (bucketName, versioningData, versioningStatus, versioningField, renderVersioning)=>{
72
+ let defaultValue = 'Inactive';
73
+ if (versioningStatus === STATUS_PENDING) defaultValue = /*#__PURE__*/ jsx(Loader, {});
74
+ else if (versioningStatus === STATUS_ERROR) defaultValue = /*#__PURE__*/ jsx(ErrorField, {});
75
+ else if (versioningData?.Status === VERSIONING_STATUS_ENABLED) defaultValue = 'Active';
76
+ return {
77
+ id: 'versioning',
78
+ label: 'Versioning',
79
+ value: resolveFieldValue(bucketName, {
80
+ slotOverride: versioningField,
81
+ renderOverride: renderVersioning,
82
+ defaultValue
83
+ })
84
+ };
85
+ };
86
+ const createLocationField = (bucketName, locationField, renderLocation)=>({
87
+ id: 'location',
88
+ label: 'Location',
89
+ value: resolveFieldValue(bucketName, {
90
+ slotOverride: locationField,
91
+ renderOverride: renderLocation,
92
+ defaultValue: /*#__PURE__*/ jsx(BucketLocation, {
93
+ bucketName: bucketName
94
+ })
95
+ })
96
+ });
97
+ const createObjectLockField = (bucketName, objectLockStatus, isObjectLockNotConfigured, isObjectLockEnabled, objectLockField, renderObjectLock)=>{
98
+ let defaultValue;
99
+ defaultValue = objectLockStatus === STATUS_PENDING ? /*#__PURE__*/ jsx(Loader, {}) : objectLockStatus !== STATUS_ERROR || isObjectLockNotConfigured ? isObjectLockEnabled ? 'Enabled' : 'Disabled' : /*#__PURE__*/ jsx(ErrorField, {});
100
+ return {
101
+ id: 'objectLock',
102
+ label: 'Object-lock',
103
+ value: resolveFieldValue(bucketName, {
104
+ slotOverride: objectLockField,
105
+ renderOverride: renderObjectLock,
106
+ defaultValue
107
+ })
108
+ };
109
+ };
110
+ const createDefaultRetentionField = (bucketName, objectLockData, objectLockStatus, defaultRetentionField, renderDefaultRetention)=>{
111
+ const defaultValue = objectLockStatus === STATUS_PENDING ? /*#__PURE__*/ jsx(Loader, {}) : getDefaultBucketRetention(objectLockData);
112
+ return {
113
+ id: 'defaultRetention',
114
+ label: 'Default Retention',
115
+ value: resolveFieldValue(bucketName, {
116
+ slotOverride: defaultRetentionField,
117
+ renderOverride: renderDefaultRetention,
118
+ defaultValue
119
+ }),
120
+ actions: /*#__PURE__*/ jsx(EditRetentionButton, {
121
+ bucketName: bucketName
122
+ })
123
+ };
124
+ };
125
+ const createOwnerField = (bucketName, aclData, aclStatus, ownerField, renderOwner)=>{
126
+ let defaultValue = 'N/A';
127
+ if (aclStatus === STATUS_PENDING) defaultValue = /*#__PURE__*/ jsx(Loader, {});
128
+ else if (aclStatus === STATUS_ERROR) defaultValue = /*#__PURE__*/ jsx(ErrorField, {});
129
+ else if (aclData?.Owner?.DisplayName) defaultValue = aclData.Owner.DisplayName;
130
+ return {
131
+ id: 'owner',
132
+ label: 'Owner',
133
+ value: resolveFieldValue(bucketName, {
134
+ slotOverride: ownerField,
135
+ renderOverride: renderOwner,
136
+ defaultValue
137
+ })
138
+ };
139
+ };
140
+ const createAclField = (bucketName, aclData, aclStatus, aclField, renderAcl)=>{
141
+ let defaultValue = 'N/A';
142
+ if (aclStatus === STATUS_PENDING) defaultValue = /*#__PURE__*/ jsx(Loader, {});
143
+ else if (aclStatus === STATUS_ERROR) defaultValue = /*#__PURE__*/ jsx(ErrorField, {});
144
+ else if (aclData?.Grants?.length) {
145
+ const count = aclData.Grants.length;
146
+ defaultValue = `${count} Grantee${1 !== count ? 's' : ''}`;
147
+ }
148
+ return {
149
+ id: 'acl',
150
+ label: 'ACL',
151
+ value: resolveFieldValue(bucketName, {
152
+ slotOverride: aclField,
153
+ renderOverride: renderAcl,
154
+ defaultValue
155
+ })
156
+ };
157
+ };
158
+ const createCorsField = (bucketName, corsData, corsStatus, corsError, onEditCors, corsField, renderCors)=>{
159
+ let defaultValue;
160
+ const ERROR_NO_SUCH_CORS = 'NoSuchCORSConfiguration';
161
+ if (corsStatus === STATUS_ERROR && corsError?.name !== ERROR_NO_SUCH_CORS) defaultValue = /*#__PURE__*/ jsx(ErrorField, {});
162
+ else {
163
+ const hasCors = !!(corsData?.CORSRules && corsData.CORSRules.length > 0);
164
+ const handleEditCors = ()=>onEditCors?.(bucketName);
165
+ defaultValue = /*#__PURE__*/ jsxs(Box, {
166
+ display: "flex",
167
+ justifyContent: "space-between",
168
+ alignItems: "center",
169
+ gap: spacing.r8,
170
+ children: [
171
+ /*#__PURE__*/ jsx("span", {
172
+ children: hasCors ? 'Yes' : 'No'
173
+ }),
174
+ /*#__PURE__*/ jsx(BucketConfigEditButton, {
175
+ hasConfig: hasCors,
176
+ isLoading: corsStatus === STATUS_PENDING,
177
+ onEdit: handleEditCors,
178
+ configName: "bucket CORS"
179
+ })
180
+ ]
181
+ });
182
+ }
183
+ return {
184
+ id: 'cors',
185
+ label: 'CORS',
186
+ value: resolveFieldValue(bucketName, {
187
+ slotOverride: corsField,
188
+ renderOverride: renderCors ? (name)=>renderCors(name, onEditCors) : void 0,
189
+ defaultValue
190
+ })
191
+ };
192
+ };
193
+ const createPublicField = (bucketName, aclStatus, isPublic, publicField, renderPublic)=>{
194
+ const defaultValue = aclStatus === STATUS_PENDING ? /*#__PURE__*/ jsx(Loader, {}) : isPublic ? 'Yes' : 'No';
195
+ return {
196
+ id: 'public',
197
+ label: 'Public',
198
+ value: resolveFieldValue(bucketName, {
199
+ slotOverride: publicField,
200
+ renderOverride: renderPublic,
201
+ defaultValue
202
+ })
203
+ };
204
+ };
205
+ const createBucketPolicyField = (bucketName, policyData, policyStatus, policyError, onEditPolicy, bucketPolicyField, renderBucketPolicy)=>{
206
+ let defaultValue;
207
+ if (policyStatus === STATUS_ERROR && policyError?.name !== ERROR_NO_SUCH_BUCKET_POLICY) defaultValue = /*#__PURE__*/ jsx(ErrorField, {});
208
+ else {
209
+ const hasPolicy = !!policyData?.Policy;
210
+ const handleEditPolicy = ()=>onEditPolicy?.(bucketName);
211
+ defaultValue = /*#__PURE__*/ jsxs(Box, {
212
+ display: "flex",
213
+ justifyContent: "space-between",
214
+ alignItems: "center",
215
+ gap: spacing.r8,
216
+ children: [
217
+ /*#__PURE__*/ jsx("span", {
218
+ children: hasPolicy ? 'Configured' : 'Not configured'
219
+ }),
220
+ /*#__PURE__*/ jsx(BucketConfigEditButton, {
221
+ hasConfig: hasPolicy,
222
+ isLoading: policyStatus === STATUS_PENDING,
223
+ onEdit: handleEditPolicy,
224
+ configName: "bucket policy"
225
+ })
226
+ ]
227
+ });
228
+ }
229
+ return {
230
+ id: 'bucketPolicy',
231
+ label: 'Bucket Policy',
232
+ value: resolveFieldValue(bucketName, {
233
+ slotOverride: bucketPolicyField,
234
+ renderOverride: renderBucketPolicy ? (name)=>renderBucketPolicy(name, onEditPolicy) : void 0,
235
+ defaultValue
236
+ })
237
+ };
238
+ };
239
+ const BucketOverviewContext = /*#__PURE__*/ createContext(null);
240
+ function useBucketOverviewContext() {
241
+ const context = useContext(BucketOverviewContext);
242
+ if (!context) throw new Error('BucketOverview components must be used within BucketOverview');
243
+ return context;
244
+ }
245
+ const getDefaultBucketRetention = (objectLockData)=>{
246
+ const defaultRetention = objectLockData?.ObjectLockConfiguration?.Rule?.DefaultRetention;
247
+ if (!defaultRetention || !defaultRetention.Days && !defaultRetention.Years) return 'Inactive';
248
+ let retentionPeriod = '';
249
+ if (defaultRetention.Days) {
250
+ const unit = 1 === defaultRetention.Days ? 'day' : 'days';
251
+ retentionPeriod = `${defaultRetention.Days} ${unit}`;
252
+ } else if (defaultRetention.Years) {
253
+ const unit = 1 === defaultRetention.Years ? 'year' : 'years';
254
+ retentionPeriod = `${defaultRetention.Years} ${unit}`;
255
+ }
256
+ const mode = defaultRetention.Mode || 'GOVERNANCE';
257
+ const capitalizedMode = mode.charAt(0).toUpperCase() + mode.slice(1).toLowerCase();
258
+ return `${capitalizedMode} - ${retentionPeriod}`;
259
+ };
260
+ const BucketOverviewRoot = ({ bucketName, children })=>{
261
+ const contextValue = useMemo(()=>({
262
+ bucketName
263
+ }), [
264
+ bucketName
265
+ ]);
266
+ return /*#__PURE__*/ jsx(BucketOverviewContext.Provider, {
267
+ value: contextValue,
268
+ children: /*#__PURE__*/ jsx(TableContainer, {
269
+ children: children
270
+ })
271
+ });
272
+ };
273
+ const Actions = /*#__PURE__*/ memo(({ onEmptyBucket, onDeleteBucket, renderEmptyButton, renderDeleteButton, isEmptyBucketDisabled = true, isDeleteBucketDisabled = false })=>{
274
+ const { bucketName } = useBucketOverviewContext();
275
+ return /*#__PURE__*/ jsxs(Box, {
276
+ display: "flex",
277
+ justifyContent: "flex-end",
278
+ paddingBottom: spacing.r16,
279
+ children: [
280
+ renderEmptyButton ? renderEmptyButton(bucketName) : /*#__PURE__*/ jsx(Button, {
281
+ icon: /*#__PURE__*/ jsx(Icon, {
282
+ name: "Eraser"
283
+ }),
284
+ disabled: isEmptyBucketDisabled,
285
+ variant: "danger",
286
+ label: "Empty Bucket",
287
+ onClick: onEmptyBucket
288
+ }),
289
+ renderDeleteButton ? renderDeleteButton(bucketName) : /*#__PURE__*/ jsx(Button, {
290
+ icon: /*#__PURE__*/ jsx(Icon, {
291
+ name: "Delete"
292
+ }),
293
+ disabled: isDeleteBucketDisabled,
294
+ variant: "danger",
295
+ label: "Delete Bucket",
296
+ onClick: onDeleteBucket
297
+ })
298
+ ]
299
+ });
300
+ });
301
+ Actions.displayName = 'BucketOverview.Actions';
302
+ const Section = /*#__PURE__*/ memo(({ title, children })=>/*#__PURE__*/ jsxs(Group, {
303
+ children: [
304
+ /*#__PURE__*/ jsx(GroupName, {
305
+ children: title
306
+ }),
307
+ /*#__PURE__*/ jsx(GroupContent, {
308
+ children: children
309
+ })
310
+ ]
311
+ }));
312
+ Section.displayName = 'BucketOverview.Section';
313
+ const Field = /*#__PURE__*/ memo(({ label, value, loading, error, errorMessage = 'Error', children, actions })=>{
314
+ const renderValue = ()=>{
315
+ if (loading) return /*#__PURE__*/ jsx(Loader, {});
316
+ if (error) return errorMessage;
317
+ return children || value || 'N/A';
318
+ };
319
+ return /*#__PURE__*/ jsxs(Row, {
320
+ children: [
321
+ /*#__PURE__*/ jsx(Key, {
322
+ children: label
323
+ }),
324
+ actions ? /*#__PURE__*/ jsxs(GroupValues, {
325
+ children: [
326
+ renderValue(),
327
+ actions
328
+ ]
329
+ }) : /*#__PURE__*/ jsx(Value, {
330
+ children: renderValue()
331
+ })
332
+ ]
333
+ });
334
+ });
335
+ Field.displayName = 'BucketOverview.Field';
336
+ const Sections = /*#__PURE__*/ memo(({ children })=>/*#__PURE__*/ jsx(Table, {
337
+ children: /*#__PURE__*/ jsx(Body, {
338
+ children: children
339
+ })
340
+ }));
341
+ Sections.displayName = 'BucketOverview.Sections';
342
+ const GeneralSection = /*#__PURE__*/ memo(({ nameField, versioningField, locationField, renderName, renderVersioning, renderLocation })=>{
343
+ const { bucketName } = useBucketOverviewContext();
344
+ const { extraBucketOverviewGeneral } = useDataBrowserUICustomization();
13
345
  const { data: versioningData, status: versioningStatus } = useGetBucketVersioning({
14
346
  Bucket: bucketName
15
347
  });
16
- const { data: aclData, status: aclStatus } = useGetBucketAcl({
348
+ const fields = useMemo(()=>{
349
+ const defaultFields = {
350
+ name: createNameField(bucketName, nameField, renderName),
351
+ versioning: createVersioningField(bucketName, versioningData, versioningStatus, versioningField, renderVersioning),
352
+ location: createLocationField(bucketName, locationField, renderLocation)
353
+ };
354
+ return mergeFieldsWithExtras(defaultFields, extraBucketOverviewGeneral, bucketName, [
355
+ 'name',
356
+ 'versioning',
357
+ 'location'
358
+ ]);
359
+ }, [
360
+ bucketName,
361
+ extraBucketOverviewGeneral,
362
+ nameField,
363
+ versioningField,
364
+ locationField,
365
+ renderName,
366
+ renderVersioning,
367
+ renderLocation,
368
+ versioningData,
369
+ versioningStatus
370
+ ]);
371
+ return /*#__PURE__*/ jsx(Section, {
372
+ title: "General",
373
+ children: fields.map((field)=>/*#__PURE__*/ jsx(Field, {
374
+ label: field.label,
375
+ actions: field.actions,
376
+ children: field.value
377
+ }, field.id))
378
+ });
379
+ });
380
+ GeneralSection.displayName = 'BucketOverview.GeneralSection';
381
+ const DataProtectionSection = /*#__PURE__*/ memo(({ objectLockField, defaultRetentionField, renderObjectLock, renderDefaultRetention })=>{
382
+ const { bucketName } = useBucketOverviewContext();
383
+ const { extraBucketOverviewDataProtection } = useDataBrowserUICustomization();
384
+ const { data: objectLockData, status: objectLockStatus, error: objectLockError } = useGetBucketObjectLockConfiguration({
17
385
  Bucket: bucketName
18
386
  });
19
- const { data: corsData, status: corsStatus } = useGetBucketCors({
387
+ const isObjectLockNotConfigured = objectLockStatus === STATUS_ERROR && isNotFoundError(objectLockError);
388
+ const isObjectLockEnabled = objectLockData?.ObjectLockConfiguration?.ObjectLockEnabled === OBJECT_LOCK_ENABLED;
389
+ const fields = useMemo(()=>{
390
+ const defaultFields = {
391
+ objectLock: createObjectLockField(bucketName, objectLockStatus, isObjectLockNotConfigured, isObjectLockEnabled, objectLockField, renderObjectLock),
392
+ defaultRetention: createDefaultRetentionField(bucketName, objectLockData, objectLockStatus, defaultRetentionField, renderDefaultRetention)
393
+ };
394
+ const fieldOrder = isObjectLockEnabled ? [
395
+ 'objectLock',
396
+ 'defaultRetention'
397
+ ] : [
398
+ 'objectLock'
399
+ ];
400
+ return mergeFieldsWithExtras(defaultFields, extraBucketOverviewDataProtection, bucketName, fieldOrder);
401
+ }, [
402
+ bucketName,
403
+ extraBucketOverviewDataProtection,
404
+ objectLockField,
405
+ defaultRetentionField,
406
+ renderObjectLock,
407
+ renderDefaultRetention,
408
+ objectLockData,
409
+ objectLockStatus,
410
+ isObjectLockNotConfigured,
411
+ isObjectLockEnabled
412
+ ]);
413
+ return /*#__PURE__*/ jsx(Section, {
414
+ title: "Data protection",
415
+ children: fields.map((field)=>/*#__PURE__*/ jsx(Field, {
416
+ label: field.label,
417
+ actions: field.actions,
418
+ children: field.value
419
+ }, field.id))
420
+ });
421
+ });
422
+ DataProtectionSection.displayName = 'BucketOverview.DataProtectionSection';
423
+ const PermissionsSection = /*#__PURE__*/ memo(({ onEditPolicy, onEditCors, ownerField, aclField, corsField, publicField, bucketPolicyField, renderOwner, renderAcl, renderCors, renderPublic, renderBucketPolicy })=>{
424
+ const { bucketName } = useBucketOverviewContext();
425
+ const { extraBucketOverviewPermissions } = useDataBrowserUICustomization();
426
+ const config = useDataBrowserConfig();
427
+ const { data: aclData, status: aclStatus } = useGetBucketAcl({
20
428
  Bucket: bucketName
21
429
  });
22
- const { data: objectLockData, status: objectLockStatus } = useGetBucketObjectLockConfiguration({
430
+ const { data: corsData, status: corsStatus, error: corsError } = useGetBucketCors({
23
431
  Bucket: bucketName
24
432
  });
25
433
  const { data: policyData, error: policyError, status: policyStatus } = useGetBucketPolicy({
26
434
  Bucket: bucketName
27
435
  });
28
- return /*#__PURE__*/ jsxs(TableContainer, {
29
- children: [
30
- /*#__PURE__*/ jsxs(Box, {
31
- display: "flex",
32
- justifyContent: "flex-end",
33
- paddingBottom: spacing.r16,
34
- children: [
35
- renderEmptyButton ? renderEmptyButton(bucketName) : /*#__PURE__*/ jsx(Button, {
36
- icon: /*#__PURE__*/ jsx(Icon, {
37
- name: "Eraser"
38
- }),
39
- disabled: isEmptyBucketDisabled,
40
- variant: "danger",
41
- label: "Empty Bucket",
42
- onClick: onEmptyBucket,
43
- style: {
44
- marginRight: "1rem"
45
- }
46
- }),
47
- renderDeleteButton ? renderDeleteButton(bucketName) : /*#__PURE__*/ jsx(Button, {
48
- icon: /*#__PURE__*/ jsx(Icon, {
49
- name: "Delete"
50
- }),
51
- disabled: isDeleteBucketDisabled,
52
- variant: "danger",
53
- label: "Delete Bucket",
54
- onClick: onDeleteBucket
55
- })
56
- ]
57
- }),
58
- /*#__PURE__*/ jsx(Table, {
59
- children: /*#__PURE__*/ jsxs(Body, {
60
- children: [
61
- /*#__PURE__*/ jsxs(Group, {
62
- children: [
63
- /*#__PURE__*/ jsx(GroupName, {
64
- children: "General"
65
- }),
66
- /*#__PURE__*/ jsxs(GroupContent, {
67
- children: [
68
- /*#__PURE__*/ jsxs(Row, {
69
- children: [
70
- /*#__PURE__*/ jsx(Key, {
71
- children: "Name"
72
- }),
73
- /*#__PURE__*/ jsx(Value, {
74
- width: "15rem",
75
- children: /*#__PURE__*/ jsx(ConstrainedText, {
76
- text: bucketName,
77
- lineClamp: 2
78
- })
79
- })
80
- ]
81
- }),
82
- /*#__PURE__*/ jsxs(Row, {
83
- children: [
84
- /*#__PURE__*/ jsx(Key, {
85
- children: "Versioning"
86
- }),
87
- /*#__PURE__*/ jsx(Value, {
88
- children: "pending" === versioningStatus ? /*#__PURE__*/ jsx(Loader, {}) : "error" === versioningStatus ? "Error" : versioningData?.Status === "Enabled" ? "Active" : "Inactive"
89
- })
90
- ]
91
- }),
92
- /*#__PURE__*/ jsxs(Row, {
93
- children: [
94
- /*#__PURE__*/ jsx(Key, {
95
- children: "Location"
96
- }),
97
- /*#__PURE__*/ jsx(Value, {
98
- children: /*#__PURE__*/ jsx(BucketLocation, {
99
- bucketName: bucketName
100
- })
101
- })
102
- ]
103
- })
104
- ]
105
- })
106
- ]
107
- }),
108
- /*#__PURE__*/ jsxs(Group, {
109
- children: [
110
- /*#__PURE__*/ jsx(GroupName, {
111
- children: "Data protection"
112
- }),
113
- /*#__PURE__*/ jsx(GroupContent, {
114
- children: /*#__PURE__*/ jsxs(Row, {
115
- children: [
116
- /*#__PURE__*/ jsx(Key, {
117
- children: "Object-lock"
118
- }),
119
- /*#__PURE__*/ jsx(Value, {
120
- children: "pending" === objectLockStatus ? /*#__PURE__*/ jsx(Loader, {}) : "error" === objectLockStatus ? "Disabled" : objectLockData?.ObjectLockConfiguration?.ObjectLockEnabled === "Enabled" ? "Enabled" : "Disabled"
121
- })
122
- ]
123
- })
124
- })
125
- ]
126
- }),
127
- /*#__PURE__*/ jsxs(Group, {
128
- children: [
129
- /*#__PURE__*/ jsx(GroupName, {
130
- children: "Permissions"
131
- }),
132
- /*#__PURE__*/ jsxs(GroupContent, {
133
- children: [
134
- /*#__PURE__*/ jsxs(Row, {
135
- children: [
136
- /*#__PURE__*/ jsx(Key, {
137
- children: "Owner"
138
- }),
139
- /*#__PURE__*/ jsx(Value, {
140
- children: "pending" === aclStatus ? /*#__PURE__*/ jsx(Loader, {}) : "error" === aclStatus ? "Error" : aclData?.Owner?.DisplayName || "N/A"
141
- })
142
- ]
143
- }),
144
- /*#__PURE__*/ jsxs(Row, {
145
- children: [
146
- /*#__PURE__*/ jsx(Key, {
147
- children: "ACL"
148
- }),
149
- /*#__PURE__*/ jsx(Value, {
150
- children: "pending" === aclStatus ? /*#__PURE__*/ jsx(Loader, {}) : "error" === aclStatus ? "Error" : aclData?.Grants?.length ? `${aclData.Grants.length} Grantee${1 !== aclData.Grants.length ? "s" : ""}` : "N/A"
151
- })
152
- ]
153
- }),
154
- /*#__PURE__*/ jsxs(Row, {
155
- children: [
156
- /*#__PURE__*/ jsx(Key, {
157
- children: "CORS"
158
- }),
159
- /*#__PURE__*/ jsx(Value, {
160
- children: "pending" === corsStatus ? /*#__PURE__*/ jsx(Loader, {}) : "error" === corsStatus ? "No" : corsData?.CORSRules && corsData.CORSRules.length > 0 ? "Yes" : "No"
161
- })
162
- ]
163
- }),
164
- /*#__PURE__*/ jsxs(Row, {
165
- children: [
166
- /*#__PURE__*/ jsx(Key, {
167
- children: "Public"
168
- }),
169
- /*#__PURE__*/ jsx(Value, {
170
- children: "pending" === aclStatus ? /*#__PURE__*/ jsx(Loader, {}) : "error" === aclStatus ? "No" : aclData?.Grants ? aclData.Grants.find((grant)=>grant.Grantee?.URI === (config.publicAclIndicator || "http://acs.amazonaws.com/groups/global/AllUsers")) ? "Yes" : "No" : "No"
171
- })
172
- ]
173
- }),
174
- /*#__PURE__*/ jsxs(Row, {
175
- children: [
176
- /*#__PURE__*/ jsx(Key, {
177
- children: "Bucket Policy"
178
- }),
179
- /*#__PURE__*/ jsx(Value, {
180
- children: "error" === policyStatus && policyError?.name !== "NoSuchBucketPolicy" ? "Error" : /*#__PURE__*/ jsxs(Box, {
181
- display: "flex",
182
- justifyContent: "space-between",
183
- alignItems: "center",
184
- gap: spacing.r8,
185
- children: [
186
- /*#__PURE__*/ jsx("span", {
187
- children: policyData?.Policy ? "Configured" : "Not configured"
188
- }),
189
- /*#__PURE__*/ jsx(BucketPolicyButton, {
190
- hasPolicy: !!policyData?.Policy,
191
- isLoading: "pending" === policyStatus,
192
- onEdit: ()=>onEditPolicy?.(bucketName)
193
- })
194
- ]
195
- })
196
- })
197
- ]
198
- })
199
- ]
200
- })
201
- ]
202
- })
203
- ]
204
- })
205
- })
206
- ]
436
+ const isPublic = useMemo(()=>aclData?.Grants?.some((grant)=>grant.Grantee?.URI === (config.publicAclIndicator || DEFAULT_PUBLIC_ACL_URI)) ?? false, [
437
+ aclData?.Grants,
438
+ config.publicAclIndicator
439
+ ]);
440
+ const fields = useMemo(()=>{
441
+ const defaultFields = {
442
+ owner: createOwnerField(bucketName, aclData, aclStatus, ownerField, renderOwner),
443
+ acl: createAclField(bucketName, aclData, aclStatus, aclField, renderAcl),
444
+ cors: createCorsField(bucketName, corsData, corsStatus, corsError, onEditCors, corsField, renderCors),
445
+ public: createPublicField(bucketName, aclStatus, isPublic, publicField, renderPublic),
446
+ bucketPolicy: createBucketPolicyField(bucketName, policyData, policyStatus, policyError, onEditPolicy, bucketPolicyField, renderBucketPolicy)
447
+ };
448
+ return mergeFieldsWithExtras(defaultFields, extraBucketOverviewPermissions, bucketName, [
449
+ 'owner',
450
+ 'acl',
451
+ 'cors',
452
+ 'public',
453
+ 'bucketPolicy'
454
+ ]);
455
+ }, [
456
+ bucketName,
457
+ extraBucketOverviewPermissions,
458
+ ownerField,
459
+ aclField,
460
+ corsField,
461
+ publicField,
462
+ bucketPolicyField,
463
+ renderOwner,
464
+ renderAcl,
465
+ renderCors,
466
+ renderPublic,
467
+ renderBucketPolicy,
468
+ onEditPolicy,
469
+ onEditCors,
470
+ aclData,
471
+ aclStatus,
472
+ corsData,
473
+ corsStatus,
474
+ corsError,
475
+ policyData,
476
+ policyError,
477
+ policyStatus,
478
+ isPublic
479
+ ]);
480
+ return /*#__PURE__*/ jsx(Section, {
481
+ title: "Permissions",
482
+ children: fields.map((field)=>/*#__PURE__*/ jsx(Field, {
483
+ label: field.label,
484
+ actions: field.actions,
485
+ children: field.value
486
+ }, field.id))
207
487
  });
208
- };
209
- export { BucketOverview };
488
+ });
489
+ PermissionsSection.displayName = 'BucketOverview.PermissionsSection';
490
+ const BucketOverview = BucketOverviewRoot;
491
+ BucketOverview.Actions = Actions;
492
+ BucketOverview.Sections = Sections;
493
+ BucketOverview.Section = Section;
494
+ BucketOverview.Field = Field;
495
+ BucketOverview.GeneralSection = GeneralSection;
496
+ BucketOverview.DataProtectionSection = DataProtectionSection;
497
+ BucketOverview.PermissionsSection = PermissionsSection;
498
+ export { BucketOverview, BucketOverviewContext, Field as BucketOverviewField, Section as BucketOverviewSection, useBucketOverviewContext };