import {__} from '@wordpress/i18n'; import {useSelect} from '@wordpress/data'; import {addQueryArgs} from '@wordpress/url'; import apiFetch from '@wordpress/api-fetch'; import useSWR from 'swr'; import {InspectorControls, useBlockProps} from '@wordpress/block-editor'; import {BlockEditProps} from '@wordpress/blocks'; import {PanelBody, SelectControl, TextControl, ToggleControl} from '@wordpress/components'; import ServerSideRender from '@wordpress/server-side-render'; import useCampaign from '../shared/hooks/useCampaign'; import CampaignSelector from '../shared/components/CampaignSelector'; /** * @since 4.0.0 */ export default function Edit({attributes, setAttributes}: BlockEditProps<{ campaignId: number; buttonText: string; useDefaultForm: boolean; selectedForm: string; }>) { const blockProps = useBlockProps(); const {buttonText = __('Donate', 'give')} = attributes; const {campaign, hasResolved} = useCampaign(attributes.campaignId); const adminBaseUrl = useSelect( // @ts-ignore (select) => select('core').getSite()?.url + '/wp-admin/edit.php?post_type=give_forms&page=give-campaigns', [] ); const campaignForms = (() => { const {data, isLoading}: { data: { items: [] }, isLoading: boolean } = useSWR( addQueryArgs('/give-api/v2/admin/forms', {campaignId: attributes.campaignId, status: 'publish'}), path => apiFetch({path}) ) if (isLoading) { return [{label: __('Loading...', 'give'), value: ''}] } const options = data?.items.map((form: { name: string, id: string }) => ({ label: form.name, value: form.id })) return [ {label: __('Select form', 'give'), value: ''}, ...options ]; })(); return (
setAttributes({campaignId})} > {hasResolved && campaign?.id && ( setAttributes({buttonText})} /> setAttributes({useDefaultForm})} help={ <> {__('Uses the campaign’s default form.', 'give')} {` `} {__('Change default form', 'give')} } /> {!attributes.useDefaultForm && ( setAttributes({selectedForm})} options={campaignForms} value={attributes.selectedForm} help={__('Donations are collected through this form.', 'give')} /> )} )}
); }