HEX
Server: Apache
System: Linux WWW 6.1.0-40-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.153-1 (2025-09-20) x86_64
User: web11 (1011)
PHP: 8.2.29
Disabled: NONE
Upload Files
File: /var/www/ippmt.kauko.lt/wp-content/plugins/wp-photo-album-plus/blocks/upload/block.js
/**
 * WPPA Upload block
 *
 * Version: 8.5.01.001
 */

jQuery(document).ready(function(){
( function ( blocks, editor, i18n, element, components, _, blockEditor ) {

	var el = element.createElement;
	var __ = i18n.__;
	var RichText = blockEditor.RichText;
	var useBlockProps = blockEditor.useBlockProps;
	var wppaUploadAlbumList = wppaAlbumList.slice();
	wppaUploadAlbumList[0] = { label: __( '--- A selectionbox with all albums the user may upload to ---', 'wp-photo-album-plus' ), value: "0" };

	blocks.registerBlockType( 'wp-photo-album-plus/upload', {
		title: __( 'WPPA+ upload', 'wp-photo-album-plus' ),
		icon: el( 'img', {
							src: 	wppaImageDirectory+'camera32.png',
							style: 	{ width: '24px', height: '24px' },
						} ),
		category: 'layout',
		attributes: {
			widgetTitle: {
				type: 'string',
				selector: 'h2',
				default: '',
			},
			wppaAlbum: {
				type: 'number',
				default: 0,
			},
			wppaLoginOnly: {
				type: 'boolean',
				default: false,
			},
			wppaAdminOnly: {
				type: 'boolean',
				default: false,
			},
			wppaShortcode: {
				type: 'string',
				default: '[wppa type="upload"]',
			}
		},

		edit: function( props ) {
			var blockProps = wp.blockEditor.useBlockProps();
			var attributes = props.attributes;

			return el(
				'div',
				blockProps,
				el('h2',null,__( 'WPPA Upload form', 'wp-photo-album-plus' )),
				wppaOnWidgets() ?
				el( RichText, {
					tagName: 'h3',
					placeholder: __( 'Enter widget caption', 'wp-photo-album-plus' ),
					value: attributes.widgetTitle,
					onChange: function ( value ) {
						props.setAttributes( { widgetTitle: value } );
					},
				}) : null,
				el(
					wp.components.SelectControl,
					{
						help: __( 'If you want to limit uploads to a specific album, select it here', 'wp-photo-album-plus' ),
						value: props.attributes.wppaAlbum,
						options: wppaUploadAlbumList,
						onChange: function( val ) {
							props.setAttributes( { wppaAlbum: parseInt(val) } );
							props.setAttributes( { wppaShortcode: evaluate(props) } );
						},
					}
				),
				( ! attributes.wppaAdminOnly ?
					el( wp.components.CheckboxControl, {
						label: __( 'Show to logged in users only?', 'wp-photo-album-plus' ),
						checked: attributes.wppaLoginOnly,
						onChange: function ( value ) {
							props.setAttributes( { wppaLoginOnly: value } );
						},
					}) : null
				),
				el( wp.components.CheckboxControl, {
					label: __( 'Show to admin only?', 'wp-photo-album-plus' ),
					checked: attributes.wppaAdminOnly,
					onChange: function ( value ) {
						props.setAttributes( { wppaAdminOnly: value } );
						if ( value ) {
							props.setAttributes( { wppaLoginOnly: false } );
						}
					},
				}),
				el('small',null,__( 'Corresponding shortcode', 'wp-photo-album-plus' )+': '+ evaluate(props)),
			);
		},

		save: function( props ) {
			var attributes = props.attributes;

			return el(
				'div',
				{},
				el('h3',{},attributes.widgetTitle),
				el('div',{},evaluate(props)),
			);
		}
	} );

	function evaluate( props ) {
		var attributes = props.attributes;

		var shortcode = '[wppa type="upload"';
		if ( attributes.wppaAlbum ) {
			shortcode += ' album="'+attributes.wppaAlbum+'"';
		}
		if ( attributes.wppaAdminOnly ) {
			shortcode += ' login="admin"';
		}
		else if ( attributes.wppaLoginOnly ) {
			shortcode += ' login="yes"';
		}
		if ( wppaOnWidgets() ) {
			shortcode += ' widget="upload"';
		}
		shortcode += ']';

		return shortcode;
	}

} )(
	window.wp.blocks,
	window.wp.editor,
	window.wp.i18n,
	window.wp.element,
	window.wp.components,
	window._,
	window.wp.blockEditor
)});