@blaze-cms/plugin-media-ui 0.146.0-node18.1 → 0.146.0-rc-eagle.0

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 (334) hide show
  1. package/CHANGELOG.md +10 -16
  2. package/lib/components/CardMedia/CardMedia.js +168 -221
  3. package/lib/components/CardMedia/CardMedia.js.map +1 -1
  4. package/lib/components/CardMedia/index.js +2 -3
  5. package/lib/components/CardMedia/index.js.map +1 -1
  6. package/lib/components/EditMediaFile/EditMediaFile.js +162 -113
  7. package/lib/components/EditMediaFile/EditMediaFile.js.map +1 -1
  8. package/lib/components/EditMediaFile/EditMediaFilePage.js +81 -97
  9. package/lib/components/EditMediaFile/EditMediaFilePage.js.map +1 -1
  10. package/lib/components/EditMediaFile/index.js +2 -3
  11. package/lib/components/EditMediaFile/index.js.map +1 -1
  12. package/lib/components/EditorAdapter/EditorAdapter.js +43 -22
  13. package/lib/components/EditorAdapter/EditorAdapter.js.map +1 -1
  14. package/lib/components/EditorAdapter/index.js +2 -3
  15. package/lib/components/EditorAdapter/index.js.map +1 -1
  16. package/lib/components/FileList/FilesListContext/index.js +3 -4
  17. package/lib/components/FileList/FilesListContext/index.js.map +1 -1
  18. package/lib/components/FileList/FilesListProvider/index.js +27 -29
  19. package/lib/components/FileList/FilesListProvider/index.js.map +1 -1
  20. package/lib/components/FileList/useFileList/index.js +3 -6
  21. package/lib/components/FileList/useFileList/index.js.map +1 -1
  22. package/lib/components/FileList/useGetFiles/getFiles.js +164 -185
  23. package/lib/components/FileList/useGetFiles/getFiles.js.map +1 -1
  24. package/lib/components/FileList/useGetFiles/index.js +2 -3
  25. package/lib/components/FileList/useGetFiles/index.js.map +1 -1
  26. package/lib/components/FileList/useGetFiles/useGetFiles.js +88 -133
  27. package/lib/components/FileList/useGetFiles/useGetFiles.js.map +1 -1
  28. package/lib/components/FileList/useGetFilesList/getCounters.js +10 -30
  29. package/lib/components/FileList/useGetFilesList/getCounters.js.map +1 -1
  30. package/lib/components/FileList/useGetFilesList/index.js +2 -3
  31. package/lib/components/FileList/useGetFilesList/index.js.map +1 -1
  32. package/lib/components/FileList/useGetFilesList/useGetFilesList.js +89 -110
  33. package/lib/components/FileList/useGetFilesList/useGetFilesList.js.map +1 -1
  34. package/lib/components/FilePreview/Actions/index.js +24 -38
  35. package/lib/components/FilePreview/Actions/index.js.map +1 -1
  36. package/lib/components/FilePreview/Image/Image.js +35 -24
  37. package/lib/components/FilePreview/Image/Image.js.map +1 -1
  38. package/lib/components/FilePreview/Image/RawImage.js +25 -27
  39. package/lib/components/FilePreview/Image/RawImage.js.map +1 -1
  40. package/lib/components/FilePreview/Image/imageSchema.js +2 -3
  41. package/lib/components/FilePreview/Image/imageSchema.js.map +1 -1
  42. package/lib/components/FilePreview/Image/index.js +1 -2
  43. package/lib/components/FilePreview/Image/index.js.map +1 -1
  44. package/lib/components/FilePreview/ModalContext.js +9 -0
  45. package/lib/components/FilePreview/ModalContext.js.map +1 -0
  46. package/lib/components/FilePreview/PDF/PDF.js +44 -31
  47. package/lib/components/FilePreview/PDF/PDF.js.map +1 -1
  48. package/lib/components/FilePreview/PDF/RawPDF.js +27 -29
  49. package/lib/components/FilePreview/PDF/RawPDF.js.map +1 -1
  50. package/lib/components/FilePreview/PDF/index.js +1 -2
  51. package/lib/components/FilePreview/PDF/index.js.map +1 -1
  52. package/lib/components/FilePreview/PDF/schema.js +1 -2
  53. package/lib/components/FilePreview/PDF/schema.js.map +1 -1
  54. package/lib/components/FilePreview/get-preview.js +12 -10
  55. package/lib/components/FilePreview/get-preview.js.map +1 -1
  56. package/lib/components/FilePreview/index.js +66 -57
  57. package/lib/components/FilePreview/index.js.map +1 -1
  58. package/lib/components/FilePreview/previewDefault/PreviewDefault.js +35 -23
  59. package/lib/components/FilePreview/previewDefault/PreviewDefault.js.map +1 -1
  60. package/lib/components/FilePreview/previewDefault/RawPreviewDefault.js +33 -27
  61. package/lib/components/FilePreview/previewDefault/RawPreviewDefault.js.map +1 -1
  62. package/lib/components/FilePreview/previewDefault/icons/DefaultIcon.js +120 -123
  63. package/lib/components/FilePreview/previewDefault/icons/DefaultIcon.js.map +1 -1
  64. package/lib/components/FilePreview/previewDefault/icons/index.js +2 -3
  65. package/lib/components/FilePreview/previewDefault/icons/index.js.map +1 -1
  66. package/lib/components/FilePreview/previewDefault/index.js +1 -2
  67. package/lib/components/FilePreview/previewDefault/index.js.map +1 -1
  68. package/lib/components/FilePreview/previewDefault/previewDefaultSchema.js +1 -2
  69. package/lib/components/FilePreview/previewDefault/previewDefaultSchema.js.map +1 -1
  70. package/lib/components/FilePreviewReadOnly/FileList.js +10 -12
  71. package/lib/components/FilePreviewReadOnly/FileList.js.map +1 -1
  72. package/lib/components/FilePreviewReadOnly/FilePreviewList.js +14 -20
  73. package/lib/components/FilePreviewReadOnly/FilePreviewList.js.map +1 -1
  74. package/lib/components/FilePreviewReadOnly/FilePreviewReadOnly.js +52 -98
  75. package/lib/components/FilePreviewReadOnly/FilePreviewReadOnly.js.map +1 -1
  76. package/lib/components/FilePreviewReadOnly/index.js +2 -3
  77. package/lib/components/FilePreviewReadOnly/index.js.map +1 -1
  78. package/lib/components/FilePreviewReadOnly/mappers/format-initial-value.js +7 -8
  79. package/lib/components/FilePreviewReadOnly/mappers/format-initial-value.js.map +1 -1
  80. package/lib/components/FilePreviewReadOnly/mappers/index.js +1 -2
  81. package/lib/components/FilePreviewReadOnly/mappers/index.js.map +1 -1
  82. package/lib/components/FileUploadAdapter/FileList.js +26 -39
  83. package/lib/components/FileUploadAdapter/FileList.js.map +1 -1
  84. package/lib/components/FileUploadAdapter/FilePreviewList.js +14 -20
  85. package/lib/components/FileUploadAdapter/FilePreviewList.js.map +1 -1
  86. package/lib/components/FileUploadAdapter/FileReorderList.js +18 -21
  87. package/lib/components/FileUploadAdapter/FileReorderList.js.map +1 -1
  88. package/lib/components/FileUploadAdapter/FileReorderListItem.js +20 -23
  89. package/lib/components/FileUploadAdapter/FileReorderListItem.js.map +1 -1
  90. package/lib/components/FileUploadAdapter/FileUploadAdapter.js +238 -338
  91. package/lib/components/FileUploadAdapter/FileUploadAdapter.js.map +1 -1
  92. package/lib/components/FileUploadAdapter/index.js +2 -3
  93. package/lib/components/FileUploadAdapter/index.js.map +1 -1
  94. package/lib/components/FileUploadAdapter/mappers/format-initial-value.js +7 -8
  95. package/lib/components/FileUploadAdapter/mappers/format-initial-value.js.map +1 -1
  96. package/lib/components/FileUploadAdapter/mappers/get-button-text.js +9 -6
  97. package/lib/components/FileUploadAdapter/mappers/get-button-text.js.map +1 -1
  98. package/lib/components/FileUploadAdapter/mappers/get-format.js +7 -13
  99. package/lib/components/FileUploadAdapter/mappers/get-format.js.map +1 -1
  100. package/lib/components/FileUploadAdapter/mappers/get-number-files-pending-to-fetch.js +6 -5
  101. package/lib/components/FileUploadAdapter/mappers/get-number-files-pending-to-fetch.js.map +1 -1
  102. package/lib/components/FileUploadAdapter/mappers/index.js +6 -7
  103. package/lib/components/FileUploadAdapter/mappers/index.js.map +1 -1
  104. package/lib/components/FileUploadAdapter/mappers/is-unselecting.js +2 -10
  105. package/lib/components/FileUploadAdapter/mappers/is-unselecting.js.map +1 -1
  106. package/lib/components/FileUploadAdapter/mappers/transform-to-array.js +2 -5
  107. package/lib/components/FileUploadAdapter/mappers/transform-to-array.js.map +1 -1
  108. package/lib/components/FileUploadAdapter/useLimit.js +4 -10
  109. package/lib/components/FileUploadAdapter/useLimit.js.map +1 -1
  110. package/lib/components/FileUploadModal/FileUploadModal.js +150 -145
  111. package/lib/components/FileUploadModal/FileUploadModal.js.map +1 -1
  112. package/lib/components/FileUploadModal/index.js +2 -3
  113. package/lib/components/FileUploadModal/index.js.map +1 -1
  114. package/lib/components/FilterPanel/FilterPanel.js +68 -88
  115. package/lib/components/FilterPanel/FilterPanel.js.map +1 -1
  116. package/lib/components/FilterPanel/index.js +2 -3
  117. package/lib/components/FilterPanel/index.js.map +1 -1
  118. package/lib/components/ListingContainer/Listing/Listing.js +58 -48
  119. package/lib/components/ListingContainer/Listing/Listing.js.map +1 -1
  120. package/lib/components/ListingContainer/Listing/MediaListing/MediaFileList/MediaFileList.js +75 -92
  121. package/lib/components/ListingContainer/Listing/MediaListing/MediaFileList/MediaFileList.js.map +1 -1
  122. package/lib/components/ListingContainer/Listing/MediaListing/MediaFileList/index.js +2 -3
  123. package/lib/components/ListingContainer/Listing/MediaListing/MediaFileList/index.js.map +1 -1
  124. package/lib/components/ListingContainer/Listing/MediaListing/MediaListing.js +22 -26
  125. package/lib/components/ListingContainer/Listing/MediaListing/MediaListing.js.map +1 -1
  126. package/lib/components/ListingContainer/Listing/MediaListing/index.js +2 -3
  127. package/lib/components/ListingContainer/Listing/MediaListing/index.js.map +1 -1
  128. package/lib/components/ListingContainer/Listing/index.js +2 -3
  129. package/lib/components/ListingContainer/Listing/index.js.map +1 -1
  130. package/lib/components/ListingContainer/ListingContainer.js +69 -92
  131. package/lib/components/ListingContainer/ListingContainer.js.map +1 -1
  132. package/lib/components/ListingContainer/index.js +2 -3
  133. package/lib/components/ListingContainer/index.js.map +1 -1
  134. package/lib/components/ListingContainer/mappers/exist-previous.js +3 -10
  135. package/lib/components/ListingContainer/mappers/exist-previous.js.map +1 -1
  136. package/lib/components/ListingContainer/mappers/index.js +2 -3
  137. package/lib/components/ListingContainer/mappers/index.js.map +1 -1
  138. package/lib/components/MediaListing.js +14 -26
  139. package/lib/components/MediaListing.js.map +1 -1
  140. package/lib/constants.js +15 -16
  141. package/lib/constants.js.map +1 -1
  142. package/lib/icons/MediaLibraryIcon.js +17 -20
  143. package/lib/icons/MediaLibraryIcon.js.map +1 -1
  144. package/lib/icons/index.js +2 -3
  145. package/lib/icons/index.js.map +1 -1
  146. package/lib/index.js +67 -92
  147. package/lib/index.js.map +1 -1
  148. package/lib/utils/available-filters/available-filters.js +1 -2
  149. package/lib/utils/available-filters/available-filters.js.map +1 -1
  150. package/lib/utils/bustUrl.js +13 -0
  151. package/lib/utils/bustUrl.js.map +1 -0
  152. package/lib/utils/media-context/index.js +4 -5
  153. package/lib/utils/media-context/index.js.map +1 -1
  154. package/lib/utils/media-context/media-context.js +3 -4
  155. package/lib/utils/media-context/media-context.js.map +1 -1
  156. package/lib/utils/media-context/useMediaContext.js +2 -4
  157. package/lib/utils/media-context/useMediaContext.js.map +1 -1
  158. package/package.json +14 -14
  159. package/src/components/CardMedia/CardMedia.js +27 -8
  160. package/src/components/EditMediaFile/EditMediaFile.js +115 -37
  161. package/src/components/EditMediaFile/EditMediaFilePage.js +35 -9
  162. package/src/components/EditorAdapter/EditorAdapter.js +31 -4
  163. package/src/components/FilePreview/Actions/index.js +25 -27
  164. package/src/components/FilePreview/Image/Image.js +15 -2
  165. package/src/components/FilePreview/Image/imageSchema.js +1 -1
  166. package/src/components/FilePreview/ModalContext.js +3 -0
  167. package/src/components/FilePreview/PDF/PDF.js +17 -4
  168. package/src/components/FilePreview/index.js +35 -6
  169. package/src/components/FilePreview/previewDefault/PreviewDefault.js +16 -3
  170. package/src/components/FilePreview/previewDefault/RawPreviewDefault.js +17 -7
  171. package/src/components/FilePreviewReadOnly/FileList.js +1 -3
  172. package/src/components/FilePreviewReadOnly/FilePreviewReadOnly.js +17 -29
  173. package/src/components/FileUploadAdapter/FileUploadAdapter.js +42 -18
  174. package/src/components/FileUploadAdapter/mappers/get-button-text.js +4 -3
  175. package/src/components/FileUploadAdapter/mappers/get-number-files-pending-to-fetch.js +6 -4
  176. package/src/components/FileUploadModal/FileUploadModal.js +88 -42
  177. package/src/components/ListingContainer/Listing/Listing.js +15 -5
  178. package/src/components/ListingContainer/Listing/MediaListing/MediaFileList/MediaFileList.js +11 -5
  179. package/src/components/ListingContainer/Listing/MediaListing/MediaListing.js +10 -2
  180. package/src/components/ListingContainer/ListingContainer.js +13 -4
  181. package/src/index.js +17 -14
  182. package/src/utils/bustUrl.js +6 -0
  183. package/lib-es/components/CardMedia/CardMedia.js +0 -219
  184. package/lib-es/components/CardMedia/CardMedia.js.map +0 -1
  185. package/lib-es/components/CardMedia/index.js +0 -3
  186. package/lib-es/components/CardMedia/index.js.map +0 -1
  187. package/lib-es/components/EditMediaFile/EditMediaFile.js +0 -115
  188. package/lib-es/components/EditMediaFile/EditMediaFile.js.map +0 -1
  189. package/lib-es/components/EditMediaFile/EditMediaFilePage.js +0 -86
  190. package/lib-es/components/EditMediaFile/EditMediaFilePage.js.map +0 -1
  191. package/lib-es/components/EditMediaFile/index.js +0 -3
  192. package/lib-es/components/EditMediaFile/index.js.map +0 -1
  193. package/lib-es/components/EditorAdapter/EditorAdapter.js +0 -39
  194. package/lib-es/components/EditorAdapter/EditorAdapter.js.map +0 -1
  195. package/lib-es/components/EditorAdapter/index.js +0 -3
  196. package/lib-es/components/EditorAdapter/index.js.map +0 -1
  197. package/lib-es/components/FileList/FilesListContext/index.js +0 -4
  198. package/lib-es/components/FileList/FilesListContext/index.js.map +0 -1
  199. package/lib-es/components/FileList/FilesListProvider/index.js +0 -36
  200. package/lib-es/components/FileList/FilesListProvider/index.js.map +0 -1
  201. package/lib-es/components/FileList/useFileList/index.js +0 -5
  202. package/lib-es/components/FileList/useFileList/index.js.map +0 -1
  203. package/lib-es/components/FileList/useGetFiles/getFiles.js +0 -179
  204. package/lib-es/components/FileList/useGetFiles/getFiles.js.map +0 -1
  205. package/lib-es/components/FileList/useGetFiles/index.js +0 -3
  206. package/lib-es/components/FileList/useGetFiles/index.js.map +0 -1
  207. package/lib-es/components/FileList/useGetFiles/useGetFiles.js +0 -114
  208. package/lib-es/components/FileList/useGetFiles/useGetFiles.js.map +0 -1
  209. package/lib-es/components/FileList/useGetFilesList/getCounters.js +0 -11
  210. package/lib-es/components/FileList/useGetFilesList/getCounters.js.map +0 -1
  211. package/lib-es/components/FileList/useGetFilesList/index.js +0 -3
  212. package/lib-es/components/FileList/useGetFilesList/index.js.map +0 -1
  213. package/lib-es/components/FileList/useGetFilesList/useGetFilesList.js +0 -172
  214. package/lib-es/components/FileList/useGetFilesList/useGetFilesList.js.map +0 -1
  215. package/lib-es/components/FilePreview/Actions/index.js +0 -38
  216. package/lib-es/components/FilePreview/Actions/index.js.map +0 -1
  217. package/lib-es/components/FilePreview/Image/Image.js +0 -27
  218. package/lib-es/components/FilePreview/Image/Image.js.map +0 -1
  219. package/lib-es/components/FilePreview/Image/RawImage.js +0 -31
  220. package/lib-es/components/FilePreview/Image/RawImage.js.map +0 -1
  221. package/lib-es/components/FilePreview/Image/imageSchema.js +0 -53
  222. package/lib-es/components/FilePreview/Image/imageSchema.js.map +0 -1
  223. package/lib-es/components/FilePreview/Image/index.js +0 -12
  224. package/lib-es/components/FilePreview/Image/index.js.map +0 -1
  225. package/lib-es/components/FilePreview/PDF/PDF.js +0 -34
  226. package/lib-es/components/FilePreview/PDF/PDF.js.map +0 -1
  227. package/lib-es/components/FilePreview/PDF/RawPDF.js +0 -33
  228. package/lib-es/components/FilePreview/PDF/RawPDF.js.map +0 -1
  229. package/lib-es/components/FilePreview/PDF/index.js +0 -12
  230. package/lib-es/components/FilePreview/PDF/index.js.map +0 -1
  231. package/lib-es/components/FilePreview/PDF/schema.js +0 -21
  232. package/lib-es/components/FilePreview/PDF/schema.js.map +0 -1
  233. package/lib-es/components/FilePreview/get-preview.js +0 -28
  234. package/lib-es/components/FilePreview/get-preview.js.map +0 -1
  235. package/lib-es/components/FilePreview/index.js +0 -85
  236. package/lib-es/components/FilePreview/index.js.map +0 -1
  237. package/lib-es/components/FilePreview/previewDefault/PreviewDefault.js +0 -27
  238. package/lib-es/components/FilePreview/previewDefault/PreviewDefault.js.map +0 -1
  239. package/lib-es/components/FilePreview/previewDefault/RawPreviewDefault.js +0 -31
  240. package/lib-es/components/FilePreview/previewDefault/RawPreviewDefault.js.map +0 -1
  241. package/lib-es/components/FilePreview/previewDefault/icons/DefaultIcon.js +0 -121
  242. package/lib-es/components/FilePreview/previewDefault/icons/DefaultIcon.js.map +0 -1
  243. package/lib-es/components/FilePreview/previewDefault/icons/index.js +0 -3
  244. package/lib-es/components/FilePreview/previewDefault/icons/index.js.map +0 -1
  245. package/lib-es/components/FilePreview/previewDefault/index.js +0 -12
  246. package/lib-es/components/FilePreview/previewDefault/index.js.map +0 -1
  247. package/lib-es/components/FilePreview/previewDefault/previewDefaultSchema.js +0 -25
  248. package/lib-es/components/FilePreview/previewDefault/previewDefaultSchema.js.map +0 -1
  249. package/lib-es/components/FilePreviewReadOnly/FileList.js +0 -18
  250. package/lib-es/components/FilePreviewReadOnly/FileList.js.map +0 -1
  251. package/lib-es/components/FilePreviewReadOnly/FilePreviewList.js +0 -22
  252. package/lib-es/components/FilePreviewReadOnly/FilePreviewList.js.map +0 -1
  253. package/lib-es/components/FilePreviewReadOnly/FilePreviewReadOnly.js +0 -66
  254. package/lib-es/components/FilePreviewReadOnly/FilePreviewReadOnly.js.map +0 -1
  255. package/lib-es/components/FilePreviewReadOnly/index.js +0 -3
  256. package/lib-es/components/FilePreviewReadOnly/index.js.map +0 -1
  257. package/lib-es/components/FilePreviewReadOnly/mappers/format-initial-value.js +0 -11
  258. package/lib-es/components/FilePreviewReadOnly/mappers/format-initial-value.js.map +0 -1
  259. package/lib-es/components/FilePreviewReadOnly/mappers/index.js +0 -3
  260. package/lib-es/components/FilePreviewReadOnly/mappers/index.js.map +0 -1
  261. package/lib-es/components/FileUploadAdapter/FileList.js +0 -52
  262. package/lib-es/components/FileUploadAdapter/FileList.js.map +0 -1
  263. package/lib-es/components/FileUploadAdapter/FilePreviewList.js +0 -22
  264. package/lib-es/components/FileUploadAdapter/FilePreviewList.js.map +0 -1
  265. package/lib-es/components/FileUploadAdapter/FileReorderList.js +0 -32
  266. package/lib-es/components/FileUploadAdapter/FileReorderList.js.map +0 -1
  267. package/lib-es/components/FileUploadAdapter/FileReorderListItem.js +0 -24
  268. package/lib-es/components/FileUploadAdapter/FileReorderListItem.js.map +0 -1
  269. package/lib-es/components/FileUploadAdapter/FileUploadAdapter.js +0 -367
  270. package/lib-es/components/FileUploadAdapter/FileUploadAdapter.js.map +0 -1
  271. package/lib-es/components/FileUploadAdapter/index.js +0 -3
  272. package/lib-es/components/FileUploadAdapter/index.js.map +0 -1
  273. package/lib-es/components/FileUploadAdapter/mappers/format-initial-value.js +0 -11
  274. package/lib-es/components/FileUploadAdapter/mappers/format-initial-value.js.map +0 -1
  275. package/lib-es/components/FileUploadAdapter/mappers/get-button-text.js +0 -9
  276. package/lib-es/components/FileUploadAdapter/mappers/get-button-text.js.map +0 -1
  277. package/lib-es/components/FileUploadAdapter/mappers/get-format.js +0 -12
  278. package/lib-es/components/FileUploadAdapter/mappers/get-format.js.map +0 -1
  279. package/lib-es/components/FileUploadAdapter/mappers/get-number-files-pending-to-fetch.js +0 -6
  280. package/lib-es/components/FileUploadAdapter/mappers/get-number-files-pending-to-fetch.js.map +0 -1
  281. package/lib-es/components/FileUploadAdapter/mappers/index.js +0 -8
  282. package/lib-es/components/FileUploadAdapter/mappers/index.js.map +0 -1
  283. package/lib-es/components/FileUploadAdapter/mappers/is-unselecting.js +0 -2
  284. package/lib-es/components/FileUploadAdapter/mappers/is-unselecting.js.map +0 -1
  285. package/lib-es/components/FileUploadAdapter/mappers/transform-to-array.js +0 -2
  286. package/lib-es/components/FileUploadAdapter/mappers/transform-to-array.js.map +0 -1
  287. package/lib-es/components/FileUploadAdapter/useLimit.js +0 -13
  288. package/lib-es/components/FileUploadAdapter/useLimit.js.map +0 -1
  289. package/lib-es/components/FileUploadModal/FileUploadModal.js +0 -113
  290. package/lib-es/components/FileUploadModal/FileUploadModal.js.map +0 -1
  291. package/lib-es/components/FileUploadModal/index.js +0 -3
  292. package/lib-es/components/FileUploadModal/index.js.map +0 -1
  293. package/lib-es/components/FilterPanel/FilterPanel.js +0 -135
  294. package/lib-es/components/FilterPanel/FilterPanel.js.map +0 -1
  295. package/lib-es/components/FilterPanel/index.js +0 -3
  296. package/lib-es/components/FilterPanel/index.js.map +0 -1
  297. package/lib-es/components/ListingContainer/Listing/Listing.js +0 -58
  298. package/lib-es/components/ListingContainer/Listing/Listing.js.map +0 -1
  299. package/lib-es/components/ListingContainer/Listing/MediaListing/MediaFileList/MediaFileList.js +0 -145
  300. package/lib-es/components/ListingContainer/Listing/MediaListing/MediaFileList/MediaFileList.js.map +0 -1
  301. package/lib-es/components/ListingContainer/Listing/MediaListing/MediaFileList/index.js +0 -3
  302. package/lib-es/components/ListingContainer/Listing/MediaListing/MediaFileList/index.js.map +0 -1
  303. package/lib-es/components/ListingContainer/Listing/MediaListing/MediaListing.js +0 -24
  304. package/lib-es/components/ListingContainer/Listing/MediaListing/MediaListing.js.map +0 -1
  305. package/lib-es/components/ListingContainer/Listing/MediaListing/index.js +0 -3
  306. package/lib-es/components/ListingContainer/Listing/MediaListing/index.js.map +0 -1
  307. package/lib-es/components/ListingContainer/Listing/index.js +0 -3
  308. package/lib-es/components/ListingContainer/Listing/index.js.map +0 -1
  309. package/lib-es/components/ListingContainer/ListingContainer.js +0 -106
  310. package/lib-es/components/ListingContainer/ListingContainer.js.map +0 -1
  311. package/lib-es/components/ListingContainer/index.js +0 -3
  312. package/lib-es/components/ListingContainer/index.js.map +0 -1
  313. package/lib-es/components/ListingContainer/mappers/exist-previous.js +0 -3
  314. package/lib-es/components/ListingContainer/mappers/exist-previous.js.map +0 -1
  315. package/lib-es/components/ListingContainer/mappers/index.js +0 -3
  316. package/lib-es/components/ListingContainer/mappers/index.js.map +0 -1
  317. package/lib-es/components/MediaListing.js +0 -29
  318. package/lib-es/components/MediaListing.js.map +0 -1
  319. package/lib-es/constants.js +0 -36
  320. package/lib-es/constants.js.map +0 -1
  321. package/lib-es/icons/MediaLibraryIcon.js +0 -70
  322. package/lib-es/icons/MediaLibraryIcon.js.map +0 -1
  323. package/lib-es/icons/index.js +0 -3
  324. package/lib-es/icons/index.js.map +0 -1
  325. package/lib-es/index.js +0 -61
  326. package/lib-es/index.js.map +0 -1
  327. package/lib-es/utils/available-filters/available-filters.js +0 -26
  328. package/lib-es/utils/available-filters/available-filters.js.map +0 -1
  329. package/lib-es/utils/media-context/index.js +0 -4
  330. package/lib-es/utils/media-context/index.js.map +0 -1
  331. package/lib-es/utils/media-context/media-context.js +0 -6
  332. package/lib-es/utils/media-context/media-context.js.map +0 -1
  333. package/lib-es/utils/media-context/useMediaContext.js +0 -4
  334. package/lib-es/utils/media-context/useMediaContext.js.map +0 -1
