@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.
- package/CHANGELOG.md +10 -16
- package/lib/components/CardMedia/CardMedia.js +168 -221
- package/lib/components/CardMedia/CardMedia.js.map +1 -1
- package/lib/components/CardMedia/index.js +2 -3
- package/lib/components/CardMedia/index.js.map +1 -1
- package/lib/components/EditMediaFile/EditMediaFile.js +162 -113
- package/lib/components/EditMediaFile/EditMediaFile.js.map +1 -1
- package/lib/components/EditMediaFile/EditMediaFilePage.js +81 -97
- package/lib/components/EditMediaFile/EditMediaFilePage.js.map +1 -1
- package/lib/components/EditMediaFile/index.js +2 -3
- package/lib/components/EditMediaFile/index.js.map +1 -1
- package/lib/components/EditorAdapter/EditorAdapter.js +43 -22
- package/lib/components/EditorAdapter/EditorAdapter.js.map +1 -1
- package/lib/components/EditorAdapter/index.js +2 -3
- package/lib/components/EditorAdapter/index.js.map +1 -1
- package/lib/components/FileList/FilesListContext/index.js +3 -4
- package/lib/components/FileList/FilesListContext/index.js.map +1 -1
- package/lib/components/FileList/FilesListProvider/index.js +27 -29
- package/lib/components/FileList/FilesListProvider/index.js.map +1 -1
- package/lib/components/FileList/useFileList/index.js +3 -6
- package/lib/components/FileList/useFileList/index.js.map +1 -1
- package/lib/components/FileList/useGetFiles/getFiles.js +164 -185
- package/lib/components/FileList/useGetFiles/getFiles.js.map +1 -1
- package/lib/components/FileList/useGetFiles/index.js +2 -3
- package/lib/components/FileList/useGetFiles/index.js.map +1 -1
- package/lib/components/FileList/useGetFiles/useGetFiles.js +88 -133
- package/lib/components/FileList/useGetFiles/useGetFiles.js.map +1 -1
- package/lib/components/FileList/useGetFilesList/getCounters.js +10 -30
- package/lib/components/FileList/useGetFilesList/getCounters.js.map +1 -1
- package/lib/components/FileList/useGetFilesList/index.js +2 -3
- package/lib/components/FileList/useGetFilesList/index.js.map +1 -1
- package/lib/components/FileList/useGetFilesList/useGetFilesList.js +89 -110
- package/lib/components/FileList/useGetFilesList/useGetFilesList.js.map +1 -1
- package/lib/components/FilePreview/Actions/index.js +24 -38
- package/lib/components/FilePreview/Actions/index.js.map +1 -1
- package/lib/components/FilePreview/Image/Image.js +35 -24
- package/lib/components/FilePreview/Image/Image.js.map +1 -1
- package/lib/components/FilePreview/Image/RawImage.js +25 -27
- package/lib/components/FilePreview/Image/RawImage.js.map +1 -1
- package/lib/components/FilePreview/Image/imageSchema.js +2 -3
- package/lib/components/FilePreview/Image/imageSchema.js.map +1 -1
- package/lib/components/FilePreview/Image/index.js +1 -2
- package/lib/components/FilePreview/Image/index.js.map +1 -1
- package/lib/components/FilePreview/ModalContext.js +9 -0
- package/lib/components/FilePreview/ModalContext.js.map +1 -0
- package/lib/components/FilePreview/PDF/PDF.js +44 -31
- package/lib/components/FilePreview/PDF/PDF.js.map +1 -1
- package/lib/components/FilePreview/PDF/RawPDF.js +27 -29
- package/lib/components/FilePreview/PDF/RawPDF.js.map +1 -1
- package/lib/components/FilePreview/PDF/index.js +1 -2
- package/lib/components/FilePreview/PDF/index.js.map +1 -1
- package/lib/components/FilePreview/PDF/schema.js +1 -2
- package/lib/components/FilePreview/PDF/schema.js.map +1 -1
- package/lib/components/FilePreview/get-preview.js +12 -10
- package/lib/components/FilePreview/get-preview.js.map +1 -1
- package/lib/components/FilePreview/index.js +66 -57
- package/lib/components/FilePreview/index.js.map +1 -1
- package/lib/components/FilePreview/previewDefault/PreviewDefault.js +35 -23
- package/lib/components/FilePreview/previewDefault/PreviewDefault.js.map +1 -1
- package/lib/components/FilePreview/previewDefault/RawPreviewDefault.js +33 -27
- package/lib/components/FilePreview/previewDefault/RawPreviewDefault.js.map +1 -1
- package/lib/components/FilePreview/previewDefault/icons/DefaultIcon.js +120 -123
- package/lib/components/FilePreview/previewDefault/icons/DefaultIcon.js.map +1 -1
- package/lib/components/FilePreview/previewDefault/icons/index.js +2 -3
- package/lib/components/FilePreview/previewDefault/icons/index.js.map +1 -1
- package/lib/components/FilePreview/previewDefault/index.js +1 -2
- package/lib/components/FilePreview/previewDefault/index.js.map +1 -1
- package/lib/components/FilePreview/previewDefault/previewDefaultSchema.js +1 -2
- package/lib/components/FilePreview/previewDefault/previewDefaultSchema.js.map +1 -1
- package/lib/components/FilePreviewReadOnly/FileList.js +10 -12
- package/lib/components/FilePreviewReadOnly/FileList.js.map +1 -1
- package/lib/components/FilePreviewReadOnly/FilePreviewList.js +14 -20
- package/lib/components/FilePreviewReadOnly/FilePreviewList.js.map +1 -1
- package/lib/components/FilePreviewReadOnly/FilePreviewReadOnly.js +52 -98
- package/lib/components/FilePreviewReadOnly/FilePreviewReadOnly.js.map +1 -1
- package/lib/components/FilePreviewReadOnly/index.js +2 -3
- package/lib/components/FilePreviewReadOnly/index.js.map +1 -1
- package/lib/components/FilePreviewReadOnly/mappers/format-initial-value.js +7 -8
- package/lib/components/FilePreviewReadOnly/mappers/format-initial-value.js.map +1 -1
- package/lib/components/FilePreviewReadOnly/mappers/index.js +1 -2
- package/lib/components/FilePreviewReadOnly/mappers/index.js.map +1 -1
- package/lib/components/FileUploadAdapter/FileList.js +26 -39
- package/lib/components/FileUploadAdapter/FileList.js.map +1 -1
- package/lib/components/FileUploadAdapter/FilePreviewList.js +14 -20
- package/lib/components/FileUploadAdapter/FilePreviewList.js.map +1 -1
- package/lib/components/FileUploadAdapter/FileReorderList.js +18 -21
- package/lib/components/FileUploadAdapter/FileReorderList.js.map +1 -1
- package/lib/components/FileUploadAdapter/FileReorderListItem.js +20 -23
- package/lib/components/FileUploadAdapter/FileReorderListItem.js.map +1 -1
- package/lib/components/FileUploadAdapter/FileUploadAdapter.js +238 -338
- package/lib/components/FileUploadAdapter/FileUploadAdapter.js.map +1 -1
- package/lib/components/FileUploadAdapter/index.js +2 -3
- package/lib/components/FileUploadAdapter/index.js.map +1 -1
- package/lib/components/FileUploadAdapter/mappers/format-initial-value.js +7 -8
- package/lib/components/FileUploadAdapter/mappers/format-initial-value.js.map +1 -1
- package/lib/components/FileUploadAdapter/mappers/get-button-text.js +9 -6
- package/lib/components/FileUploadAdapter/mappers/get-button-text.js.map +1 -1
- package/lib/components/FileUploadAdapter/mappers/get-format.js +7 -13
- package/lib/components/FileUploadAdapter/mappers/get-format.js.map +1 -1
- package/lib/components/FileUploadAdapter/mappers/get-number-files-pending-to-fetch.js +6 -5
- package/lib/components/FileUploadAdapter/mappers/get-number-files-pending-to-fetch.js.map +1 -1
- package/lib/components/FileUploadAdapter/mappers/index.js +6 -7
- package/lib/components/FileUploadAdapter/mappers/index.js.map +1 -1
- package/lib/components/FileUploadAdapter/mappers/is-unselecting.js +2 -10
- package/lib/components/FileUploadAdapter/mappers/is-unselecting.js.map +1 -1
- package/lib/components/FileUploadAdapter/mappers/transform-to-array.js +2 -5
- package/lib/components/FileUploadAdapter/mappers/transform-to-array.js.map +1 -1
- package/lib/components/FileUploadAdapter/useLimit.js +4 -10
- package/lib/components/FileUploadAdapter/useLimit.js.map +1 -1
- package/lib/components/FileUploadModal/FileUploadModal.js +150 -145
- package/lib/components/FileUploadModal/FileUploadModal.js.map +1 -1
- package/lib/components/FileUploadModal/index.js +2 -3
- package/lib/components/FileUploadModal/index.js.map +1 -1
- package/lib/components/FilterPanel/FilterPanel.js +68 -88
- package/lib/components/FilterPanel/FilterPanel.js.map +1 -1
- package/lib/components/FilterPanel/index.js +2 -3
- package/lib/components/FilterPanel/index.js.map +1 -1
- package/lib/components/ListingContainer/Listing/Listing.js +58 -48
- package/lib/components/ListingContainer/Listing/Listing.js.map +1 -1
- package/lib/components/ListingContainer/Listing/MediaListing/MediaFileList/MediaFileList.js +75 -92
- package/lib/components/ListingContainer/Listing/MediaListing/MediaFileList/MediaFileList.js.map +1 -1
- package/lib/components/ListingContainer/Listing/MediaListing/MediaFileList/index.js +2 -3
- package/lib/components/ListingContainer/Listing/MediaListing/MediaFileList/index.js.map +1 -1
- package/lib/components/ListingContainer/Listing/MediaListing/MediaListing.js +22 -26
- package/lib/components/ListingContainer/Listing/MediaListing/MediaListing.js.map +1 -1
- package/lib/components/ListingContainer/Listing/MediaListing/index.js +2 -3
- package/lib/components/ListingContainer/Listing/MediaListing/index.js.map +1 -1
- package/lib/components/ListingContainer/Listing/index.js +2 -3
- package/lib/components/ListingContainer/Listing/index.js.map +1 -1
- package/lib/components/ListingContainer/ListingContainer.js +69 -92
- package/lib/components/ListingContainer/ListingContainer.js.map +1 -1
- package/lib/components/ListingContainer/index.js +2 -3
- package/lib/components/ListingContainer/index.js.map +1 -1
- package/lib/components/ListingContainer/mappers/exist-previous.js +3 -10
- package/lib/components/ListingContainer/mappers/exist-previous.js.map +1 -1
- package/lib/components/ListingContainer/mappers/index.js +2 -3
- package/lib/components/ListingContainer/mappers/index.js.map +1 -1
- package/lib/components/MediaListing.js +14 -26
- package/lib/components/MediaListing.js.map +1 -1
- package/lib/constants.js +15 -16
- package/lib/constants.js.map +1 -1
- package/lib/icons/MediaLibraryIcon.js +17 -20
- package/lib/icons/MediaLibraryIcon.js.map +1 -1
- package/lib/icons/index.js +2 -3
- package/lib/icons/index.js.map +1 -1
- package/lib/index.js +67 -92
- package/lib/index.js.map +1 -1
- package/lib/utils/available-filters/available-filters.js +1 -2
- package/lib/utils/available-filters/available-filters.js.map +1 -1
- package/lib/utils/bustUrl.js +13 -0
- package/lib/utils/bustUrl.js.map +1 -0
- package/lib/utils/media-context/index.js +4 -5
- package/lib/utils/media-context/index.js.map +1 -1
- package/lib/utils/media-context/media-context.js +3 -4
- package/lib/utils/media-context/media-context.js.map +1 -1
- package/lib/utils/media-context/useMediaContext.js +2 -4
- package/lib/utils/media-context/useMediaContext.js.map +1 -1
- package/package.json +14 -14
- package/src/components/CardMedia/CardMedia.js +27 -8
- package/src/components/EditMediaFile/EditMediaFile.js +115 -37
- package/src/components/EditMediaFile/EditMediaFilePage.js +35 -9
- package/src/components/EditorAdapter/EditorAdapter.js +31 -4
- package/src/components/FilePreview/Actions/index.js +25 -27
- package/src/components/FilePreview/Image/Image.js +15 -2
- package/src/components/FilePreview/Image/imageSchema.js +1 -1
- package/src/components/FilePreview/ModalContext.js +3 -0
- package/src/components/FilePreview/PDF/PDF.js +17 -4
- package/src/components/FilePreview/index.js +35 -6
- package/src/components/FilePreview/previewDefault/PreviewDefault.js +16 -3
- package/src/components/FilePreview/previewDefault/RawPreviewDefault.js +17 -7
- package/src/components/FilePreviewReadOnly/FileList.js +1 -3
- package/src/components/FilePreviewReadOnly/FilePreviewReadOnly.js +17 -29
- package/src/components/FileUploadAdapter/FileUploadAdapter.js +42 -18
- package/src/components/FileUploadAdapter/mappers/get-button-text.js +4 -3
- package/src/components/FileUploadAdapter/mappers/get-number-files-pending-to-fetch.js +6 -4
- package/src/components/FileUploadModal/FileUploadModal.js +88 -42
- package/src/components/ListingContainer/Listing/Listing.js +15 -5
- package/src/components/ListingContainer/Listing/MediaListing/MediaFileList/MediaFileList.js +11 -5
- package/src/components/ListingContainer/Listing/MediaListing/MediaListing.js +10 -2
- package/src/components/ListingContainer/ListingContainer.js +13 -4
- package/src/index.js +17 -14
- package/src/utils/bustUrl.js +6 -0
- package/lib-es/components/CardMedia/CardMedia.js +0 -219
- package/lib-es/components/CardMedia/CardMedia.js.map +0 -1
- package/lib-es/components/CardMedia/index.js +0 -3
- package/lib-es/components/CardMedia/index.js.map +0 -1
- package/lib-es/components/EditMediaFile/EditMediaFile.js +0 -115
- package/lib-es/components/EditMediaFile/EditMediaFile.js.map +0 -1
- package/lib-es/components/EditMediaFile/EditMediaFilePage.js +0 -86
- package/lib-es/components/EditMediaFile/EditMediaFilePage.js.map +0 -1
- package/lib-es/components/EditMediaFile/index.js +0 -3
- package/lib-es/components/EditMediaFile/index.js.map +0 -1
- package/lib-es/components/EditorAdapter/EditorAdapter.js +0 -39
- package/lib-es/components/EditorAdapter/EditorAdapter.js.map +0 -1
- package/lib-es/components/EditorAdapter/index.js +0 -3
- package/lib-es/components/EditorAdapter/index.js.map +0 -1
- package/lib-es/components/FileList/FilesListContext/index.js +0 -4
- package/lib-es/components/FileList/FilesListContext/index.js.map +0 -1
- package/lib-es/components/FileList/FilesListProvider/index.js +0 -36
- package/lib-es/components/FileList/FilesListProvider/index.js.map +0 -1
- package/lib-es/components/FileList/useFileList/index.js +0 -5
- package/lib-es/components/FileList/useFileList/index.js.map +0 -1
- package/lib-es/components/FileList/useGetFiles/getFiles.js +0 -179
- package/lib-es/components/FileList/useGetFiles/getFiles.js.map +0 -1
- package/lib-es/components/FileList/useGetFiles/index.js +0 -3
- package/lib-es/components/FileList/useGetFiles/index.js.map +0 -1
- package/lib-es/components/FileList/useGetFiles/useGetFiles.js +0 -114
- package/lib-es/components/FileList/useGetFiles/useGetFiles.js.map +0 -1
- package/lib-es/components/FileList/useGetFilesList/getCounters.js +0 -11
- package/lib-es/components/FileList/useGetFilesList/getCounters.js.map +0 -1
- package/lib-es/components/FileList/useGetFilesList/index.js +0 -3
- package/lib-es/components/FileList/useGetFilesList/index.js.map +0 -1
- package/lib-es/components/FileList/useGetFilesList/useGetFilesList.js +0 -172
- package/lib-es/components/FileList/useGetFilesList/useGetFilesList.js.map +0 -1
- package/lib-es/components/FilePreview/Actions/index.js +0 -38
- package/lib-es/components/FilePreview/Actions/index.js.map +0 -1
- package/lib-es/components/FilePreview/Image/Image.js +0 -27
- package/lib-es/components/FilePreview/Image/Image.js.map +0 -1
- package/lib-es/components/FilePreview/Image/RawImage.js +0 -31
- package/lib-es/components/FilePreview/Image/RawImage.js.map +0 -1
- package/lib-es/components/FilePreview/Image/imageSchema.js +0 -53
- package/lib-es/components/FilePreview/Image/imageSchema.js.map +0 -1
- package/lib-es/components/FilePreview/Image/index.js +0 -12
- package/lib-es/components/FilePreview/Image/index.js.map +0 -1
- package/lib-es/components/FilePreview/PDF/PDF.js +0 -34
- package/lib-es/components/FilePreview/PDF/PDF.js.map +0 -1
- package/lib-es/components/FilePreview/PDF/RawPDF.js +0 -33
- package/lib-es/components/FilePreview/PDF/RawPDF.js.map +0 -1
- package/lib-es/components/FilePreview/PDF/index.js +0 -12
- package/lib-es/components/FilePreview/PDF/index.js.map +0 -1
- package/lib-es/components/FilePreview/PDF/schema.js +0 -21
- package/lib-es/components/FilePreview/PDF/schema.js.map +0 -1
- package/lib-es/components/FilePreview/get-preview.js +0 -28
- package/lib-es/components/FilePreview/get-preview.js.map +0 -1
- package/lib-es/components/FilePreview/index.js +0 -85
- package/lib-es/components/FilePreview/index.js.map +0 -1
- package/lib-es/components/FilePreview/previewDefault/PreviewDefault.js +0 -27
- package/lib-es/components/FilePreview/previewDefault/PreviewDefault.js.map +0 -1
- package/lib-es/components/FilePreview/previewDefault/RawPreviewDefault.js +0 -31
- package/lib-es/components/FilePreview/previewDefault/RawPreviewDefault.js.map +0 -1
- package/lib-es/components/FilePreview/previewDefault/icons/DefaultIcon.js +0 -121
- package/lib-es/components/FilePreview/previewDefault/icons/DefaultIcon.js.map +0 -1
- package/lib-es/components/FilePreview/previewDefault/icons/index.js +0 -3
- package/lib-es/components/FilePreview/previewDefault/icons/index.js.map +0 -1
- package/lib-es/components/FilePreview/previewDefault/index.js +0 -12
- package/lib-es/components/FilePreview/previewDefault/index.js.map +0 -1
- package/lib-es/components/FilePreview/previewDefault/previewDefaultSchema.js +0 -25
- package/lib-es/components/FilePreview/previewDefault/previewDefaultSchema.js.map +0 -1
- package/lib-es/components/FilePreviewReadOnly/FileList.js +0 -18
- package/lib-es/components/FilePreviewReadOnly/FileList.js.map +0 -1
- package/lib-es/components/FilePreviewReadOnly/FilePreviewList.js +0 -22
- package/lib-es/components/FilePreviewReadOnly/FilePreviewList.js.map +0 -1
- package/lib-es/components/FilePreviewReadOnly/FilePreviewReadOnly.js +0 -66
- package/lib-es/components/FilePreviewReadOnly/FilePreviewReadOnly.js.map +0 -1
- package/lib-es/components/FilePreviewReadOnly/index.js +0 -3
- package/lib-es/components/FilePreviewReadOnly/index.js.map +0 -1
- package/lib-es/components/FilePreviewReadOnly/mappers/format-initial-value.js +0 -11
- package/lib-es/components/FilePreviewReadOnly/mappers/format-initial-value.js.map +0 -1
- package/lib-es/components/FilePreviewReadOnly/mappers/index.js +0 -3
- package/lib-es/components/FilePreviewReadOnly/mappers/index.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/FileList.js +0 -52
- package/lib-es/components/FileUploadAdapter/FileList.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/FilePreviewList.js +0 -22
- package/lib-es/components/FileUploadAdapter/FilePreviewList.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/FileReorderList.js +0 -32
- package/lib-es/components/FileUploadAdapter/FileReorderList.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/FileReorderListItem.js +0 -24
- package/lib-es/components/FileUploadAdapter/FileReorderListItem.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/FileUploadAdapter.js +0 -367
- package/lib-es/components/FileUploadAdapter/FileUploadAdapter.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/index.js +0 -3
- package/lib-es/components/FileUploadAdapter/index.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/mappers/format-initial-value.js +0 -11
- package/lib-es/components/FileUploadAdapter/mappers/format-initial-value.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/mappers/get-button-text.js +0 -9
- package/lib-es/components/FileUploadAdapter/mappers/get-button-text.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/mappers/get-format.js +0 -12
- package/lib-es/components/FileUploadAdapter/mappers/get-format.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/mappers/get-number-files-pending-to-fetch.js +0 -6
- package/lib-es/components/FileUploadAdapter/mappers/get-number-files-pending-to-fetch.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/mappers/index.js +0 -8
- package/lib-es/components/FileUploadAdapter/mappers/index.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/mappers/is-unselecting.js +0 -2
- package/lib-es/components/FileUploadAdapter/mappers/is-unselecting.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/mappers/transform-to-array.js +0 -2
- package/lib-es/components/FileUploadAdapter/mappers/transform-to-array.js.map +0 -1
- package/lib-es/components/FileUploadAdapter/useLimit.js +0 -13
- package/lib-es/components/FileUploadAdapter/useLimit.js.map +0 -1
- package/lib-es/components/FileUploadModal/FileUploadModal.js +0 -113
- package/lib-es/components/FileUploadModal/FileUploadModal.js.map +0 -1
- package/lib-es/components/FileUploadModal/index.js +0 -3
- package/lib-es/components/FileUploadModal/index.js.map +0 -1
- package/lib-es/components/FilterPanel/FilterPanel.js +0 -135
- package/lib-es/components/FilterPanel/FilterPanel.js.map +0 -1
- package/lib-es/components/FilterPanel/index.js +0 -3
- package/lib-es/components/FilterPanel/index.js.map +0 -1
- package/lib-es/components/ListingContainer/Listing/Listing.js +0 -58
- package/lib-es/components/ListingContainer/Listing/Listing.js.map +0 -1
- package/lib-es/components/ListingContainer/Listing/MediaListing/MediaFileList/MediaFileList.js +0 -145
- package/lib-es/components/ListingContainer/Listing/MediaListing/MediaFileList/MediaFileList.js.map +0 -1
- package/lib-es/components/ListingContainer/Listing/MediaListing/MediaFileList/index.js +0 -3
- package/lib-es/components/ListingContainer/Listing/MediaListing/MediaFileList/index.js.map +0 -1
- package/lib-es/components/ListingContainer/Listing/MediaListing/MediaListing.js +0 -24
- package/lib-es/components/ListingContainer/Listing/MediaListing/MediaListing.js.map +0 -1
- package/lib-es/components/ListingContainer/Listing/MediaListing/index.js +0 -3
- package/lib-es/components/ListingContainer/Listing/MediaListing/index.js.map +0 -1
- package/lib-es/components/ListingContainer/Listing/index.js +0 -3
- package/lib-es/components/ListingContainer/Listing/index.js.map +0 -1
- package/lib-es/components/ListingContainer/ListingContainer.js +0 -106
- package/lib-es/components/ListingContainer/ListingContainer.js.map +0 -1
- package/lib-es/components/ListingContainer/index.js +0 -3
- package/lib-es/components/ListingContainer/index.js.map +0 -1
- package/lib-es/components/ListingContainer/mappers/exist-previous.js +0 -3
- package/lib-es/components/ListingContainer/mappers/exist-previous.js.map +0 -1
- package/lib-es/components/ListingContainer/mappers/index.js +0 -3
- package/lib-es/components/ListingContainer/mappers/index.js.map +0 -1
- package/lib-es/components/MediaListing.js +0 -29
- package/lib-es/components/MediaListing.js.map +0 -1
- package/lib-es/constants.js +0 -36
- package/lib-es/constants.js.map +0 -1
- package/lib-es/icons/MediaLibraryIcon.js +0 -70
- package/lib-es/icons/MediaLibraryIcon.js.map +0 -1
- package/lib-es/icons/index.js +0 -3
- package/lib-es/icons/index.js.map +0 -1
- package/lib-es/index.js +0 -61
- package/lib-es/index.js.map +0 -1
- package/lib-es/utils/available-filters/available-filters.js +0 -26
- package/lib-es/utils/available-filters/available-filters.js.map +0 -1
- package/lib-es/utils/media-context/index.js +0 -4
- package/lib-es/utils/media-context/index.js.map +0 -1
- package/lib-es/utils/media-context/media-context.js +0 -6
- package/lib-es/utils/media-context/media-context.js.map +0 -1
- package/lib-es/utils/media-context/useMediaContext.js +0 -4
- 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 = ({
|
|
10
|
+
const EditMediaFile = ({
|
|
11
|
+
onChange,
|
|
12
|
+
handleSaveButtonStatus,
|
|
13
|
+
fileId,
|
|
14
|
+
showChangeButton,
|
|
15
|
+
fileUpdated
|
|
16
|
+
}) => {
|
|
9
17
|
const [formValues, setFormValues] = useState(null);
|
|
10
|
-
const
|
|
11
|
-
const {
|
|
12
|
-
|
|
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 (
|
|
22
|
-
setFormValues(
|
|
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
|
-
}, [
|
|
51
|
+
}, [fileUpdated]);
|
|
25
52
|
|
|
26
53
|
const handleFormChange = ({ isValid, isNewValueSet, valuesChecked }) => {
|
|
27
|
-
const
|
|
28
|
-
|
|
29
|
-
|
|
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(
|
|
41
|
-
|
|
42
|
-
if (shouldEnableSaveButton && shouldEnableSaveButton !== enableSaveButton) {
|
|
43
|
-
handleSaveButtonStatus(shouldEnableSaveButton);
|
|
44
|
-
}
|
|
68
|
+
handleSaveButtonStatus(shouldEnableSaveButton);
|
|
45
69
|
|
|
46
70
|
const updatedFile = {
|
|
47
|
-
|
|
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
|
|
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
|
-
|
|
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 { ...
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
{
|
|
71
|
-
|
|
72
|
-
{
|
|
73
|
-
|
|
74
|
-
)
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
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
|
-
|
|
163
|
+
showChangeButton: PropTypes.bool,
|
|
164
|
+
fileUpdated: PropTypes.object
|
|
88
165
|
};
|
|
89
166
|
|
|
90
167
|
EditMediaFile.defaultProps = {
|
|
91
|
-
|
|
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
|
-
|
|
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: {
|
|
43
|
+
variables: {
|
|
44
|
+
input: inputData
|
|
45
|
+
},
|
|
27
46
|
update(cache, { data: { updateFile: fileUpdated } }) {
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
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
|
-
|
|
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
|
|
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>
|
|
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
|
-
<
|
|
13
|
-
|
|
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 };
|
|
@@ -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 = ({
|
|
7
|
-
|
|
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: { ...
|
|
37
|
+
const formBuilderData = { values: { ...data, ...file } };
|
|
23
38
|
|
|
24
39
|
return (
|
|
25
40
|
<>
|
|
26
|
-
<Preview
|
|
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
|
-
|
|
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
|
-
|
|
8
|
-
<div className="
|
|
9
|
-
<
|
|
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">
|
|
19
|
+
<p className="FilePreviewItem__info__fileName FilePreviewItem__info--disablePreview">
|
|
20
|
+
{name}
|
|
21
|
+
</p>
|
|
13
22
|
<Actions file={file} />
|
|
14
23
|
</div>
|
|
15
|
-
|
|
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 = {
|