@scaleflex/widget-explorer 4.4.0 → 4.5.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 (588) hide show
  1. package/CHANGELOG.md +22 -0
  2. package/README.md +21 -3
  3. package/dist/style.css +2197 -0
  4. package/dist/style.min.css +1 -0
  5. package/lib/Explorer.styled.js +48 -0
  6. package/lib/components/ActionBar/ActionBar.styled.js +103 -0
  7. package/lib/components/ActionBar/DownloadWithExportButton.js +231 -0
  8. package/lib/components/ActionBar/SelectionMenu.js +111 -0
  9. package/lib/components/ActionBar/index.js +105 -0
  10. package/lib/components/AddFilesPanel/AddFiles.js +183 -0
  11. package/lib/components/AddFilesPanel/AddFiles.styled.js +137 -0
  12. package/lib/components/AddFilesPanel/index.js +59 -0
  13. package/lib/components/AiSwitcher/AiSwitcher.constants.js +1 -0
  14. package/lib/components/AiSwitcher/AiSwitcher.styled.js +24 -0
  15. package/lib/components/AiSwitcher/index.js +81 -0
  16. package/lib/components/AssetsList/AssetsList.styled.js +217 -0
  17. package/lib/components/AssetsList/GridView/FilesAccordion.js +76 -0
  18. package/lib/components/AssetsList/GridView/FilesSection/FileCell.js +260 -0
  19. package/lib/components/AssetsList/GridView/FilesSection/FileOverlayOptions.js +140 -0
  20. package/lib/components/AssetsList/GridView/FilesSection/FilesSection.styled.js +15 -0
  21. package/lib/components/AssetsList/GridView/FilesSection/index.js +31 -0
  22. package/lib/components/AssetsList/GridView/FilesSkeleton.js +47 -0
  23. package/lib/components/AssetsList/GridView/FoldersSection/FolderCell.js +239 -0
  24. package/lib/components/AssetsList/GridView/FoldersSection/FolderPreviewGrid.js +106 -0
  25. package/lib/components/AssetsList/GridView/FoldersSection/FolderTopOptions.js +70 -0
  26. package/lib/components/AssetsList/GridView/FoldersSection/index.js +23 -0
  27. package/lib/components/AssetsList/GridView/FoldersSkeleton.js +77 -0
  28. package/lib/components/AssetsList/GridView/GridView.styled.js +11 -0
  29. package/lib/components/AssetsList/GridView/SearchGridView/SearchGridView.styled.js +15 -0
  30. package/lib/components/AssetsList/GridView/SearchGridView/SearchGridViewSkeleton.js +30 -0
  31. package/lib/components/AssetsList/GridView/SearchGridView/index.js +97 -0
  32. package/lib/components/AssetsList/GridView/index.js +196 -0
  33. package/lib/components/AssetsList/ListView/AssetsSection/AssetsSectionTableHeader.js +152 -0
  34. package/lib/components/AssetsList/ListView/AssetsSection/AssetsSectionTableRow.js +333 -0
  35. package/lib/components/AssetsList/ListView/AssetsSection/index.js +99 -0
  36. package/lib/components/AssetsList/ListView/ColumnsMenu.js +89 -0
  37. package/lib/components/AssetsList/ListView/FilesAccordion.js +74 -0
  38. package/lib/components/AssetsList/ListView/FilesSkeleton.js +68 -0
  39. package/lib/components/AssetsList/ListView/FoldersSection/FoldersSectionTableHeader.js +98 -0
  40. package/lib/components/AssetsList/ListView/FoldersSection/FoldersSectionTableRow.js +156 -0
  41. package/lib/components/AssetsList/ListView/FoldersSection/index.js +54 -0
  42. package/lib/components/AssetsList/ListView/FoldersSkeleton.js +67 -0
  43. package/lib/components/AssetsList/ListView/ListView.styled.js +181 -0
  44. package/lib/components/AssetsList/ListView/ListView.utils.js +30 -0
  45. package/lib/components/AssetsList/ListView/SearchListView/index.js +109 -0
  46. package/lib/components/AssetsList/ListView/index.js +203 -0
  47. package/lib/components/AssetsList/ScrollToTop.js +70 -0
  48. package/lib/components/AssetsList/SearchView.hook.js +241 -0
  49. package/lib/components/AssetsList/__SearchTestPannel.js +238 -0
  50. package/lib/components/AssetsList/__SearchTestPannel.mock.js +1 -0
  51. package/lib/components/AssetsList/index.js +266 -0
  52. package/lib/components/AssetsList/relevanceBadge.js +15 -0
  53. package/lib/components/AssetsView/AssetsView.styled.js +25 -0
  54. package/lib/components/AssetsView/AssetsView.thunks.js +64 -0
  55. package/lib/components/AssetsView/index.js +142 -0
  56. package/lib/components/AuthExplorerView.js +79 -0
  57. package/lib/components/Breadcrumbs/BreadCrumbViews/BreadCrumbsViews.styled.js +30 -0
  58. package/lib/components/Breadcrumbs/BreadCrumbViews/index.js +32 -0
  59. package/lib/components/Breadcrumbs/Breadcrumb.js +52 -0
  60. package/lib/components/Breadcrumbs/Breadcrumbs.styled.js +81 -0
  61. package/lib/components/Breadcrumbs/BreadcrumbsSkeleton.js +12 -0
  62. package/lib/components/Breadcrumbs/index.js +295 -0
  63. package/lib/components/BulkEditPanel/BulkEdit.js +330 -0
  64. package/lib/components/BulkEditPanel/BulkEditPanel.styled.js +62 -0
  65. package/lib/components/BulkEditPanel/BulkEditPanel.utils.js +55 -0
  66. package/lib/components/BulkEditPanel/components/AssetsList/AssetsList.constants.js +29 -0
  67. package/lib/components/BulkEditPanel/components/AssetsList/AssetsList.js +148 -0
  68. package/lib/components/BulkEditPanel/components/AssetsList/AssetsList.styled.js +81 -0
  69. package/lib/components/BulkEditPanel/components/AssetsList/Columns/Columns.styled.js +99 -0
  70. package/lib/components/BulkEditPanel/components/AssetsList/Columns/FileMetadataField.js +263 -0
  71. package/lib/components/BulkEditPanel/components/AssetsList/Columns/FileTagField.js +228 -0
  72. package/lib/components/BulkEditPanel/components/AssetsList/Columns/FileTextField.js +107 -0
  73. package/lib/components/BulkEditPanel/components/AssetsList/Columns/MetadataColumn.js +142 -0
  74. package/lib/components/BulkEditPanel/components/AssetsList/Columns/TableRow.js +139 -0
  75. package/lib/components/BulkEditPanel/components/AssetsList/Columns/TagsColumn.js +58 -0
  76. package/lib/components/BulkEditPanel/components/AssetsList/Columns/TagsField.js +80 -0
  77. package/lib/components/BulkEditPanel/components/AssetsList/Columns/TextColumn.js +53 -0
  78. package/lib/components/BulkEditPanel/components/AssetsList/Columns/columns.utils.js +272 -0
  79. package/lib/components/BulkEditPanel/components/AssetsList/Columns/getActiveColumn.js +23 -0
  80. package/lib/components/BulkEditPanel/components/AssetsList/FloatyPreview.js +55 -0
  81. package/lib/components/BulkEditPanel/components/AssetsList/FloatyPreview.styled.js +21 -0
  82. package/lib/components/BulkEditPanel/components/AssetsList/TableBody.js +64 -0
  83. package/lib/components/BulkEditPanel/components/AssetsList/TableHeader.js +67 -0
  84. package/lib/components/BulkEditPanel/components/BulkEditFooter.js +33 -0
  85. package/lib/components/BulkEditPanel/components/ConfirmationModal/ConfirmationModal.js +47 -0
  86. package/lib/components/BulkEditPanel/components/ConfirmationModal/ConfirmationModal.styled.js +25 -0
  87. package/lib/components/BulkEditPanel/components/MainContent/MainContent.js +110 -0
  88. package/lib/components/BulkEditPanel/components/MainContent/MainContent.styled.js +12 -0
  89. package/lib/components/BulkEditPanel/components/MainContent/index.js +2 -0
  90. package/lib/components/BulkEditPanel/components/Sidebar/Sidebar.styled.js +53 -0
  91. package/lib/components/BulkEditPanel/components/Sidebar/Sidebar.utils.js +28 -0
  92. package/lib/components/BulkEditPanel/components/Sidebar/index.js +158 -0
  93. package/lib/components/BulkEditPanel/components/Tabs/Metadata/Metadata.js +246 -0
  94. package/lib/components/BulkEditPanel/components/Tabs/Metadata/Metadata.styled.js +17 -0
  95. package/lib/components/BulkEditPanel/components/Tabs/Tags/Tags.js +222 -0
  96. package/lib/components/BulkEditPanel/components/Tabs/Tags/Tags.mixin.js +20 -0
  97. package/lib/components/BulkEditPanel/components/Tabs/Tags/Tags.styled.js +123 -0
  98. package/lib/components/BulkEditPanel/components/Tabs/Tags/TagsContianer.js +31 -0
  99. package/lib/components/BulkEditPanel/components/Tabs/Tags/TagsPaper.js +95 -0
  100. package/lib/components/BulkEditPanel/components/Tabs/Text/Text.js +167 -0
  101. package/lib/components/BulkEditPanel/components/Tabs/Text/Text.styled.js +15 -0
  102. package/lib/components/BulkEditPanel/components/Tabs/tabs.constants.js +113 -0
  103. package/lib/components/BulkEditPanel/components/Tabs/tabs.js +43 -0
  104. package/lib/components/BulkEditPanel/components/Tabs/tabs.utils.js +239 -0
  105. package/lib/components/BulkEditPanel/index.js +28 -0
  106. package/lib/components/CollectionsView/CollectionFolderIcon.js +35 -0
  107. package/lib/components/CollectionsView/CollectionVirtualFoldersTree/CollectionTreeSkeletion.js +26 -0
  108. package/lib/components/CollectionsView/CollectionVirtualFoldersTree/CollectionVirtualFoldersTree.styled.js +52 -0
  109. package/lib/components/CollectionsView/CollectionVirtualFoldersTree/CollectionVirtualFoldersTree.utils.js +24 -0
  110. package/lib/components/CollectionsView/CollectionVirtualFoldersTree/Folder.js +88 -0
  111. package/lib/components/CollectionsView/CollectionVirtualFoldersTree/Tree.js +50 -0
  112. package/lib/components/CollectionsView/CollectionVirtualFoldersTree/index.js +75 -0
  113. package/lib/components/CollectionsView/CollectionsSkeleton.js +30 -0
  114. package/lib/components/CollectionsView/CollectionsTree/ActiveCollectionContent.js +61 -0
  115. package/lib/components/CollectionsView/CollectionsTree/CollectionTreeItem.js +44 -0
  116. package/lib/components/CollectionsView/CollectionsTree/CollectionsContent.js +130 -0
  117. package/lib/components/CollectionsView/CollectionsTree/CollectionsTree.styled.js +84 -0
  118. package/lib/components/CollectionsView/CollectionsTree/index.js +47 -0
  119. package/lib/components/CollectionsView/CollectionsView.styled.js +38 -0
  120. package/lib/components/CollectionsView/VirtualFoldersGrid.js +67 -0
  121. package/lib/components/CollectionsView/index.js +188 -0
  122. package/lib/components/ContextMenu/BeforeUploadMenu/index.js +51 -0
  123. package/lib/components/ContextMenu/ContextMenu.constants.js +64 -0
  124. package/lib/components/ContextMenu/ContextMenu.hooks.js +35 -0
  125. package/lib/components/ContextMenu/ContextMenu.styled.js +107 -0
  126. package/lib/components/ContextMenu/ContextMenuContent.js +202 -0
  127. package/lib/components/ContextMenu/ContextMenuItem.js +142 -0
  128. package/lib/components/ContextMenu/FileMenu/CollaborateSection/index.js +33 -0
  129. package/lib/components/ContextMenu/FileMenu/DeleteSection/index.js +25 -0
  130. package/lib/components/ContextMenu/FileMenu/EditSection/index.js +42 -0
  131. package/lib/components/ContextMenu/FileMenu/FindSection/index.js +29 -0
  132. package/lib/components/ContextMenu/FileMenu/index.js +15 -0
  133. package/lib/components/ContextMenu/FolderMenu/CollaborateSection/index.js +17 -0
  134. package/lib/components/ContextMenu/FolderMenu/DeleteSection/index.js +41 -0
  135. package/lib/components/ContextMenu/FolderMenu/EditSection/index.js +49 -0
  136. package/lib/components/ContextMenu/FolderMenu/FindSection/index.js +49 -0
  137. package/lib/components/ContextMenu/FolderMenu/FolderMenu.utils.js +31 -0
  138. package/lib/components/ContextMenu/FolderMenu/index.js +14 -0
  139. package/lib/components/ContextMenu/MenuOptions/AddVariationOption.js +59 -0
  140. package/lib/components/ContextMenu/MenuOptions/BulkEditOption.js +47 -0
  141. package/lib/components/ContextMenu/MenuOptions/CdnLinkOption.js +54 -0
  142. package/lib/components/ContextMenu/MenuOptions/DeleteOption.js +70 -0
  143. package/lib/components/ContextMenu/MenuOptions/DownloadOption.js +88 -0
  144. package/lib/components/ContextMenu/MenuOptions/EditImageOption.js +63 -0
  145. package/lib/components/ContextMenu/MenuOptions/EditVideoOption.js +87 -0
  146. package/lib/components/ContextMenu/MenuOptions/LocateFileOption.js +45 -0
  147. package/lib/components/ContextMenu/MenuOptions/ManagaAccessOption.js +67 -0
  148. package/lib/components/ContextMenu/MenuOptions/ManageDetailsOption.js +52 -0
  149. package/lib/components/ContextMenu/MenuOptions/MoveOption.js +54 -0
  150. package/lib/components/ContextMenu/MenuOptions/PreviewOption.js +35 -0
  151. package/lib/components/ContextMenu/MenuOptions/RenameOption.js +66 -0
  152. package/lib/components/ContextMenu/MenuOptions/TransformationOption.js +63 -0
  153. package/lib/components/ContextMenu/MultipleMenu/CollaborateSection/index.js +31 -0
  154. package/lib/components/ContextMenu/MultipleMenu/DeleteSection/index.js +6 -0
  155. package/lib/components/ContextMenu/MultipleMenu/EditSection/index.js +14 -0
  156. package/lib/components/ContextMenu/MultipleMenu/FindSection/index.js +14 -0
  157. package/lib/components/ContextMenu/MultipleMenu/index.js +14 -0
  158. package/lib/components/ContextMenu/SharedMenus/DownloadFolderSubMenu.js +36 -0
  159. package/lib/components/ContextMenu/SharedMenus/DownloadSubMenu.js +70 -0
  160. package/lib/components/ContextMenu/index.js +34 -0
  161. package/lib/components/ContextMenu/utils/calculateMenuHeight.js +20 -0
  162. package/lib/components/ContextMenu/utils/calculateMenuPosition.js +42 -0
  163. package/lib/components/ContextMenu/utils/createSeparator.js +14 -0
  164. package/lib/components/ContextMenu/utils/editMedia.js +17 -0
  165. package/lib/components/ContextMenu/utils/getFileLocation.js +8 -0
  166. package/lib/components/ContextMenu/utils/getFilteredOptions.js +20 -0
  167. package/lib/components/ContextMenu/utils/getProperFolderSelections.js +7 -0
  168. package/lib/components/ContextMenu/utils/isEmptyFolderSelection.js +5 -0
  169. package/lib/components/ContextMenu/utils/isFileContextMenu.js +5 -0
  170. package/lib/components/ContextMenu/utils/isFirstFileVisibilityPublic.js +9 -0
  171. package/lib/components/ContextMenu/utils/isMenuItemVisible.js +5 -0
  172. package/lib/components/ContextMenu/utils/isMixedFiles.js +9 -0
  173. package/lib/components/ContextMenu/utils/isMultipleSelection.js +6 -0
  174. package/lib/components/ContextMenu/utils/isSeparatorHidden.js +7 -0
  175. package/lib/components/ContextMenu/utils/triggerDownload.js +45 -0
  176. package/lib/components/CropPanel/CropOptions.js +155 -0
  177. package/lib/components/CropPanel/CropPanel.constants.js +44 -0
  178. package/lib/components/CropPanel/CropPanel.styled.js +107 -0
  179. package/lib/components/CropPanel/CropPanel.utils.js +48 -0
  180. package/lib/components/CropPanel/CropPanelContent.js +209 -0
  181. package/lib/components/CropPanel/ImageOptions.js +326 -0
  182. package/lib/components/CropPanel/ImageResize.js +207 -0
  183. package/lib/components/CropPanel/Option.js +113 -0
  184. package/lib/components/CropPanel/index.js +22 -0
  185. package/lib/components/Details/Details.constants.js +76 -0
  186. package/lib/components/Details/Details.utils.js +232 -0
  187. package/lib/components/Details/DetailsSideBar.styled.js +139 -0
  188. package/lib/components/Details/EditActionButtons/EditActionButtons.styled.js +27 -0
  189. package/lib/components/Details/EditActionButtons/index.js +38 -0
  190. package/lib/components/Details/FileDetails.js +31 -0
  191. package/lib/components/Details/FileItem/CustomMetadataTab.js +50 -0
  192. package/lib/components/Details/FileItem/FileItem.styled.js +47 -0
  193. package/lib/components/Details/FileItem/GeneralTab.js +113 -0
  194. package/lib/components/Details/FileItem/SharedFileEditData.js +97 -0
  195. package/lib/components/Details/FileItem/index.js +2 -0
  196. package/lib/components/Details/FolderDetails.js +138 -0
  197. package/lib/components/Details/FolderItemList/FolderListItem.js +77 -0
  198. package/lib/components/Details/FolderItemList/index.js +62 -0
  199. package/lib/components/Details/MultiItemsDetails.js +69 -0
  200. package/lib/components/Details/MultipleItems.js +71 -0
  201. package/lib/components/Details/TabChips.js +51 -0
  202. package/lib/components/Details/TabPanels.js +42 -0
  203. package/lib/components/Details/Title.js +52 -0
  204. package/lib/components/Details/index.js +53 -0
  205. package/lib/components/DnD/Dnd.styled.js +11 -0
  206. package/lib/components/DnD/DragImage.js +61 -0
  207. package/lib/components/DnD/index.js +219 -0
  208. package/lib/components/Drawer/Drawer.styled.js +45 -0
  209. package/lib/components/Drawer/Drawer.utils.js +163 -0
  210. package/lib/components/Drawer/Resizer.js +141 -0
  211. package/lib/components/Drawer/ResizerCore.js +213 -0
  212. package/lib/components/Drawer/index.js +68 -0
  213. package/lib/components/EmptyViewPlaceholder/EmptyViewPlaceholder.styled.js +39 -0
  214. package/lib/components/EmptyViewPlaceholder/index.js +58 -0
  215. package/lib/components/ExploreView.js +46 -0
  216. package/lib/components/ExplorerUI.js +17 -0
  217. package/lib/components/ExplorerWrapper.js +114 -0
  218. package/lib/components/FacetedSearch/DrawerBody/index.js +42 -0
  219. package/lib/components/FacetedSearch/DrawerWrapper/index.js +83 -0
  220. package/lib/components/FacetedSearch/FacetedSearch.constants.js +27 -0
  221. package/lib/components/FacetedSearch/FacetedSearch.styled.js +101 -0
  222. package/lib/components/FacetedSearch/FacetedSearch.utils.js +3 -0
  223. package/lib/components/FacetedSearch/Field/Date.js +69 -0
  224. package/lib/components/FacetedSearch/Field/Placeholder.js +20 -0
  225. package/lib/components/FacetedSearch/Field/Select.js +136 -0
  226. package/lib/components/FacetedSearch/Field/Switch.js +59 -0
  227. package/lib/components/FacetedSearch/Field/index.js +27 -0
  228. package/lib/components/FacetedSearch/GroupWrapper/index.js +129 -0
  229. package/lib/components/FacetedSearch/StaticFields/Date.js +152 -0
  230. package/lib/components/FacetedSearch/index.js +12 -0
  231. package/lib/components/FileItem/FileInfo/FileInfo.styled.js +126 -0
  232. package/lib/components/FileItem/FileInfo/FileInfo.utils.js +13 -0
  233. package/lib/components/FileItem/FileInfo/FileMetadata.js +37 -0
  234. package/lib/components/FileItem/FileInfo/FileName.js +197 -0
  235. package/lib/components/FileItem/FileInfo/index.js +200 -0
  236. package/lib/components/FileItem/FileItem.mixin.js +22 -0
  237. package/lib/components/FileItem/FileItem.styled.js +54 -0
  238. package/lib/components/FileItem/FileUploadTopOptions.js +87 -0
  239. package/lib/components/FileItem/PreUploadFileThumbnail/FileThumbnail.js +61 -0
  240. package/lib/components/FileItem/PreUploadFileThumbnail/PreUploadFileThumbnail.styled.js +8 -0
  241. package/lib/components/FileItem/PreUploadFileThumbnail/index.js +27 -0
  242. package/lib/components/FileItem/index.js +164 -0
  243. package/lib/components/FileWindowPanel/Body/ActionButtons.js +70 -0
  244. package/lib/components/FileWindowPanel/Body/Body.constants.js +5 -0
  245. package/lib/components/FileWindowPanel/Body/Body.styled.js +196 -0
  246. package/lib/components/FileWindowPanel/Body/BodyFile.js +165 -0
  247. package/lib/components/FileWindowPanel/Body/Footer.js +60 -0
  248. package/lib/components/FileWindowPanel/Body/Preview.js +232 -0
  249. package/lib/components/FileWindowPanel/Body/PreviewPlaceholder.js +20 -0
  250. package/lib/components/FileWindowPanel/Body/VideoEmbed.js +80 -0
  251. package/lib/components/FileWindowPanel/Body/index.js +108 -0
  252. package/lib/components/FileWindowPanel/FileTabs/FileTabButtons.js +98 -0
  253. package/lib/components/FileWindowPanel/FileTabs/FileTabs.constants.js +50 -0
  254. package/lib/components/FileWindowPanel/FileTabs/FileTabs.styled.js +99 -0
  255. package/lib/components/FileWindowPanel/FileTabs/FileTabsList.js +91 -0
  256. package/lib/components/FileWindowPanel/FileTabs/GeneralTab/EditableField.js +78 -0
  257. package/lib/components/FileWindowPanel/FileTabs/GeneralTab/FieldLabel.js +40 -0
  258. package/lib/components/FileWindowPanel/FileTabs/GeneralTab/FieldRow.js +57 -0
  259. package/lib/components/FileWindowPanel/FileTabs/GeneralTab/FieldValue.js +20 -0
  260. package/lib/components/FileWindowPanel/FileTabs/GeneralTab/FieldWithTooltip.js +29 -0
  261. package/lib/components/FileWindowPanel/FileTabs/GeneralTab/GeneralSection.js +183 -0
  262. package/lib/components/FileWindowPanel/FileTabs/GeneralTab/GeneralTab.constants.js +2 -0
  263. package/lib/components/FileWindowPanel/FileTabs/GeneralTab/GeneralTab.styled.js +112 -0
  264. package/lib/components/FileWindowPanel/FileTabs/GeneralTab/GeneralTabSkeleton.js +70 -0
  265. package/lib/components/FileWindowPanel/FileTabs/GeneralTab/TableSeparator.js +10 -0
  266. package/lib/components/FileWindowPanel/FileTabs/GeneralTab/index.js +100 -0
  267. package/lib/components/FileWindowPanel/FileTabs/MetadataTab/CustomMetadataSection.js +247 -0
  268. package/lib/components/FileWindowPanel/FileTabs/MetadataTab/EmbeddedMetadataSection.js +31 -0
  269. package/lib/components/FileWindowPanel/FileTabs/MetadataTab/MetadataTab.constants.js +2 -0
  270. package/lib/components/FileWindowPanel/FileTabs/MetadataTab/MetadataTab.styled.js +134 -0
  271. package/lib/components/FileWindowPanel/FileTabs/MetadataTab/MetadataTabSkeleton.js +70 -0
  272. package/lib/components/FileWindowPanel/FileTabs/MetadataTab/index.js +181 -0
  273. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/VariationItem.js +78 -0
  274. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/Variations.constants.js +26 -0
  275. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/Variations.styled.js +177 -0
  276. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/Variations.thunks.js +99 -0
  277. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/Variations.utils.js +23 -0
  278. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/VariationsContent.js +92 -0
  279. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/VariationsEditModalContent.js +57 -0
  280. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/VariationsSearch.js +44 -0
  281. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/VariationsSkeleton.js +35 -0
  282. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/VariationsTabNavigator.js +35 -0
  283. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/VariationsTabs.js +40 -0
  284. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/VariationsTopOptions.js +204 -0
  285. package/lib/components/FileWindowPanel/FileTabs/VariationsTab/index.js +606 -0
  286. package/lib/components/FileWindowPanel/FileTabs/index.js +83 -0
  287. package/lib/components/FileWindowPanel/FileWindow.js +221 -0
  288. package/lib/components/FileWindowPanel/FileWindow.styled.js +19 -0
  289. package/lib/components/FileWindowPanel/FileWindow.utils.js +38 -0
  290. package/lib/components/FileWindowPanel/Header/AfterUploadActionBtns.js +69 -0
  291. package/lib/components/FileWindowPanel/Header/BeforeUploadActionBtns.js +100 -0
  292. package/lib/components/FileWindowPanel/Header/FileWindowHeader.styled.js +56 -0
  293. package/lib/components/FileWindowPanel/Header/MutualActionBtns.js +92 -0
  294. package/lib/components/FileWindowPanel/Header/index.js +118 -0
  295. package/lib/components/FileWindowPanel/index.js +60 -0
  296. package/lib/components/Filters/Filters.constants.js +358 -0
  297. package/lib/components/Filters/Filters.styled.js +235 -0
  298. package/lib/components/Filters/Filters.utils.js +536 -0
  299. package/lib/components/Filters/FiltersContext.js +59 -0
  300. package/lib/components/Filters/FiltersSkeleton.js +14 -0
  301. package/lib/components/Filters/Groups/Date/index.js +201 -0
  302. package/lib/components/Filters/Groups/Folders/FoldersSkeleton.js +43 -0
  303. package/lib/components/Filters/Groups/Folders/index.js +109 -0
  304. package/lib/components/Filters/Groups/Image/Colors.js +73 -0
  305. package/lib/components/Filters/Groups/Image/Faces.js +64 -0
  306. package/lib/components/Filters/Groups/Image/Orientations.js +64 -0
  307. package/lib/components/Filters/Groups/Image/Resolutions.js +65 -0
  308. package/lib/components/Filters/Groups/Image/Tooltip.js +14 -0
  309. package/lib/components/Filters/Groups/Image/index.js +104 -0
  310. package/lib/components/Filters/Groups/LicenseExpiry/LicenseExpiry.styled.js +17 -0
  311. package/lib/components/Filters/Groups/LicenseExpiry/index.js +97 -0
  312. package/lib/components/Filters/Groups/Metadata/Advanced/ConditionSelector.js +40 -0
  313. package/lib/components/Filters/Groups/Metadata/Advanced/ExtraRow/ConditionSelector.js +35 -0
  314. package/lib/components/Filters/Groups/Metadata/Advanced/ExtraRow/ValueSelector.js +33 -0
  315. package/lib/components/Filters/Groups/Metadata/Advanced/ExtraRow/index.js +18 -0
  316. package/lib/components/Filters/Groups/Metadata/Advanced/Field/AutoComplete.js +56 -0
  317. package/lib/components/Filters/Groups/Metadata/Advanced/Field/Boolean.js +35 -0
  318. package/lib/components/Filters/Groups/Metadata/Advanced/Field/Date.js +36 -0
  319. package/lib/components/Filters/Groups/Metadata/Advanced/Field/GeoPointField.js +30 -0
  320. package/lib/components/Filters/Groups/Metadata/Advanced/Field/Numeric.js +32 -0
  321. package/lib/components/Filters/Groups/Metadata/Advanced/Field/Select.js +55 -0
  322. package/lib/components/Filters/Groups/Metadata/Advanced/Field/Tags.js +21 -0
  323. package/lib/components/Filters/Groups/Metadata/Advanced/Field/Text.js +39 -0
  324. package/lib/components/Filters/Groups/Metadata/Advanced/Field/index.js +52 -0
  325. package/lib/components/Filters/Groups/Metadata/Advanced/KeySelector.js +34 -0
  326. package/lib/components/Filters/Groups/Metadata/Advanced/Row.js +53 -0
  327. package/lib/components/Filters/Groups/Metadata/Advanced/index.js +48 -0
  328. package/lib/components/Filters/Groups/Metadata/Basic/Field/Date.js +45 -0
  329. package/lib/components/Filters/Groups/Metadata/Basic/Field/Field.utils.js +58 -0
  330. package/lib/components/Filters/Groups/Metadata/Basic/Field/Numeric.js +51 -0
  331. package/lib/components/Filters/Groups/Metadata/Basic/Field/OptionsPopup.js +87 -0
  332. package/lib/components/Filters/Groups/Metadata/Basic/Field/Select.js +168 -0
  333. package/lib/components/Filters/Groups/Metadata/Basic/Field/Switch.js +41 -0
  334. package/lib/components/Filters/Groups/Metadata/Basic/Field/Tags.js +38 -0
  335. package/lib/components/Filters/Groups/Metadata/Basic/Field/Text.js +57 -0
  336. package/lib/components/Filters/Groups/Metadata/Basic/Field/Uri.js +54 -0
  337. package/lib/components/Filters/Groups/Metadata/Basic/Field/index.js +46 -0
  338. package/lib/components/Filters/Groups/Metadata/Basic/GroupWrapper.js +79 -0
  339. package/lib/components/Filters/Groups/Metadata/Basic/index.js +80 -0
  340. package/lib/components/Filters/Groups/Metadata/Metadata.constants.js +42 -0
  341. package/lib/components/Filters/Groups/Metadata/Metadata.styled.js +150 -0
  342. package/lib/components/Filters/Groups/Metadata/Metadata.utils.js +160 -0
  343. package/lib/components/Filters/Groups/Metadata/MetadataFiltersContext.js +329 -0
  344. package/lib/components/Filters/Groups/Metadata/Placeholder.js +25 -0
  345. package/lib/components/Filters/Groups/Metadata/common/TagsField/TagsMenu.js +81 -0
  346. package/lib/components/Filters/Groups/Metadata/common/TagsField/TagsSearchPlaceholder.js +18 -0
  347. package/lib/components/Filters/Groups/Metadata/common/TagsField/index.js +142 -0
  348. package/lib/components/Filters/Groups/Metadata/index.js +111 -0
  349. package/lib/components/Filters/Groups/Size/index.js +125 -0
  350. package/lib/components/Filters/Groups/Tags/FilteredTags.js +62 -0
  351. package/lib/components/Filters/Groups/Tags/SelectedTags.js +51 -0
  352. package/lib/components/Filters/Groups/Tags/SuggestedTags.js +43 -0
  353. package/lib/components/Filters/Groups/Tags/index.js +146 -0
  354. package/lib/components/Filters/Groups/TypeAndFormat/Format.js +65 -0
  355. package/lib/components/Filters/Groups/TypeAndFormat/Type.js +85 -0
  356. package/lib/components/Filters/Groups/TypeAndFormat/index.js +114 -0
  357. package/lib/components/Filters/Groups/common/DateRangeField/DateRangeField.styled.js +10 -0
  358. package/lib/components/Filters/Groups/common/DateRangeField/index.js +72 -0
  359. package/lib/components/Filters/Groups/common/FilterFooter.js +67 -0
  360. package/lib/components/Filters/Groups/common/FilterOptions.js +29 -0
  361. package/lib/components/Filters/Groups/common/FilterSearch.js +22 -0
  362. package/lib/components/Filters/Groups/common/FilterSearch.styled.js +15 -0
  363. package/lib/components/Filters/Groups/common/FilterSkeleton.js +44 -0
  364. package/lib/components/Filters/Groups/common/TimeFrames.js +35 -0
  365. package/lib/components/Filters/Groups/index.js +55 -0
  366. package/lib/components/Filters/Placeholder.js +29 -0
  367. package/lib/components/Filters/hooks/useDateTypeFilterValues.js +182 -0
  368. package/lib/components/Filters/hooks/useFilters.js +79 -0
  369. package/lib/components/Filters/index.js +78 -0
  370. package/lib/components/FoldersView/FoldersTree/FoldersTree.styled.js +193 -0
  371. package/lib/components/FoldersView/FoldersTree/FoldersTree.utils.js +78 -0
  372. package/lib/components/FoldersView/FoldersTree/FoldersTreeHeader.js +52 -0
  373. package/lib/components/FoldersView/FoldersTree/FoldersTreeList.js +64 -0
  374. package/lib/components/FoldersView/FoldersTree/FoldersTreeListItem.js +270 -0
  375. package/lib/components/FoldersView/FoldersTree/FoldersTreeSearch.js +70 -0
  376. package/lib/components/FoldersView/FoldersTree/FoldersTreeSkeleton.js +23 -0
  377. package/lib/components/FoldersView/FoldersTree/NoFoldersResult.js +19 -0
  378. package/lib/components/FoldersView/FoldersTree/SearchedFoldersItem.js +113 -0
  379. package/lib/components/FoldersView/FoldersTree/index.js +163 -0
  380. package/lib/components/FoldersView/hooks/useAddFolder.js +60 -0
  381. package/lib/components/FoldersView/index.js +282 -0
  382. package/lib/components/GalleryRoleSelect/CustomRolesTab.js +47 -0
  383. package/lib/components/GalleryRoleSelect/CustomRolesTab.styled.js +10 -0
  384. package/lib/components/GalleryRoleSelect/GalleryRoleSelect.constants.js +11 -0
  385. package/lib/components/GalleryRoleSelect/GalleryRoleSelect.styled.js +132 -0
  386. package/lib/components/GalleryRoleSelect/GalleryRoleSelect.utils.js +87 -0
  387. package/lib/components/GalleryRoleSelect/StandardRolesTab.js +58 -0
  388. package/lib/components/GalleryRoleSelect/index.js +234 -0
  389. package/lib/components/HeaderBar/FacetedSearchToggleButton.js +28 -0
  390. package/lib/components/HeaderBar/HeaderBar.styled.js +25 -0
  391. package/lib/components/HeaderBar/RightSide.js +127 -0
  392. package/lib/components/HeaderBar/index.js +81 -0
  393. package/lib/components/ImageEditorPanel/index.js +33 -0
  394. package/lib/components/InfiniteScroll/InfiniteScroll.js +97 -0
  395. package/lib/components/InfiniteScroll/InfiniteScroll.styled.js +11 -0
  396. package/lib/components/Informer/index.js +9 -0
  397. package/lib/components/LabelsView/LabelsTree/LabelsTree.styled.js +86 -0
  398. package/lib/components/LabelsView/LabelsTree/LabelsTreeSkeleton.js +21 -0
  399. package/lib/components/LabelsView/LabelsTree/index.js +128 -0
  400. package/lib/components/LabelsView/LabelsView.styled.js +10 -0
  401. package/lib/components/LabelsView/index.js +139 -0
  402. package/lib/components/LoginScreen/LoginScreen.styled.js +39 -0
  403. package/lib/components/LoginScreen/index.js +133 -0
  404. package/lib/components/MainMenu/MainMenu.styled.js +12 -0
  405. package/lib/components/MainMenu/index.js +77 -0
  406. package/lib/components/Modals/AddNewFolder/AddNewFolder.hooks.js +99 -0
  407. package/lib/components/Modals/AddNewFolder/index.js +1 -0
  408. package/lib/components/Modals/ConfirmationModal/ConfirmationModal.hooks.js +101 -0
  409. package/lib/components/Modals/ConfirmationModal/index.js +1 -0
  410. package/lib/components/Modals/DeleteItems/DeleteItems.hooks.js +233 -0
  411. package/lib/components/Modals/DeleteItems/index.js +1 -0
  412. package/lib/components/Modals/DeleteModal/DeleteModal.hooks.js +87 -0
  413. package/lib/components/Modals/DeleteModal/index.js +1 -0
  414. package/lib/components/Modals/DownloadConsent/DownlaodConsent.styled.js +8 -0
  415. package/lib/components/Modals/DownloadConsent/DownloadConsent.hooks.js +101 -0
  416. package/lib/components/Modals/DownloadConsent/DownloadConsentContent.js +52 -0
  417. package/lib/components/Modals/DownloadConsent/index.js +2 -0
  418. package/lib/components/Modals/Modals.js +386 -0
  419. package/lib/components/Modals/Modals.styled.js +80 -0
  420. package/lib/components/Modals/MoveItems/MoveItems.hooks.js +88 -0
  421. package/lib/components/Modals/MoveItems/index.js +1 -0
  422. package/lib/components/Modals/TransformedDownload/PdfModalContent.js +109 -0
  423. package/lib/components/Modals/TransformedDownload/TransformedDownload.hooks.js +197 -0
  424. package/lib/components/Modals/TransformedDownload/TransformedDownload.styled.js +29 -0
  425. package/lib/components/Modals/TransformedDownload/TransformedDownload.utils.js +46 -0
  426. package/lib/components/Modals/TransformedDownload/index.js +2 -0
  427. package/lib/components/Modals/index.js +8 -0
  428. package/lib/components/NoItems/NoItems.styled.js +54 -0
  429. package/lib/components/NoItems/index.js +50 -0
  430. package/lib/components/PdftronPanel/index.js +31 -0
  431. package/lib/components/PickerPanel/PickerPanel.styled.js +41 -0
  432. package/lib/components/PickerPanel/PickerPanelContent.js +100 -0
  433. package/lib/components/PickerPanel/index.js +21 -0
  434. package/lib/components/ProgressPanel/ProgressPanel.utils.js +29 -0
  435. package/lib/components/ProgressPanel/index.js +37 -0
  436. package/lib/components/TopBar/AppliedFilterChips/AppliedFilterChips.styled.js +11 -0
  437. package/lib/components/TopBar/AppliedFilterChips/index.js +77 -0
  438. package/lib/components/TopBar/Search/ContextDropdown/ContextDropdown.styled.js +59 -0
  439. package/lib/components/TopBar/Search/ContextDropdown/ContextDropdown.utils.js +67 -0
  440. package/lib/components/TopBar/Search/ContextDropdown/index.js +170 -0
  441. package/lib/components/TopBar/Search/PrependedOptions/TempFilterRegexInput.js +133 -0
  442. package/lib/components/TopBar/Search/Search.utils.js +88 -0
  443. package/lib/components/TopBar/Search/SimilarSearchTag.js +60 -0
  444. package/lib/components/TopBar/Search/index.js +251 -0
  445. package/lib/components/TopBar/TopBar.styled.js +37 -0
  446. package/lib/components/TopBar/index.js +61 -0
  447. package/lib/components/TopSection/TopSection.styled.js +22 -0
  448. package/lib/components/TopSection/index.js +58 -0
  449. package/lib/components/UploadBar/UploadBar.styled.js +84 -0
  450. package/lib/components/UploadBar/index.js +222 -0
  451. package/lib/components/UploadStatus/index.js +20 -0
  452. package/lib/components/UploadsPanel/UploadsList/Header.js +19 -0
  453. package/lib/components/UploadsPanel/UploadsList/List.js +29 -0
  454. package/lib/components/UploadsPanel/UploadsList/PreUploadPlugins.js +22 -0
  455. package/lib/components/UploadsPanel/UploadsList/UploadsList.styled.js +64 -0
  456. package/lib/components/UploadsPanel/UploadsList/UploadsList.utils.js +17 -0
  457. package/lib/components/UploadsPanel/UploadsList/UploadsVirtualGrid.js +29 -0
  458. package/lib/components/UploadsPanel/UploadsList/index.js +55 -0
  459. package/lib/components/UploadsPanel/UploadsPanel.styled.js +24 -0
  460. package/lib/components/UploadsPanel/UploadsPanelTopBar.js +16 -0
  461. package/lib/components/UploadsPanel/index.js +36 -0
  462. package/lib/components/UrlBuilderModal/UrlBuilderModal.styled.js +9 -0
  463. package/lib/components/UrlBuilderModal/index.js +97 -0
  464. package/lib/components/Views/ErroredViewPlaceholder.js +48 -0
  465. package/lib/components/Views/Views.constants.js +55 -0
  466. package/lib/components/Views/Views.styled.js +87 -0
  467. package/lib/components/Views/index.js +107 -0
  468. package/lib/components/common/DeleteModalItemText/DeleteModalItemText.styled.js +8 -0
  469. package/lib/components/common/DeleteModalItemText/index.js +29 -0
  470. package/lib/components/common/EditDetailsButton/EditDetailsButton.styled.js +35 -0
  471. package/lib/components/common/EditDetailsButton/index.js +28 -0
  472. package/lib/components/common/ExpiryDateTooltipContent/ExpiryDateTooltipContent.styled.js +16 -0
  473. package/lib/components/common/ExpiryDateTooltipContent/index.js +29 -0
  474. package/lib/components/common/FileApprovalsInfoPopup/index.js +46 -0
  475. package/lib/components/common/FileMetadataFieldValue/CustomMetadataFieldValue.js +48 -0
  476. package/lib/components/common/FileMetadataFieldValue/FileMetadataFieldValue.styled.js +66 -0
  477. package/lib/components/common/FileMetadataFieldValue/FileMetadataFieldValue.utils.js +315 -0
  478. package/lib/components/common/FileMetadataFieldValue/GeneralMetadataFieldValue.js +120 -0
  479. package/lib/components/common/FileMetadataFieldValue/index.js +26 -0
  480. package/lib/components/common/FileMetadataFieldValue/utils/getFontInfo.js +78 -0
  481. package/lib/components/common/FolderSelector/BrowseFoldersMenu.js +114 -0
  482. package/lib/components/common/FolderSelector/FolderSearchMenu.js +45 -0
  483. package/lib/components/common/FolderSelector/FolderSelector.styled.js +41 -0
  484. package/lib/components/common/FolderSelector/index.js +186 -0
  485. package/lib/components/common/FormattedUriLink/FormattedUriLink.styled.js +15 -0
  486. package/lib/components/common/FormattedUriLink/index.js +21 -0
  487. package/lib/components/common/OriginalBadge/OriginalBadge.styled.js +17 -0
  488. package/lib/components/common/OriginalBadge/index.js +14 -0
  489. package/lib/components/common/SanitizedHtmlElement/index.js +11 -0
  490. package/lib/components/common/Sort/Sort.constants.js +88 -0
  491. package/lib/components/common/Sort/Sort.styled.js +47 -0
  492. package/lib/components/common/Sort/Sort.utils.js +14 -0
  493. package/lib/components/common/Sort/index.js +183 -0
  494. package/lib/components/common/TextWithCopyIcon/TextWithCopyIcon.styled.js +44 -0
  495. package/lib/components/common/TextWithCopyIcon/index.js +71 -0
  496. package/lib/components/common/TopBarUploadButton/index.js +40 -0
  497. package/lib/components/common/TrimmedFilePathWithLocate/TrimmedFilePathWithLocate.utils.js +3 -0
  498. package/lib/components/common/TrimmedFilePathWithLocate/index.js +34 -0
  499. package/lib/components/common/TrimmedFolderPathWithLocate/index.js +13 -0
  500. package/lib/components/common/TrimmedPathWithLocate/TrimmedPathWithLocate.styled.js +30 -0
  501. package/lib/components/common/TrimmedPathWithLocate/index.js +40 -0
  502. package/lib/components/metadata.adapter.js +365 -0
  503. package/lib/defaultLocale.js +1396 -0
  504. package/lib/hooks/index.js +16 -0
  505. package/lib/hooks/useAssetsPicker.js +274 -0
  506. package/lib/hooks/useDownloadFilesCsv.js +20 -0
  507. package/lib/hooks/useEditFileDetails.js +505 -0
  508. package/lib/hooks/useExplorer.js +6 -0
  509. package/lib/hooks/useExplorerI18n.js +10 -0
  510. package/lib/hooks/useExplorerInformer.js +10 -0
  511. package/lib/hooks/useFetchFileFolderPermissions.js +31 -0
  512. package/lib/hooks/useFetchMetadataTagsBySearchQuery.js +38 -0
  513. package/lib/hooks/useFileMetadata.js +117 -0
  514. package/lib/hooks/useFilterSearch.js +37 -0
  515. package/lib/hooks/useForcedFilters.js +39 -0
  516. package/lib/hooks/useIsOverflow.js +25 -0
  517. package/lib/hooks/useIsSmallScreen.js +20 -0
  518. package/lib/hooks/useLocateFile.js +231 -0
  519. package/lib/hooks/usePrevious.js +9 -0
  520. package/lib/hooks/useSearchSuggestions.js +168 -0
  521. package/lib/hooks/useStartUpload.js +43 -0
  522. package/lib/hooks/useToLocaleNumber.js +14 -0
  523. package/lib/hooks/useValidateFileName.js +324 -0
  524. package/lib/index.js +1616 -0
  525. package/lib/slices/collections.slice.js +714 -0
  526. package/lib/slices/common.slice.js +217 -0
  527. package/lib/slices/drag.slice.js +75 -0
  528. package/lib/slices/files.slice.js +1310 -0
  529. package/lib/slices/filters.slice.js +382 -0
  530. package/lib/slices/folders.slice.js +978 -0
  531. package/lib/slices/foldersTree.slice.js +501 -0
  532. package/lib/slices/index.js +36 -0
  533. package/lib/slices/labels.slice.js +652 -0
  534. package/lib/slices/metadata.slice.js +494 -0
  535. package/lib/slices/panels.slice.js +351 -0
  536. package/lib/slices/search.slice.js +995 -0
  537. package/lib/slices/selections.slice.js +315 -0
  538. package/lib/slices/targets.slice.js +44 -0
  539. package/lib/slices/topSection.slice.js +71 -0
  540. package/lib/slices/views.slice.js +357 -0
  541. package/lib/thunks/archive.thunks.js +175 -0
  542. package/lib/thunks/downloads.thunks.js +415 -0
  543. package/lib/thunks/items.thunks.js +274 -0
  544. package/lib/thunks/permissions.thunks.js +66 -0
  545. package/lib/thunks/uploads.thunks.js +235 -0
  546. package/lib/utils/SearchSuggestions/SearchSuggestionsMenu.js +95 -0
  547. package/lib/utils/SearchSuggestions/SuggestionMode.js +70 -0
  548. package/lib/utils/SearchSuggestions/SuggestionModeAttribute.js +87 -0
  549. package/lib/utils/SearchSuggestions/SuggestionModeExpression.js +121 -0
  550. package/lib/utils/SearchSuggestions/SuggestionModeTag.js +87 -0
  551. package/lib/utils/SearchSuggestions/SuggestionsManager.js +242 -0
  552. package/lib/utils/SearchSuggestions/constants.js +14 -0
  553. package/lib/utils/SearchSuggestions/index.js +4 -0
  554. package/lib/utils/SearchSuggestions/styled.js +12 -0
  555. package/lib/utils/availableScreenSizes.js +4 -0
  556. package/lib/utils/constants.js +14 -0
  557. package/lib/utils/convertItemsToFilesFoldersUuids.js +12 -0
  558. package/lib/utils/convertItemstoFoldersParentUuids.js +12 -0
  559. package/lib/utils/createPromise.js +9 -0
  560. package/lib/utils/createSuperFocus.js +43 -0
  561. package/lib/utils/decodeB64ToStr.js +11 -0
  562. package/lib/utils/filters.js +333 -0
  563. package/lib/utils/formatFolderPath.js +10 -0
  564. package/lib/utils/formatPinSubTitle.js +17 -0
  565. package/lib/utils/getAcquirerTitle.js +10 -0
  566. package/lib/utils/getActiveOverlayEl.js +11 -0
  567. package/lib/utils/getApiPathtype.js +10 -0
  568. package/lib/utils/getClosestStr.js +22 -0
  569. package/lib/utils/getItemUuids.js +12 -0
  570. package/lib/utils/getLabelsTotalAssetsCount.js +6 -0
  571. package/lib/utils/getMoveAndDeleteData.js +15 -0
  572. package/lib/utils/getParentFolderPath.js +4 -0
  573. package/lib/utils/getQueryStringFromUrl.js +6 -0
  574. package/lib/utils/getScrollableParent.js +15 -0
  575. package/lib/utils/getStringValueExistedInObj.js +9 -0
  576. package/lib/utils/isEmbeddableAsset.js +6 -0
  577. package/lib/utils/isFileVersion.js +9 -0
  578. package/lib/utils/mapArrayKeysToObjValues.js +33 -0
  579. package/lib/utils/mapFiltersToShownFormat.js +252 -0
  580. package/lib/utils/prepareExportedFilesLinks.js +12 -0
  581. package/lib/utils/prepareSearchUrl.js +75 -0
  582. package/lib/utils/removeBackground.js +60 -0
  583. package/lib/utils/removeExtraUrlParams.js +13 -0
  584. package/lib/utils/scrollToAndFocusItemElement.js +16 -0
  585. package/lib/utils/toggleFolderNotFoundModal.js +25 -0
  586. package/lib/utils/trapFocus.js +59 -0
  587. package/lib/utils/truncateString.js +28 -0
  588. package/package.json +8 -8