@@ -2,14 +2,30 @@ import React, { useState, useEffect } from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import { getQuery } from '@blaze-cms/admin-ui-utils';
4
4
  import { useQuery } from '@apollo/client';
5
+ import { useToasts } from '@blaze-react/toaster';
5
6
  import FilePreview from '../FilePreview';
7
+ import FileUploadModal from '../FileUploadModal';
6
8
  import { STORE_KEY, NAME } from '../../constants';
7
9
 
8
- const EditMediaFile = ({ onChange, handleSaveButtonStatus, enableSaveButton, fileId }) => {
10
+ const EditMediaFile = ({
11
+ onChange,
12
+ handleSaveButtonStatus,
13
+ fileId,
14
+ showChangeButton,
15
+ fileUpdated
16
+ }) => {
9
17
  const [formValues, setFormValues] = useState(null);
10
- const query = getQuery('GET_FILE_BY_ID');
11
- const { loading, data: { file } = {} } = useQuery(query, {
12
- variables: { id: fileId }
18
+ const [displayFileUploadModal, setDisplayFileUploadModal] = useState(false);
19
+ const { addToast } = useToasts();
20
+
21
+ const fileQuery = getQuery('GET_FILE_BY_ID');
22
+ const {
23
+ loading,
24
+ data: { file } = {},
25
+ refetch: refetchFile
26
+ } = useQuery(fileQuery, {
27
+ variables: { id: fileId },
28
+ fetchPolicy: 'cache-and-network'
13
29
  });
14
30
 
15
31
  const fileStoresType = getQuery('GET_FILE_STORES');
@@ -18,65 +34,125 @@ const EditMediaFile = ({ onChange, handleSaveButtonStatus, enableSaveButton, fil
18
34
  });
19
35
 
20
36
  useEffect(() => {
21
- if (!formValues && file) {
22
- setFormValues(file);
37
+ if (file) {
38
+ setFormValues(prevFormValues => {
39
+ if (!prevFormValues || prevFormValues.updated !== file.updated) {
40
+ return file;
41
+ }
42
+ return prevFormValues;
43
+ });
44
+ }
45
+ }, [file]);
46
+
47
+ useEffect(() => {
48
+ if (fileUpdated && fileUpdated.updated) {
49
+ setFormValues(fileUpdated);
23
50
  }
24
- }, [file, formValues, storeType]);
51
+ }, [fileUpdated]);
25
52
 
26
53
  const handleFormChange = ({ isValid, isNewValueSet, valuesChecked }) => {
27
- const valuesCheckedWithoutName = valuesChecked.filter(({ id }) => {
28
- if (id === NAME || id === STORE_KEY) return false;
29
- return true;
30
- });
54
+ const baseFile = formValues || file;
55
+ const valuesCheckedWithoutName = valuesChecked.filter(
56
+ ({ id }) => id !== NAME && id !== STORE_KEY
57
+ );
31
58
 
32
59
  const dataValues = valuesCheckedWithoutName.reduce((acc, { id, value }) => {
33
60
  acc[id] = value;
34
61
  return acc;
35
62
  }, {});
63
+
36
64
  const { value: newFileName } = valuesChecked.find(({ id }) => id === NAME) || {};
37
65
  const { value: storeKey } = valuesChecked.find(({ id }) => id === STORE_KEY) || {};
38
66
 
39
67
  const shouldEnableSaveButton = isNewValueSet && isValid;
40
- handleSaveButtonStatus(false);
41
-
42
- if (shouldEnableSaveButton && shouldEnableSaveButton !== enableSaveButton) {
43
- handleSaveButtonStatus(shouldEnableSaveButton);
44
- }
68
+ handleSaveButtonStatus(shouldEnableSaveButton);
45
69
 
46
70
  const updatedFile = {
47
- id: file.id,
48
- name: newFileName,
49
- storeKey,
50
- data: dataValues
71
+ ...baseFile,
72
+ name: newFileName || baseFile.name,
73
+ storeKey: storeKey || baseFile.storeKey,
74
+ data: { ...(baseFile.data || {}), ...dataValues }
51
75
  };
76
+
52
77
  setFormValues(updatedFile);
53
- onChange(updatedFile);
78
+ // Strip GraphQL metadata field __typename before passing data to onChange.
79
+ const { __typename, ...cleanData } = updatedFile.data || {};
80
+ onChange({ id: updatedFile.id, name: updatedFile.name, data: cleanData });
54
81
  };
55
82
 
56
- const getFileWithStoreType = () => {
57
- if (storeType) {
83
+ const getFileWithStoreType = sourceFile => {
84
+ const base = sourceFile || file;
85
+ if (storeType && base) {
58
86
  const storeOptions = storeType.map(type => [type.key, type.name]);
59
87
  const defaultStore = storeType.find(type => type.isDefault) || null;
60
- return { ...file, store: { defaultStore, storeOptions } };
88
+ return { ...base, store: { defaultStore, storeOptions } };
89
+ }
90
+ return base;
91
+ };
92
+
93
+ const closeModalAndSetValue = async (isSaving, values, toastMessage) => {
94
+ if (toastMessage) {
95
+ addToast(toastMessage, { appearance: 'success', autoDismiss: true });
61
96
  }
62
97
 
63
- return file;
98
+ if (values) {
99
+ const updated =
100
+ values.id === fileId
101
+ ? values
102
+ : {
103
+ ...(formValues || file),
104
+ ...values,
105
+ url: values.url || (formValues || file).url
106
+ };
107
+ setFormValues(updated);
108
+ onChange(updated);
109
+ handleSaveButtonStatus(true);
110
+ } else {
111
+ const { data: { file: refreshedFile } = {} } = await refetchFile({
112
+ id: fileId,
113
+ timestamp: Date.now()
114
+ });
115
+ if (refreshedFile) {
116
+ setFormValues(refreshedFile);
117
+ onChange(refreshedFile);
118
+ handleSaveButtonStatus(true);
119
+ }
120
+ }
121
+
122
+ setDisplayFileUploadModal(false);
64
123
  };
65
124
 
66
- const fileWithStoreType = getFileWithStoreType();
125
+ if (loading) return <div>loading...</div>;
126
+
127
+ const fileToRender = formValues || file;
128
+ const fileWithStoreType = getFileWithStoreType(fileToRender);
67
129
 
68
- return (
130
+ return !loading ? (
69
131
  <>
70
- {!loading ? (
71
- <>
72
- {file ? (
73
- <FilePreview file={fileWithStoreType} handleFormChange={handleFormChange} displayForm />
74
- ) : null}
75
- </>
76
- ) : (
77
- <div>loading...</div>
132
+ {!!file && (
133
+ <FilePreview
134
+ file={fileWithStoreType}
135
+ handleFormChange={handleFormChange}
136
+ handleChangeFile={() => setDisplayFileUploadModal(true)}
137
+ displayForm
138
+ showChangeButton={showChangeButton}
139
+ />
140
+ )}
141
+ {displayFileUploadModal && (
142
+ <div className="file-upload-modal-wrapper">
143
+ <FileUploadModal
144
+ onClose={() => setDisplayFileUploadModal(false)}
145
+ closeModalAndSetValue={closeModalAndSetValue}
146
+ simpleLayout
147
+ fileId={fileId}
148
+ storeKey={file && file.storeKey}
149
+ getSelectedFiles={() => {}}
150
+ />
151
+ </div>
78
152
  )}
79
153
  </>
154
+ ) : (
155
+ <div>loading...</div>
80
156
  );
81
157
  };
82
158
 
@@ -84,11 +160,13 @@ EditMediaFile.propTypes = {
84
160
  fileId: PropTypes.string.isRequired,
85
161
  onChange: PropTypes.func.isRequired,
86
162
  handleSaveButtonStatus: PropTypes.func.isRequired,
87
- enableSaveButton: PropTypes.bool
163
+ showChangeButton: PropTypes.bool,
164
+ fileUpdated: PropTypes.object
88
165
  };
89
166
 
90
167
  EditMediaFile.defaultProps = {
91
- enableSaveButton: false
168
+ showChangeButton: false,
169
+ fileUpdated: null
92
170
  };
93
171
 
94
172
  export default EditMediaFile;
@@ -20,19 +20,44 @@ const EditMediaFilePage = ({ match, history }) => {
20
20
  };
21
21
 
22
22
  const handleFormSave = async () => {
23
+ if (!file) {
24
+ addToast('No file data to update', {
25
+ appearance: 'error',
26
+ autoDismiss: true
27
+ });
28
+ return;
29
+ }
30
+
23
31
  try {
24
- await client.mutate({
32
+ const inputData = {
33
+ id: file.id,
34
+ name: file.name,
35
+ data: file.data,
36
+ storeKey: file.storeKey
37
+ };
38
+
39
+ const {
40
+ data: { updateFile: updatedFile }
41
+ } = await client.mutate({
25
42
  mutation: getMutation('UPDATE_FILE'),
26
- variables: { input: file },
43
+ variables: {
44
+ input: inputData
45
+ },
27
46
  update(cache, { data: { updateFile: fileUpdated } }) {
28
- cache.writeQuery({
29
- query: getQuery('GET_FILE_BY_ID'),
30
- variables: { id: match.params.fileId },
31
- data: { file: fileUpdated.result }
32
- });
47
+ try {
48
+ cache.writeQuery({
49
+ query: getQuery('GET_FILE_BY_ID'),
50
+ variables: { id: match.params.fileId },
51
+ data: { file: fileUpdated.result }
52
+ });
53
+ } catch (e) {
54
+ console.error(e); //eslint-disable-line
55
+ }
33
56
  }
34
57
  });
35
58
 
59
+ setFile(updatedFile.result);
60
+
36
61
  addToast(`File: ${file.name} has been updated`, {
37
62
  appearance: 'success',
38
63
  autoDismiss: true
@@ -42,7 +67,6 @@ const EditMediaFilePage = ({ match, history }) => {
42
67
  appearance: 'error',
43
68
  autoDismiss: true
44
69
  });
45
- console.error(e); //eslint-disable-line
46
70
  }
47
71
  setShouldEnableSaveButton(false);
48
72
  };
@@ -60,11 +84,13 @@ const EditMediaFilePage = ({ match, history }) => {
60
84
  fileId={match.params.fileId}
61
85
  handleSaveButtonStatus={handleSaveButtonStatus}
62
86
  handleFormSave={handleFormSave}
87
+ showChangeButton
88
+ fileUpdated={file}
63
89
  />
64
90
  <div className="page__content__mediaWrapperActions">
65
91
  <Button onClick={pushBack}>Cancel</Button>
66
92
  <Button onClick={handleFormSave} modifiers={buttonModifiers}>
67
- Save
93
+ Apply
68
94
  </Button>
69
95
  </div>
70
96
  </div>
@@ -1,16 +1,41 @@
1
1
  import React from 'react';
2
2
  import DraftEditor from '@blaze-react/drafteditor';
3
3
  import PropTypes from 'prop-types';
4
+ import Tooltip from '@blaze-react/tooltip';
4
5
 
5
- const DraftEditorAdapter = ({ id, value, onChange, error, validationMessage, label, ...props }) => (
6
+ const customStyleMap = {
7
+ SUPERSCRIPT: {
8
+ fontSize: '0.75em',
9
+ verticalAlign: 'super'
10
+ },
11
+ SUBSCRIPT: {
12
+ fontSize: '0.75em',
13
+ verticalAlign: 'sub'
14
+ }
15
+ };
16
+
17
+ const DraftEditorAdapter = ({
18
+ id,
19
+ value,
20
+ onChange,
21
+ error,
22
+ validationMessage,
23
+ label,
24
+ tooltip,
25
+ ...props
26
+ }) => (
6
27
  <div className="form-field form-field--full-width">
7
- <label>{label}</label>
28
+ <label>
29
+ <Tooltip tooltipContent={tooltip} />
30
+ </label>
8
31
  <DraftEditor
9
32
  name={id}
10
33
  value={value}
11
34
  onChange={onChange}
12
35
  error={error}
13
36
  validationMessage={validationMessage}
37
+ tooltip={{ tooltipContent: tooltip }}
38
+ customStyleMap={customStyleMap}
14
39
  />
15
40
  </div>
16
41
  );
@@ -21,12 +46,14 @@ DraftEditorAdapter.propTypes = {
21
46
  onChange: PropTypes.func.isRequired,
22
47
  error: PropTypes.bool,
23
48
  validationMessage: PropTypes.string,
24
- label: PropTypes.string.isRequired
49
+ label: PropTypes.string.isRequired,
50
+ tooltip: PropTypes.string
25
51
  };
26
52
 
27
53
  DraftEditorAdapter.defaultProps = {
28
54
  error: false,
29
- validationMessage: undefined
55
+ validationMessage: undefined,
56
+ tooltip: ''
30
57
  };
31
58
 
32
59
  export default DraftEditorAdapter;
@@ -7,34 +7,32 @@ const Actions = ({ file }) => {
7
7
  const [, extension] = file.mimetype.split('/');
8
8
 
9
9
  return (
10
- <>
11
- <div className="FilePreviewItem__info__actions">
12
- <div className="FilePreviewItem__info__actions FilePreviewItem__info__actions--media-type">
13
- <i className="FilePreviewItem__info__actionsIcon material-icons">insert_photo</i>{' '}
14
- <span>{extension}</span>
15
- </div>
16
- <div>
17
- {handleEditModal && (
18
- <div
19
- data-testid={`open-media-library-${file.id}`}
20
- className="FilePreviewItem__info__actionsIcon material-icons edit"
21
- aria-hidden="true"
22
- onClick={() => handleEditModal(file)}>
23
- <i className="fas fa-pen fa-xs" />
24
- </div>
25
- )}
26
- {onUnselectFile && (
27
- <div
28
- data-testid={`unselect-${file.id}`}
29
- className="FilePreviewItem__info__actionsIcon material-icons delete"
30
- aria-hidden="true"
31
- onClick={() => onUnselectFile([file.id])}>
32
- <i className="fas fa-trash fa-xs" />
33
- </div>
34
- )}
35
- </div>
10
+ <div className="FilePreviewItem__info__actions">
11
+ <div className="FilePreviewItem__info__actions FilePreviewItem__info__actions--media-type">
12
+ <i className="FilePreviewItem__info__actionsIcon material-icons">insert_photo</i>{' '}
13
+ <span>{extension}</span>
36
14
  </div>
37
- </>
15
+ <div>
16
+ {handleEditModal && (
17
+ <div
18
+ data-testid={`open-media-library-${file.id}`}
19
+ className="FilePreviewItem__info__actionsIcon material-icons edit"
20
+ aria-hidden="true"
21
+ onClick={() => handleEditModal(file)}>
22
+ <i className="fas fa-pen fa-xs" />
23
+ </div>
24
+ )}
25
+ {onUnselectFile && (
26
+ <div
27
+ data-testid={`unselect-${file.id}`}
28
+ className="FilePreviewItem__info__actionsIcon material-icons delete"
29
+ aria-hidden="true"
30
+ onClick={() => onUnselectFile([file.id])}>
31
+ <i className="fas fa-trash fa-xs" />
32
+ </div>
33
+ )}
34
+ </div>
35
+ </div>
38
36
  );
39
37
  };
40
38
 
@@ -1,7 +1,8 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
+ import Button from '@blaze-react/button';
3
4
 
4
- const Image = ({ url, name, children }) => (
5
+ const Image = ({ url, name, children, handleChangeFile, showChangeButton }) => (
5
6
  <div className="preview">
6
7
  <div className="preview__file preview__file--image">
7
8
  <img src={url} alt={name} />
@@ -12,6 +13,11 @@ const Image = ({ url, name, children }) => (
12
13
  Original
13
14
  </a>
14
15
  </p>
16
+ {showChangeButton && (
17
+ <div className="preview__change-button">
18
+ <Button onClick={handleChangeFile}>Change file</Button>
19
+ </div>
20
+ )}
15
21
  </div>
16
22
  </div>
17
23
  {children}
@@ -21,7 +27,14 @@ const Image = ({ url, name, children }) => (
21
27
  Image.propTypes = {
22
28
  url: PropTypes.string.isRequired,
23
29
  name: PropTypes.string.isRequired,
24
- children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired
30
+ children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired,
31
+ handleChangeFile: PropTypes.func,
32
+ showChangeButton: PropTypes.bool
33
+ };
34
+
35
+ Image.defaultProps = {
36
+ handleChangeFile: () => {},
37
+ showChangeButton: false
25
38
  };
26
39
 
27
40
  export { Image };
@@ -40,7 +40,7 @@ const imageSchema = {
40
40
  hrefUrl: {
41
41
  type: 'string',
42
42
  format: 'uri-template',
43
- label: 'url',
43
+ label: 'Image hyperlink',
44
44
  showInForm: true,
45
45
  formFieldType: 'text',
46
46
  description: 'Url format is not valid'
@@ -0,0 +1,3 @@
1
+ import { createContext } from 'react';
2
+
3
+ export const ModalContext = createContext(false);
@@ -1,10 +1,11 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
+ import Button from '@blaze-react/button';
3
4
 
4
- const PDF = ({ mimetype, url, name, children }) => (
5
- <div className="preview">
5
+ const PDF = ({ mimetype, url, name, children, handleChangeFile, showChangeButton }) => (
6
+ <div className="preview" key={`pdf-${url}`}>
6
7
  <div className="preview__file preview__file--pdf">
7
- <object data={url} type={mimetype} className="preview__file--pdf">
8
+ <object key={url} data={url} type={mimetype} className="preview__file--pdf">
8
9
  <p>
9
10
  <a href={url} rel="noopener noreferrer" target="_blank">
10
11
  Download {name}
@@ -18,6 +19,11 @@ const PDF = ({ mimetype, url, name, children }) => (
18
19
  Original
19
20
  </a>
20
21
  </p>
22
+ {showChangeButton && (
23
+ <div className="preview__change-button">
24
+ <Button onClick={handleChangeFile}>Change file</Button>
25
+ </div>
26
+ )}
21
27
  </div>
22
28
  </div>
23
29
  {children}
@@ -28,7 +34,14 @@ PDF.propTypes = {
28
34
  mimetype: PropTypes.string.isRequired,
29
35
  url: PropTypes.string.isRequired,
30
36
  name: PropTypes.string.isRequired,
31
- children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired
37
+ children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired,
38
+ handleChangeFile: PropTypes.func,
39
+ showChangeButton: PropTypes.bool
40
+ };
41
+
42
+ PDF.defaultProps = {
43
+ handleChangeFile: () => {},
44
+ showChangeButton: false
32
45
  };
33
46
 
34
47
  export { PDF };
@@ -3,8 +3,23 @@ import { FormBuilder } from '@blaze-cms/react-form-builder';
3
3
  import PropTypes from 'prop-types';
4
4
  import { getPreview } from './get-preview';
5
5
 
6
- const FilePreview = ({ file, handleFormChange, displayForm, previewType, children }) => {
7
- const { name, url, mimetype, data, store } = file;
6
+ const FilePreview = ({
7
+ file,
8
+ handleFormChange,
9
+ displayForm,
10
+ previewType,
11
+ children,
12
+ handleChangeFile,
13
+ showChangeButton,
14
+ disableFilePreview
15
+ }) => {
16
+ const { name, url, mimetype, data, store, updated } = file;
17
+ const bustUrl = (srcUrl, version) => {
18
+ if (!srcUrl) return srcUrl;
19
+ const sep = srcUrl.includes('?') ? '&' : '?';
20
+ return `${srcUrl}${sep}v=${version || Date.now()}`;
21
+ };
22
+ const displayUrl = bustUrl(url, updated);
8
23
  const [Preview, schema] = getPreview({ mimetype, previewType });
9
24
  const shouldRenderForm = schema && displayForm;
10
25
 
@@ -19,11 +34,19 @@ const FilePreview = ({ file, handleFormChange, displayForm, previewType, childre
19
34
  }
20
35
  }
21
36
 
22
- const formBuilderData = { values: { ...file, ...data } };
37
+ const formBuilderData = { values: { ...data, ...file } };
23
38
 
24
39
  return (
25
40
  <>
26
- <Preview mimetype={mimetype} url={url} name={name} {...data} file={file}>
41
+ <Preview
42
+ mimetype={mimetype}
43
+ url={displayUrl}
44
+ name={name}
45
+ {...data}
46
+ file={file}
47
+ handleChangeFile={handleChangeFile}
48
+ disableFilePreview={disableFilePreview}
49
+ showChangeButton={showChangeButton}>
27
50
  {shouldRenderForm && (
28
51
  <div className="preview__details">
29
52
  <div className="preview__filename">{file.filename}</div>
@@ -50,10 +73,13 @@ FilePreview.propTypes = {
50
73
  file: PropTypes.object.isRequired,
51
74
  fileName: PropTypes.string,
52
75
  handleFormChange: PropTypes.func,
76
+ handleChangeFile: PropTypes.func,
53
77
  displayForm: PropTypes.bool,
54
78
  handlers: PropTypes.object,
55
79
  previewType: PropTypes.oneOf(Object.keys(FilePreview.availablePreviewTypes)),
56
- children: PropTypes.oneOfType([PropTypes.array, PropTypes.object, PropTypes.string])
80
+ children: PropTypes.oneOfType([PropTypes.array, PropTypes.object, PropTypes.string]),
81
+ showChangeButton: PropTypes.bool,
82
+ disableFilePreview: PropTypes.bool
57
83
  };
58
84
 
59
85
  FilePreview.defaultProps = {
@@ -62,7 +88,10 @@ FilePreview.defaultProps = {
62
88
  handlers: {},
63
89
  previewType: FilePreview.availablePreviewTypes.card,
64
90
  handleFormChange: () => {},
65
- children: []
91
+ handleChangeFile: () => {},
92
+ children: [],
93
+ showChangeButton: false,
94
+ disableFilePreview: true
66
95
  };
67
96
 
68
97
  export default FilePreview;
@@ -1,9 +1,10 @@
1
1
  import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
+ import Button from '@blaze-react/button';
3
4
  import { DefaultIcon } from './icons';
4
5
 
5
- const PreviewDefault = ({ url, name, children }) => (
6
- <div className="preview">
6
+ const PreviewDefault = ({ url, name, children, handleChangeFile, showChangeButton }) => (
7
+ <div className="preview" key={`default-${url}`}>
7
8
  <div className="preview__file preview__file--default">
8
9
  <div className="preview__file--icon">
9
10
  <DefaultIcon />
@@ -16,6 +17,11 @@ const PreviewDefault = ({ url, name, children }) => (
16
17
  Original
17
18
  </a>
18
19
  </p>
20
+ {showChangeButton && (
21
+ <div className="preview__change-button">
22
+ <Button onClick={handleChangeFile}>Change file</Button>
23
+ </div>
24
+ )}
19
25
  </div>
20
26
  </div>
21
27
  {children}
@@ -25,7 +31,14 @@ const PreviewDefault = ({ url, name, children }) => (
25
31
  PreviewDefault.propTypes = {
26
32
  url: PropTypes.string.isRequired,
27
33
  name: PropTypes.string.isRequired,
28
- children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired
34
+ children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]).isRequired,
35
+ handleChangeFile: PropTypes.func,
36
+ showChangeButton: PropTypes.bool
37
+ };
38
+
39
+ PreviewDefault.defaultProps = {
40
+ handleChangeFile: () => {},
41
+ showChangeButton: false
29
42
  };
30
43
 
31
44
  export { PreviewDefault };
@@ -2,24 +2,34 @@ import React from 'react';
2
2
  import PropTypes from 'prop-types';
3
3
  import Actions from '../Actions';
4
4
 
5
- const RawPreviewDefault = ({ url, name, file }) => (
5
+ const RawPreviewDefault = ({ url, name, file, disableFilePreview }) => (
6
6
  <div className="FilePreview">
7
- <div className="FilePreviewItem">
8
- <div className="FilePreviewItem__wrapper">
9
- <img className="FilePreviewItem__wrapper__default" src={url} alt={name} />
7
+ {!disableFilePreview ? (
8
+ <div className="FilePreviewItem">
9
+ <div className="FilePreviewItem__wrapper">
10
+ <img className="FilePreviewItem__wrapper__default" src={url} alt={name} />
11
+ </div>
12
+ <div className="FilePreviewItem__info">
13
+ <p className="FilePreviewItem__info__fileName">{name}</p>
14
+ <Actions file={file} />
15
+ </div>
10
16
  </div>
17
+ ) : (
11
18
  <div className="FilePreviewItem__info">
12
- <p className="FilePreviewItem__info__fileName">{name}</p>
19
+ <p className="FilePreviewItem__info__fileName FilePreviewItem__info--disablePreview">
20
+ {name}
21
+ </p>
13
22
  <Actions file={file} />
14
23
  </div>
15
- </div>
24
+ )}
16
25
  </div>
17
26
  );
18
27
 
19
28
  RawPreviewDefault.propTypes = {
20
29
  url: PropTypes.string.isRequired,
21
30
  name: PropTypes.string.isRequired,
22
- file: PropTypes.object.isRequired
31
+ file: PropTypes.object.isRequired,
32
+ disableFilePreview: PropTypes.bool.isRequired
23
33
  };
24
34
 
25
35
  export { RawPreviewDefault };
@@ -3,9 +3,7 @@ import PropTypes from 'prop-types';
3
3
  import FilePreviewList from './FilePreviewList';
4
4
 
5
5
  const FileList = ({ selectedFiles, children }) => (
6
- <>
7
- <FilePreviewList selectedFiles={selectedFiles}>{children}</FilePreviewList>
8
- </>
6
+ <FilePreviewList selectedFiles={selectedFiles}>{children}</FilePreviewList>
9
7
  );
10
8
 
11
9
  FileList.propTypes = {