UNPKG

@gechiui/block-editor

Version:
71 lines (68 loc) 1.99 kB
/** * GeChiUI dependencies */ import apiFetch from '@gechiui/api-fetch'; import { useDispatch } from '@gechiui/data'; import { useCallback, useMemo, useState } from '@gechiui/element'; import { __, sprintf } from '@gechiui/i18n'; import { store as noticesStore } from '@gechiui/notices'; export default function useSaveImage(_ref) { let { crop, rotation, height, width, aspect, url, id, onSaveImage, onFinishEditing } = _ref; const { createErrorNotice } = useDispatch(noticesStore); const [isInProgress, setIsInProgress] = useState(false); const cancel = useCallback(() => { setIsInProgress(false); onFinishEditing(); }, [setIsInProgress, onFinishEditing]); const apply = useCallback(() => { setIsInProgress(true); let attrs = {}; // The crop script may return some very small, sub-pixel values when the image was not cropped. // Crop only when the new size has changed by more than 0.1%. if (crop.width < 99.9 || crop.height < 99.9) { attrs = crop; } if (rotation > 0) { attrs.rotation = rotation; } attrs.src = url; apiFetch({ path: `/gc/v2/media/${id}/edit`, method: 'POST', data: attrs }).then(response => { onSaveImage({ id: response.id, url: response.source_url, height: height && width ? width / aspect : undefined }); }).catch(error => { createErrorNotice(sprintf( /* translators: 1. Error message */ __('无法编辑图片。%s'), error.message), { id: 'image-editing-error', type: 'snackbar' }); }).finally(() => { setIsInProgress(false); onFinishEditing(); }); }, [setIsInProgress, crop, rotation, height, width, aspect, url, onSaveImage, createErrorNotice, setIsInProgress, onFinishEditing]); return useMemo(() => ({ isInProgress, apply, cancel }), [isInProgress, apply, cancel]); } //# sourceMappingURL=use-save-image.js.map