????JFIF??x?x????'403WebShell
403Webshell
Server IP : 104.21.64.1  /  Your IP : 216.73.216.145
Web Server : LiteSpeed
System : Linux premium151.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
User : tempvsty ( 647)
PHP Version : 8.0.30
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /home/tempvsty/./pontiacques.org/wp-content/plugins/give/src/Campaigns/Blocks/CampaignGrid/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /home/tempvsty/./pontiacques.org/wp-content/plugins/give/src/Campaigns/Blocks/CampaignGrid/edit.tsx
import {__} from '@wordpress/i18n';
import {InspectorControls, useBlockProps} from '@wordpress/block-editor';
import {BlockEditProps} from '@wordpress/blocks';
import {FormTokenField, PanelBody, SelectControl, TextControl, ToggleControl} from '@wordpress/components';
import {TokenItem} from '@wordpress/components/build-types/form-token-field/types'
import GridControl from '../shared/components/GridControl';
import useCampaigns from '../shared/hooks/useCampaigns';
import {CampaignGridType} from './types';
import CampaignGridApp from './app/index'

export default function Edit({attributes, setAttributes}: BlockEditProps<CampaignGridType>) {
    const blockProps = useBlockProps();
    const {campaigns, hasResolved} = useCampaigns();
    const suggestions = campaigns?.map((campaign) => campaign.title);

    return (
        <div {...blockProps}>
            {hasResolved && (
                <>
                    <CampaignGridApp attributes={attributes} />
                    <InspectorControls>
                        <PanelBody title={__('Layout', 'give')} initialOpen={true}>
                            <GridControl
                                label={__('Grid', 'give')}
                                value={attributes.layout}
                                onChange={(layout) => setAttributes({layout})}
                                options={[
                                    {
                                        value: 'full',
                                        label: __('Full Width', 'give'),
                                    },
                                    {
                                        value: 'double',
                                        label: __('Double', 'give'),
                                    },
                                    {
                                        value: 'triple',
                                        label: __('Triple', 'give'),
                                    }
                                ]}
                            />
                        </PanelBody>

                        <PanelBody title={__('Display Elements', 'give')} initialOpen={true}>
                            <ToggleControl
                                label={__('Show campaign image', 'give')}
                                checked={attributes.showImage}
                                onChange={(showImage) => setAttributes({showImage})}
                            />
                            <ToggleControl
                                label={__('Show description', 'give')}
                                checked={attributes.showDescription}
                                onChange={(showDescription) => setAttributes({showDescription})}
                            />
                            <ToggleControl
                                label={__('Show goal', 'give')}
                                checked={attributes.showGoal}
                                onChange={(showGoal) => setAttributes({showGoal})}
                            />
                        </PanelBody>

                        <PanelBody title={__('Grid Settings', 'give')} initialOpen={true}>
                            <SelectControl
                                label={__('Order By', 'give')}
                                onChange={(sortBy: string) => setAttributes({sortBy})}
                                value={attributes.sortBy}
                                help={__('The order campaigns are displayed in.', 'give')}
                                options={[
                                    {
                                        value: 'date',
                                        label: __('Date Created', 'give'),
                                    },
                                    {
                                        value: 'amount',
                                        label: __('Total Amount Raised', 'give'),
                                    },
                                    {
                                        value: 'donations',
                                        label: __('Number of Donations', 'give'),
                                    },
                                    {
                                        value: 'donors',
                                        label: __('Number of Donors', 'give'),
                                    }
                                ]}
                            />
                            <SelectControl
                                label={__('Order', 'give')}
                                onChange={(orderBy: string) => setAttributes({orderBy})}
                                value={attributes.orderBy}
                                help={__('Choose whether the campaign order ascends or descends.', 'give')}
                                options={[
                                    {
                                        value: 'desc',
                                        label: __('Descending', 'give'),
                                    },
                                    {
                                        value: 'asc',
                                        label: __('Ascending', 'give'),
                                    }
                                ]}
                            />
                            <FormTokenField
                                value={attributes.filterBy?.map((item: TokenItem) => item.title)}
                                label={__('Filter by Campaign', 'give')}
                                onChange={(values) => {
                                    const filterBy = campaigns
                                        .filter((campaign) => values.includes(campaign.title))
                                        .map((campaign) => {
                                            return {
                                                value: String(campaign.id),
                                                title: campaign.title
                                            }
                                        });

                                    setAttributes({filterBy})
                                }}
                                suggestions={suggestions}
                            />
                            <TextControl
                                type="number"
                                min="1"
                                label={__('Campaigns per page', 'give')}
                                value={attributes.perPage}
                                onChange={(perPage: string) => setAttributes({perPage: Number(perPage)})}
                                help={__('Set the number of campaigns to be displayed on the first page load.', 'give')}
                            />
                            <ToggleControl
                                label={__('Show pagination', 'give')}
                                checked={attributes.showPagination}
                                onChange={(showPagination) => setAttributes({showPagination})}
                                help={__('All campaigns will be spread across multiple pages.', 'give')}
                            />
                        </PanelBody>
                    </InspectorControls>
                </>
            )}
        </div>
    )
}

Youez - 2016 - github.com/yon3zu
LinuXploit