Current File : /home/pacjaorg/wpt.pacja.org/copwordpres/wp-content/plugins/breadcrumb-navxt/bcn_gutenberg_block.js
/**
 * A Gutenberg Breadcrumb Block
 */
( function( blocks, components, i18n, element ) {
	const { __ } = wp.i18n;
	const { registerBlockType, InspectorControls } = wp.blocks;
	const { Component } = wp.element;
	const { decodeEntities } = wp.htmlEntities;
	wp.data.use( wp.data.plugins.controls );
	const { data, apiFetch } = wp;
	const { registerStore, withSelect, select, dispatch } = data;
	const el = wp.element.createElement;
	const iconBCN = el('svg', { viewBox: "0 0 24 24", xmlns: "http://www.w3.org/2000/svg" },
			el('path', { d: "M0.6 7.2C0.4 7.2 0.4 7.2 0.4 7.4V16.9C0.4 17.1 0.4 17.1 0.6 17.1H10.9C11.1 17.1 11.1 17.1 11.3 16.9L16 12.1 11.3 7.4C11.1 7.2 11.1 7.2 10.9 7.2ZM15 7.2 19.9 12.1 15 17.1H18.7C18.9 17.1 18.9 17.1 19.1 16.9L23.8 12.1 19.1 7.4C18.9 7.2 18.9 7.2 18.7 7.2Z" } )
		);
	
	const DEFAULT_STATE = {
			breadcrumbTrails: {}
	};
	
	const actions = {
		setBreadcrumbTrail( post, breadcrumbTrail) {
			return {
				type: 'SET_BREADCRUMB_TRAIL',
				post,
				breadcrumbTrail,
			}
		},
		fetchFromAPI( path ) {
			return {
				type: 'FETCH_FROM_API',
				path,
			}
		}
	};
	
	registerStore('breadcrumb-navxt', {
		reducer( state = DEFAULT_STATE, action ) {
			switch ( action.type ) {
				case 'SET_BREADCRUMB_TRAIL' :
					return {
						...state,
						breadcrumbTrails: {
							...state.breadcrumbTrails,
							[ action.post ]: action.breadcrumbTrail,
							},
					};
			}
			return state;
		},
		
		actions,
		
		selectors: {
			getBreadcrumbTrail( state, post ) {
				const { breadcrumbTrails } = state;
				const breadcrumbTrail = breadcrumbTrails[ post ];
				return breadcrumbTrail;
			},
		},
		
		controls: {
			FETCH_FROM_API( action ) {
				return apiFetch( { path: action.path } );
			},
		},
		
		resolvers: {
			* getBreadcrumbTrail( post ) {
				const path = '/bcn/v1/post/' + post;
				const breadcrumbTrail = yield actions.fetchFromAPI( path );
				return actions.setBreadcrumbTrail( post, breadcrumbTrail );
			}
		},
	} );
	function renderBreadcrumbTrail( breadcrumbTrail ) {
		var trailString = [];
		const length = breadcrumbTrail.itemListElement.length;
		breadcrumbTrail.itemListElement.forEach( function( listElement, index ) {
			if( index > 0 ) {
				trailString.push( decodeEntities( bcnOpts.hseparator ) );
			}
			if( index < length - 1 || bcnOpts.bcurrent_item_linked) {
				trailString.push( el( 'a', { href: listElement.item['@id'] }, decodeEntities( listElement.item.name ) ) );
			}
			else {
				trailString.push( el( 'span', { }, decodeEntities( listElement.item.name ) ) );
			}
		});
		return trailString;
	}
	function displayBreadcrumbTrail( { breadcrumbTrail } ) {
		if( ! breadcrumbTrail ) {
			return __( 'Loading...', 'breadcrumb-navxt' );
		}
		if( breadcrumbTrail.itemListElement === 0 ) {
			return __( 'No breadcrumb trail', 'breadcrumb-navxt' );
		}
		var breadcrumb = breadcrumbTrail.itemListElement[ 0 ];
		return renderBreadcrumbTrail(breadcrumbTrail);
	}
	registerBlockType( 'bcn/breadcrumb-trail', {
		title: __( 'Breadcrumb Trail', 'breadcrumb-navxt' ),
		description: __( "Display a breadcrumb trail representing this post's location on this website.", 'breadcrumb-navxt'),
		icon: iconBCN,
		category: 'widgets',

		edit: withSelect( ( select, ownProps ) => {
			const { getBreadcrumbTrail } = select( 'breadcrumb-navxt' );
			return {
				breadcrumbTrail: getBreadcrumbTrail( select( 'core/editor' ).getCurrentPostId() ),
			};
		} )( displayBreadcrumbTrail ),

		save: function() {
			//Rendering in PHP
			return null;
		},
	} );
} )(
	window.wp.blocks,
	window.wp.components,
	window.wp.i18n,
	window.wp.element
);
Site is undergoing maintenance

PACJA Events

Maintenance mode is on

Site will be available soon. Thank you for your patience!