Wordpress-plugin-Gutenberg-.../src/block/block.js

260 lines
16 KiB
JavaScript

/**
* BLOCK: mobilizon
*
* Registering a basic block with Gutenberg.
* Simple block, renders and saves the same content without any interactivity.
*/
import * as MobilizonWrapper from './../mobilizon-helper';
// Import CSS.
import './editor.scss';
import './style.scss';
const { __ } = wp.i18n; // Import __() from wp.i18n
const { registerBlockType } = wp.blocks; // Import registerBlockType() from wp.blocks
const { RichText, InspectorControls } = wp.blockEditor;
const { Placeholder, PanelBody, PanelRow, CheckboxControl, RangeControl, ColorPicker, TextControl } = wp.components;
// Custom icon for the block
const el = wp.element.createElement;
const iconEl = el('img', { class: "wp-block-cgb-mobilizon-icon", src: "" });
/**
* Register: aa Gutenberg Block.
*
* Registers a new block provided a unique name and an object defining its
* behavior. Once registered, the block is made editor as an option to any
* editor interface where blocks are implemented.
*
* @link https://wordpress.org/gutenberg/handbook/block-api/
* @param {string} name Block name.
* @param {Object} settings Block settings.
* @return {?WPBlock} The block, if it has been successfully
* registered; otherwise `undefined`.
*/
registerBlockType( 'cgb/block-mobilizon', {
// Block name. Block names must be string that contains a namespace prefix. Example: my-plugin/my-custom-block.
title: __( 'Mobilizon' ), // Block title.
icon: iconEl, // Block icon from Dashicons → https://developer.wordpress.org/resource/dashicons/.
category: 'common', // Block category — Group blocks together based on common traits E.g. common, formatting, layout widgets, embed.
keywords: [
__( 'mobilizon' ),
__( 'events' ),
],
attributes: {
mobilizonInputField: {
type: 'string',
default: ''
},
mobilizonInputFieldIsValid: {
type: 'boolean',
default: false
},
mobilizonInputFieldHelpText: {
type: 'string',
default: ''
},
mobilizonBaseURL: {
type: 'string',
default: ''
},
mobilizonGroupName: {
type: 'string',
default: ''
},
mobilizonEventLimit: {
type: 'int',
default: 0
},
mobilizonShowHeaderImage: {
type: 'boolean',
default: true
},
myRichText: {
type: 'string',
source: 'html',
selector: 'p'
},
toggle: {
type: 'boolean',
default: true
},
favoriteAnimal: {
type: 'string',
default: 'dogs'
},
favoriteColor: {
type: 'string',
default: '#DDDDDD'
},
activateLasers: {
type: 'boolean',
default: false
}
},
/**
* The edit function describes the structure of your block in the context of the editor.
* This represents what the editor will render when the block is used.
*
* The "edit" property must be a valid function.
*
* @link https://wordpress.org/gutenberg/handbook/block-api/block-edit-save/
*
* @param {Object} props Props.
* @returns {Mixed} JSX Component.
*/
// edit: ( props ) => {
// // Creates a <p class='wp-block-cgb-block-mobilizon'></p>.
// return (
// <div className={ props.className }>
// <p>Mobilizon Gutenberg Block</p>
// </div>
// );
// },
edit: (props) => {
const { attributes, setAttributes } = props;
async function updateAndValidateMobilizonActor(newtext) {
// Update the input-text-field, so one can see the input while typing
setAttributes({ mobilizonInputField: newtext })
// Assume that any valid string of an Mobilizon actor or instance is more than 7 characters long (May be risky!).
newtext = newtext.trim();
if (newtext.length > 7) {
// Possible Actors: @user@example.org or example.org/@user or http(s)://example.org/@user
if (newtext.includes("@")) {
// Here we may have actor+instance (actor means mobilizon-group)
// Possible formats could be "@actor@mobilizon.fr" or "https://mobilizon.fr/@actor" or even "mobilizon.fr/@actor"
var splitted = newtext.split("@");
if ( splitted.length <= 3) {
if (splitted.length === 3 && splitted[0] === "") {
var baseURL = splitted[2];
var groupName = splitted[1];
}
else {
var baseURL = splitted[0];
var groupName = splitted[1];
}
// Asume that the instance name is at least 6 characters long (may be risky)
if (baseURL.includes(".") && baseURL.length > 5) {
// Add https protocol if not present
if (!baseURL.startsWith("https://")) {
baseURL = "https://" + baseURL;
}
if ( await MobilizonWrapper.isMobilizonInstance(baseURL)) {
// Now check if the group exists as well
if ( await MobilizonWrapper.groupExists(baseURL, groupName) ) {
setAttributes({ mobilizonBaseURL: baseURL});
setAttributes({ mobilizonGroupName: groupName });
setAttributes({ mobilizonInputFieldHelpText: "" });
setAttributes({ mobilizonInputFieldIsValid: true });
} else {
var helperText = "The group " + groupName + " does not exist on " + baseURL;
setAttributes({ mobilizonInputFieldHelpText: helperText });
}
}
}
}
}
else {
// Here we only have the instance domain alone, no actor (group)!
// Instance-URL must have at least one dot, an the after the first dot there must at least be two more characters for a valid domain
if (newtext.includes(".") && newtext.substring(newtext.indexOf(".")).length > 2) {
var baseURL = newtext;
// Add https protocol if not present
if (!baseURL.startsWith("https://")) {
baseURL = "https://" + baseURL;
}
if ( await MobilizonWrapper.isMobilizonInstance(baseURL)) {
setAttributes({ mobilizonBaseURL: baseURL});
setAttributes({ mobilizonGroupName: "" });
setAttributes({ mobilizonInputFieldHelpText: "" });
setAttributes({ mobilizonInputFieldIsValid: true });
} else {
var helperText = baseURL + " is not a mobilizon instance";
setAttributes({ mobilizonInputFieldHelpText: helperText });
}
}
}
} else {
var helperText = newtext + " is no valid mobilizon actor"
setAttributes({ mobilizonInputFieldHelpText: helperText });
}
}
return (
<div className={ props.className }>
<InspectorControls>
<PanelBody
title="Settings"
initialOpen={true}
>
<PanelRow>
<RangeControl
label="Limit how many events are shown (0 means no limit)"
value={ attributes.mobilizonEventLimit }
onChange={ ( value ) => setAttributes({ mobilizonEventLimit: value })}
min={ 0 }
max={ 20 }
/>
</PanelRow>
<PanelRow>
<CheckboxControl
label="Header Images"
help="Set if the header images for each event are shown in the list?"
checked={attributes.mobilizonShowHeaderImage}
onChange={(newval) => setAttributes({ mobilizonShowHeaderImage: newval })}
/>
</PanelRow>
</PanelBody>
</InspectorControls>
<Placeholder icon={ iconEl } label="Mobilizon Event List">
<TextControl
tagName="h2"
placeholder="@example@mobilizon.fr"
label="Fediverse handle or URL of a Mobilizon-group or Mobilizon-Instance-URL"
help={ attributes.mobilizonInputFieldHelpText }
value={ attributes.mobilizonInputField }
onChange={(newtext) => updateAndValidateMobilizonActor(newtext)}
/>
</Placeholder>
</div>
);
},
/**
* The save function defines the way in which the different attributes should be combined
* into the final markup, which is then serialized by Gutenberg into post_content.
*
* The "save" property must be specified and must be a valid function.
*
* @link https://wordpress.org/gutenberg/handbook/block-api/block-edit-save/
*
* @param {Object} props Props.
* @returns {Mixed} JSX Frontend HTML.
*/
save: ( props ) => {
return ( null );
},
} );