Skip to content

Commit

Permalink
Merge pull request #929 from publishpress/develop
Browse files Browse the repository at this point in the history
Develop
  • Loading branch information
htmgarcia authored Apr 26, 2022
2 parents 9addd1c + af675a5 commit b2f653c
Show file tree
Hide file tree
Showing 41 changed files with 508 additions and 890 deletions.
6 changes: 3 additions & 3 deletions src/advanced-gutenberg.php
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@
* Plugin Name: PublishPress Blocks
* Plugin URI: https://publishpress.com/blocks/
* Description: PublishPress Blocks has everything you need to build professional websites with the Gutenberg editor.
* Version: 2.12.0
* Tested up to: 5.9.2
* Version: 2.13.0
* Tested up to: 5.9.3
* Author: PublishPress
* Author URI: https://publishpress.com/
* License: GPL2
Expand Down Expand Up @@ -39,7 +39,7 @@
defined('ABSPATH') || die;

if (! defined('ADVANCED_GUTENBERG_VERSION')) {
define('ADVANCED_GUTENBERG_VERSION', '2.12.0');
define('ADVANCED_GUTENBERG_VERSION', '2.13.0');
}

if (! defined('ADVANCED_GUTENBERG_PLUGIN')) {
Expand Down
2 changes: 1 addition & 1 deletion src/assets/blocks/accordion/block.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -330,7 +330,7 @@

registerBlockType( 'advgb/accordion', {
title: __( 'Accordion', 'advanced-gutenberg' ),
description: __( 'Easy to create an accordion for your post/page.', 'advanced-gutenberg' ),
description: __( 'Create a sliding accordion display for your content.', 'advanced-gutenberg' ),
icon: {
src: accordionBlockIcon,
foreground: typeof advgbBlocks !== 'undefined' ? advgbBlocks.color : undefined,
Expand Down
2 changes: 1 addition & 1 deletion src/assets/blocks/advaccordion/accordion.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -280,7 +280,7 @@

registerBlockType( 'advgb/accordion-item', {
title: __( 'Accordion Item', 'advanced-gutenberg' ),
description: __( 'Easy to create an accordion for your post/page.', 'advanced-gutenberg' ),
description: __( 'Create a sliding accordion display for your content.', 'advanced-gutenberg' ),
icon: {
src: accordionBlockIcon,
foreground: typeof advgbBlocks !== 'undefined' ? advgbBlocks.color : undefined,
Expand Down
2 changes: 1 addition & 1 deletion src/assets/blocks/advaccordion/block.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -352,7 +352,7 @@

registerBlockType( 'advgb/accordions', {
title: __( 'Advanced Accordion', 'advanced-gutenberg' ),
description: __( 'Easy to create an accordion for your post/page.', 'advanced-gutenberg' ),
description: __( 'Create a sliding accordion display for your content.', 'advanced-gutenberg' ),
icon: {
src: accordionBlockIcon,
foreground: typeof advgbBlocks !== 'undefined' ? advgbBlocks.color : undefined,
Expand Down
38 changes: 33 additions & 5 deletions src/assets/blocks/advbutton/block.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,15 @@ import {IconListPopupHook} from "../0-adv-components/icon-class.jsx";
const previewImageDataSquaredOutline = '';
const previewImageDataSquared = '';

function advgb_relAttribute(attributes) {
let values = [
attributes.noreferrer ? 'noreferrer' : '',
attributes.nofollow ? 'nofollow' : ''
].filter( Boolean ).join(' ');

return values;
}

class AdvButton extends Component {
constructor() {
super( ...arguments );
Expand Down Expand Up @@ -55,6 +64,14 @@ import {IconListPopupHook} from "../0-adv-components/icon-class.jsx";
componentDidMount() {
const { attributes, setAttributes, clientId } = this.props;
setAttributes( { id: 'advgbbtn-' + clientId } );

// Reset attributes when Pro is not available
if( advgbBlocks.advgb_pro !== 'undefined' && advgbBlocks.advgb_pro !== '1' ) {
setAttributes( {
noreferrer: true,
nofollow: false
} );
}
}

componentDidUpdate() {
Expand Down Expand Up @@ -129,7 +146,8 @@ import {IconListPopupHook} from "../0-adv-components/icon-class.jsx";
paddingTop, paddingRight, paddingBottom, paddingLeft,
borderWidth, borderColor, borderRadius, borderStyle,
hoverTextColor, hoverBgColor, hoverShadowColor, hoverShadowH, hoverShadowV, hoverShadowBlur, hoverShadowSpread,
hoverOpacity, transitionSpeed, iconDisplay, icon, iconSize, iconColor, iconTheme, iconPosition, iconSpacing, isPreview
hoverOpacity, transitionSpeed, iconDisplay, icon, iconSize, iconColor, iconTheme, iconPosition, iconSpacing,
noreferrer, nofollow, isPreview
} = attributes;

const isStyleSquared = className.indexOf('-squared') > -1;
Expand Down Expand Up @@ -178,7 +196,7 @@ import {IconListPopupHook} from "../0-adv-components/icon-class.jsx";
<span className={`${className} align${align}`}
style={ { display: 'inline-block' } }
>
<span className={ `wp-block-advgb-button_link ${id}` }>
<span className={ `wp-block-advgb-button_link ${id}` } rel={ advgb_relAttribute(attributes) }>
{ iconDisplay && (
<i className={iconClass}>
{icon}
Expand Down Expand Up @@ -665,6 +683,14 @@ import {IconListPopupHook} from "../0-adv-components/icon-class.jsx";
type: 'number',
default: 7,
},
noreferrer: {
type: 'boolean',
default: true,
},
nofollow: {
type: 'boolean',
default: false,
},
changed: {
type: 'boolean',
default: false,
Expand All @@ -677,7 +703,7 @@ import {IconListPopupHook} from "../0-adv-components/icon-class.jsx";

registerBlockType( 'advgb/button', {
title: __( 'Advanced Button', 'advanced-gutenberg' ),
description: __( 'New button with more styles.', 'advanced-gutenberg' ),
description: __( 'Advanced button block with more options and styles.', 'advanced-gutenberg' ),
icon: {
src: buttonBlockIcon,
foreground: typeof advgbBlocks !== 'undefined' ? advgbBlocks.color : undefined,
Expand Down Expand Up @@ -741,7 +767,9 @@ import {IconListPopupHook} from "../0-adv-components/icon-class.jsx";
iconColor,
iconTheme,
iconPosition,
iconSpacing
iconSpacing,
noreferrer,
nofollow
} = attributes;

const iconClass = [
Expand All @@ -756,7 +784,7 @@ import {IconListPopupHook} from "../0-adv-components/icon-class.jsx";
href={ url || '#' }
title={ title }
target={ !urlOpenNewTab ? '_self' : '_blank' }
rel="noopener noreferrer">
rel={ 'noopener ' + advgb_relAttribute(attributes) }>
{ iconDisplay && (
<i className={iconClass}>
{icon}
Expand Down
50 changes: 47 additions & 3 deletions src/assets/blocks/advtabs/block.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
wpBlockEditor = wp.blockEditor || wp.editor;
const { __ } = wpI18n;
const { Component, Fragment } = wpElement;
const { registerBlockType, createBlock } = wpBlocks;
const { registerBlockType, createBlock, cloneBlock } = wpBlocks;
const { InspectorControls, RichText, PanelColorSettings, InnerBlocks } = wpBlockEditor;
const { Dashicon, Tooltip, PanelBody, RangeControl, SelectControl, Button, TextControl } = wpComponents;
const { withDispatch, select, dispatch } = wp.data;
Expand Down Expand Up @@ -176,6 +176,28 @@
childBlocks.forEach( childBlockId => updateBlockAttributes( childBlockId, {tabAnchors: tabAnchors} ) );
}

duplicateTab(index) {
const { attributes, setAttributes, clientId } = this.props;
const { insertBlock } = !wp.blockEditor ? dispatch( 'core/editor' ) : dispatch( 'core/block-editor' );
const { getBlockOrder, getBlock } = !wp.blockEditor ? select( 'core/editor' ) : select( 'core/block-editor' );
const childBlocks = getBlockOrder(clientId);
const blockTab = getBlock(childBlocks[index]);
const clonedTab = cloneBlock(blockTab);

insertBlock(clonedTab, attributes.tabHeaders.length, clientId);
setAttributes( {
tabHeaders: [
...attributes.tabHeaders,
`${attributes.tabHeaders[index]} (${__('copy', 'advanced-gutenberg')})`
],
tabAnchors: [
...attributes.tabAnchors,
''
]
} );
this.props.resetOrder();
}

addTab() {
const { attributes, setAttributes, clientId } = this.props;
const { insertBlock } = !wp.blockEditor ? dispatch( 'core/editor' ) : dispatch( 'core/block-editor' );
Expand Down Expand Up @@ -256,6 +278,20 @@
this.props.updateTabActive(newIndex)
}

translatableText(text) {
switch(text){
case 'desktop':
return __('desktop', 'advanced-gutenberg');
break;
case 'tablet':
return __('tablet', 'advanced-gutenberg');
break;
case 'mobile':
return __('mobile', 'advanced-gutenberg');
break;
}
}

render() {
const { attributes, setAttributes, clientId } = this.props;
const { viewport } = this.state;
Expand Down Expand Up @@ -310,7 +346,7 @@
key={ index }
onClick={ () => this.setState( { viewport: device } ) }
>
{device}
{this.translatableText(device)}
</div>
)
} ) }
Expand Down Expand Up @@ -488,6 +524,14 @@
</span>
</Tooltip>
) }
<Tooltip text={ __( 'Duplicate tab', 'advanced-gutenberg' ) }>
<span className="advgb-tab-duplicate"
onClick={ () => this.duplicateTab(index) }
style={ { display: tabActive === index ? 'block' : 'none' } }
>
<Dashicon icon="admin-page"/>
</span>
</Tooltip>
</Fragment>
) }
{tabHeaders.length > 1 && (
Expand Down Expand Up @@ -650,7 +694,7 @@

registerBlockType( 'advgb/adv-tabs', {
title: __( 'Advanced Tabs', 'advanced-gutenberg' ),
description: __( 'Create your own tabs never easy like this.', 'advanced-gutenberg' ),
description: __( 'Create horizontal or vertical tabs to display your content.', 'advanced-gutenberg' ),
icon: {
src: tabsBlockIcon,
foreground: typeof advgbBlocks !== 'undefined' ? advgbBlocks.color : undefined,
Expand Down
4 changes: 2 additions & 2 deletions src/assets/blocks/advvideo/block.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -600,7 +600,7 @@

registerBlockType( 'advgb/video', {
title: __( 'Advanced Video', 'advanced-gutenberg' ),
description: __( 'Powerful block for insert and embed video.', 'advanced-gutenberg' ),
description: __( 'Add more options and styles for videos in your Media Library.', 'advanced-gutenberg' ),
icon: {
src: advVideoBlockIcon,
foreground: typeof advgbBlocks !== 'undefined' ? advgbBlocks.color : undefined,
Expand Down Expand Up @@ -798,4 +798,4 @@
},
}]
} );
})( wp.i18n, wp.blocks, wp.element, wp.blockEditor, wp.components );
})( wp.i18n, wp.blocks, wp.element, wp.blockEditor, wp.components );
Loading

0 comments on commit b2f653c

Please sign in to comment.