Files
pole-book/server/node_modules/@strapi/upload/dist/admin/hooks/useBulkMove.mjs

78 lines
2.5 KiB
JavaScript

import { useNotification, useFetchClient } from '@strapi/admin/strapi-admin';
import { useIntl } from 'react-intl';
import { useQueryClient, useMutation } from 'react-query';
import { pluginId } from '../pluginId.mjs';
import 'byte-size';
import 'date-fns';
import { getTrad } from '../utils/getTrad.mjs';
import 'qs';
import '../constants.mjs';
import '../utils/urlYupSchema.mjs';
const useBulkMove = ()=>{
const { formatMessage } = useIntl();
const { toggleNotification } = useNotification();
const queryClient = useQueryClient();
const { post } = useFetchClient();
const bulkMoveQuery = ({ destinationFolderId, filesAndFolders })=>{
const payload = filesAndFolders.reduce((acc, selected)=>{
const { id, type } = selected;
const key = type === 'asset' ? 'fileIds' : 'folderIds';
if (!acc[key]) {
acc[key] = [];
}
acc[key].push(id);
return acc;
}, {});
return post('/upload/actions/bulk-move', {
...payload,
destinationFolderId
});
};
const mutation = useMutation(bulkMoveQuery, {
onSuccess (res) {
const { data: { data } } = res;
if (data?.files?.length > 0) {
queryClient.refetchQueries([
pluginId,
'assets'
], {
active: true
});
queryClient.refetchQueries([
pluginId,
'asset-count'
], {
active: true
});
}
// folders need to be re-fetched in any case, because assets might have been
// moved into a sub-folder and therefore the count needs to be updated
queryClient.refetchQueries([
pluginId,
'folders'
], {
active: true
});
toggleNotification({
type: 'success',
message: formatMessage({
id: getTrad('modal.move.success-label'),
defaultMessage: 'Elements have been moved successfully.'
})
});
}
});
const move = (destinationFolderId, filesAndFolders)=>mutation.mutateAsync({
destinationFolderId,
filesAndFolders
});
return {
...mutation,
move
};
};
export { useBulkMove };
//# sourceMappingURL=useBulkMove.mjs.map