@scality/data-browser-library 1.0.0-preview.9 → 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 (285) 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.js +271 -105
  9. package/dist/components/__tests__/BucketDetails.test.d.ts +1 -0
  10. package/dist/components/__tests__/BucketDetails.test.js +421 -0
  11. package/dist/components/__tests__/BucketLifecycleFormPage.test.d.ts +13 -0
  12. package/dist/components/__tests__/BucketLifecycleFormPage.test.js +178 -178
  13. package/dist/components/__tests__/BucketLifecycleList.test.js +85 -85
  14. package/dist/components/__tests__/BucketList.test.js +463 -239
  15. package/dist/components/__tests__/BucketNotificationFormPage.test.d.ts +1 -0
  16. package/dist/components/__tests__/BucketNotificationFormPage.test.js +348 -0
  17. package/dist/components/__tests__/BucketNotificationList.test.d.ts +1 -0
  18. package/dist/components/__tests__/BucketNotificationList.test.js +379 -0
  19. package/dist/components/__tests__/BucketOverview.test.js +281 -266
  20. package/dist/components/__tests__/BucketPolicyPage.test.js +151 -99
  21. package/dist/components/__tests__/BucketReplicationFormPage.test.d.ts +15 -0
  22. package/dist/components/__tests__/BucketReplicationFormPage.test.js +544 -544
  23. package/dist/components/__tests__/BucketReplicationList.test.js +106 -106
  24. package/dist/components/__tests__/CreateFolderButton.test.js +56 -56
  25. package/dist/components/__tests__/DeleteBucketButton.test.js +64 -64
  26. package/dist/components/__tests__/DeleteBucketConfigRuleButton.test.js +47 -47
  27. package/dist/components/__tests__/DeleteObjectButton.test.js +64 -64
  28. package/dist/components/__tests__/EmptyBucketButton.test.js +59 -59
  29. package/dist/components/__tests__/MetadataSearch.test.js +65 -65
  30. package/dist/components/__tests__/ObjectList.test.js +741 -240
  31. package/dist/components/__tests__/UploadButton.test.js +45 -45
  32. package/dist/components/breadcrumb/Breadcrumb.d.ts +6 -0
  33. package/dist/components/breadcrumb/Breadcrumb.js +37 -0
  34. package/dist/components/breadcrumb/DataBrowserBreadcrumb.d.ts +1 -0
  35. package/dist/components/breadcrumb/DataBrowserBreadcrumb.js +10 -0
  36. package/dist/components/breadcrumb/__tests__/Breadcrumb.test.d.ts +1 -0
  37. package/dist/components/breadcrumb/__tests__/Breadcrumb.test.js +196 -0
  38. package/dist/components/breadcrumb/__tests__/DataBrowserBreadcrumb.test.d.ts +1 -0
  39. package/dist/components/breadcrumb/__tests__/DataBrowserBreadcrumb.test.js +153 -0
  40. package/dist/components/breadcrumb/__tests__/useBreadcrumbPaths.test.d.ts +1 -0
  41. package/dist/components/breadcrumb/__tests__/useBreadcrumbPaths.test.js +134 -0
  42. package/dist/components/breadcrumb/index.d.ts +8 -0
  43. package/dist/components/breadcrumb/index.js +4 -0
  44. package/dist/components/breadcrumb/useBreadcrumbPaths.d.ts +2 -0
  45. package/dist/components/breadcrumb/useBreadcrumbPaths.js +82 -0
  46. package/dist/components/buckets/BucketAccessor.d.ts +2 -0
  47. package/dist/components/buckets/BucketAccessor.js +125 -0
  48. package/dist/components/buckets/BucketConfigEditButton.d.ts +8 -0
  49. package/dist/components/buckets/{BucketPolicyButton.js → BucketConfigEditButton.js} +9 -5
  50. package/dist/components/buckets/BucketCorsPage.d.ts +1 -0
  51. package/dist/components/buckets/BucketCorsPage.js +234 -0
  52. package/dist/components/buckets/BucketCreate.d.ts +3 -2
  53. package/dist/components/buckets/BucketCreate.js +89 -47
  54. package/dist/components/buckets/BucketDetails.d.ts +42 -0
  55. package/dist/components/buckets/BucketDetails.js +249 -85
  56. package/dist/components/buckets/BucketLifecycleFormPage.js +206 -190
  57. package/dist/components/buckets/BucketLifecycleList.d.ts +2 -2
  58. package/dist/components/buckets/BucketLifecycleList.js +47 -47
  59. package/dist/components/buckets/BucketList.d.ts +7 -8
  60. package/dist/components/buckets/BucketList.js +158 -101
  61. package/dist/components/buckets/BucketLocation.js +4 -4
  62. package/dist/components/buckets/BucketOverview.d.ts +22 -2
  63. package/dist/components/buckets/BucketOverview.js +394 -187
  64. package/dist/components/buckets/BucketPage.js +43 -21
  65. package/dist/components/buckets/BucketPolicyPage.js +155 -127
  66. package/dist/components/buckets/BucketReplicationFormPage.js +134 -133
  67. package/dist/components/buckets/BucketReplicationList.d.ts +2 -2
  68. package/dist/components/buckets/BucketReplicationList.js +42 -42
  69. package/dist/components/buckets/BucketVersioning.d.ts +4 -0
  70. package/dist/components/buckets/BucketVersioning.js +76 -0
  71. package/dist/components/buckets/DeleteBucketButton.js +8 -8
  72. package/dist/components/buckets/DeleteBucketConfigRuleButton.d.ts +2 -2
  73. package/dist/components/buckets/DeleteBucketConfigRuleButton.js +2 -2
  74. package/dist/components/buckets/EmptyBucketButton.js +24 -24
  75. package/dist/components/buckets/EmptyBucketSummary.d.ts +2 -2
  76. package/dist/components/buckets/EmptyBucketSummary.js +1 -1
  77. package/dist/components/buckets/EmptyBucketSummaryList.d.ts +1 -1
  78. package/dist/components/buckets/EmptyBucketSummaryList.js +22 -22
  79. package/dist/components/buckets/__tests__/BucketVersioning.test.d.ts +1 -0
  80. package/dist/components/buckets/__tests__/BucketVersioning.test.js +163 -0
  81. package/dist/components/buckets/notifications/BucketNotificationFormPage.d.ts +1 -0
  82. package/dist/components/buckets/notifications/BucketNotificationFormPage.js +316 -0
  83. package/dist/components/buckets/notifications/BucketNotificationList.d.ts +10 -0
  84. package/dist/components/buckets/notifications/BucketNotificationList.js +267 -0
  85. package/dist/components/buckets/notifications/EventsSection.js +145 -29
  86. package/dist/components/buckets/notifications/__tests__/events.test.d.ts +1 -0
  87. package/dist/components/buckets/notifications/__tests__/events.test.js +56 -0
  88. package/dist/components/buckets/notifications/events.d.ts +71 -7
  89. package/dist/components/buckets/notifications/events.js +98 -16
  90. package/dist/components/index.d.ts +27 -20
  91. package/dist/components/index.js +17 -10
  92. package/dist/components/layouts/ArrowNavigation.d.ts +3 -0
  93. package/dist/components/layouts/ArrowNavigation.js +28 -0
  94. package/dist/components/layouts/BrowserPageLayout.d.ts +5 -1
  95. package/dist/components/layouts/BrowserPageLayout.js +10 -5
  96. package/dist/components/objects/CreateFolderButton.d.ts +2 -2
  97. package/dist/components/objects/CreateFolderButton.js +12 -12
  98. package/dist/components/objects/DeleteObjectButton.d.ts +1 -1
  99. package/dist/components/objects/DeleteObjectButton.js +19 -21
  100. package/dist/components/objects/GetPresignedUrlButton.d.ts +7 -0
  101. package/dist/components/objects/GetPresignedUrlButton.js +255 -0
  102. package/dist/components/objects/ObjectDetails/ObjectMetadata.d.ts +2 -2
  103. package/dist/components/objects/ObjectDetails/ObjectMetadata.js +263 -230
  104. package/dist/components/objects/ObjectDetails/ObjectSummary.d.ts +2 -2
  105. package/dist/components/objects/ObjectDetails/ObjectSummary.js +540 -138
  106. package/dist/components/objects/ObjectDetails/ObjectTags.d.ts +2 -2
  107. package/dist/components/objects/ObjectDetails/ObjectTags.js +95 -123
  108. package/dist/components/objects/ObjectDetails/__tests__/ObjectDetails.test.d.ts +1 -0
  109. package/dist/components/objects/ObjectDetails/__tests__/ObjectDetails.test.js +516 -0
  110. package/dist/components/objects/ObjectDetails/__tests__/ObjectSummary.test.d.ts +1 -0
  111. package/dist/components/objects/ObjectDetails/__tests__/ObjectSummary.test.js +1064 -0
  112. package/dist/components/objects/ObjectDetails/index.d.ts +18 -2
  113. package/dist/components/objects/ObjectDetails/index.js +152 -40
  114. package/dist/components/objects/ObjectList.d.ts +12 -10
  115. package/dist/components/objects/ObjectList.js +590 -263
  116. package/dist/components/objects/ObjectLock/EditRetentionButton.js +4 -4
  117. package/dist/components/objects/ObjectLock/ObjectLockRetentionSettings.js +15 -15
  118. package/dist/components/objects/ObjectLock/ObjectLockSettings.d.ts +1 -1
  119. package/dist/components/objects/ObjectLock/ObjectLockSettings.js +32 -31
  120. package/dist/components/objects/ObjectLock/ObjectLockSettingsUtils.d.ts +1 -1
  121. package/dist/components/objects/ObjectLock/ObjectLockSettingsUtils.js +6 -6
  122. package/dist/components/objects/ObjectLock/__tests__/EditRetentionButton.test.js +51 -51
  123. package/dist/components/objects/ObjectLock/__tests__/ObjectLockSettings.test.js +78 -78
  124. package/dist/components/objects/ObjectPage.js +12 -8
  125. package/dist/components/objects/UploadButton.d.ts +3 -3
  126. package/dist/components/objects/UploadButton.js +10 -10
  127. package/dist/components/objects/__tests__/GetPresignedUrlButton.test.d.ts +1 -0
  128. package/dist/components/objects/__tests__/GetPresignedUrlButton.test.js +531 -0
  129. package/dist/components/providers/DataBrowserProvider.d.ts +23 -12
  130. package/dist/components/providers/DataBrowserProvider.js +60 -38
  131. package/dist/components/providers/QueryProvider.d.ts +9 -0
  132. package/dist/components/providers/QueryProvider.js +21 -0
  133. package/dist/components/search/MetadataSearch.js +29 -28
  134. package/dist/components/search/SearchHints.js +1 -1
  135. package/dist/components/ui/ArrayFieldActions.js +12 -7
  136. package/dist/components/ui/ConfirmDeleteRuleModal.d.ts +2 -2
  137. package/dist/components/ui/ConfirmDeleteRuleModal.js +6 -1
  138. package/dist/components/ui/DeleteObjectModalContent.d.ts +1 -1
  139. package/dist/components/ui/DeleteObjectModalContent.js +12 -12
  140. package/dist/components/ui/FilterFormSection.d.ts +2 -2
  141. package/dist/components/ui/FilterFormSection.js +29 -29
  142. package/dist/components/ui/Search.elements.d.ts +2 -2
  143. package/dist/components/ui/Search.elements.js +7 -7
  144. package/dist/components/ui/Table.elements.d.ts +2 -1
  145. package/dist/components/ui/Table.elements.js +18 -12
  146. package/dist/config/__tests__/factory.test.d.ts +1 -0
  147. package/dist/config/__tests__/factory.test.js +311 -0
  148. package/dist/config/factory.d.ts +10 -56
  149. package/dist/config/factory.js +23 -71
  150. package/dist/config/types.d.ts +212 -34
  151. package/dist/contexts/DataBrowserUICustomizationContext.d.ts +27 -0
  152. package/dist/contexts/DataBrowserUICustomizationContext.js +13 -0
  153. package/dist/hooks/__tests__/useAccessibleBuckets.test.d.ts +1 -0
  154. package/dist/hooks/__tests__/useAccessibleBuckets.test.js +145 -0
  155. package/dist/hooks/__tests__/useISVBucketDetection.test.js +45 -45
  156. package/dist/hooks/__tests__/useIsBucketEmpty.test.js +27 -27
  157. package/dist/hooks/__tests__/useLoginMutation.test.d.ts +1 -0
  158. package/dist/hooks/__tests__/useLoginMutation.test.js +194 -0
  159. package/dist/hooks/bucketConfiguration.d.ts +8 -1
  160. package/dist/hooks/bucketConfiguration.js +52 -51
  161. package/dist/hooks/bucketOperations.d.ts +10 -1
  162. package/dist/hooks/bucketOperations.js +10 -9
  163. package/dist/hooks/factories/__tests__/useCreateS3FunctionMutationHook.test.js +80 -80
  164. package/dist/hooks/factories/__tests__/useCreateS3InfiniteQueryHook.test.js +80 -80
  165. package/dist/hooks/factories/__tests__/useCreateS3LoginHook.test.js +44 -44
  166. package/dist/hooks/factories/__tests__/useCreateS3MutationHook.test.js +63 -63
  167. package/dist/hooks/factories/__tests__/useCreateS3QueryHook.test.js +65 -65
  168. package/dist/hooks/factories/index.d.ts +4 -4
  169. package/dist/hooks/factories/index.js +2 -2
  170. package/dist/hooks/factories/useCreateS3InfiniteQueryHook.d.ts +2 -2
  171. package/dist/hooks/factories/useCreateS3InfiniteQueryHook.js +16 -13
  172. package/dist/hooks/factories/useCreateS3LoginHook.d.ts +2 -2
  173. package/dist/hooks/factories/useCreateS3LoginHook.js +1 -1
  174. package/dist/hooks/factories/useCreateS3MutationHook.d.ts +3 -3
  175. package/dist/hooks/factories/useCreateS3MutationHook.js +7 -2
  176. package/dist/hooks/factories/useCreateS3QueryHook.d.ts +2 -2
  177. package/dist/hooks/factories/useCreateS3QueryHook.js +11 -6
  178. package/dist/hooks/index.d.ts +19 -12
  179. package/dist/hooks/index.js +16 -9
  180. package/dist/hooks/loginOperations.d.ts +1 -1
  181. package/dist/hooks/loginOperations.js +1 -1
  182. package/dist/hooks/objectOperations.d.ts +2 -2
  183. package/dist/hooks/objectOperations.js +50 -49
  184. package/dist/hooks/presignedOperations.d.ts +4 -4
  185. package/dist/hooks/presignedOperations.js +5 -5
  186. package/dist/hooks/useAccessibleBuckets.d.ts +11 -0
  187. package/dist/hooks/useAccessibleBuckets.js +115 -0
  188. package/dist/hooks/useBatchObjectLegalHold.d.ts +11 -0
  189. package/dist/hooks/useBatchObjectLegalHold.js +48 -0
  190. package/dist/hooks/useBucketConfigEditor.d.ts +31 -0
  191. package/dist/hooks/useBucketConfigEditor.js +82 -0
  192. package/dist/hooks/useDataBrowserNavigate.d.ts +28 -0
  193. package/dist/hooks/useDataBrowserNavigate.js +24 -0
  194. package/dist/hooks/useDeleteBucketConfigRule.d.ts +2 -2
  195. package/dist/hooks/useDeleteBucketConfigRule.js +4 -4
  196. package/dist/hooks/useEmptyBucket.js +11 -11
  197. package/dist/hooks/useFeatures.d.ts +7 -0
  198. package/dist/hooks/useFeatures.js +8 -0
  199. package/dist/hooks/useISVBucketDetection.js +6 -6
  200. package/dist/hooks/useIsBucketEmpty.js +4 -4
  201. package/dist/hooks/useLimitedAccessFlow.d.ts +48 -0
  202. package/dist/hooks/useLimitedAccessFlow.js +23 -0
  203. package/dist/hooks/useS3Client.d.ts +6 -0
  204. package/dist/hooks/useS3Client.js +3 -2
  205. package/dist/hooks/useS3ConfigSwitch.d.ts +11 -0
  206. package/dist/hooks/useS3ConfigSwitch.js +37 -0
  207. package/dist/hooks/useSupportedNotificationEvents.d.ts +6 -0
  208. package/dist/hooks/useSupportedNotificationEvents.js +8 -0
  209. package/dist/index.d.ts +6 -6
  210. package/dist/index.js +2 -2
  211. package/dist/schemas/bucketPolicySchema.json +3 -13
  212. package/dist/test/msw/handlers/deleteBucket.d.ts +1 -1
  213. package/dist/test/msw/handlers/deleteBucket.js +20 -10
  214. package/dist/test/msw/handlers/getBucketAcl.d.ts +1 -1
  215. package/dist/test/msw/handlers/getBucketAcl.js +29 -17
  216. package/dist/test/msw/handlers/getBucketLocation.d.ts +1 -1
  217. package/dist/test/msw/handlers/getBucketLocation.js +29 -15
  218. package/dist/test/msw/handlers/getBucketPolicy.d.ts +1 -1
  219. package/dist/test/msw/handlers/getBucketPolicy.js +52 -32
  220. package/dist/test/msw/handlers/headObject.d.ts +1 -1
  221. package/dist/test/msw/handlers/headObject.js +31 -13
  222. package/dist/test/msw/handlers/listBuckets.d.ts +1 -1
  223. package/dist/test/msw/handlers/listBuckets.js +5 -3
  224. package/dist/test/msw/handlers/listObjectVersions.d.ts +1 -1
  225. package/dist/test/msw/handlers/listObjectVersions.js +38 -26
  226. package/dist/test/msw/handlers/listObjects.d.ts +1 -1
  227. package/dist/test/msw/handlers/listObjects.js +35 -23
  228. package/dist/test/msw/handlers/objectLegalHold.d.ts +1 -1
  229. package/dist/test/msw/handlers/objectLegalHold.js +32 -17
  230. package/dist/test/msw/handlers/objectRetention.d.ts +1 -1
  231. package/dist/test/msw/handlers/objectRetention.js +31 -17
  232. package/dist/test/msw/handlers/putBucketAcl.d.ts +1 -1
  233. package/dist/test/msw/handlers/putBucketAcl.js +29 -14
  234. package/dist/test/msw/handlers/putObject.d.ts +1 -1
  235. package/dist/test/msw/handlers/putObject.js +27 -12
  236. package/dist/test/msw/handlers.d.ts +3 -3
  237. package/dist/test/msw/handlers.js +77 -54
  238. package/dist/test/msw/index.d.ts +2 -2
  239. package/dist/test/msw/index.js +1 -1
  240. package/dist/test/msw/server.d.ts +1 -1
  241. package/dist/test/msw/server.js +1 -1
  242. package/dist/test/msw/utils.js +2 -2
  243. package/dist/test/setup.d.ts +1 -1
  244. package/dist/test/setup.js +13 -30
  245. package/dist/test/testUtils.d.ts +85 -33
  246. package/dist/test/testUtils.js +176 -111
  247. package/dist/test/utils/errorHandling.test.js +119 -119
  248. package/dist/types/index.d.ts +49 -36
  249. package/dist/types/monaco.d.ts +13 -0
  250. package/dist/types/monaco.js +0 -0
  251. package/dist/utils/__tests__/proxyMiddleware.test.d.ts +1 -0
  252. package/dist/utils/__tests__/proxyMiddleware.test.js +579 -0
  253. package/dist/utils/__tests__/s3Client.test.d.ts +1 -0
  254. package/dist/utils/__tests__/s3Client.test.js +340 -0
  255. package/dist/utils/__tests__/s3ConfigIdentifier.test.d.ts +1 -0
  256. package/dist/utils/__tests__/s3ConfigIdentifier.test.js +437 -0
  257. package/dist/utils/constants.d.ts +10 -0
  258. package/dist/utils/constants.js +19 -9
  259. package/dist/utils/deletion/index.d.ts +2 -2
  260. package/dist/utils/deletion/index.js +1 -1
  261. package/dist/utils/deletion/messages.d.ts +1 -1
  262. package/dist/utils/deletion/messages.js +4 -4
  263. package/dist/utils/errorHandling.d.ts +3 -3
  264. package/dist/utils/errorHandling.js +6 -6
  265. package/dist/utils/hooks.js +8 -8
  266. package/dist/utils/index.d.ts +5 -4
  267. package/dist/utils/index.js +4 -2
  268. package/dist/utils/proxyMiddleware.d.ts +32 -13
  269. package/dist/utils/proxyMiddleware.js +90 -36
  270. package/dist/utils/s3Client.d.ts +14 -4
  271. package/dist/utils/s3Client.js +5 -26
  272. package/dist/utils/s3ConfigIdentifier.d.ts +79 -0
  273. package/dist/utils/s3ConfigIdentifier.js +57 -0
  274. package/dist/utils/s3RuleUtils.d.ts +5 -5
  275. package/dist/utils/s3RuleUtils.js +17 -17
  276. package/package.json +10 -8
  277. package/dist/components/__tests__/BucketNotificationCreatePage.test.js +0 -316
  278. package/dist/components/buckets/BucketPolicyButton.d.ts +0 -7
  279. package/dist/components/buckets/notifications/BucketNotificationCreatePage.d.ts +0 -1
  280. package/dist/components/buckets/notifications/BucketNotificationCreatePage.js +0 -234
  281. package/dist/hooks/useLoginMutation.d.ts +0 -21
  282. package/dist/hooks/useLoginMutation.js +0 -9
  283. package/dist/utils/useFeatures.d.ts +0 -1
  284. package/dist/utils/useFeatures.js +0 -7
  285. /package/dist/components/__tests__/{BucketNotificationCreatePage.test.d.ts → BucketAccessor.test.d.ts} +0 -0
