HEX
Server: nginx/1.22.1
System: Linux VM-4-16-centos 3.10.0-1160.105.1.el7.x86_64 #1 SMP Thu Dec 7 15:39:45 UTC 2023 x86_64
User: www (1001)
PHP: 7.1.33
Disabled: NONE
Upload Files
File: /www/wwwroot/wen.haoynn.cn/wp-content/plugins/easy-image-collage/assets/js/blocks/collage/index.js
const { __ } = wp.i18n;
const {
    Button,
    Disabled,
    ToolbarGroup,
    ToolbarButton,
} = wp.components;
const ServerSideRender = wp.serverSideRender;
const { registerBlockType } = wp.blocks;
const { Fragment } = wp.element;
const {
    BlockControls,
} = wp.blockEditor;

import '../../../../css/public.scss';

registerBlockType( 'easy-image-collage/collage', {
    title: __( 'Easy Image Collage' ),
    description: __( 'Display multiple images in a collage.' ),
    icon: 'layout',
    keywords: [ 'eic' ],
    category: 'layout',
    supports: {
		html: false,
    },
    transforms: {
        from: [
            {
                type: 'shortcode',
                tag: 'easy-image-collage',
                attributes: {
                    id: {
                        type: 'number',
                        shortcode: ( { named: { id = '' } } ) => {
                            return parseInt( id.replace( 'id', '' ) );
                        },
                    },
                },
            },
        ]
    },
    edit: (props) => {
        const { attributes, setAttributes, isSelected, className } = props;

        const modalCallback = ( id ) => {
            setAttributes({
                id,
                updated: Date.now(),
            });
        };

        return (
            <div className={ className }>{
                attributes.id
                ?
                <Fragment>
                    <BlockControls>
                        <ToolbarGroup>
                            <ToolbarButton
                                icon="edit"
                                label={ __( 'Edit' ) }
                                onClick={ () => { EasyImageCollage.btnEditGrid( attributes.id, modalCallback ); } }
                            />
                        </ToolbarGroup>
                    </BlockControls>
                    <Disabled>    
                        <ServerSideRender
                            block="easy-image-collage/collage"
                            attributes={ attributes }
                        />
                    </Disabled>
                </Fragment>
                :
                <Fragment>
                    <Button
                        isPrimary
                        isLarge
                        onClick={ () => {
                            EasyImageCollage.btnCreateGrid( attributes.id, modalCallback );
                        }}>
                        { __( 'Create new Image Collage' ) }
                    </Button>
                </Fragment>
            }</div>
        )
    },
    save: (props) => {
        const id = props.attributes.id;

        if ( !id ) {
            return null;
        } else {
            // Store shortcode for compatibility with Classic Editor.
            return `[easy-image-collage id=${props.attributes.id}]`;
        }
    },
    deprecated: [
        {
            attributes: {
                id: {
                    type: 'number',
                    default: 0
                }
            },
            save: (props) => { return null; }
        }
    ],
} );