@@ -0,0 +1,606 @@
1
+ var _excluded = ["variantUrl", "name", "desc"],
2
+ _excluded2 = ["variantUrl", "name"];
3
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
4
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
5
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
6
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
7
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
8
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
9
+ function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var n = Object.getOwnPropertySymbols(e); for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
10
+ function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; }
11
+ function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
12
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
13
+ function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
14
+ function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
15
+ function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
16
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
17
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
18
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
19
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
20
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
21
+ import { useState, useEffect, useMemo, useRef } from 'react';
22
+ import { useDispatch, useSelector } from 'react-redux';
23
+ import { Button, InputGroup } from '@scaleflex/ui/core';
24
+ import { PC } from '@scaleflex/widget-common';
25
+ import { Download, Lock, Preset, Rename } from '@scaleflex/icons';
26
+ import { useTheme } from '@scaleflex/ui/theme/hooks';
27
+ import handlePromise from '@scaleflex/widget-utils/lib/handlePromise';
28
+ import getFileNameAndExtension from '@scaleflex/widget-utils/lib/getFileNameAndExtension';
29
+ import { useModal } from '@scaleflex/widget-core/lib/hooks';
30
+ import { isVisibilityPublic } from '@scaleflex/widget-utils/lib/visibility';
31
+ import getFileLink from '@scaleflex/widget-utils/lib/getFileLink';
32
+ import isFunction from '@scaleflex/widget-utils/lib/isFunction';
33
+ import cuid from 'cuid';
34
+ import { useExplorer } from '../../../../hooks';
35
+ import StyledVariants from './Variations.styled';
36
+ import VariationsSearch from './VariationsSearch';
37
+ import { createRemovedBackgroundVariantObject } from './Variations.utils';
38
+ import { addNewVariant, deleteVariant, editVariant, getVariants, addNewPreset } from './Variations.thunks';
39
+ import { fetchFileByUuid, filesVariationsUpdated, fileUpdated, selectFilesVariations } from '../../../../slices/files.slice';
40
+ import { useTransformedDownloadModal } from '../../../Modals/TransformedDownload';
41
+ import VariationsContent from './VariationsContent';
42
+ import VariationsSkeleton from './VariationsSkeleton';
43
+ import ErroredViewPlaceholder from '../../../Views/ErroredViewPlaceholder';
44
+ import UrlBuilderModal from '../../../UrlBuilderModal';
45
+ import getQueryStringFromUrl from '../../../../utils/getQueryStringFromUrl';
46
+ import { VARIATIONS_TAB_IDS } from './Variations.constants';
47
+ import { selectPresets } from '../../../../slices/metadata.slice';
48
+ import VariationsTabNavigator from './VariationsTabNavigator';
49
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
50
+ var _isUnMounting = false;
51
+ var extractVariantQuery = function extractVariantQuery(variantUrl) {
52
+ return variantUrl.substr(variantUrl.indexOf('?') + 1);
53
+ };
54
+ var URL_BUILDER_OPENED_AS_MODE = {
55
+ PRESET: 'preset',
56
+ VARIANT: 'variant'
57
+ };
58
+ var VariationsTab = function VariationsTab(_ref) {
59
+ var originalFile = _ref.originalFile,
60
+ previewedFile = _ref.previewedFile,
61
+ setPreviewedFile = _ref.setPreviewedFile,
62
+ activeVariationsTabId = _ref.activeVariationsTabId,
63
+ setActiveVariationsTabId = _ref.setActiveVariationsTabId;
64
+ var dispatch = useDispatch();
65
+ var toggleModal = useModal();
66
+ var theme = useTheme();
67
+ var _useExplorer = useExplorer(),
68
+ i18n = _useExplorer.i18n,
69
+ info = _useExplorer.info,
70
+ _useExplorer$opts = _useExplorer.opts,
71
+ hideDownloadVariationsOption = _useExplorer$opts.hideDownloadVariationsOption,
72
+ variationsShowAddPresetButton = _useExplorer$opts.variationsShowAddPresetButton,
73
+ variationsHideManualSubTab = _useExplorer$opts.variationsHideManualSubTab;
74
+ var triggerTransformedDownloadModal = useTransformedDownloadModal();
75
+ var displayedFileVariant = useSelector(selectFilesVariations);
76
+ var presets = useSelector(selectPresets);
77
+ var _useState = useState(true),
78
+ _useState2 = _slicedToArray(_useState, 2),
79
+ isLoading = _useState2[0],
80
+ setIsLoading = _useState2[1];
81
+ var _useState3 = useState(''),
82
+ _useState4 = _slicedToArray(_useState3, 2),
83
+ searchQuery = _useState4[0],
84
+ setSearchQuery = _useState4[1];
85
+ var _useState5 = useState([]),
86
+ _useState6 = _slicedToArray(_useState5, 2),
87
+ originalVariants = _useState6[0],
88
+ setOriginalVariants = _useState6[1];
89
+ var _useState7 = useState(false),
90
+ _useState8 = _slicedToArray(_useState7, 2),
91
+ showUrlBuilderModal = _useState8[0],
92
+ setShowUrlBuilderModal = _useState8[1];
93
+ var _useState9 = useState(''),
94
+ _useState10 = _slicedToArray(_useState9, 2),
95
+ queryString = _useState10[0],
96
+ setQueryString = _useState10[1];
97
+ var _useState11 = useState(null),
98
+ _useState12 = _slicedToArray(_useState11, 2),
99
+ selectedVariant = _useState12[0],
100
+ setSelectedVariant = _useState12[1];
101
+ var urlBuilderSaveModeRef = useRef(URL_BUILDER_OPENED_AS_MODE.VARIANT);
102
+ var url = getFileLink(originalFile, 'cdn');
103
+ var isAutomaticTabActive = activeVariationsTabId === VARIATIONS_TAB_IDS.AUTOMATIC;
104
+ var customVariants = useMemo(function () {
105
+ return originalVariants.filter(function (variant) {
106
+ return !presets.includes(variant.name) && !variant.bgRemoved;
107
+ });
108
+ }, [originalVariants, presets]);
109
+ var presetsVariants = useMemo(function () {
110
+ var presetMappedVariants = presets.map(function (preset) {
111
+ // Handle case where preset might be an object with {name, desc} properties
112
+ var presetName = typeof preset === 'string' ? preset : (preset === null || preset === void 0 ? void 0 : preset.name) || (preset === null || preset === void 0 ? void 0 : preset.desc) || 'Unknown';
113
+ return {
114
+ url: "".concat(url, "&p=").concat(presetName),
115
+ name: presetName,
116
+ uuid: cuid()
117
+ };
118
+ });
119
+ var bgRemovedVariants = originalVariants.filter(function (variant) {
120
+ return variant.bgRemoved && !presets.some(function (preset) {
121
+ var presetName = typeof preset === 'string' ? preset : (preset === null || preset === void 0 ? void 0 : preset.name) || (preset === null || preset === void 0 ? void 0 : preset.desc);
122
+ return presetName === variant.name;
123
+ });
124
+ });
125
+ return [].concat(_toConsumableArray(bgRemovedVariants), _toConsumableArray(presetMappedVariants));
126
+ }, [url, presets, originalVariants]);
127
+ var nextVariants = isAutomaticTabActive ? presetsVariants : customVariants;
128
+ var searchedVariants = useMemo(function () {
129
+ if (!searchQuery) {
130
+ return nextVariants;
131
+ }
132
+ var loweredCaseValue = searchQuery.toLowerCase();
133
+ return nextVariants.filter(function (variant) {
134
+ return variant.name.toLowerCase().includes(loweredCaseValue);
135
+ });
136
+ }, [searchQuery, originalVariants, nextVariants]);
137
+ var triggerSaveRequest = function triggerSaveRequest(requestPromise, successFn) {
138
+ setIsLoading(true);
139
+ return handlePromise(requestPromise, function () {
140
+ if (_isUnMounting) {
141
+ return;
142
+ }
143
+ successFn.apply(void 0, arguments);
144
+ }, info, function () {
145
+ if (_isUnMounting) {
146
+ return;
147
+ }
148
+ setIsLoading(false);
149
+ });
150
+ };
151
+ var handleSavingNewPreset = function handleSavingNewPreset(_ref2) {
152
+ var variantUrl = _ref2.variantUrl,
153
+ name = _ref2.name,
154
+ desc = _ref2.desc,
155
+ moreProps = _objectWithoutProperties(_ref2, _excluded);
156
+ var _ref3 = moreProps || {},
157
+ onClose = _ref3.onClose;
158
+ if (isFunction(onClose)) {
159
+ onClose();
160
+ }
161
+ info(i18n('explorerFileWindowVariationSavedInfo', 3000));
162
+ var newPreset = {
163
+ name: name,
164
+ desc: desc,
165
+ params: extractVariantQuery(variantUrl).split('&').reduce(function (acc, curr) {
166
+ var _curr$split = curr.split('='),
167
+ _curr$split2 = _slicedToArray(_curr$split, 2),
168
+ key = _curr$split2[0],
169
+ value = _curr$split2[1];
170
+ acc[key] = value;
171
+ return acc;
172
+ }, {}),
173
+ sampleImgSrc: url
174
+ };
175
+ triggerSaveRequest(dispatch(addNewPreset({
176
+ preset: newPreset
177
+ })), function (_) {
178
+ info(i18n('explorerFileWindowPresetAddedInfo'), 'success');
179
+ setShowUrlBuilderModal(false);
180
+ }, setIsLoading);
181
+ };
182
+ var handleUrlBuilderNewSave = function handleUrlBuilderNewSave() {
183
+ if (urlBuilderSaveModeRef.current === URL_BUILDER_OPENED_AS_MODE.PRESET) {
184
+ triggerAddPresetModal.apply(void 0, arguments);
185
+ return;
186
+ }
187
+ triggerAddVariantModal.apply(void 0, arguments);
188
+ };
189
+ var handleSavingNewVariant = function handleSavingNewVariant(_ref4) {
190
+ var variantUrl = _ref4.variantUrl,
191
+ name = _ref4.name,
192
+ moreProps = _objectWithoutProperties(_ref4, _excluded2);
193
+ var _ref5 = moreProps || {},
194
+ onClose = _ref5.onClose;
195
+ if (isFunction(onClose)) {
196
+ onClose();
197
+ }
198
+ var _getFileNameAndExtens = getFileNameAndExtension(originalFile.name, originalFile.type),
199
+ extension = _getFileNameAndExtens.extension;
200
+ info(i18n('explorerFileWindowVariationSavedInfo', 3000));
201
+ var newVariantData = {
202
+ name: name,
203
+ url: variantUrl,
204
+ query: extractVariantQuery(variantUrl),
205
+ extension: extension
206
+ };
207
+ triggerSaveRequest(dispatch(addNewVariant({
208
+ fileUuid: originalFile.uuid,
209
+ data: newVariantData
210
+ })), function (newVariant) {
211
+ info(i18n('explorerFileWindowVariationAddedInfo'), 'success');
212
+ dispatch(filesVariationsUpdated(newVariant));
213
+ setShowUrlBuilderModal(false);
214
+ setOriginalVariants([].concat(_toConsumableArray(originalVariants), [newVariant]));
215
+ }, setIsLoading);
216
+ };
217
+ var triggerAddPresetModal = function triggerAddPresetModal(variantUrl, moreProps) {
218
+ var tmpData = {
219
+ name: '',
220
+ desc: '',
221
+ error: ''
222
+ };
223
+ var updateName = function updateName(e, setPrimaryButtonDisabled, updateData) {
224
+ var newName = e.target.value;
225
+ var isExistingName = presets.find(function (preset) {
226
+ var _preset$name;
227
+ return ((_preset$name = preset.name) === null || _preset$name === void 0 ? void 0 : _preset$name.toLowerCase()) === (newName === null || newName === void 0 ? void 0 : newName.toLowerCase());
228
+ });
229
+ tmpData.name = newName;
230
+ if (!newName) {
231
+ tmpData.error = i18n('mutualizedFieldRequired');
232
+ } else if (isExistingName) {
233
+ tmpData.error = i18n('explorerFileWindowVariationsNameExistsError');
234
+ } else if (/[{}|\\^~@`,\s]/.test(newName)) {
235
+ tmpData.error = i18n('explorerFileWindowAddPresetNameRegexError');
236
+ } else {
237
+ tmpData.error = '';
238
+ }
239
+ setPrimaryButtonDisabled(Boolean(tmpData.error) || !newName || isExistingName);
240
+ updateData(_objectSpread({}, tmpData));
241
+ };
242
+ var updateDescription = function updateDescription(e, updateData) {
243
+ var newDesc = e.target.value;
244
+ tmpData.desc = newDesc;
245
+ updateData(_objectSpread({}, tmpData));
246
+ };
247
+ var presetNameInputId = 'filerobotPresetNameModalInput';
248
+ toggleModal({
249
+ icon: /*#__PURE__*/_jsx(Preset, {
250
+ size: 29,
251
+ color: theme.palette[PC.AccentPrimary]
252
+ }),
253
+ showTitleLabel: true,
254
+ title: i18n('explorerFileWindowAddPresetTitle'),
255
+ content: function content(_ref6) {
256
+ var updateData = _ref6.updateData,
257
+ data = _ref6.data,
258
+ setPrimaryButtonDisabled = _ref6.setPrimaryButtonDisabled;
259
+ return /*#__PURE__*/_jsxs(StyledVariants.PresetInputsWrapper, {
260
+ children: [/*#__PURE__*/_jsx(InputGroup, {
261
+ onChange: function onChange(e) {
262
+ return updateName(e, setPrimaryButtonDisabled, updateData);
263
+ },
264
+ error: Boolean(data.error),
265
+ hint: data.error,
266
+ label: "".concat(i18n('mutualizedNameFieldLabel'), " *"),
267
+ placeholder: i18n('explorerFileWindowAddPresetNamePlaceholder'),
268
+ value: tmpData.name || data.name || '',
269
+ InputProps: {
270
+ fullWidth: true
271
+ },
272
+ fullWidth: true,
273
+ focusOnMount: true
274
+ }), /*#__PURE__*/_jsx(InputGroup, {
275
+ type: "textarea",
276
+ onChange: function onChange(e) {
277
+ return updateDescription(e, updateData);
278
+ },
279
+ label: i18n('explorerFileWindowAddPresetDescLabel'),
280
+ placeholder: i18n('explorerFileWindowAddPresetDescPlaceholder'),
281
+ value: tmpData.desc || data.desc || '',
282
+ fullWidth: true
283
+ })]
284
+ });
285
+ },
286
+ onButtonPrimaryClick: function onButtonPrimaryClick() {
287
+ return handleSavingNewPreset(_objectSpread(_objectSpread({
288
+ variantUrl: variantUrl
289
+ }, tmpData), moreProps));
290
+ },
291
+ inputToFocus: presetNameInputId,
292
+ enterKeySubmits: true,
293
+ disablePrimaryButton: true,
294
+ modalStyle: {
295
+ width: 450,
296
+ maxWidth: 'none'
297
+ },
298
+ rootModalStyles: {
299
+ zIndex: 1500
300
+ },
301
+ modalBodyStyle: {
302
+ textAlign: 'center',
303
+ padding: '12px 32px'
304
+ },
305
+ modalFooterStyle: {
306
+ flexDirection: 'row',
307
+ padding: '12px 32px 32px 32px'
308
+ },
309
+ primaryTitleStyle: {
310
+ textAlign: 'center'
311
+ },
312
+ modalSecondaryButtonColor: 'basic',
313
+ contentStyle: {
314
+ textAlign: 'center'
315
+ },
316
+ modalPrimaryButton: {
317
+ width: 187
318
+ },
319
+ modalSecondaryButton: {
320
+ width: 187
321
+ },
322
+ inlineActionButtons: true
323
+ });
324
+ };
325
+ var triggerAddVariantModal = function triggerAddVariantModal(variantUrl) {
326
+ var moreProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
327
+ var _ref7 = moreProps || {},
328
+ ratioGroupKey = _ref7.ratioGroupKey,
329
+ ratioTitleKey = _ref7.ratioTitleKey;
330
+ var name = '';
331
+ if (ratioGroupKey && ratioTitleKey) {
332
+ name = "".concat(i18n(ratioGroupKey) || ratioGroupKey, " - ").concat(i18n(ratioTitleKey) || ratioTitleKey);
333
+ } else {
334
+ var _getFileNameAndExtens2 = getFileNameAndExtension(originalFile.name),
335
+ existingName = _getFileNameAndExtens2.name;
336
+ name = "".concat(existingName, " (").concat((customVariants.length || 1) + 1, ")");
337
+ }
338
+ var updateName = function updateName(e, setPrimaryButtonDisabled, updateData) {
339
+ var error = '';
340
+ var newName = e.target.value;
341
+ var isExistingName = presets.includes(newName) || customVariants.some(function (variant) {
342
+ return variant.name === newName;
343
+ });
344
+ name = newName;
345
+ if (!newName) {
346
+ error = i18n('mutualizedFieldRequired');
347
+ } else if (isExistingName) {
348
+ error = i18n('explorerFileWindowVariationsNameExistsError');
349
+ }
350
+ setPrimaryButtonDisabled(Boolean(error) || !newName || isExistingName);
351
+ updateData({
352
+ name: name,
353
+ error: error
354
+ });
355
+ };
356
+ var variantNameInputId = 'filerobotVariantNameModalInput';
357
+ toggleModal({
358
+ icon: /*#__PURE__*/_jsx(Rename, {
359
+ size: 29,
360
+ color: theme.palette[PC.AccentPrimary]
361
+ }),
362
+ showTitleLabel: true,
363
+ title: i18n('explorerFileWindowAddVariationTitle'),
364
+ content: function content(_ref8) {
365
+ var updateData = _ref8.updateData,
366
+ data = _ref8.data,
367
+ setPrimaryButtonDisabled = _ref8.setPrimaryButtonDisabled;
368
+ return /*#__PURE__*/_jsx(InputGroup, {
369
+ onChange: function onChange(e) {
370
+ return updateName(e, setPrimaryButtonDisabled, updateData);
371
+ },
372
+ error: Boolean(data.error),
373
+ hint: data.error,
374
+ label: "".concat(i18n('mutualizedNameFieldLabel'), " *"),
375
+ value: name || data.name || '',
376
+ fullWidth: true,
377
+ focusOnMount: true
378
+ });
379
+ },
380
+ onButtonPrimaryClick: function onButtonPrimaryClick() {
381
+ return handleSavingNewVariant(_objectSpread({
382
+ variantUrl: variantUrl,
383
+ name: name
384
+ }, moreProps));
385
+ },
386
+ inputToFocus: variantNameInputId,
387
+ enterKeySubmits: true,
388
+ modalStyle: {
389
+ width: 450,
390
+ maxWidth: 'none'
391
+ },
392
+ rootModalStyles: {
393
+ zIndex: 1500
394
+ },
395
+ modalBodyStyle: {
396
+ textAlign: 'center',
397
+ padding: '12px 32px'
398
+ },
399
+ modalFooterStyle: {
400
+ flexDirection: 'row',
401
+ padding: '12px 32px 32px 32px'
402
+ },
403
+ primaryTitleStyle: {
404
+ textAlign: 'center'
405
+ },
406
+ modalSecondaryButtonColor: 'basic',
407
+ contentStyle: {
408
+ textAlign: 'center'
409
+ },
410
+ modalPrimaryButton: {
411
+ width: 187
412
+ },
413
+ modalSecondaryButton: {
414
+ width: 187
415
+ },
416
+ inlineActionButtons: true
417
+ });
418
+ };
419
+ var addNewVariantFile = function addNewVariantFile() {
420
+ if (originalFile.uuid !== previewedFile.uuid) {
421
+ return;
422
+ }
423
+ urlBuilderSaveModeRef.current = URL_BUILDER_OPENED_AS_MODE.VARIANT;
424
+ setQueryString('');
425
+ setShowUrlBuilderModal(true);
426
+ };
427
+ var triggerAddNewPresetModal = function triggerAddNewPresetModal() {
428
+ urlBuilderSaveModeRef.current = URL_BUILDER_OPENED_AS_MODE.PRESET;
429
+ setQueryString('');
430
+ setShowUrlBuilderModal(true);
431
+ };
432
+ var downloadAllVariants = function downloadAllVariants() {
433
+ var variantsWithExtensions = searchedVariants.map(function (variant) {
434
+ var _ref9, _variant$info, _variant$info2;
435
+ return _objectSpread(_objectSpread({}, variant), {}, {
436
+ extension: variant.bgRemoved ? 'png' : getFileNameAndExtension(variant.name).extension || ((_ref9 = ((_variant$info = variant.info) === null || _variant$info === void 0 ? void 0 : _variant$info.ext) || ((_variant$info2 = variant.info) === null || _variant$info2 === void 0 ? void 0 : _variant$info2.img_type)) === null || _ref9 === void 0 ? void 0 : _ref9.toLowerCase())
437
+ });
438
+ });
439
+ triggerTransformedDownloadModal(variantsWithExtensions, {
440
+ isVariant: true,
441
+ hideResizeCropOptions: true
442
+ });
443
+ };
444
+ var submitVariantEdit = function submitVariantEdit(data) {
445
+ toggleModal(null);
446
+ triggerSaveRequest(dispatch(editVariant({
447
+ fileUuid: originalFile.uuid,
448
+ data: data
449
+ })), function (updatedVariant) {
450
+ setOriginalVariants(originalVariants.map(function (variant) {
451
+ return variant.uuid === data.uuid ? updatedVariant : variant;
452
+ }));
453
+ dispatch(filesVariationsUpdated(updatedVariant));
454
+ info(i18n('mutualizedVariantUpdatedInfo'), 'success');
455
+ });
456
+ };
457
+ var editVariantFile = function editVariantFile(variant) {
458
+ // order here is important as we must use the preview url if exists
459
+ var variantUrl = variant.preview || (_typeof(variant.url) === 'object' ? variant.url.cdn : variant.url);
460
+ var queryString = getQueryStringFromUrl(variantUrl);
461
+ setQueryString(queryString);
462
+ setShowUrlBuilderModal(true);
463
+ };
464
+ var deleteVariantFile = function deleteVariantFile(variantUuid) {
465
+ toggleModal(null);
466
+ if (variantUuid === originalFile.uuid) {
467
+ info(i18n('variantDeleteOriginalError'));
468
+ return;
469
+ }
470
+ triggerSaveRequest(dispatch(deleteVariant({
471
+ fileUuid: originalFile.uuid,
472
+ variantUuid: variantUuid
473
+ })), function (_) {
474
+ setOriginalVariants(originalVariants.filter(function (variant) {
475
+ return variant.uuid !== variantUuid;
476
+ }));
477
+ info(i18n('explorerFileWindowDeletePopupText'), 'success');
478
+ dispatch(filesVariationsUpdated(originalFile));
479
+ });
480
+ };
481
+ useEffect(function () {
482
+ _isUnMounting = false;
483
+ var mainFile = previewedFile || displayedFileVariant || originalFile;
484
+ if (previewedFile.uuid && !variationsHideManualSubTab) {
485
+ triggerSaveRequest(dispatch(getVariants(previewedFile.uuid)), function (loadedVariants) {
486
+ var mainVariants = [mainFile];
487
+ if (mainFile.info.remove_background) {
488
+ mainVariants.push(createRemovedBackgroundVariantObject(mainFile));
489
+ }
490
+ setOriginalVariants([].concat(mainVariants, _toConsumableArray(loadedVariants)));
491
+ dispatch(filesVariationsUpdated(mainVariants[0]));
492
+ }, setIsLoading);
493
+ } else {
494
+ var activeVariant = activeVariationsTabId === VARIATIONS_TAB_IDS.AUTOMATIC ? selectedVariant && (presetsVariants === null || presetsVariants === void 0 ? void 0 : presetsVariants.find(function (variant) {
495
+ return variant.name === selectedVariant.name;
496
+ })) || (presetsVariants === null || presetsVariants === void 0 ? void 0 : presetsVariants[0]) : mainFile;
497
+ dispatch(filesVariationsUpdated(activeVariant));
498
+ setIsLoading(false);
499
+ }
500
+ if (mainFile.removedBackground && !mainFile.info.remove_background) {
501
+ triggerSaveRequest(dispatch(fetchFileByUuid(originalFile.uuid)), function (updatedFile) {
502
+ var originalVariantsWithRemovedBg = [mainFile];
503
+ if (updatedFile.info.remove_background) {
504
+ originalVariantsWithRemovedBg.push(createRemovedBackgroundVariantObject(updatedFile));
505
+ setOriginalVariants(originalVariantsWithRemovedBg);
506
+ }
507
+ dispatch(fileUpdated({
508
+ info: _objectSpread(_objectSpread({}, originalFile.info), {}, {
509
+ remove_background: updatedFile.info.remove_background
510
+ })
511
+ }));
512
+ }, setIsLoading);
513
+ }
514
+ return function () {
515
+ dispatch(filesVariationsUpdated({}));
516
+ _isUnMounting = true;
517
+ };
518
+ }, [previewedFile.uuid]);
519
+ useEffect(function () {
520
+ setSearchQuery('');
521
+ }, [originalVariants]);
522
+ useEffect(function () {
523
+ var nextActiveTabId = !variationsHideManualSubTab && (presetsVariants.length === 0 || activeVariationsTabId === VARIATIONS_TAB_IDS.MANUAL) ? VARIATIONS_TAB_IDS.MANUAL : VARIATIONS_TAB_IDS.AUTOMATIC;
524
+ setActiveVariationsTabId(nextActiveTabId);
525
+ return function () {
526
+ setActiveVariationsTabId(null);
527
+ };
528
+ }, [presetsVariants, variationsHideManualSubTab]);
529
+ if (isLoading) {
530
+ return /*#__PURE__*/_jsx(VariationsSkeleton, {
531
+ i18n: i18n,
532
+ activeTabId: activeVariationsTabId
533
+ });
534
+ }
535
+ var isPublicFile = isVisibilityPublic(originalFile === null || originalFile === void 0 ? void 0 : originalFile.visibility);
536
+ if (!isPublicFile) {
537
+ return /*#__PURE__*/_jsx(ErroredViewPlaceholder, {
538
+ icon: /*#__PURE__*/_jsx(Lock, {
539
+ size: 60
540
+ }),
541
+ title: i18n('explorerFileWindowVariationsTabDisabledTitle'),
542
+ description: i18n('explorerFileWindowVariationsTabDisabledDesc')
543
+ });
544
+ }
545
+ var currentVariantsCount = searchedVariants.length;
546
+ var originalVariantsCount = nextVariants.length;
547
+ return /*#__PURE__*/_jsxs(_Fragment, {
548
+ children: [/*#__PURE__*/_jsx(VariationsTabNavigator, {
549
+ i18n: i18n,
550
+ activeTabId: activeVariationsTabId,
551
+ setActiveTabId: setActiveVariationsTabId,
552
+ customVariants: customVariants,
553
+ presetsVariants: presetsVariants,
554
+ selectedVariant: selectedVariant
555
+ }), /*#__PURE__*/_jsxs(StyledVariants.Actions, {
556
+ children: [/*#__PURE__*/_jsx(StyledVariants.Title, {
557
+ children: isAutomaticTabActive ? i18n('explorerFileWindowVariationsPresetsTabLabel') : i18n('explorerFileWindowVariationsCustomTabLabel')
558
+ }), !hideDownloadVariationsOption && originalVariantsCount > 1 && currentVariantsCount > 0 && /*#__PURE__*/_jsx(Button, {
559
+ badge: "(".concat(currentVariantsCount, ")"),
560
+ startIcon: /*#__PURE__*/_jsx(Download, {}),
561
+ size: "sm",
562
+ color: "link-primary",
563
+ onClick: downloadAllVariants,
564
+ disabled: currentVariantsCount === 0,
565
+ children: i18n('explorerFileWindowVariationsDownloadAllButton')
566
+ })]
567
+ }), /*#__PURE__*/_jsx(VariationsSearch, {
568
+ originalVariants: originalVariants || [],
569
+ setSearchQuery: setSearchQuery,
570
+ isAutomaticTabActive: isAutomaticTabActive
571
+ }), /*#__PURE__*/_jsx(VariationsContent, {
572
+ variants: searchedVariants,
573
+ originalFile: originalFile,
574
+ previewedFile: previewedFile,
575
+ displayedFileVariant: displayedFileVariant,
576
+ setPreviewedFile: setPreviewedFile,
577
+ addNewVariant: addNewVariantFile,
578
+ editVariantFile: editVariantFile,
579
+ editVariantName: submitVariantEdit,
580
+ setSelectedVariant: setSelectedVariant,
581
+ deleteVariant: deleteVariantFile,
582
+ searchQuery: searchQuery,
583
+ originalVariantsCount: originalVariantsCount,
584
+ isLoading: isLoading,
585
+ i18n: i18n,
586
+ activeTabId: activeVariationsTabId,
587
+ addNewPreset: triggerAddNewPresetModal,
588
+ showAddPresetButton: variationsShowAddPresetButton
589
+ }), /*#__PURE__*/_jsx(UrlBuilderModal, {
590
+ queryString: queryString,
591
+ showUrlBuilderModal: showUrlBuilderModal,
592
+ setShowUrlBuilderModal: setShowUrlBuilderModal,
593
+ originalFile: originalFile,
594
+ onNewSave: handleUrlBuilderNewSave,
595
+ headerTitle: i18n('explorerFileWindowAddVariationButton'),
596
+ actionButtonLabel: i18n('mutualizedSaveButton'),
597
+ urlTitle: i18n('explorerFileWindowVariationsUrlBuilderModalTitle'),
598
+ i18n: i18n,
599
+ selectedVariant: selectedVariant,
600
+ extractVariantQuery: extractVariantQuery,
601
+ submitVariantEdit: submitVariantEdit,
602
+ info: info
603
+ })]
604
+ });
605
+ };
606
+ export default VariationsTab;