@@ -1,37 +1,276 @@
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 { createContext, useContext } from "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
7
  import { isNotFoundError } from "../../utils/errorHandling.js";
8
+ import { EditRetentionButton } from "../objects/ObjectLock/EditRetentionButton.js";
9
+ import { useDataBrowserConfig } from "../providers/DataBrowserProvider.js";
8
10
  import { Body, Group, GroupContent, GroupName, GroupValues, Key, Row, Table, TableContainer, Value } from "../ui/Table.elements.js";
11
+ import { BucketConfigEditButton } from "./BucketConfigEditButton.js";
9
12
  import { BucketLocation } from "./BucketLocation.js";
10
- import { BucketPolicyButton } from "./BucketPolicyButton.js";
11
- import { EditRetentionButton } from "../objects/ObjectLock/EditRetentionButton.js";
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
+ };
12
239
  const BucketOverviewContext = /*#__PURE__*/ createContext(null);
13
240
  function useBucketOverviewContext() {
14
241
  const context = useContext(BucketOverviewContext);
15
- if (!context) throw new Error("BucketOverview components must be used within BucketOverview");
242
+ if (!context) throw new Error('BucketOverview components must be used within BucketOverview');
16
243
  return context;
17
244
  }
18
- function getDefaultBucketRetention(objectLockData) {
19
- if (!objectLockData?.ObjectLockConfiguration?.Rule?.DefaultRetention || !objectLockData.ObjectLockConfiguration.Rule.DefaultRetention.Days && !objectLockData.ObjectLockConfiguration.Rule.DefaultRetention.Years) return "Inactive";
20
- const defaultRetention = objectLockData.ObjectLockConfiguration.Rule.DefaultRetention;
21
- const retentionPeriod = defaultRetention.Days ? `${defaultRetention.Days} ${1 === defaultRetention.Days ? "day" : "days"}` : defaultRetention.Years ? `${defaultRetention.Years} ${1 === defaultRetention.Years ? "year" : "years"}` : "";
22
- const mode = defaultRetention.Mode || "GOVERNANCE";
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';
23
257
  const capitalizedMode = mode.charAt(0).toUpperCase() + mode.slice(1).toLowerCase();
24
258
  return `${capitalizedMode} - ${retentionPeriod}`;
25
- }
26
- const BucketOverviewRoot = ({ bucketName, children })=>/*#__PURE__*/ jsx(BucketOverviewContext.Provider, {
27
- value: {
259
+ };
260
+ const BucketOverviewRoot = ({ bucketName, children })=>{
261
+ const contextValue = useMemo(()=>({
28
262
  bucketName
29
- },
263
+ }), [
264
+ bucketName
265
+ ]);
266
+ return /*#__PURE__*/ jsx(BucketOverviewContext.Provider, {
267
+ value: contextValue,
30
268
  children: /*#__PURE__*/ jsx(TableContainer, {
31
269
  children: children
32
270
  })
33
271
  });
34
- const Actions = ({ onEmptyBucket, onDeleteBucket, renderEmptyButton, renderDeleteButton, isEmptyBucketDisabled = true, isDeleteBucketDisabled = false })=>{
272
+ };
273
+ const Actions = /*#__PURE__*/ memo(({ onEmptyBucket, onDeleteBucket, renderEmptyButton, renderDeleteButton, isEmptyBucketDisabled = true, isDeleteBucketDisabled = false })=>{
35
274
  const { bucketName } = useBucketOverviewContext();
36
275
  return /*#__PURE__*/ jsxs(Box, {
37
276
  display: "flex",
@@ -45,10 +284,7 @@ const Actions = ({ onEmptyBucket, onDeleteBucket, renderEmptyButton, renderDelet
45
284
  disabled: isEmptyBucketDisabled,
46
285
  variant: "danger",
47
286
  label: "Empty Bucket",
48
- onClick: onEmptyBucket,
49
- style: {
50
- marginRight: "1rem"
51
- }
287
+ onClick: onEmptyBucket
52
288
  }),
53
289
  renderDeleteButton ? renderDeleteButton(bucketName) : /*#__PURE__*/ jsx(Button, {
54
290
  icon: /*#__PURE__*/ jsx(Icon, {
@@ -61,8 +297,9 @@ const Actions = ({ onEmptyBucket, onDeleteBucket, renderEmptyButton, renderDelet
61
297
  })
62
298
  ]
63
299
  });
64
- };
65
- const Section = ({ title, children })=>/*#__PURE__*/ jsxs(Group, {
300
+ });
301
+ Actions.displayName = 'BucketOverview.Actions';
302
+ const Section = /*#__PURE__*/ memo(({ title, children })=>/*#__PURE__*/ jsxs(Group, {
66
303
  children: [
67
304
  /*#__PURE__*/ jsx(GroupName, {
68
305
  children: title
@@ -71,12 +308,13 @@ const Section = ({ title, children })=>/*#__PURE__*/ jsxs(Group, {
71
308
  children: children
72
309
  })
73
310
  ]
74
- });
75
- const Field = ({ label, value, loading, error, errorMessage = "Error", children, actions })=>{
311
+ }));
312
+ Section.displayName = 'BucketOverview.Section';
313
+ const Field = /*#__PURE__*/ memo(({ label, value, loading, error, errorMessage = 'Error', children, actions })=>{
76
314
  const renderValue = ()=>{
77
315
  if (loading) return /*#__PURE__*/ jsx(Loader, {});
78
316
  if (error) return errorMessage;
79
- return children || value || "N/A";
317
+ return children || value || 'N/A';
80
318
  };
81
319
  return /*#__PURE__*/ jsxs(Row, {
82
320
  children: [
@@ -93,193 +331,162 @@ const Field = ({ label, value, loading, error, errorMessage = "Error", children,
93
331
  })
94
332
  ]
95
333
  });
96
- };
97
- const Sections = ({ children })=>/*#__PURE__*/ jsx(Table, {
334
+ });
335
+ Field.displayName = 'BucketOverview.Field';
336
+ const Sections = /*#__PURE__*/ memo(({ children })=>/*#__PURE__*/ jsx(Table, {
98
337
  children: /*#__PURE__*/ jsx(Body, {
99
338
  children: children
100
339
  })
101
- });
102
- const GeneralSection = ({ nameField, versioningField, locationField, renderName, renderVersioning, renderLocation })=>{
340
+ }));
341
+ Sections.displayName = 'BucketOverview.Sections';
342
+ const GeneralSection = /*#__PURE__*/ memo(({ nameField, versioningField, locationField, renderName, renderVersioning, renderLocation })=>{
103
343
  const { bucketName } = useBucketOverviewContext();
344
+ const { extraBucketOverviewGeneral } = useDataBrowserUICustomization();
104
345
  const { data: versioningData, status: versioningStatus } = useGetBucketVersioning({
105
346
  Bucket: bucketName
106
347
  });
107
- return /*#__PURE__*/ jsxs(Section, {
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, {
108
372
  title: "General",
109
- children: [
110
- nameField ? /*#__PURE__*/ jsx(Field, {
111
- label: "Name",
112
- children: nameField
113
- }) : renderName ? /*#__PURE__*/ jsx(Field, {
114
- label: "Name",
115
- children: renderName(bucketName)
116
- }) : /*#__PURE__*/ jsx(Field, {
117
- label: "Name",
118
- value: /*#__PURE__*/ jsx(ConstrainedText, {
119
- text: bucketName,
120
- lineClamp: 2
121
- })
122
- }),
123
- versioningField ? /*#__PURE__*/ jsx(Field, {
124
- label: "Versioning",
125
- children: versioningField
126
- }) : renderVersioning ? /*#__PURE__*/ jsx(Field, {
127
- label: "Versioning",
128
- children: renderVersioning(bucketName)
129
- }) : /*#__PURE__*/ jsx(Field, {
130
- label: "Versioning",
131
- loading: "pending" === versioningStatus,
132
- error: "error" === versioningStatus,
133
- value: versioningData?.Status === "Enabled" ? "Active" : "Inactive"
134
- }),
135
- locationField ? /*#__PURE__*/ jsx(Field, {
136
- label: "Location",
137
- children: locationField
138
- }) : renderLocation ? /*#__PURE__*/ jsx(Field, {
139
- label: "Location",
140
- children: renderLocation(bucketName)
141
- }) : /*#__PURE__*/ jsx(Field, {
142
- label: "Location",
143
- value: /*#__PURE__*/ jsx(BucketLocation, {
144
- bucketName: bucketName
145
- })
146
- })
147
- ]
373
+ children: fields.map((field)=>/*#__PURE__*/ jsx(Field, {
374
+ label: field.label,
375
+ actions: field.actions,
376
+ children: field.value
377
+ }, field.id))
148
378
  });
149
- };
150
- const DataProtectionSection = ({ objectLockField, defaultRetentionField, renderObjectLock, renderDefaultRetention })=>{
379
+ });
380
+ GeneralSection.displayName = 'BucketOverview.GeneralSection';
381
+ const DataProtectionSection = /*#__PURE__*/ memo(({ objectLockField, defaultRetentionField, renderObjectLock, renderDefaultRetention })=>{
151
382
  const { bucketName } = useBucketOverviewContext();
383
+ const { extraBucketOverviewDataProtection } = useDataBrowserUICustomization();
152
384
  const { data: objectLockData, status: objectLockStatus, error: objectLockError } = useGetBucketObjectLockConfiguration({
153
385
  Bucket: bucketName
154
386
  });
155
- const isObjectLockNotConfigured = "error" === objectLockStatus && isNotFoundError(objectLockError);
156
- const isObjectLockEnabled = objectLockData?.ObjectLockConfiguration?.ObjectLockEnabled === "Enabled";
157
- return /*#__PURE__*/ jsxs(Section, {
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, {
158
414
  title: "Data protection",
159
- children: [
160
- objectLockField ? /*#__PURE__*/ jsx(Field, {
161
- label: "Object-lock",
162
- children: objectLockField
163
- }) : renderObjectLock ? /*#__PURE__*/ jsx(Field, {
164
- label: "Object-lock",
165
- children: renderObjectLock(bucketName)
166
- }) : /*#__PURE__*/ jsx(Field, {
167
- label: "Object-lock",
168
- loading: "pending" === objectLockStatus,
169
- error: "error" === objectLockStatus && !isObjectLockNotConfigured,
170
- value: isObjectLockEnabled ? "Enabled" : "Disabled"
171
- }),
172
- !defaultRetentionField && !renderDefaultRetention && isObjectLockEnabled && /*#__PURE__*/ jsx(Field, {
173
- label: "Default Retention",
174
- loading: "pending" === objectLockStatus,
175
- value: getDefaultBucketRetention(objectLockData),
176
- actions: /*#__PURE__*/ jsx(EditRetentionButton, {
177
- bucketName: bucketName
178
- })
179
- }),
180
- defaultRetentionField && /*#__PURE__*/ jsx(Field, {
181
- label: "Default Retention",
182
- children: defaultRetentionField
183
- }),
184
- renderDefaultRetention && /*#__PURE__*/ jsx(Field, {
185
- label: "Default Retention",
186
- children: renderDefaultRetention(bucketName)
187
- })
188
- ]
415
+ children: fields.map((field)=>/*#__PURE__*/ jsx(Field, {
416
+ label: field.label,
417
+ actions: field.actions,
418
+ children: field.value
419
+ }, field.id))
189
420
  });
190
- };
191
- const PermissionsSection = ({ onEditPolicy, ownerField, aclField, corsField, publicField, bucketPolicyField, renderOwner, renderAcl, renderCors, renderPublic, renderBucketPolicy })=>{
421
+ });
422
+ DataProtectionSection.displayName = 'BucketOverview.DataProtectionSection';
423
+ const PermissionsSection = /*#__PURE__*/ memo(({ onEditPolicy, onEditCors, ownerField, aclField, corsField, publicField, bucketPolicyField, renderOwner, renderAcl, renderCors, renderPublic, renderBucketPolicy })=>{
192
424
  const { bucketName } = useBucketOverviewContext();
193
- const { getS3Config } = useDataBrowserContext();
194
- const config = getS3Config();
425
+ const { extraBucketOverviewPermissions } = useDataBrowserUICustomization();
426
+ const config = useDataBrowserConfig();
195
427
  const { data: aclData, status: aclStatus } = useGetBucketAcl({
196
428
  Bucket: bucketName
197
429
  });
198
- const { data: corsData, status: corsStatus } = useGetBucketCors({
430
+ const { data: corsData, status: corsStatus, error: corsError } = useGetBucketCors({
199
431
  Bucket: bucketName
200
432
  });
201
433
  const { data: policyData, error: policyError, status: policyStatus } = useGetBucketPolicy({
202
434
  Bucket: bucketName
203
435
  });
204
- const isPublic = aclData?.Grants?.find((grant)=>grant.Grantee?.URI === (config.publicAclIndicator || "http://acs.amazonaws.com/groups/global/AllUsers"));
205
- return /*#__PURE__*/ jsxs(Section, {
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, {
206
481
  title: "Permissions",
207
- children: [
208
- ownerField ? /*#__PURE__*/ jsx(Field, {
209
- label: "Owner",
210
- children: ownerField
211
- }) : renderOwner ? /*#__PURE__*/ jsx(Field, {
212
- label: "Owner",
213
- children: renderOwner(bucketName)
214
- }) : /*#__PURE__*/ jsx(Field, {
215
- label: "Owner",
216
- loading: "pending" === aclStatus,
217
- error: "error" === aclStatus,
218
- value: aclData?.Owner?.DisplayName || "N/A"
219
- }),
220
- aclField ? /*#__PURE__*/ jsx(Field, {
221
- label: "ACL",
222
- children: aclField
223
- }) : renderAcl ? /*#__PURE__*/ jsx(Field, {
224
- label: "ACL",
225
- children: renderAcl(bucketName)
226
- }) : /*#__PURE__*/ jsx(Field, {
227
- label: "ACL",
228
- loading: "pending" === aclStatus,
229
- error: "error" === aclStatus,
230
- value: aclData?.Grants?.length ? `${aclData.Grants.length} Grantee${1 !== aclData.Grants.length ? "s" : ""}` : "N/A"
231
- }),
232
- corsField ? /*#__PURE__*/ jsx(Field, {
233
- label: "CORS",
234
- children: corsField
235
- }) : renderCors ? /*#__PURE__*/ jsx(Field, {
236
- label: "CORS",
237
- children: renderCors(bucketName)
238
- }) : /*#__PURE__*/ jsx(Field, {
239
- label: "CORS",
240
- loading: "pending" === corsStatus,
241
- value: corsData?.CORSRules && corsData.CORSRules.length > 0 ? "Yes" : "No"
242
- }),
243
- publicField ? /*#__PURE__*/ jsx(Field, {
244
- label: "Public",
245
- children: publicField
246
- }) : renderPublic ? /*#__PURE__*/ jsx(Field, {
247
- label: "Public",
248
- children: renderPublic(bucketName)
249
- }) : /*#__PURE__*/ jsx(Field, {
250
- label: "Public",
251
- loading: "pending" === aclStatus,
252
- value: isPublic ? "Yes" : "No"
253
- }),
254
- bucketPolicyField ? /*#__PURE__*/ jsx(Field, {
255
- label: "Bucket Policy",
256
- children: bucketPolicyField
257
- }) : renderBucketPolicy ? /*#__PURE__*/ jsx(Field, {
258
- label: "Bucket Policy",
259
- children: renderBucketPolicy(bucketName, onEditPolicy)
260
- }) : /*#__PURE__*/ jsx(Field, {
261
- label: "Bucket Policy",
262
- error: "error" === policyStatus && policyError?.name !== "NoSuchBucketPolicy",
263
- children: /*#__PURE__*/ jsxs(Box, {
264
- display: "flex",
265
- justifyContent: "space-between",
266
- alignItems: "center",
267
- gap: spacing.r8,
268
- children: [
269
- /*#__PURE__*/ jsx("span", {
270
- children: policyData?.Policy ? "Configured" : "Not configured"
271
- }),
272
- /*#__PURE__*/ jsx(BucketPolicyButton, {
273
- hasPolicy: !!policyData?.Policy,
274
- isLoading: "pending" === policyStatus,
275
- onEdit: ()=>onEditPolicy?.(bucketName)
276
- })
277
- ]
278
- })
279
- })
280
- ]
482
+ children: fields.map((field)=>/*#__PURE__*/ jsx(Field, {
483
+ label: field.label,
484
+ actions: field.actions,
485
+ children: field.value
486
+ }, field.id))
281
487
  });
282
- };
488
+ });
489
+ PermissionsSection.displayName = 'BucketOverview.PermissionsSection';
283
490
  const BucketOverview = BucketOverviewRoot;
284
491
  BucketOverview.Actions = Actions;
285
492
  BucketOverview.Sections = Sections;
@@ -288,4 +495,4 @@ BucketOverview.Field = Field;
288
495
  BucketOverview.GeneralSection = GeneralSection;
289
496
  BucketOverview.DataProtectionSection = DataProtectionSection;
290
497
  BucketOverview.PermissionsSection = PermissionsSection;
291
- export { BucketOverview, Field as BucketOverviewField, Section as BucketOverviewSection };
498
+ export { BucketOverview, BucketOverviewContext, Field as BucketOverviewField, Section as BucketOverviewSection, useBucketOverviewContext };