Skip to content

Commit

Permalink
Abstract LegacyTemplate block (woocommerce#4991)
Browse files Browse the repository at this point in the history
* Legacy Template block

* Return render_single_product value

* Make placeholder text translatable

* Don't allow removing the block

* Update block title

Co-authored-by: Albert Juhé Lluveras <[email protected]>
  • Loading branch information
2 people authored and jonny-bull committed Dec 16, 2021
1 parent 2e1df38 commit c95da1a
Show file tree
Hide file tree
Showing 5 changed files with 149 additions and 8 deletions.
71 changes: 71 additions & 0 deletions assets/js/blocks/legacy-template/index.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,71 @@
/**
* External dependencies
*/
import { registerExperimentalBlockType } from '@woocommerce/block-settings';
import { useBlockProps } from '@wordpress/block-editor';
import { Placeholder } from '@wordpress/components';
import { __, sprintf } from '@wordpress/i18n';

interface Props {
attributes: {
template: string;
};
}

const Edit = ( { attributes }: Props ) => {
const blockProps = useBlockProps();
return (
<div { ...blockProps }>
<Placeholder
label={ sprintf(
/* translators: %s is the template name */
__(
'Wireframe template for %s will be rendered here.',
'woo-gutenberg-products-block'
),
attributes.template
) }
/>
</div>
);
};

registerExperimentalBlockType( 'woocommerce/legacy-template', {
title: __( 'WooCommerce Legacy Template', 'woo-gutenberg-products-block' ),
category: 'woocommerce',
apiVersion: 2,
keywords: [ __( 'WooCommerce', 'woo-gutenberg-products-block' ) ],
description: __(
'Renders legacy WooCommerce PHP templates.',
'woo-gutenberg-products-block'
),
supports: {
align: false,
html: false,
multiple: false,
reusable: false,
inserter: false,
},
example: {
attributes: {
isPreview: true,
},
},
attributes: {
/**
* Template attribute is used to determine which core PHP template gets rendered.
*/
template: {
type: 'string',
default: 'any',
},
lock: {
type: 'object',
default: {
remove: true,
},
},
},
edit: Edit,
save: () => null,
} );
1 change: 1 addition & 0 deletions bin/webpack-entries.js
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,7 @@ const blocks = {
'single-product': {
isExperimental: true,
},
'legacy-template': {},
};

// Returns the entries for each block given a relative path (ie: `index.js`,
Expand Down
22 changes: 14 additions & 8 deletions src/BlockTypes/AbstractBlock.php
Original file line number Diff line number Diff line change
Expand Up @@ -176,16 +176,22 @@ protected function register_chunk_translations( $chunks ) {
* Registers the block type with WordPress.
*/
protected function register_block_type() {
$block_settings = [
'render_callback' => $this->get_block_type_render_callback(),
'editor_script' => $this->get_block_type_editor_script( 'handle' ),
'editor_style' => $this->get_block_type_editor_style(),
'style' => $this->get_block_type_style(),
'attributes' => $this->get_block_type_attributes(),
'supports' => $this->get_block_type_supports(),
];

if ( isset( $this->api_version ) && '2' === $this->api_version ) {
$block_settings['api_version'] = 2;
}

register_block_type(
$this->get_block_type(),
array(
'render_callback' => $this->get_block_type_render_callback(),
'editor_script' => $this->get_block_type_editor_script( 'handle' ),
'editor_style' => $this->get_block_type_editor_style(),
'style' => $this->get_block_type_style(),
'attributes' => $this->get_block_type_attributes(),
'supports' => $this->get_block_type_supports(),
)
$block_settings
);
}

Expand Down
62 changes: 62 additions & 0 deletions src/BlockTypes/LegacyTemplate.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
<?php
namespace Automattic\WooCommerce\Blocks\BlockTypes;

/**
* Legacy Single Product class
*
* @internal
*/
class LegacyTemplate extends AbstractDynamicBlock {
/**
* Block name.
*
* @var string
*/
protected $block_name = 'legacy-template';

/**
* API version.
*
* @var string
*/
protected $api_version = '2';

/**
* Render method for the Legacy Template block. This method will determine which template to render.
*
* @param array $attributes Block attributes.
* @param string $content Block content.
*
* @return string | void Rendered block type output.
*/
protected function render( $attributes, $content ) {
if ( null === $attributes['template'] ) {
return;
}

if ( 'single-product' === $attributes['template'] ) {
return $this->render_single_product();
} else {
ob_start();

echo "You're using the LegacyTemplate block";

wp_reset_postdata();
return ob_get_clean();
}
}

/**
* Render method for the single product template and parts.
*
* @return string Rendered block type output.
*/
protected function render_single_product() {
ob_start();

echo 'This method will render the single product template';

wp_reset_postdata();
return ob_get_clean();
}
}
1 change: 1 addition & 0 deletions src/BlockTypesController.php
Original file line number Diff line number Diff line change
Expand Up @@ -174,6 +174,7 @@ protected function get_block_types() {
'AttributeFilter',
'StockFilter',
'ActiveFilters',
'LegacyTemplate',
];

if ( Package::feature()->is_feature_plugin_build() ) {
Expand Down

0 comments on commit c95da1a

Please sign in to comment.