STRATO-apps/wordpress_03/app/wp-content/plugins/aimogen-pro/scripts/aiomatic-image-generator.js

SHA-256: 7350e8b2d1e8053962c6333d55bc97e111c9a14132af1826ff466b2cb0dbbe57
"use strict"; 
const { registerBlockType: customRegisterBlockType7 } = wp.blocks;
const mygcel7 = wp.element.createElement;

customRegisterBlockType7( 'aiomatic-automatic-ai-content-writer/aiomatic-image-generator', {
    title: 'Aimogen Image Generator Form',
    icon: 'text',
    category: 'embed',
    attributes: {
        image_size : {
            default: '1024x1024',
            type:   'string',
        },
        image_model : {
            default: 'dalle2',
            type:   'string',
        },
        user_token_cap_per_day : {
            default: '',
            type:   'string',
        },
        prompt_templates : {
            default: '',
            type:   'string',
        },
        prompt_editable : {
            default: '',
            type:   'string',
        }
    },
    keywords: ['list', 'posts', 'aiomatic'],
    edit: (function( props ) {
        var image_size = props.attributes.image_size;
        var user_token_cap_per_day = props.attributes.user_token_cap_per_day;
        var prompt_templates = props.attributes.prompt_templates;
        var prompt_editable = props.attributes.prompt_editable;
        var image_model = props.attributes.image_model;
        function updateMessage( event ) {
            props.setAttributes( { image_size: event.target.value} );
		}
        function updateMessage6( event ) {
            props.setAttributes( { user_token_cap_per_day: event.target.value} );
		}
        function updateMessage7( event ) {
            props.setAttributes( { prompt_templates: event.target.value} );
		}
        function updateMessage8( event ) {
            props.setAttributes( { prompt_editable: event.target.value} );
		}
        function updateMessage9( event ) {
            props.setAttributes( { image_model: event.target.value} );
		}
		return mygcel7(
			'div', 
			{ className: 'coderevolution_gutenberg_div' },
            mygcel7(
				'h4',
				{ className: 'coderevolution_gutenberg_title' },
                'Aimogen Image Generator Form ',
                mygcel7(
                    'div', 
                    {className:'bws_help_box bws_help_box_right dashicons dashicons-editor-help'}
                    ,
                    mygcel7(
                        'div', 
                        {className:'bws_hidden_help_text'},
                        'This block is used to generate AI images.'
                    )
                )
			),
            mygcel7(
				'br'
			),
            mygcel7(
				'br'
			),
            mygcel7(
				'label',
				{ className: 'coderevolution_gutenberg_label' },
                'Image Size: '
			),
            mygcel7(
                'div', 
                {className:'bws_help_box bws_help_box_right dashicons dashicons-editor-help'}
                ,
                mygcel7(
                    'div', 
                    {className:'bws_hidden_help_text'},
                    'Select the image size for AI generated images.'
                )
            ),
            mygcel7(
				'select',
				{ value: image_size, onChange: updateMessage, className: 'coderevolution_gutenberg_select' }, 
                mygcel7(
                    'option',
                    { value: 'default'},
                    'default'
                ), 
                mygcel7(
                    'option',
                    { value: '1024x1024'},
                    '1024x1024'
                ), 
                mygcel7(
                    'option',
                    { value: '512x512'},
                    '512x512 (only for Dall-E 2)'
                ), 
                mygcel7(
                    'option',
                    { value: '256x256'},
                    '256x256 (only for Dall-E 2)'
                ), 
                mygcel7(
                    'option',
                    { value: '1024x1792'},
                    '1024x1792 (only for Dall-E 3)'
                ), 
                mygcel7(
                    'option',
                    { value: '1792x1024'},
                    '1792x1024 (only for Dall-E 3)'
                ), 
                mygcel7(
                    'option',
                    { value: '1024x1536'},
                    '1024x1536 (only for gpt-image-1, gpt-image-1-mini, gpt-image-1.5, chatgpt-image-latest)'
                ), 
                mygcel7(
                    'option',
                    { value: '1536x1024'},
                    '1536x1024 (only for gpt-image-1, gpt-image-1-mini, gpt-image-1.5, chatgpt-image-latest)'
                )
            ),
            mygcel7(
				'br'
			),
            mygcel7(
				'label',
				{ className: 'coderevolution_gutenberg_label' },
                'Image Model: '
			),
            mygcel7(
                'div', 
                {className:'bws_help_box bws_help_box_right dashicons dashicons-editor-help'}
                ,
                mygcel7(
                    'div', 
                    {className:'bws_hidden_help_text'},
                    'Select the image model to use. Note that for Dall-E 3 models, only the 1024x1024 or larger image sizes are supported, while for the Dall-E 2 model, 1024x1024 or smaller sizes are supported.'
                )
            ),
            mygcel7(
				'select',
				{ value: image_model, onChange: updateMessage9, className: 'coderevolution_gutenberg_select' }, 
                mygcel7(
                    'option',
                    { value: 'dalle2'},
                    'Dall-E 2'
                ), 
                mygcel7(
                    'option',
                    { value: 'dalle3'},
                    'Dall-E 3'
                ), 
                mygcel7(
                    'option',
                    { value: 'dalle3hd'},
                    'Dall-E 3 HD'
                ), 
                mygcel7(
                    'option',
                    { value: 'gpt-image-1'},
                    'gpt-image-1'
                ), 
                mygcel7(
                    'option',
                    { value: 'gpt-image-1-mini'},
                    'gpt-image-1-mini'
                ), 
                mygcel7(
                    'option',
                    { value: 'gpt-image-1.5'},
                    'gpt-image-1.5'
                ), 
                mygcel7(
                    'option',
                    { value: 'chatgpt-image-latest'},
                    'chatgpt-image-latest'
                )
            ),
            mygcel7(
				'br'
			),
            mygcel7(
				'label',
				{ className: 'coderevolution_gutenberg_label' },
                'Daily Token Count for Logged In Users: '
			),
            mygcel7(
                'div', 
                {className:'bws_help_box bws_help_box_right dashicons dashicons-editor-help'}
                ,
                mygcel7(
                    'div', 
                    {className:'bws_hidden_help_text'},
                    'Set the daily token count for logged in users. Users who are not logged in will not be allowed to submit the form. To disable this feature, leave this field blank.'
                )
            ),
			mygcel7(
				'input',
				{ type:'number',min:0,placeholder:'Daily token count for users', value: user_token_cap_per_day, onChange: updateMessage6, className: 'coderevolution_gutenberg_input' }
			),
            mygcel7(
				'br'
			),
            mygcel7(
				'label',
				{ className: 'coderevolution_gutenberg_label' },
                'Prompt Templates (Semicolon Separated): '
			),
            mygcel7(
                'div', 
                {className:'bws_help_box bws_help_box_right dashicons dashicons-editor-help'}
                ,
                mygcel7(
                    'div', 
                    {className:'bws_hidden_help_text'},
                    'Add a semicolon (;) separated list of prompt templates from which the users will be able to select and submit one.'
                )
            ),
			mygcel7(
				'input',
				{ type:'text',placeholder:'Template1;Template2;Template3', value: prompt_templates, onChange: updateMessage7, className: 'coderevolution_gutenberg_input' }
			),
            mygcel7(
				'br'
			),
            mygcel7(
				'label',
				{ className: 'coderevolution_gutenberg_label' },
                'Prompt Editable: '
			),
            mygcel7(
                'div', 
                {className:'bws_help_box bws_help_box_right dashicons dashicons-editor-help'}
                ,
                mygcel7(
                    'div', 
                    {className:'bws_hidden_help_text'},
                    'Select wheather the prompt will be editable by users. This is useful when combined with prompt templates from above, when you don\'t want the users to edit the entered template.'
                )
            ),
            mygcel7(
				'select',
				{ value: prompt_editable, onChange: updateMessage8, className: 'coderevolution_gutenberg_select' },
                mygcel7(
                    'option',
                    { value: 'yes'},
                    'yes'
                ), 
                mygcel7(
                    'option',
                    { value: 'no'},
                    'no'
                )
            ),
		);
    }),
    save: (function( props ) {
       return null;
    }),
} );