Full Site Editing - Version 0.22

Version Description

  • Starter Page Templates: Improved previews with many visual glitches fixed
  • Starter Page Templates: Make page title visibility depend on theme setting
  • Starter Page Templates: Hide templates using unavailable blocks
  • Starter Page Templates: Track template insertion on Dotcom sites
  • Site Editor: initialize core FSE on Dotcom sites
  • Enable Gutenberg NUX with Gutenberg copy
  • Improved unit testing commands
Download this release

Release Info

Developer marekhrabe
Plugin Icon wp plugin Full Site Editing
Version 0.22
Comparing to
See all releases

Code changes from version 0.21 to 0.22

full-site-editing-plugin.php CHANGED
@@ -2,7 +2,7 @@
2
  /**
3
  * Plugin Name: Full Site Editing
4
  * Description: Enhances your page creation workflow within the Block Editor.
5
- * Version: 0.21
6
  * Author: Automattic
7
  * Author URI: https://automattic.com/wordpress-plugins/
8
  * License: GPLv2 or later
@@ -35,11 +35,20 @@ namespace A8C\FSE;
35
  *
36
  * @var string
37
  */
38
- define( 'PLUGIN_VERSION', '0.21' );
39
 
40
  // Always include these helper files for dotcom FSE.
41
  require_once __DIR__ . '/dotcom-fse/helpers.php';
42
 
 
 
 
 
 
 
 
 
 
43
  /**
44
  * Load Full Site Editing.
45
  */
@@ -216,11 +225,10 @@ function load_blog_posts_block() {
216
  }
217
  add_action( 'plugins_loaded', __NAMESPACE__ . '\load_blog_posts_block' );
218
 
219
- // @TODO - Uncomment once ready to deploy wpcom NUX.
220
  /**
221
  * Load WPCOM Block Editor NUX
222
  */
223
- // function load_wpcom_block_editor_nux() {
224
- // require_once __DIR__ . '/wpcom-block-editor-nux/class-wpcom-block-editor-nux.php';
225
- // }
226
- // add_action( 'plugins_loaded', __NAMESPACE__ . '\load_wpcom_block_editor_nux' );
2
  /**
3
  * Plugin Name: Full Site Editing
4
  * Description: Enhances your page creation workflow within the Block Editor.
5
+ * Version: 0.22
6
  * Author: Automattic
7
  * Author URI: https://automattic.com/wordpress-plugins/
8
  * License: GPLv2 or later
35
  *
36
  * @var string
37
  */
38
+ define( 'PLUGIN_VERSION', '0.22' );
39
 
40
  // Always include these helper files for dotcom FSE.
41
  require_once __DIR__ . '/dotcom-fse/helpers.php';
42
 
43
+ /**
44
+ * Load Core Site Editor.
45
+ */
46
+ function load_core_site_editor() {
47
+ require_once __DIR__ . '/site-editor/index.php';
48
+ initialize_site_editor();
49
+ }
50
+ add_action( 'plugins_loaded', __NAMESPACE__ . '\load_core_site_editor' );
51
+
52
  /**
53
  * Load Full Site Editing.
54
  */
225
  }
226
  add_action( 'plugins_loaded', __NAMESPACE__ . '\load_blog_posts_block' );
227
 
 
228
  /**
229
  * Load WPCOM Block Editor NUX
230
  */
231
+ function load_wpcom_block_editor_nux() {
232
+ require_once __DIR__ . '/wpcom-block-editor-nux/class-wpcom-block-editor-nux.php';
233
+ }
234
+ add_action( 'plugins_loaded', __NAMESPACE__ . '\load_wpcom_block_editor_nux' );
readme.txt CHANGED
@@ -1,9 +1,9 @@
1
  === Full Site Editing ===
2
- Contributors: alexislloyd, allancole, automattic, codebykat, copons, dmsnell, get_dave, glendaviesnz, gwwar, iamtakashi, Joen, kwight, marekhrabe, mattwiebe, mkaz, mmtr86, mppfeiffer, nrqsnchz, obenland, okenobi, vindl, noahtallen, owolski, nosolosw
3
  Tags: block, blocks, editor, gutenberg, page
4
  Requires at least: 5.0
5
  Tested up to: 5.3
6
- Stable tag: 0.21
7
  Requires PHP: 5.6.20
8
  License: GPLv2 or later
9
  License URI: https://www.gnu.org/licenses/gpl-2.0.html
@@ -42,6 +42,15 @@ This plugin is experimental, so we don't provide any support for it outside of w
42
 
43
  == Changelog ==
44
 
 
 
 
 
 
 
 
 
 
45
  = 0.21 =
46
  * Linting fixes and page layout selector improvements.
47
 
1
  === Full Site Editing ===
2
+ Contributors: alexislloyd, allancole, automattic, bartkalisz, codebykat, copons, dmsnell, get_dave, glendaviesnz, gwwar, iamtakashi, jeryj, Joen, kwight, marekhrabe, mattwiebe, mkaz, mmtr86, mppfeiffer, nrqsnchz, obenland, okenobi, vindl, noahtallen, owolski, nosolosw
3
  Tags: block, blocks, editor, gutenberg, page
4
  Requires at least: 5.0
5
  Tested up to: 5.3
6
+ Stable tag: 0.22
7
  Requires PHP: 5.6.20
8
  License: GPLv2 or later
9
  License URI: https://www.gnu.org/licenses/gpl-2.0.html
42
 
43
  == Changelog ==
44
 
45
+ = 0.22 =
46
+ * Starter Page Templates: Improved previews with many visual glitches fixed
47
+ * Starter Page Templates: Make page title visibility depend on theme setting
48
+ * Starter Page Templates: Hide templates using unavailable blocks
49
+ * Starter Page Templates: Track template insertion on Dotcom sites
50
+ * Site Editor: initialize core FSE on Dotcom sites
51
+ * Enable Gutenberg NUX with Gutenberg copy
52
+ * Improved unit testing commands
53
+
54
  = 0.21 =
55
  * Linting fixes and page layout selector improvements.
56
 
site-editor/index.php ADDED
@@ -0,0 +1,97 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <?php
2
+ /**
3
+ * WP.com Site Editor.
4
+ *
5
+ * The purpose of this code is to allow us to use core's Site Editor experiment
6
+ * on Dotcom and Atomic. The corresponding core functionality is initialized here:
7
+ * https://github.com/WordPress/gutenberg/blob/master/lib/edit-site-page.php
8
+ *
9
+ * We should aim to reuse as much of the core code as possible and use this to adjust it to some
10
+ * specifics of our platforms, or in cases when we want to extend the default experience.
11
+ *
12
+ * It's end goal is somewhat similar to the dotcom-fse project that's also part of this plugin.
13
+ * The difference being that that was a custom Dotcom solution and this one is being built on
14
+ * top of core FSE. When ready, it should completely replace the existing dotcom-fse functionality.
15
+ *
16
+ * @package A8C\FSE
17
+ */
18
+
19
+ namespace A8C\FSE;
20
+
21
+ /**
22
+ * Enables/Disables site editor experiment per blog sticker.
23
+ */
24
+ function initialize_site_editor() {
25
+ if ( ! is_site_editor_active() ) {
26
+ return;
27
+ }
28
+
29
+ // Force enable required Gutenberg experiments if they are not already active.
30
+ add_filter( 'option_gutenberg-experiments', __NAMESPACE__ . '\enable_site_editor_experiment' );
31
+
32
+ // TODO: Currently this action is removed on Dotcom. Circle back and find a cleaner way to deal with this.
33
+ add_action( 'admin_menu', 'gutenberg_menu' );
34
+
35
+ // Dotcom-specific overrides for API requests and similar.
36
+ add_action( 'admin_enqueue_scripts', __NAMESPACE__ . '\enqueue_override_scripts' );
37
+ }
38
+
39
+ /**
40
+ * Used to filter corresponding Site Editor experiment options.
41
+ *
42
+ * These need to be toggled on for the Site Editor to work properly.
43
+ * Furthermore, it's not enough to set them just on a given site.
44
+ * In WP.com context this needs to be enabled in API context too,
45
+ * and since we want to have it selectively enabled for some subset of
46
+ * sites initially, we can't set this option for the whole API.
47
+ * Instead we'll intercept it with it options filter (option_gutenberg-experiments)
48
+ * and override its values for certain sites.
49
+ *
50
+ * @param array $experiments_option Default experiments option array.
51
+ *
52
+ * @return array Experiments option array with FSE values enabled.
53
+ */
54
+ function enable_site_editor_experiment( $experiments_option ) {
55
+ if ( ! is_array( $experiments_option ) ) {
56
+ $experiments_option = array();
57
+ }
58
+
59
+ if ( empty( $experiments_option['gutenberg-full-site-editing'] ) ) {
60
+ $experiments_option['gutenberg-full-site-editing'] = 1;
61
+ }
62
+
63
+ if ( empty( $experiments_option['gutenberg-full-site-editing-demo'] ) ) {
64
+ $experiments_option['gutenberg-full-site-editing-demo'] = 1;
65
+ }
66
+
67
+ return $experiments_option;
68
+ }
69
+
70
+ /**
71
+ * We need to load Dotcom scripts to override default behavior.
72
+ *
73
+ * One example is routing API requests to public-api.
74
+ */
75
+ function enqueue_override_scripts() {
76
+ /*
77
+ * TODO: clean up this workaround later if possible.
78
+ * Currently this works because the required Dotcom overrides are hooked to this action.
79
+ */
80
+ do_action( 'enqueue_block_editor_assets' );
81
+ }
82
+
83
+ /**
84
+ * Whether or not core Site Editor is active.
85
+ *
86
+ * @returns bool True if Site Editor is active, false otherwise.
87
+ */
88
+ function is_site_editor_active() {
89
+ /**
90
+ * Can be used to enable Site Editor functionality.
91
+ *
92
+ * @since 0.22
93
+ *
94
+ * @param bool true if Site Editor should be enabled, false otherwise.
95
+ */
96
+ return apply_filters( 'a8c_enable_core_site_editor', false );
97
+ }
starter-page-templates/class-starter-page-templates.php CHANGED
@@ -172,15 +172,16 @@ class Starter_Page_Templates {
172
  $config = apply_filters(
173
  'fse_starter_page_templates_config',
174
  [
175
- 'siteInformation' => array_merge( $default_info, $site_info ),
176
- 'templates' => array_merge( $default_templates, $vertical_templates ),
177
- 'vertical' => $vertical,
178
- 'segment' => $segment,
179
  // phpcs:ignore WordPress.Security.NonceVerification.NoNonceVerification
180
- 'screenAction' => isset( $_GET['new-homepage'] ) ? 'add' : $screen->action,
181
- 'theme' => normalize_theme_slug( get_stylesheet() ),
182
  // phpcs:ignore WordPress.Security.NonceVerification.NoNonceVerification
183
- 'isFrontPage' => isset( $_GET['post'] ) && get_option( 'page_on_front' ) === $_GET['post'],
 
184
  ]
185
  );
186
  wp_localize_script( 'starter-page-templates', 'starterPageTemplatesConfig', $config );
172
  $config = apply_filters(
173
  'fse_starter_page_templates_config',
174
  [
175
+ 'siteInformation' => array_merge( $default_info, $site_info ),
176
+ 'templates' => array_merge( $default_templates, $vertical_templates ),
177
+ 'vertical' => $vertical,
178
+ 'segment' => $segment,
179
  // phpcs:ignore WordPress.Security.NonceVerification.NoNonceVerification
180
+ 'screenAction' => isset( $_GET['new-homepage'] ) ? 'add' : $screen->action,
181
+ 'theme' => normalize_theme_slug( get_stylesheet() ),
182
  // phpcs:ignore WordPress.Security.NonceVerification.NoNonceVerification
183
+ 'isFrontPage' => isset( $_GET['post'] ) && get_option( 'page_on_front' ) === $_GET['post'],
184
+ 'hideFrontPageTitle' => get_theme_mod( 'hide_front_page_title' ),
185
  ]
186
  );
187
  wp_localize_script( 'starter-page-templates', 'starterPageTemplatesConfig', $config );
starter-page-templates/dist/starter-page-templates.asset.php CHANGED
@@ -1 +1 @@
1
- <?php return array('dependencies' => array('lodash', 'wp-api-fetch', 'wp-block-editor', 'wp-blocks', 'wp-components', 'wp-compose', 'wp-data', 'wp-edit-post', 'wp-element', 'wp-i18n', 'wp-nux', 'wp-plugins', 'wp-polyfill', 'wp-url'), 'version' => 'f6c2eb5c4c327d51953b2e611af92dda');
1
+ <?php return array('dependencies' => array('lodash', 'wp-api-fetch', 'wp-block-editor', 'wp-blocks', 'wp-components', 'wp-compose', 'wp-data', 'wp-edit-post', 'wp-editor', 'wp-element', 'wp-hooks', 'wp-i18n', 'wp-nux', 'wp-plugins', 'wp-polyfill', 'wp-url'), 'version' => 'c5ea3a2d0a7fbc2cafc527640bc39fc8');
starter-page-templates/dist/starter-page-templates.css CHANGED
@@ -1 +1 @@
1
- .page-template-modal-screen-overlay{animation:none;background-color:transparent;z-index:99}@media screen and (min-width:783px){body:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{left:36px}}@media screen and (min-width:961px){body:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{left:160px}}@media screen and (min-width:783px){body:not(.is-fullscreen-mode).folded .page-template-modal-screen-overlay{left:36px}body:not(.is-fullscreen-mode):not(.folded):not(.auto-fold) .page-template-modal-screen-overlay{left:160px}}body.admin-bar:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{top:46px}@media screen and (min-width:783px){body.admin-bar:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{top:32px}}.page-template-modal{width:100%;height:100vh;animation:none;box-shadow:none;border:none;top:0;left:0;right:0;bottom:0;transform:none;max-width:none;max-height:none;background-color:#eee}.page-template-modal .components-modal__header-heading-container{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.page-template-modal__close-button{display:block;position:absolute;z-index:20;top:9px;width:36px;height:36px;left:10px}.page-template-modal .components-modal__header:after{display:block;position:absolute;content:" ";border-right:1px solid #e2e4e7;height:100%;left:56px}.page-template-modal .components-modal__content{overflow-y:scroll;-webkit-overflow-scrolling:touch}.page-template-modal__inner{position:relative;margin:0 auto;padding:0 20px 40px}.page-template-modal__list{margin-bottom:20px}.page-template-modal__list .components-base-control__label{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.template-selector-control__options{display:grid;grid-template-columns:1fr;grid-gap:.75em}@media screen and (min-width:660px){.template-selector-control__options{margin-top:0;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}.template-selector-item__label{display:block;width:100%;font-size:14px;text-align:center;border:2px solid #e2e4e7;border-radius:6px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;overflow:hidden;background-color:#fff;position:relative;transform:translateZ(0)}.template-selector-item__label:focus{box-shadow:0 0 0 1px #fff,0 0 0 3px #00a0d2;outline:2px solid transparent}.template-selector-item__label:hover{border:2px solid #c9c9ca}.template-selector-item__label.is-selected{border:2px solid #555d66;outline:2px solid transparent;outline-offset:-2px}.template-selector-item__label.is-selected:focus{box-shadow:0 0 0 1px #fff,0 0 0 3px #00a0d2;border:2px solid #555d66;outline:4px solid transparent;outline-offset:-4px}.template-selector-item__preview-wrap{width:100%;display:block;margin:0 auto;background:#fff;border-radius:0;overflow:hidden;height:0;padding-top:120%;box-sizing:content-box;position:relative;pointer-events:none;opacity:1;transform:translateZ(0)}@media screen and (min-width:660px){.template-selector-item__preview-wrap{padding-top:100%}}.template-selector-item__preview-wrap.is-rendering{opacity:.5}.template-selector-item__media{width:100%;display:block;position:absolute;top:0;left:0}@media screen and (min-width:660px){.page-template-modal__form{max-width:20%}}@media screen and (min-width:783px){.page-template-modal__form{max-width:30%}}.page-template-modal__form-title{font-weight:700;margin-bottom:1em;text-align:center}@media screen and (min-width:660px){.page-template-modal__form-title{text-align:left}}.page-template-modal__buttons{position:absolute;right:0;top:0;z-index:10;height:56px;display:flex;align-items:center;padding-right:24px}@media screen and (min-width:660px){.page-template-modal__buttons{display:flex}}.page-template-modal__buttons.is-visually-hidden{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.page-template-modal__buttons .components-button{height:33px;line-height:32px}.template-selector-preview{display:none;position:fixed;top:157px;bottom:24px;left:calc(20% + 48px);right:24px;background:#fff;border-radius:2px;overflow:hidden;box-shadow:0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.12),0 1px 5px 0 rgba(0,0,0,.2)}@media screen and (min-width:660px){.template-selector-preview{display:block}.template-selector-preview.is-blank-preview{align-items:center;display:flex;justify-content:center}}@media screen and (min-width:783px){.template-selector-preview{top:143px;left:calc(30% + 72px)}body:not(.auto-fold):not(.folded) .template-selector-preview{left:calc(30% + 172px)}}@media screen and (min-width:961px){.template-selector-preview{left:calc(30% + 172px)}body.folded .template-selector-preview{left:calc(30% + 72px)}}body.is-fullscreen-mode .template-selector-preview{top:111px}@media screen and (min-width:783px){body.is-fullscreen-mode .template-selector-preview{left:calc(30% + 48px)!important}}.template-selector-preview .edit-post-visual-editor{margin:0;padding:0}.template-selector-preview.not-selected .editor-styles-wrapper{position:relative;width:100%;height:100%}.template-selector-preview.not-selected .editor-styles-wrapper .template-selector-preview__empty-state{position:absolute;width:100%;text-align:center;height:50px;line-height:50px;top:50%;margin:-25px 0 0}.page-template-modal__loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:flex-end}.page-template-modal__loading .components-spinner{float:none}.sidebar-modal-opener{display:flex;flex-direction:column;align-items:center;justify-content:center}.sidebar-modal-opener .template-selector-item__label{max-width:300px}.sidebar-modal-opener__button{margin-top:20px}.sidebar-modal-opener__warning-modal{display:flex;flex-direction:column;justify-content:center;align-items:center}.sidebar-modal-opener__warning-text{max-width:300px;font-size:1rem;line-height:1.5rem}.sidebar-modal-opener__warning-options{float:right;margin-top:20px}.sidebar-modal-opener__warning-options .components-button{margin-left:12px}.block-iframe-preview{position:absolute;top:0;left:0;transform-origin:top left;text-align:initial;margin:0;overflow:visible;min-height:auto;width:1440px}.block-iframe-preview-body{margin:0;padding:0;overflow-x:hidden;overflow-y:auto}.block-iframe-preview-body>.block-editor,.block-iframe-preview-body>.block-editor>.edit-post-visual-editor{padding:0;margin:0}.block-iframe-preview-body .block-editor-inserter,.block-iframe-preview-body .block-list-appender{display:none!important;visibility:hidden;position:absolute;left:-9999vw}.block-iframe-preview-body .editor-styles-wrapper .wp-block-cover{height:auto}.block-iframe-preview-body .editor-styles-wrapper .wp-block-embed__wrapper iframe{height:auto;min-height:400px}.block-iframe-preview-body [data-type="core/paragraph"] [data-rich-text-placeholder]{display:none}.block-iframe-preview-body .swiper-wrapper{display:flex}.block-iframe-preview-body .swiper-button-next,.block-iframe-preview-body .swiper-button-prev{display:none}.block-iframe-preview-body .swiper-pagination{text-align:center}.block-iframe-preview-body .swiper-pagination-bullet{border-radius:100%}.block-iframe-preview-body .editor-styles-wrapper [data-block][data-type="core/cover"]{margin-top:0;margin-bottom:0}
1
+ .page-template-modal-screen-overlay{animation:none;background-color:transparent;z-index:99}@media screen and (min-width:783px){body:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{left:36px}}@media screen and (min-width:961px){body:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{left:160px}}@media screen and (min-width:783px){body:not(.is-fullscreen-mode).folded .page-template-modal-screen-overlay{left:36px}body:not(.is-fullscreen-mode):not(.folded):not(.auto-fold) .page-template-modal-screen-overlay{left:160px}}body.admin-bar:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{top:46px}@media screen and (min-width:783px){body.admin-bar:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{top:32px}}.page-template-modal{width:100%;height:100vh;animation:none;box-shadow:none;border:none;top:0;left:0;right:0;bottom:0;transform:none;max-width:none;max-height:none;background-color:#eee}.page-template-modal .components-modal__header-heading-container{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.page-template-modal__close-button{display:block;position:absolute;z-index:20;top:9px;width:36px;height:36px;left:10px}.page-template-modal .components-modal__header:after{display:block;position:absolute;content:" ";border-right:1px solid #e2e4e7;height:100%;left:56px}.page-template-modal .components-modal__content{overflow-y:scroll;-webkit-overflow-scrolling:touch}.page-template-modal__inner{position:relative;margin:0 auto;padding:0 20px 40px}.page-template-modal__list{margin-bottom:20px}.page-template-modal__list .components-base-control__label{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.template-selector-control__options{display:grid;grid-template-columns:1fr;grid-gap:.75em}@media screen and (min-width:660px){.template-selector-control__options{margin-top:0;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}.template-selector-item__label{display:block;width:100%;font-size:14px;text-align:center;border:2px solid #e2e4e7;border-radius:6px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;overflow:hidden;background-color:#fff;position:relative;transform:translateZ(0)}.template-selector-item__label:focus{box-shadow:0 0 0 1px #fff,0 0 0 3px #00a0d2;outline:2px solid transparent}.template-selector-item__label:hover{border:2px solid #c9c9ca}.template-selector-item__label.is-selected{border:2px solid #555d66;outline:2px solid transparent;outline-offset:-2px}.template-selector-item__label.is-selected:focus{box-shadow:0 0 0 1px #fff,0 0 0 3px #00a0d2;border:2px solid #555d66;outline:4px solid transparent;outline-offset:-4px}.template-selector-item__preview-wrap{width:100%;display:block;margin:0 auto;background:#fff;border-radius:0;overflow:hidden;height:0;padding-top:120%;box-sizing:content-box;position:relative;pointer-events:none;opacity:1;transform:translateZ(0)}@media screen and (min-width:660px){.template-selector-item__preview-wrap{padding-top:100%}}.template-selector-item__preview-wrap.is-rendering{opacity:.5}.template-selector-item__media{width:100%;display:block;position:absolute;top:0;left:0}@media screen and (min-width:660px){.page-template-modal__form{max-width:20%}}@media screen and (min-width:783px){.page-template-modal__form{max-width:30%}}.page-template-modal__form-title{font-weight:700;margin-bottom:1em;text-align:center}@media screen and (min-width:660px){.page-template-modal__form-title{text-align:left}}.page-template-modal__buttons{position:absolute;right:0;top:0;z-index:10;height:56px;display:flex;align-items:center;padding-right:24px}@media screen and (min-width:660px){.page-template-modal__buttons{display:flex}}.page-template-modal__buttons.is-visually-hidden{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.page-template-modal__buttons .components-button{height:33px;line-height:32px}.template-selector-preview{display:none;position:fixed;top:157px;bottom:24px;left:calc(20% + 48px);right:24px;background:#fff;border-radius:2px;overflow:hidden;box-shadow:0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.12),0 1px 5px 0 rgba(0,0,0,.2)}@media screen and (min-width:660px){.template-selector-preview{display:block}.template-selector-preview.is-blank-preview{align-items:center;display:flex;justify-content:center}}@media screen and (min-width:783px){.template-selector-preview{top:143px;left:calc(30% + 72px)}body:not(.auto-fold):not(.folded) .template-selector-preview{left:calc(30% + 172px)}}@media screen and (min-width:961px){.template-selector-preview{left:calc(30% + 172px)}body.folded .template-selector-preview{left:calc(30% + 72px)}}body.is-fullscreen-mode .template-selector-preview{top:111px}@media screen and (min-width:783px){body.is-fullscreen-mode .template-selector-preview{left:calc(30% + 48px)!important}}.template-selector-preview .edit-post-visual-editor{margin:0;padding:0}.template-selector-preview.not-selected .editor-styles-wrapper{position:relative;width:100%;height:100%}.template-selector-preview.not-selected .editor-styles-wrapper .template-selector-preview__empty-state{position:absolute;width:100%;text-align:center;height:50px;line-height:50px;top:50%;margin:-25px 0 0}.page-template-modal__loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;align-items:flex-end}.page-template-modal__loading .components-spinner{float:none}.sidebar-modal-opener{display:flex;flex-direction:column;align-items:center;justify-content:center}.sidebar-modal-opener .template-selector-item__label{max-width:300px}.sidebar-modal-opener__button{margin-top:20px}.sidebar-modal-opener__warning-modal{display:flex;flex-direction:column;justify-content:center;align-items:center}.sidebar-modal-opener__warning-text{max-width:300px;font-size:1rem;line-height:1.5rem}.sidebar-modal-opener__warning-options{float:right;margin-top:20px}.sidebar-modal-opener__warning-options .components-button{margin-left:12px}.block-iframe-preview{position:absolute;top:0;left:0;transform-origin:top left;text-align:initial;margin:0;overflow:visible;min-height:auto;width:1440px}.block-iframe-preview-body{margin:0;padding:0;overflow-x:hidden;overflow-y:auto}.block-iframe-preview-body>.block-editor,.block-iframe-preview-body>.block-editor>.edit-post-visual-editor{padding:0;margin:0}.block-iframe-preview-body .block-editor-inserter,.block-iframe-preview-body .block-list-appender{display:none!important;visibility:hidden;position:absolute;left:-9999vw}.block-iframe-preview-body .editor-styles-wrapper .wp-block-cover{height:auto}.block-iframe-preview-body .editor-styles-wrapper .wp-block-embed__wrapper iframe{height:auto;min-height:400px}.block-iframe-preview-body [data-type="core/paragraph"] [data-rich-text-placeholder]{display:none}.block-iframe-preview-body .swiper-wrapper{display:flex}.block-iframe-preview-body .swiper-button-next,.block-iframe-preview-body .swiper-button-prev{display:none}.block-iframe-preview-body .swiper-pagination{text-align:center}.block-iframe-preview-body .swiper-pagination-bullet{border-radius:100%}.block-iframe-preview-body .editor-styles-wrapper [data-block][data-type="core/cover"][data-align=full],.block-iframe-preview-body .editor-styles-wrapper [data-block][data-type="core/group"]{margin-top:0;margin-bottom:0}.block-iframe-preview-body .block-iframe-preview__template-title{padding-top:20px}
starter-page-templates/dist/starter-page-templates.js CHANGED
@@ -1,6 +1,6 @@
1
- !function(e,t){for(var n in t)e[n]=t[n]}(window,function(e){var t={};function n(r){if(t[r])return t[r].exports;var i=t[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}return n.m=e,n.c=t,n.d=function(e,t,r){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)n.d(r,i,function(t){return e[t]}.bind(null,i));return r},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=34)}([function(e,t){!function(){e.exports=this.wp.element}()},function(e,t){!function(){e.exports=this.lodash}()},function(e,t){!function(){e.exports=this.wp.i18n}()},function(e,t){e.exports=function(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}},function(e,t){e.exports=function(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}},function(e,t){!function(){e.exports=this.wp.components}()},function(e,t){!function(){e.exports=this.wp.data}()},function(e,t){!function(){e.exports=this.wp.compose}()},function(e,t,n){var r;
2
  /*!
3
  Copyright (c) 2017 Jed Watson.
4
  Licensed under the MIT License (MIT), see
5
  http://jedwatson.github.io/classnames
6
- */!function(){"use strict";var n={}.hasOwnProperty;function i(){for(var e=[],t=0;t<arguments.length;t++){var r=arguments[t];if(r){var o=typeof r;if("string"===o||"number"===o)e.push(r);else if(Array.isArray(r)&&r.length){var a=i.apply(null,r);a&&e.push(a)}else if("object"===o)for(var s in r)n.call(r,s)&&r[s]&&e.push(s)}}return e.join(" ")}e.exports?(i.default=i,e.exports=i):void 0===(r=function(){return i}.apply(t,[]))||(e.exports=r)}()},function(e,t,n){var r=n(3);function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}e.exports=function(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?i(Object(n),!0).forEach((function(t){r(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):i(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}},function(e,t,n){var r=n(24),i=n(25),o=n(26);e.exports=function(e){return r(e)||i(e)||o()}},function(e,t){!function(){e.exports=this.wp.blocks}()},function(e,t){e.exports=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}},function(e,t){function n(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}e.exports=function(e,t,r){return t&&n(e.prototype,t),r&&n(e,r),e}},function(e,t,n){var r=n(27),i=n(4);e.exports=function(e,t){return!t||"object"!==r(t)&&"function"!=typeof t?i(e):t}},function(e,t){function n(t){return e.exports=n=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)},n(t)}e.exports=n},function(e,t,n){var r=n(28);e.exports=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&r(e,t)}},function(e,t){!function(){e.exports=this.wp.plugins}()},function(e,t,n){var r=n(31),i=n(32),o=n(33);e.exports=function(e,t){return r(e)||i(e,t)||o()}},function(e,t){!function(){e.exports=this.wp.blockEditor}()},function(e,t){function n(e,t,n,r,i,o,a){try{var s=e[o](a),l=s.value}catch(c){return void n(c)}s.done?t(l):Promise.resolve(l).then(r,i)}e.exports=function(e){return function(){var t=this,r=arguments;return new Promise((function(i,o){var a=e.apply(t,r);function s(e){n(a,i,o,s,l,"next",e)}function l(e){n(a,i,o,s,l,"throw",e)}s(void 0)}))}}},function(e,t){!function(){e.exports=this.wp.editPost}()},function(e,t){!function(){e.exports=this.wp.apiFetch}()},function(e,t){!function(){e.exports=this.wp.url}()},function(e,t){e.exports=function(e){if(Array.isArray(e)){for(var t=0,n=new Array(e.length);t<e.length;t++)n[t]=e[t];return n}}},function(e,t){e.exports=function(e){if(Symbol.iterator in Object(e)||"[object Arguments]"===Object.prototype.toString.call(e))return Array.from(e)}},function(e,t){e.exports=function(){throw new TypeError("Invalid attempt to spread non-iterable instance")}},function(e,t){function n(t){return"function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?e.exports=n=function(e){return typeof e}:e.exports=n=function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},n(t)}e.exports=n},function(e,t){function n(t,r){return e.exports=n=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e},n(t,r)}e.exports=n},function(e,t){!function(){e.exports=this.wp.nux}()},function(e,t,n){},function(e,t){e.exports=function(e){if(Array.isArray(e))return e}},function(e,t){e.exports=function(e,t){if(Symbol.iterator in Object(e)||"[object Arguments]"===Object.prototype.toString.call(e)){var n=[],r=!0,i=!1,o=void 0;try{for(var a,s=e[Symbol.iterator]();!(r=(a=s.next()).done)&&(n.push(a.value),!t||n.length!==t);r=!0);}catch(l){i=!0,o=l}finally{try{r||null==s.return||s.return()}finally{if(i)throw o}}return n}}},function(e,t){e.exports=function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}},function(e,t,n){"use strict";n.r(t);var r=n(0),i=n(2),o=n(17),a=n(6),s=n(21),l=n(9),c=n.n(l),u=n(10),p=n.n(u),m=n(12),d=n.n(m),f=n(13),b=n.n(f),g=n(14),v=n.n(g),O=n(15),h=n.n(O),j=n(4),y=n.n(j),_=n(16),w=n.n(_),T=n(3),k=n.n(T),P=n(1),E=n(8),S=n.n(E),x=(n(29),n(7)),B=n(5),N=n(11),C=(n(30),n(18)),A=n.n(C),I=n(19),L=function(e){var t=e.blocks,n=e.settings,i=e.recomputeBlockListKey;return Object(r.createElement)(I.BlockEditorProvider,{value:t,settings:n},Object(r.createElement)(B.Disabled,{key:i},Object(r.createElement)(I.BlockList,null)))},M=Object(x.compose)(x.withSafeTimeout,Object(a.withSelect)((function(e){var t=e("core/block-editor");return{settings:t?t.getSettings():{}}})))((function(e){var t=e.className,n=void 0===t?"block-iframe-preview":t,o=e.bodyClassName,a=void 0===o?"block-iframe-preview-body":o,s=e.viewportWidth,l=e.blocks,c=e.settings,u=e.setTimeout,p=void 0===u?P.noop:u,m=Object(r.useRef)(),d=Object(r.useRef)(),f=Object(r.useRef)(),b=Object(r.useState)({transform:"scale( 1 )"}),g=A()(b,2),v=g[0],O=g[1],h=Object(r.useMemo)((function(){return Object(P.castArray)(l)}),[l]),j=Object(r.useReducer)((function(e){return e+1}),0),y=A()(j,2),_=y[0],w=y[1];Object(r.useLayoutEffect)(w,[l]);var T=Object(r.useCallback)((function(){var e=Object(P.get)(m,["current","parentNode"]);if(e){var t=s||m.current.offsetWidth,n=e.offsetWidth/s,r=e.offsetHeight/n;O({width:t,height:r,transform:"scale( ".concat(n," )")})}}),[s]);return Object(r.useEffect)((function(){p((function(){var e,t,n,r;e=window.document,t=f.current.contentDocument,n=["link","style"],r={head:new DocumentFragment,body:new DocumentFragment},Object(P.each)(Object.keys(r),(function(t){return Object(P.each)(Object(P.filter)(e[t].children,(function(e){var t=e.localName;return(n.includes(t))})),(function(e){r[t].appendChild(e.cloneNode(!0))}))})),t.head.appendChild(r.head),t.body.appendChild(r.body),f.current.contentDocument.body.classList.add(a),f.current.contentDocument.body.classList.add("editor-styles-wrapper"),T()}),0)}),[p,a,T]),Object(r.useEffect)((function(){var e=Object(P.get)(f,["current","contentDocument","body"]);e&&(e.scrollTop=0)}),[_]),Object(r.useEffect)((function(){var e=d&&d.current;e&&f.current.contentDocument.body.appendChild(e)}),[_]),Object(r.useEffect)((function(){var e=Object(P.debounce)(T,300);return window.addEventListener("resize",e),function(){window.removeEventListener("resize",e)}}),[T]),Object(r.useEffect)((function(){return window.jQuery&&window.jQuery(window.document).on("wp-collapse-menu",T),function(){window.jQuery&&window.jQuery(window.document).off("wp-collapse-menu",T)}}),[T]),Object(r.createElement)("div",{ref:m},Object(r.createElement)("iframe",{ref:f,title:Object(i.__)("Preview"),className:S()("editor-styles-wrapper",n),style:v}),Object(r.createElement)("div",{ref:d,className:"block-editor",id:"rendered-blocks"},Object(r.createElement)("div",{className:"edit-post-visual-editor"},Object(r.createElement)("div",{className:"editor-styles-wrapper"},Object(r.createElement)("div",{className:"editor-writing-flow"},l&&l.length?Object(r.createElement)(L,{blocks:h,settings:c,recomputeBlockListKey:_}):null)))))})),D=function(e){var t=e.id,n=e.value,i=e.onSelect,o=e.label,a=e.useDynamicPreview,s=void 0!==a&&a,l=e.staticPreviewImg,c=e.staticPreviewImgAlt,u=void 0===c?"":c,p=e.blocks,m=void 0===p?[]:p,d=e.isSelected;if(Object(P.isNil)(t)||Object(P.isNil)(o)||Object(P.isNil)(n))return null;if(s&&(Object(P.isNil)(m)||Object(P.isEmpty)(m)))return null;var f=s?Object(r.createElement)(B.Disabled,null,Object(r.createElement)(M,{blocks:m,viewportWidth:960})):Object(r.createElement)("img",{className:"template-selector-item__media",src:l,alt:u}),b="label-".concat(t,"-").concat(n);return Object(r.createElement)("button",{type:"button",className:S()("template-selector-item__label",{"is-selected":d}),value:n,onClick:function(){i(n)},"aria-labelledby":"".concat(t," ").concat(b)},Object(r.createElement)("span",{className:"template-selector-item__preview-wrap"},f))},F={Address:Object(i._x)("123 Main St","default address","full-site-editing"),Phone:Object(i._x)("555-555-5555","default phone number","full-site-editing"),CompanyName:Object(i._x)("Your Company Name","default company name","full-site-editing"),Vertical:Object(i._x)("Business","default vertical name","full-site-editing")},W={CompanyName:"title",Address:"address",Phone:"phone",Vertical:"vertical"},G=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return e?e.replace(/{{(\w+)}}/g,(function(e,n){var r=F[n];return t[W[n]]||r||n})):""},U=Object(x.compose)(r.memo,x.withInstanceId)((function(e){var t=e.label,n=e.className,i=e.help,o=e.instanceId,a=e.templates,s=void 0===a?[]:a,l=e.blocksByTemplates,c=void 0===l?{}:l,u=e.useDynamicPreview,p=void 0!==u&&u,m=e.onTemplateSelect,d=void 0===m?P.noop:m,f=e.siteInformation,b=void 0===f?{}:f,g=e.selectedTemplate;if(Object(P.isEmpty)(s)||!Object(P.isArray)(s))return null;if(!0===p&&Object(P.isEmpty)(c))return null;var v="template-selector-control-".concat(o);return Object(r.createElement)(B.BaseControl,{label:t,id:v,help:i,className:S()(n,"template-selector-control")},Object(r.createElement)("ul",{className:"template-selector-control__options","data-testid":"template-selector-control-options"},Object(P.map)(s,(function(e){var t=e.slug,n=e.title,o=e.preview,a=e.previewAlt;return Object(r.createElement)("li",{key:"".concat(v,"-").concat(t),className:"template-selector-control__template"},Object(r.createElement)(D,{id:v,value:t,label:G(n,b),help:i,onSelect:d,staticPreviewImg:o,staticPreviewImgAlt:a,blocks:c.hasOwnProperty(t)?c[t]:[],useDynamicPreview:p,isSelected:t===g}))}))))})),R=function(e){var t=e.blocks,n=void 0===t?[]:t,o=e.viewportWidth,a=!n.length;return Object(r.createElement)("div",{className:"template-selector-preview ".concat(a?"not-selected":"")},a&&Object(r.createElement)("div",{className:"editor-styles-wrapper"},Object(r.createElement)("div",{className:"template-selector-preview__empty-state"},Object(i.__)("Select a layout to preview.","full-site-editing"))),Object(r.createElement)(M,{blocks:n,viewportWidth:o}))};window._tkq=window._tkq||[];var q=null,z=function(e,t){q&&window._tkq.push(["recordEvent","a8c_full_site_editing_template_selector_view",{blog_id:q.blogid,segment_id:e,vertical_id:t}])},Q=function(e,t){q&&window._tkq.push(["recordEvent","a8c_full_site_editing_template_selector_dismiss",{blog_id:q.blogid,segment_id:e,vertical_id:t}])},H=function(e,t,n){q&&window._tkq.push(["recordEvent","a8c_full_site_editing_template_selector_template_selected",{blog_id:q.blogid,segment_id:e,vertical_id:t,template:n}])},V=n(20),K=n.n(V),Y=n(22),J=n.n(Y),X=n(23),Z=function(e,t,n){var r=e[t=Object(X.removeQueryArgs)(t,"w","s")]||{url:t,usages:[]};return c()({},e,k()({},t,c()({},r,{usages:[].concat(p()(r.usages),p()(n))})))},$=function e(t,n){switch(t.blocksByClientId[n.clientId]=n,n.name){case"core/cover":case"core/image":var r=n.attributes.url;r&&(t.assets=Z(t.assets,r,[{prop:"url",path:[n.clientId,"attributes","url"]},{prop:"id",path:[n.clientId,"attributes","id"]}]));case"core/media-text":var i=n.attributes.mediaUrl;i&&"image"===n.attributes.mediaType&&(t.assets=Z(t.assets,i,[{prop:"url",path:[n.clientId,"attributes","mediaUrl"]},{prop:"id",path:[n.clientId,"attributes","mediaId"]}]));case"core/gallery":Object(P.forEach)(n.attributes.images,(function(e,r){t.assets=Z(t.assets,e.url,[{prop:"url",path:[n.clientId,"attributes","images",r,"url"]},{prop:"url",path:[n.clientId,"attributes","images",r,"link"]},{prop:"id",path:[n.clientId,"attributes","images",r,"id"]},{prop:"id",path:[n.clientId,"attributes","ids",r]}])}))}return Object(P.isEmpty)(n.innerBlocks)?t:Object(P.reduce)(n.innerBlocks,e,t)},ee=function(){var e=K()(regeneratorRuntime.mark((function e(t){return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,J()({method:"POST",path:"/fse/v1/sideload/image/batch",data:{resources:Object(P.map)(t)}}).then((function(e){return Object(P.reduce)(t,(function(t,n){var r=e.shift(),i=r.id,o=r.source_url;return c()({},t,k()({},n.url,{id:i,url:o}))}),{})}));case 2:return e.abrupt("return",e.sent);case 3:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),te=function(e,t){return Object(P.forEach)(e.assets,(function(n){var r=t[n.url];r&&Object(P.forEach)(n.usages,(function(t){Object(P.set)(e.blocksByClientId,t.path,r[t.prop])}))})),e.blocks},ne=function(){var e=K()(regeneratorRuntime.mark((function e(t){var n;return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(n=Object(P.reduce)(t,$,{assets:{},blocksByClientId:{},blocks:t}),!Object(P.isEmpty)(n.assets)){e.next=3;break}return e.abrupt("return",t);case 3:return e.abrupt("return",ee(n.assets).then((function(e){return te(n,e)})));case 4:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}();var re=function e(t){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:P.identity;return t.map((function(t){return(t=n(Object(N.cloneBlock)(t))).innerBlocks&&t.innerBlocks.length&&(t.innerBlocks=e(t.innerBlocks,n)),t}))},ie=function(e){function t(){var e,n;d()(this,t);for(var o=arguments.length,a=new Array(o),s=0;s<o;s++)a[s]=arguments[s];return n=v()(this,(e=h()(t)).call.apply(e,[this].concat(a))),k()(y()(n),"state",{isLoading:!1,previewedTemplate:null,error:null,isOpen:!1}),k()(y()(n),"getTitlesByTemplateSlugs",Object(P.memoize)((function(e){return Object(P.mapValues)(Object(P.keyBy)(e,"slug"),"title")}))),k()(y()(n),"getBlocksByTemplateSlugs",Object(P.memoize)((function(e){return Object(P.reduce)(e,(function(e,t){var r=t.slug,i=t.content,o=t.title;return e[r]=i?[Object(N.createBlock)("core/heading",{content:o,align:"center",level:1})].concat(p()(Object(N.parse)(G(i,n.props.siteInformation)))):[],e}),{})}))),k()(y()(n),"getBlocksForPreview",Object(P.memoize)((function(e){var t=n.getBlocksByTemplateSlug(e);return re(t,(function(e){return"jetpack/contact-form"===e.name&&void 0!==e.attributes.hasFormSettingsSet&&(e.attributes.hasFormSettingsSet=!0),e}))}))),k()(y()(n),"getBlocksForSelection",(function(e){var t=n.getBlocksByTemplateSlug(e);return re(t,(function(e){return"core/button"===e.name&&void 0!==e.attributes.url&&(e.attributes.url="#"),e}))})),k()(y()(n),"setTemplate",(function(e){if(H(n.props.segment.id,n.props.vertical.id,e),n.props.saveTemplateChoice(e),"blank"===e)return n.props.insertTemplate("",[]),void n.setState({isOpen:!1});var t=Object(P.find)(n.props.templates,{slug:e,category:"home"}),r=n.getBlocksForSelection(e);r.shift();var i=t?null:n.getTitleByTemplateSlug(e);r&&r.length?(n.setState({error:null,isLoading:!0}),n.maybePrefetchAssets(r).then((function(e){n.state.isOpen&&(n.props.insertTemplate(i,e),n.setState({isOpen:!1}))})).catch((function(e){n.setState({isLoading:!1,error:e})}))):n.setState({isOpen:!1})})),k()(y()(n),"maybePrefetchAssets",(function(e){return n.props.shouldPrefetchAssets?ne(e):Promise.resolve(e)})),k()(y()(n),"handleConfirmation",(function(e){"string"!=typeof e&&(e=n.state.previewedTemplate),n.setTemplate(e),n.props.isPromptedFromSidebar&&n.props.toggleTemplateModal()})),k()(y()(n),"previewTemplate",(function(e){n.setState({previewedTemplate:e}),window.matchMedia("(min-width: 660px)").matches||n.handleConfirmation(e)})),k()(y()(n),"closeModal",(function(e){if(e.target.matches("button.template-selector-item__label"))return!1;Q(n.props.segment.id,n.props.vertical.id);var t=Object(P.get)(window,["calypsoifyGutenberg","closeUrl"]);window.top.location=t||"edit.php?post_type=page"})),k()(y()(n),"getTemplateGroups",(function(){return{blankTemplate:Object(P.filter)(n.props.templates,{slug:"blank"}),aboutTemplates:Object(P.filter)(n.props.templates,{category:"about"}),blogTemplates:Object(P.filter)(n.props.templates,{category:"blog"}),contactTemplates:Object(P.filter)(n.props.templates,{category:"contact"}),eventTemplates:Object(P.filter)(n.props.templates,{category:"event"}),menuTemplates:Object(P.filter)(n.props.templates,{category:"menu"}),portfolioTemplates:Object(P.filter)(n.props.templates,{category:"portfolio"}),productTemplates:Object(P.filter)(n.props.templates,{category:"product"}),servicesTemplates:Object(P.filter)(n.props.templates,{category:"services"}),teamTemplates:Object(P.filter)(n.props.templates,{category:"team"}),homepageTemplates:Object(P.sortBy)(Object(P.filter)(n.props.templates,{category:"home"}),"title")}})),k()(y()(n),"renderTemplatesList",(function(e,t){return 0===e.length?null:Object(r.createElement)("fieldset",{className:"page-template-modal__list"},Object(r.createElement)("legend",{className:"page-template-modal__form-title"},t),Object(r.createElement)(U,{label:Object(i.__)("Layout","full-site-editing"),templates:e,blocksByTemplates:n.getBlocksByTemplateSlugs(n.props.templates),onTemplateSelect:n.previewTemplate,useDynamicPreview:!1,siteInformation:n.props.siteInformation,selectedTemplate:n.state.previewedTemplate}))})),n}return w()(t,e),b()(t,[{key:"componentDidMount",value:function(){this.state.isOpen&&z(this.props.segment.id,this.props.vertical.id)}},{key:"componentDidUpdate",value:function(e,t){!t.isOpen&&this.state.isOpen&&z(this.props.segment.id,this.props.vertical.id),(this.props.isWelcomeGuideActive||this.props.areTipsEnabled)&&this.props.hideWelcomeGuide()}},{key:"getBlocksByTemplateSlug",value:function(e){return Object(P.get)(this.getBlocksByTemplateSlugs(this.props.templates),[e],[])}},{key:"getTitleByTemplateSlug",value:function(e){return Object(P.get)(this.getTitlesByTemplateSlugs(this.props.templates),[e],"")}},{key:"render",value:function(){var e=this.state,t=e.previewedTemplate,n=e.isOpen,o=e.isLoading,a=this.props.isPromptedFromSidebar;if(!n)return null;var s=this.getTemplateGroups(),l=s.blankTemplate,c=s.aboutTemplates,u=s.blogTemplates,p=s.contactTemplates,m=s.eventTemplates,d=s.menuTemplates,f=s.portfolioTemplates,b=s.productTemplates,g=s.servicesTemplates,v=s.teamTemplates,O=s.homepageTemplates;return Object(r.createElement)(B.Modal,{title:Object(i.__)("Select Page Layout","full-site-editing"),className:"page-template-modal",overlayClassName:"page-template-modal-screen-overlay",shouldCloseOnClickOutside:!1,isDismissable:!1,isDismissible:!1},a?Object(r.createElement)(B.IconButton,{className:"page-template-modal__close-button components-icon-button",onClick:this.props.toggleTemplateModal,icon:"no-alt",label:Object(i.__)("Close Layout Selector")}):Object(r.createElement)(B.IconButton,{className:"page-template-modal__close-button components-icon-button",onClick:this.closeModal,icon:"arrow-left-alt2",label:Object(i.__)("Go back")}),Object(r.createElement)("div",{className:"page-template-modal__inner"},o?Object(r.createElement)("div",{className:"page-template-modal__loading"},Object(r.createElement)(B.Spinner,null),Object(i.__)("Adding layout…","full-site-editing")):Object(r.createElement)(r.Fragment,null,Object(r.createElement)("form",{className:"page-template-modal__form"},this.props.isFrontPage&&this.renderTemplatesList(O,Object(i.__)("Home Pages","full-site-editing")),this.renderTemplatesList(l,Object(i.__)("Blank","full-site-editing")),this.renderTemplatesList(c,Object(i.__)("About Pages","full-site-editing")),this.renderTemplatesList(u,Object(i.__)("Blog Pages","full-site-editing")),this.renderTemplatesList(p,Object(i.__)("Contact Pages","full-site-editing")),this.renderTemplatesList(m,Object(i.__)("Event Pages","full-site-editing")),this.renderTemplatesList(d,Object(i.__)("Menu Pages","full-site-editing")),this.renderTemplatesList(f,Object(i.__)("Portfolio Pages","full-site-editing")),this.renderTemplatesList(b,Object(i.__)("Product Pages","full-site-editing")),this.renderTemplatesList(g,Object(i.__)("Services Pages","full-site-editing")),this.renderTemplatesList(v,Object(i.__)("Team Pages","full-site-editing")),!this.props.isFrontPage&&this.renderTemplatesList(O,Object(i.__)("Home Pages","full-site-editing"))),Object(r.createElement)(R,{blocks:this.getBlocksForPreview(t),viewportWidth:1200,title:this.getTitleByTemplateSlug(t)}))),Object(r.createElement)("div",{className:S()("page-template-modal__buttons",{"is-visually-hidden":Object(P.isEmpty)(t)||o})},Object(r.createElement)(B.Button,{isPrimary:!0,isLarge:!0,disabled:Object(P.isEmpty)(t)||o,onClick:this.handleConfirmation},Object(i.sprintf)(Object(i.__)("Use %s layout","full-site-editing"),this.getTitleByTemplateSlug(t)))))}}],[{key:"getDerivedStateFromProps",value:function(e,n){return n.previewedTemplate||Object(P.isEmpty)(e.templates)?null:{isOpen:!0,previewedTemplate:t.getDefaultSelectedTemplate(e)}}}]),t}(r.Component);k()(ie,"getDefaultSelectedTemplate",(function(e){var t=Object(P.get)(e.templates,[0,"slug"]),n=e._starter_page_template;if(!e.isFrontPage&&!n)return t;"home"===n&&(n=e.theme);var r=n||e.theme;return Object(P.find)(e.templates,{slug:r})?r:Object(P.find)(e.templates,{slug:"maywood"})?"maywood":t}));var oe,ae=Object(x.compose)(Object(a.withSelect)((function(e){var t=function(){return e("core/editor").getEditedPostAttribute("meta")},n=t();return{getMeta:t,_starter_page_template:n._starter_page_template,postContentBlock:e("core/editor").getBlocks().find((function(e){return"a8c/post-content"===e.name})),isWelcomeGuideActive:e("core/edit-post").isFeatureActive("welcomeGuide"),areTipsEnabled:!!e("core/nux")&&e("core/nux").areTipsEnabled()}})),Object(a.withDispatch)((function(e,t){var n=e("core/editor");return{saveTemplateChoice:function(e){var r=t.getMeta();n.editPost({meta:c()({},r,{_starter_page_template:e})})},insertTemplate:function(r,i){r&&n.editPost({title:r});var o=t.postContentBlock;e("core/block-editor").replaceInnerBlocks(o?o.clientId:"",i,!1)},hideWelcomeGuide:function(){t.isWelcomeGuideActive?e("core/edit-post").toggleFeature("welcomeGuide"):t.areTipsEnabled&&e("core/nux").disableTips()}}})))(ie),se=function(e){function t(){var e,n;d()(this,t);for(var r=arguments.length,i=new Array(r),o=0;o<r;o++)i[o]=arguments[o];return n=v()(this,(e=h()(t)).call.apply(e,[this].concat(i))),k()(y()(n),"state",{isTemplateModalOpen:!1,isWarningOpen:!1}),k()(y()(n),"toggleTemplateModal",(function(){n.setState({isTemplateModalOpen:!n.state.isTemplateModalOpen})})),k()(y()(n),"toggleWarningModal",(function(){n.setState({isWarningOpen:!n.state.isWarningOpen})})),k()(y()(n),"getLastTemplateUsed",(function(){var e=n.props,t=e.isFrontPage,r=e.templates,i=e.theme,o=n.props.lastTemplateUsedSlug;if(!o&&t&&(o=i),!o||"blank"===o)return r[0];var a=r.find((function(e){return e.slug===o}));return a||r[0]})),n}return w()(t,e),b()(t,[{key:"render",value:function(){var e=this.getLastTemplateUsed(),t=e.slug,n=e.title,o=e.preview,a=e.previewAlt,s=this.props,l=s.isFrontPage,c=s.templates,u=s.theme,p=s.vertical,m=s.segment,d=s.siteInformation;return Object(r.createElement)("div",{className:"sidebar-modal-opener"},Object(r.createElement)(D,{id:"sidebar-modal-opener__last-template-used-preview",value:t,label:G(n,d),staticPreviewImg:o,staticPreviewImgAlt:a,onSelect:this.toggleWarningModal}),Object(r.createElement)(B.Button,{isPrimary:!0,onClick:this.toggleWarningModal,className:"sidebar-modal-opener__button"},Object(i.__)("Change Layout")),this.state.isTemplateModalOpen&&Object(r.createElement)(ae,{shouldPrefetchAssets:!1,templates:c,theme:u,vertical:p,segment:m,toggleTemplateModal:this.toggleTemplateModal,isFrontPage:l,isPromptedFromSidebar:!0}),this.state.isWarningOpen&&Object(r.createElement)(B.Modal,{title:Object(i.__)("Overwrite Page Content?"),isDismissible:!1,onRequestClose:this.toggleWarningModal,className:"sidebar-modal-opener__warning-modal"},Object(r.createElement)("div",{className:"sidebar-modal-opener__warning-text"},Object(i.__)("Changing the page's layout will remove any customizations or edits you have already made.")),Object(r.createElement)("div",{className:"sidebar-modal-opener__warning-options"},Object(r.createElement)(B.Button,{isDefault:!0,onClick:this.toggleWarningModal},Object(i.__)("Cancel")),Object(r.createElement)(B.Button,{isPrimary:!0,onClick:this.toggleTemplateModal},Object(i.__)("Change Layout")))))}}]),t}(r.Component),le=Object(x.compose)(Object(a.withSelect)((function(e){return{lastTemplateUsedSlug:e("core/editor").getEditedPostAttribute("meta")._starter_page_template}})))(se),ce=window.starterPageTemplatesConfig,ue=ce.templates,pe=void 0===ue?[]:ue,me=ce.vertical,de=ce.segment,fe=ce.tracksUserData,be=ce.siteInformation,ge=void 0===be?{}:be,ve=ce.screenAction,Oe=ce.theme,he=ce.isFrontPage;fe&&(q=oe=fe,window._tkq.push(["identifyUser",oe.userid,oe.username])),"add"===ve&&Object(o.registerPlugin)("page-templates",{render:function(){return Object(r.createElement)(ae,{isFrontPage:he,segment:de,shouldPrefetchAssets:!1,templates:pe,theme:Oe,vertical:me})}}),Object(o.registerPlugin)("page-templates-sidebar",{render:function(){return Object(r.createElement)(s.PluginDocumentSettingPanel,{name:"Template Modal Opener",title:Object(i.__)("Page Layout"),className:"page-template-modal__sidebar",icon:"none"},Object(r.createElement)(le,{isFrontPage:he,segment:de,siteInformation:ge,templates:pe,theme:Oe,vertical:me}))}});var je=Object(a.subscribe)((function(){Object(a.select)("core/edit-post").isEditorPanelOpened("page-templates-sidebar/Template Modal Opener")||Object(a.dispatch)("core/edit-post").toggleEditorPanelOpened("page-templates-sidebar/Template Modal Opener"),je()}))}]));
1
+ !function(e,t){for(var n in t)e[n]=t[n]}(window,function(e){var t={};function n(r){if(t[r])return t[r].exports;var i=t[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}return n.m=e,n.c=t,n.d=function(e,t,r){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)n.d(r,i,function(t){return e[t]}.bind(null,i));return r},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=37)}([function(e,t){!function(){e.exports=this.wp.element}()},function(e,t){!function(){e.exports=this.lodash}()},function(e,t){!function(){e.exports=this.wp.i18n}()},function(e,t){e.exports=function(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}},function(e,t){e.exports=function(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}},function(e,t){!function(){e.exports=this.wp.components}()},function(e,t){!function(){e.exports=this.wp.data}()},function(e,t){!function(){e.exports=this.wp.compose}()},function(e,t,n){var r;
2
  /*!
3
  Copyright (c) 2017 Jed Watson.
4
  Licensed under the MIT License (MIT), see
5
  http://jedwatson.github.io/classnames
6
+ */!function(){"use strict";var n={}.hasOwnProperty;function i(){for(var e=[],t=0;t<arguments.length;t++){var r=arguments[t];if(r){var o=typeof r;if("string"===o||"number"===o)e.push(r);else if(Array.isArray(r)&&r.length){var a=i.apply(null,r);a&&e.push(a)}else if("object"===o)for(var s in r)n.call(r,s)&&r[s]&&e.push(s)}}return e.join(" ")}e.exports?(i.default=i,e.exports=i):void 0===(r=function(){return i}.apply(t,[]))||(e.exports=r)}()},function(e,t,n){var r=n(3);function i(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}e.exports=function(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?i(Object(n),!0).forEach((function(t){r(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):i(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}},function(e,t){e.exports=function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}},function(e,t){function n(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}e.exports=function(e,t,r){return t&&n(e.prototype,t),r&&n(e,r),e}},function(e,t,n){var r=n(27),i=n(4);e.exports=function(e,t){return!t||"object"!==r(t)&&"function"!=typeof t?i(e):t}},function(e,t){function n(t){return e.exports=n=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)},n(t)}e.exports=n},function(e,t,n){var r=n(28);e.exports=function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&r(e,t)}},function(e,t){!function(){e.exports=this.wp.blocks}()},function(e,t){function n(){return e.exports=n=Object.assign||function(e){for(var t=1;t<arguments.length;t++){var n=arguments[t];for(var r in n)Object.prototype.hasOwnProperty.call(n,r)&&(e[r]=n[r])}return e},n.apply(this,arguments)}e.exports=n},function(e,t){!function(){e.exports=this.wp.plugins}()},function(e,t){!function(){e.exports=this.wp.hooks}()},function(e,t,n){var r=n(31),i=n(32),o=n(33);e.exports=function(e,t){return r(e)||i(e,t)||o()}},function(e,t){!function(){e.exports=this.wp.blockEditor}()},function(e,t){function n(e,t,n,r,i,o,a){try{var s=e[o](a),l=s.value}catch(c){return void n(c)}s.done?t(l):Promise.resolve(l).then(r,i)}e.exports=function(e){return function(){var t=this,r=arguments;return new Promise((function(i,o){var a=e.apply(t,r);function s(e){n(a,i,o,s,l,"next",e)}function l(e){n(a,i,o,s,l,"throw",e)}s(void 0)}))}}},function(e,t,n){var r=n(34),i=n(35),o=n(36);e.exports=function(e){return r(e)||i(e)||o()}},function(e,t){!function(){e.exports=this.wp.editPost}()},function(e,t){!function(){e.exports=this.wp.editor}()},function(e,t){!function(){e.exports=this.wp.apiFetch}()},function(e,t){!function(){e.exports=this.wp.url}()},function(e,t){function n(t){return"function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?e.exports=n=function(e){return typeof e}:e.exports=n=function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},n(t)}e.exports=n},function(e,t){function n(t,r){return e.exports=n=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e},n(t,r)}e.exports=n},function(e,t){!function(){e.exports=this.wp.nux}()},function(e,t,n){},function(e,t){e.exports=function(e){if(Array.isArray(e))return e}},function(e,t){e.exports=function(e,t){if(Symbol.iterator in Object(e)||"[object Arguments]"===Object.prototype.toString.call(e)){var n=[],r=!0,i=!1,o=void 0;try{for(var a,s=e[Symbol.iterator]();!(r=(a=s.next()).done)&&(n.push(a.value),!t||n.length!==t);r=!0);}catch(l){i=!0,o=l}finally{try{r||null==s.return||s.return()}finally{if(i)throw o}}return n}}},function(e,t){e.exports=function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}},function(e,t){e.exports=function(e){if(Array.isArray(e)){for(var t=0,n=new Array(e.length);t<e.length;t++)n[t]=e[t];return n}}},function(e,t){e.exports=function(e){if(Symbol.iterator in Object(e)||"[object Arguments]"===Object.prototype.toString.call(e))return Array.from(e)}},function(e,t){e.exports=function(){throw new TypeError("Invalid attempt to spread non-iterable instance")}},function(e,t,n){"use strict";n.r(t);var r=n(16),i=n.n(r),o=n(0),a=n(2),s=n(17),l=n(6),c=n(23),u=n(9),p=n.n(u),m=n(10),d=n.n(m),f=n(11),b=n.n(f),g=n(12),v=n.n(g),O=n(13),h=n.n(O),j=n(4),y=n.n(j),_=n(14),w=n.n(_),T=n(3),k=n.n(T),P=n(1),E=n(8),S=n.n(E),x=(n(29),n(7)),B=n(5),C=n(15),N=n(18),I=(n(30),n(19)),A=n.n(I),M=n(20),L=n(24),D=function(e){var t=e.blocks,n=e.settings,r=e.hidePageTitle,i=e.recomputeBlockListKey;return Object(o.createElement)(M.BlockEditorProvider,{value:t,settings:n},Object(o.createElement)(B.Disabled,{key:i},!r&&Object(o.createElement)("div",{className:"block-iframe-preview__template-title"},Object(o.createElement)(L.PostTitle,null)),Object(o.createElement)(M.BlockList,null)))},F=Object(x.compose)(x.withSafeTimeout,Object(l.withSelect)((function(e){var t=e("core/block-editor");return{settings:t?t.getSettings():{}}})))((function(e){var t=e.className,n=void 0===t?"block-iframe-preview":t,r=e.bodyClassName,i=void 0===r?"block-iframe-preview-body":r,s=e.viewportWidth,l=e.blocks,c=e.settings,u=e.setTimeout,p=void 0===u?P.noop:u,m=e.title,d=Object(o.useRef)(),f=Object(o.useRef)(),b=Object(o.useRef)(),g=Object(o.useState)({transform:"scale( 1 )"}),v=A()(g,2),O=v[0],h=v[1],j=Object(o.useMemo)((function(){return Object(P.castArray)(l)}),[l]),y=Object(o.useReducer)((function(e){return e+1}),0),_=A()(y,2),w=_[0],T=_[1];Object(o.useLayoutEffect)(T,[l]);var k=Object(o.useCallback)((function(){var e=Object(P.get)(d,["current","parentNode"]);if(e){var t=s||d.current.offsetWidth,n=e.offsetWidth/s,r=e.offsetHeight/n;h({width:t,height:r,transform:"scale( ".concat(n," )")})}}),[s]);return Object(o.useEffect)((function(){if(m){var e=Object(P.get)(b,["current","contentDocument","body"]);if(e){var t=e.querySelector(".editor-post-title .editor-post-title__input");t&&(t.value=m)}}}),[w]),Object(o.useEffect)((function(){p((function(){var e,t,n,r;e=window.document,t=b.current.contentDocument,n=["link","style"],r={head:new DocumentFragment,body:new DocumentFragment},Object(P.each)(Object.keys(r),(function(t){return Object(P.each)(Object(P.filter)(e[t].children,(function(e){var t=e.localName;return(n.includes(t))})),(function(e){r[t].appendChild(e.cloneNode(!0))}))})),t.head.appendChild(r.head),t.body.appendChild(r.body),b.current.contentDocument.body.classList.add(i),b.current.contentDocument.body.classList.add("editor-styles-wrapper"),k()}),0)}),[p,i,k]),Object(o.useEffect)((function(){var e=Object(P.get)(b,["current","contentDocument","body"]);e&&(e.scrollTop=0)}),[w]),Object(o.useEffect)((function(){var e=f&&f.current;e&&b.current.contentDocument.body.appendChild(e)}),[w]),Object(o.useEffect)((function(){var e=Object(P.debounce)(k,300);return window.addEventListener("resize",e),function(){window.removeEventListener("resize",e)}}),[k]),Object(o.useEffect)((function(){return window.jQuery&&window.jQuery(window.document).on("wp-collapse-menu",k),function(){window.jQuery&&window.jQuery(window.document).off("wp-collapse-menu",k)}}),[k]),Object(o.createElement)("div",{ref:d},Object(o.createElement)("iframe",{ref:b,title:Object(a.__)("Preview"),className:S()("editor-styles-wrapper",n),style:O}),Object(o.createElement)("div",{ref:f,className:"block-editor"},Object(o.createElement)("div",{className:"edit-post-visual-editor"},Object(o.createElement)("div",{className:"editor-styles-wrapper"},Object(o.createElement)("div",{className:"editor-writing-flow"},Object(o.createElement)(D,{blocks:j,settings:c,hidePageTitle:!m,recomputeBlockListKey:w}))))))})),W=function(e){var t=e.id,n=e.value,r=e.onSelect,i=e.label,a=e.useDynamicPreview,s=void 0!==a&&a,l=e.staticPreviewImg,c=e.staticPreviewImgAlt,u=void 0===c?"":c,p=e.blocks,m=void 0===p?[]:p,d=e.isSelected;if(Object(P.isNil)(t)||Object(P.isNil)(i)||Object(P.isNil)(n))return null;if(s&&(Object(P.isNil)(m)||Object(P.isEmpty)(m)))return null;var f=s?Object(o.createElement)(B.Disabled,null,Object(o.createElement)(F,{blocks:m,viewportWidth:960})):Object(o.createElement)("img",{className:"template-selector-item__media",src:l,alt:u}),b="label-".concat(t,"-").concat(n);return Object(o.createElement)("button",{type:"button",className:S()("template-selector-item__label",{"is-selected":d}),value:n,onClick:function(){r(n)},"aria-labelledby":"".concat(t," ").concat(b)},Object(o.createElement)("span",{className:"template-selector-item__preview-wrap"},f))},G={Address:Object(a._x)("123 Main St","default address","full-site-editing"),Phone:Object(a._x)("555-555-5555","default phone number","full-site-editing"),CompanyName:Object(a._x)("Your Company Name","default company name","full-site-editing"),Vertical:Object(a._x)("Business","default vertical name","full-site-editing")},U={CompanyName:"title",Address:"address",Phone:"phone",Vertical:"vertical"},R=function(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return e?e.replace(/{{(\w+)}}/g,(function(e,n){var r=G[n];return t[U[n]]||r||n})):""},q=Object(x.compose)(o.memo,x.withInstanceId)((function(e){var t=e.label,n=e.className,r=e.help,i=e.instanceId,a=e.templates,s=void 0===a?[]:a,l=e.blocksByTemplates,c=void 0===l?{}:l,u=e.useDynamicPreview,p=void 0!==u&&u,m=e.onTemplateSelect,d=void 0===m?P.noop:m,f=e.siteInformation,b=void 0===f?{}:f,g=e.selectedTemplate;if(Object(P.isEmpty)(s)||!Object(P.isArray)(s))return null;if(!0===p&&Object(P.isEmpty)(c))return null;var v="template-selector-control-".concat(i);return Object(o.createElement)(B.BaseControl,{label:t,id:v,help:r,className:S()(n,"template-selector-control")},Object(o.createElement)("ul",{className:"template-selector-control__options","data-testid":"template-selector-control-options"},Object(P.map)(s,(function(e){var t=e.slug,n=e.title,i=e.preview,a=e.previewAlt;return Object(o.createElement)("li",{key:"".concat(v,"-").concat(t),className:"template-selector-control__template"},Object(o.createElement)(W,{id:v,value:t,label:R(n,b),help:r,onSelect:d,staticPreviewImg:i,staticPreviewImgAlt:a,blocks:c.hasOwnProperty(t)?c[t]:[],useDynamicPreview:p,isSelected:t===g}))}))))})),z=function(e){var t=e.blocks,n=void 0===t?[]:t,r=e.viewportWidth,i=e.title,s=!n.length;return Object(o.createElement)("div",{className:"template-selector-preview ".concat(s?"not-selected":"")},s&&Object(o.createElement)("div",{className:"editor-styles-wrapper"},Object(o.createElement)("div",{className:"template-selector-preview__empty-state"},Object(a.__)("Select a layout to preview.","full-site-editing"))),Object(o.createElement)(F,{blocks:n,viewportWidth:r,title:i}))};window._tkq=window._tkq||[];var V=null,Q=function(e,t){V&&window._tkq.push(["recordEvent","a8c_full_site_editing_template_selector_dismiss",{blog_id:V.blogid,segment_id:e,vertical_id:t}])},H=function(e,t,n){V&&window._tkq.push(["recordEvent","a8c_full_site_editing_template_selector_template_selected",{blog_id:V.blogid,segment_id:e,vertical_id:t,template:n}])},K=n(21),Y=n.n(K),J=n(22),X=n.n(J),Z=n(25),$=n.n(Z),ee=n(26),te=function(e,t,n){var r=e[t=Object(ee.removeQueryArgs)(t,"w","s")]||{url:t,usages:[]};return p()({},e,k()({},t,p()({},r,{usages:[].concat(X()(r.usages),X()(n))})))},ne=function e(t,n){switch(t.blocksByClientId[n.clientId]=n,n.name){case"core/cover":case"core/image":var r=n.attributes.url;r&&(t.assets=te(t.assets,r,[{prop:"url",path:[n.clientId,"attributes","url"]},{prop:"id",path:[n.clientId,"attributes","id"]}]));case"core/media-text":var i=n.attributes.mediaUrl;i&&"image"===n.attributes.mediaType&&(t.assets=te(t.assets,i,[{prop:"url",path:[n.clientId,"attributes","mediaUrl"]},{prop:"id",path:[n.clientId,"attributes","mediaId"]}]));case"core/gallery":Object(P.forEach)(n.attributes.images,(function(e,r){t.assets=te(t.assets,e.url,[{prop:"url",path:[n.clientId,"attributes","images",r,"url"]},{prop:"url",path:[n.clientId,"attributes","images",r,"link"]},{prop:"id",path:[n.clientId,"attributes","images",r,"id"]},{prop:"id",path:[n.clientId,"attributes","ids",r]}])}))}return Object(P.isEmpty)(n.innerBlocks)?t:Object(P.reduce)(n.innerBlocks,e,t)},re=function(){var e=Y()(regeneratorRuntime.mark((function e(t){return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,$()({method:"POST",path:"/fse/v1/sideload/image/batch",data:{resources:Object(P.map)(t)}}).then((function(e){return Object(P.reduce)(t,(function(t,n){var r=e.shift(),i=r.id,o=r.source_url;return p()({},t,k()({},n.url,{id:i,url:o}))}),{})}));case 2:return e.abrupt("return",e.sent);case 3:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}(),ie=function(e,t){return Object(P.forEach)(e.assets,(function(n){var r=t[n.url];r&&Object(P.forEach)(n.usages,(function(t){Object(P.set)(e.blocksByClientId,t.path,r[t.prop])}))})),e.blocks},oe=function(){var e=Y()(regeneratorRuntime.mark((function e(t){var n;return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:if(n=Object(P.reduce)(t,ne,{assets:{},blocksByClientId:{},blocks:t}),!Object(P.isEmpty)(n.assets)){e.next=3;break}return e.abrupt("return",t);case 3:return e.abrupt("return",re(n.assets).then((function(e){return ie(n,e)})));case 4:case"end":return e.stop()}}),e)})));return function(t){return e.apply(this,arguments)}}();var ae=function e(t){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:P.identity;return t.map((function(t){return(t=n(Object(C.cloneBlock)(t))).innerBlocks&&t.innerBlocks.length&&(t.innerBlocks=e(t.innerBlocks,n)),t}))},se="core/missing";var le=function e(t){return!!t.find((function(t){return t.name===se||!(!t.innerBlocks||!t.innerBlocks.length)&&e(t.innerBlocks)}))},ce=function(e){function t(){var e,n;d()(this,t);for(var r=arguments.length,i=new Array(r),s=0;s<r;s++)i[s]=arguments[s];return n=v()(this,(e=h()(t)).call.apply(e,[this].concat(i))),k()(y()(n),"state",{isLoading:!1,previewedTemplate:null,error:null,isOpen:!1}),k()(y()(n),"getTitlesByTemplateSlugs",Object(P.memoize)((function(e){return Object(P.mapValues)(Object(P.keyBy)(e,"slug"),"title")}))),k()(y()(n),"getBlocksByTemplateSlugs",Object(P.memoize)((function(e){var t=Object(P.reduce)(e,(function(e,t){var r=t.slug,i=t.content;return e[r]=i?Object(C.parse)(R(i,n.props.siteInformation)):[],e}),{});return n.filterTemplatesWithMissingBlocks(t)}))),k()(y()(n),"getBlocksForPreview",Object(P.memoize)((function(e){var t=n.getBlocksByTemplateSlug(e);return ae(t,(function(e){return"jetpack/contact-form"===e.name&&void 0!==e.attributes.hasFormSettingsSet&&(e.attributes.hasFormSettingsSet=!0),e}))}))),k()(y()(n),"getBlocksForSelection",(function(e){var t=n.getBlocksByTemplateSlug(e);return ae(t,(function(e){return"core/button"===e.name&&void 0!==e.attributes.url&&(e.attributes.url="#"),e}))})),k()(y()(n),"setTemplate",(function(e){if(H(n.props.segment.id,n.props.vertical.id,e),n.props.saveTemplateChoice(e),"blank"===e)return n.props.insertTemplate("",[]),void n.setState({isOpen:!1});var t=Object(P.find)(n.props.templates,{slug:e,category:"home"}),r=n.getBlocksForSelection(e),i=t?null:n.getTitleByTemplateSlug(e);r&&r.length?(n.setState({error:null,isLoading:!0}),n.maybePrefetchAssets(r).then((function(e){n.state.isOpen&&(n.props.insertTemplate(i,e),n.setState({isOpen:!1}))})).catch((function(e){n.setState({isLoading:!1,error:e})}))):n.setState({isOpen:!1})})),k()(y()(n),"maybePrefetchAssets",(function(e){return n.props.shouldPrefetchAssets?oe(e):Promise.resolve(e)})),k()(y()(n),"handleConfirmation",(function(e){"string"!=typeof e&&(e=n.state.previewedTemplate),n.setTemplate(e),n.props.isPromptedFromSidebar&&n.props.toggleTemplateModal()})),k()(y()(n),"previewTemplate",(function(e){n.setState({previewedTemplate:e}),window.matchMedia("(min-width: 660px)").matches||n.handleConfirmation(e)})),k()(y()(n),"closeModal",(function(e){if(e.target.matches("button.template-selector-item__label"))return!1;Q(n.props.segment.id,n.props.vertical.id);var t=Object(P.get)(window,["calypsoifyGutenberg","closeUrl"]);window.top.location=t||"edit.php?post_type=page"})),k()(y()(n),"getTemplateGroups",(function(){return{blankTemplate:Object(P.filter)(n.props.templates,{slug:"blank"}),aboutTemplates:Object(P.filter)(n.props.templates,{category:"about"}),blogTemplates:Object(P.filter)(n.props.templates,{category:"blog"}),contactTemplates:Object(P.filter)(n.props.templates,{category:"contact"}),eventTemplates:Object(P.filter)(n.props.templates,{category:"event"}),menuTemplates:Object(P.filter)(n.props.templates,{category:"menu"}),portfolioTemplates:Object(P.filter)(n.props.templates,{category:"portfolio"}),productTemplates:Object(P.filter)(n.props.templates,{category:"product"}),servicesTemplates:Object(P.filter)(n.props.templates,{category:"services"}),teamTemplates:Object(P.filter)(n.props.templates,{category:"team"}),homepageTemplates:Object(P.sortBy)(Object(P.filter)(n.props.templates,{category:"home"}),"title")}})),k()(y()(n),"renderTemplatesList",(function(e,t){if(!e.length)return null;var r,i=n.getBlocksByTemplateSlugs(n.props.templates),s=Object.keys(i),l=(r=s,e.filter((function(e){return r.includes(e.slug)})));return l.length?Object(o.createElement)("fieldset",{className:"page-template-modal__list"},Object(o.createElement)("legend",{className:"page-template-modal__form-title"},t),Object(o.createElement)(q,{label:Object(a.__)("Layout","full-site-editing"),templates:l,blocksByTemplates:i,onTemplateSelect:n.previewTemplate,useDynamicPreview:!1,siteInformation:n.props.siteInformation,selectedTemplate:n.state.previewedTemplate})):null})),n}return w()(t,e),b()(t,[{key:"filterTemplatesWithMissingBlocks",value:function(e){return Object(P.reduce)(e,(function(e,t,n){return le(t)&&t.length||(e[n]=t),e}),{})}},{key:"componentDidMount",value:function(){this.state.isOpen&&this.trackCurrentView()}},{key:"componentDidUpdate",value:function(e,t){!t.isOpen&&this.state.isOpen&&this.trackCurrentView(),(this.props.isWelcomeGuideActive||this.props.areTipsEnabled)&&this.props.hideWelcomeGuide()}},{key:"trackCurrentView",value:function(){var e,t,n;e=this.props.segment.id,t=this.props.vertical.id,n=this.props.isPromptedFromSidebar?"sidebar":"add-page",V&&window._tkq.push(["recordEvent","a8c_full_site_editing_template_selector_view",{blog_id:V.blogid,segment_id:e,vertical_id:t,source:n}])}},{key:"getBlocksByTemplateSlug",value:function(e){return Object(P.get)(this.getBlocksByTemplateSlugs(this.props.templates),[e],[])}},{key:"getTitleByTemplateSlug",value:function(e){return Object(P.get)(this.getTitlesByTemplateSlugs(this.props.templates),[e],"")}},{key:"render",value:function(){var e=this.state,t=e.previewedTemplate,n=e.isOpen,r=e.isLoading,i=this.props,s=i.isPromptedFromSidebar,l=i.hidePageTitle;if(!n)return null;var c=this.getTemplateGroups(),u=c.blankTemplate,p=c.aboutTemplates,m=c.blogTemplates,d=c.contactTemplates,f=c.eventTemplates,b=c.menuTemplates,g=c.portfolioTemplates,v=c.productTemplates,O=c.servicesTemplates,h=c.teamTemplates,j=c.homepageTemplates;return Object(o.createElement)(B.Modal,{title:Object(a.__)("Select Page Layout","full-site-editing"),className:"page-template-modal",overlayClassName:"page-template-modal-screen-overlay",shouldCloseOnClickOutside:!1,isDismissable:!1,isDismissible:!1},s?Object(o.createElement)(B.IconButton,{className:"page-template-modal__close-button components-icon-button",onClick:this.props.toggleTemplateModal,icon:"no-alt",label:Object(a.__)("Close Layout Selector")}):Object(o.createElement)(B.IconButton,{className:"page-template-modal__close-button components-icon-button",onClick:this.closeModal,icon:"arrow-left-alt2",label:Object(a.__)("Go back")}),Object(o.createElement)("div",{className:"page-template-modal__inner"},r?Object(o.createElement)("div",{className:"page-template-modal__loading"},Object(o.createElement)(B.Spinner,null),Object(a.__)("Adding layout…","full-site-editing")):Object(o.createElement)(o.Fragment,null,Object(o.createElement)("form",{className:"page-template-modal__form"},this.props.isFrontPage&&this.renderTemplatesList(j,Object(a.__)("Home Pages","full-site-editing")),this.renderTemplatesList(u,Object(a.__)("Blank","full-site-editing")),this.renderTemplatesList(p,Object(a.__)("About Pages","full-site-editing")),this.renderTemplatesList(m,Object(a.__)("Blog Pages","full-site-editing")),this.renderTemplatesList(d,Object(a.__)("Contact Pages","full-site-editing")),this.renderTemplatesList(f,Object(a.__)("Event Pages","full-site-editing")),this.renderTemplatesList(b,Object(a.__)("Menu Pages","full-site-editing")),this.renderTemplatesList(g,Object(a.__)("Portfolio Pages","full-site-editing")),this.renderTemplatesList(v,Object(a.__)("Product Pages","full-site-editing")),this.renderTemplatesList(O,Object(a.__)("Services Pages","full-site-editing")),this.renderTemplatesList(h,Object(a.__)("Team Pages","full-site-editing")),!this.props.isFrontPage&&this.renderTemplatesList(j,Object(a.__)("Home Pages","full-site-editing"))),Object(o.createElement)(z,{blocks:this.getBlocksForPreview(t),viewportWidth:1200,title:!l&&this.getTitleByTemplateSlug(t)}))),Object(o.createElement)("div",{className:S()("page-template-modal__buttons",{"is-visually-hidden":Object(P.isEmpty)(t)||r})},Object(o.createElement)(B.Button,{isPrimary:!0,isLarge:!0,disabled:Object(P.isEmpty)(t)||r,onClick:this.handleConfirmation},Object(a.sprintf)(Object(a.__)("Use %s layout","full-site-editing"),this.getTitleByTemplateSlug(t)))))}}],[{key:"getDerivedStateFromProps",value:function(e,n){return n.previewedTemplate||Object(P.isEmpty)(e.templates)?null:{isOpen:!0,previewedTemplate:t.getDefaultSelectedTemplate(e)}}}]),t}(o.Component);k()(ce,"getDefaultSelectedTemplate",(function(e){var t=Object(P.get)(e.templates,[0,"slug"]),n=e._starter_page_template;if(!e.isFrontPage&&!n)return t;"home"===n&&(n=e.theme);var r=n||e.theme;return Object(P.find)(e.templates,{slug:r})?r:Object(P.find)(e.templates,{slug:"maywood"})?"maywood":t}));var ue,pe=Object(x.compose)(Object(l.withSelect)((function(e){var t=function(){return e("core/editor").getEditedPostAttribute("meta")},n=t();return{getMeta:t,_starter_page_template:n._starter_page_template,postContentBlock:e("core/editor").getBlocks().find((function(e){return"a8c/post-content"===e.name})),isWelcomeGuideActive:e("core/edit-post").isFeatureActive("welcomeGuide"),areTipsEnabled:!!e("core/nux")&&e("core/nux").areTipsEnabled()}})),Object(l.withDispatch)((function(e,t){var n=e("core/editor");return{saveTemplateChoice:function(e){var r=t.getMeta();n.editPost({meta:p()({},r,{_starter_page_template:e})})},insertTemplate:function(r,i){Object(N.addFilter)("isInsertingPageTemplate","automattic/full-site-editing/inserting-template",P.stubTrue),r&&n.editPost({title:r});var o=t.postContentBlock;e("core/block-editor").replaceInnerBlocks(o?o.clientId:"",i,!1),Object(N.removeFilter)("isInsertingPageTemplate","automattic/full-site-editing/inserting-template")},hideWelcomeGuide:function(){t.isWelcomeGuideActive?e("core/edit-post").toggleFeature("welcomeGuide"):t.areTipsEnabled&&e("core/nux").disableTips()}}})))(ce),me=function(e){function t(){var e,n;d()(this,t);for(var r=arguments.length,i=new Array(r),o=0;o<r;o++)i[o]=arguments[o];return n=v()(this,(e=h()(t)).call.apply(e,[this].concat(i))),k()(y()(n),"state",{isTemplateModalOpen:!1,isWarningOpen:!1}),k()(y()(n),"toggleTemplateModal",(function(){n.setState({isTemplateModalOpen:!n.state.isTemplateModalOpen})})),k()(y()(n),"toggleWarningModal",(function(){n.setState({isWarningOpen:!n.state.isWarningOpen})})),k()(y()(n),"getLastTemplateUsed",(function(){var e=n.props,t=e.isFrontPage,r=e.templates,i=e.theme,o=n.props.lastTemplateUsedSlug;if(!o&&t&&(o=i),!o||"blank"===o)return r[0];var a=r.find((function(e){return e.slug===o}));return a||r[0]})),n}return w()(t,e),b()(t,[{key:"render",value:function(){var e=this.getLastTemplateUsed(),t=e.slug,n=e.title,r=e.preview,i=e.previewAlt,s=this.props,l=s.templates,c=s.theme,u=s.vertical,p=s.segment,m=s.siteInformation,d=s.hidePageTitle,f=s.isFrontPage;return Object(o.createElement)("div",{className:"sidebar-modal-opener"},Object(o.createElement)(W,{id:"sidebar-modal-opener__last-template-used-preview",value:t,label:R(n,m),staticPreviewImg:r,staticPreviewImgAlt:i,onSelect:this.toggleWarningModal}),Object(o.createElement)(B.Button,{isPrimary:!0,onClick:this.toggleWarningModal,className:"sidebar-modal-opener__button"},Object(a.__)("Change Layout")),this.state.isTemplateModalOpen&&Object(o.createElement)(pe,{shouldPrefetchAssets:!1,templates:l,theme:c,vertical:u,segment:p,toggleTemplateModal:this.toggleTemplateModal,hidePageTitle:d,isFrontPage:f,isPromptedFromSidebar:!0}),this.state.isWarningOpen&&Object(o.createElement)(B.Modal,{title:Object(a.__)("Overwrite Page Content?"),isDismissible:!1,onRequestClose:this.toggleWarningModal,className:"sidebar-modal-opener__warning-modal"},Object(o.createElement)("div",{className:"sidebar-modal-opener__warning-text"},Object(a.__)("Changing the page's layout will remove any customizations or edits you have already made.")),Object(o.createElement)("div",{className:"sidebar-modal-opener__warning-options"},Object(o.createElement)(B.Button,{isDefault:!0,onClick:this.toggleWarningModal},Object(a.__)("Cancel")),Object(o.createElement)(B.Button,{isPrimary:!0,onClick:this.toggleTemplateModal},Object(a.__)("Change Layout")))))}}]),t}(o.Component),de=Object(x.compose)(Object(l.withSelect)((function(e){return{lastTemplateUsedSlug:e("core/editor").getEditedPostAttribute("meta")._starter_page_template}})))(me),fe=window.starterPageTemplatesConfig,be=fe.templates,ge=void 0===be?[]:be,ve=fe.vertical,Oe=fe.segment,he=fe.tracksUserData,je=fe.siteInformation,ye=void 0===je?{}:je,_e=fe.screenAction,we=fe.theme,Te=fe.isFrontPage,ke=fe.hideFrontPageTitle;he&&(V=ue=he,window._tkq.push(["identifyUser",ue.userid,ue.username]));var Pe={segment:Oe,templates:ge,theme:we,vertical:ve,isFrontPage:Te,hidePageTitle:Boolean(Te&&ke)};"add"===_e&&Object(s.registerPlugin)("page-templates",{render:function(){return Object(o.createElement)(pe,i()({},Pe,{shouldPrefetchAssets:!1}))}}),Object(s.registerPlugin)("page-templates-sidebar",{render:function(){return Object(o.createElement)(c.PluginDocumentSettingPanel,{name:"Template Modal Opener",title:Object(a.__)("Page Layout"),className:"page-template-modal__sidebar",icon:"none"},Object(o.createElement)(de,i()({},Pe,{siteInformation:ye})))}});var Ee=Object(l.subscribe)((function(){Object(l.select)("core/edit-post").isEditorPanelOpened("page-templates-sidebar/Template Modal Opener")||Object(l.dispatch)("core/edit-post").toggleEditorPanelOpened("page-templates-sidebar/Template Modal Opener"),Ee()}))}]));
starter-page-templates/dist/starter-page-templates.rtl.css CHANGED
@@ -1 +1 @@
1
- .page-template-modal-screen-overlay{animation:none;background-color:transparent;z-index:99}@media screen and (min-width:783px){body:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{right:36px}}@media screen and (min-width:961px){body:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{right:160px}}@media screen and (min-width:783px){body:not(.is-fullscreen-mode).folded .page-template-modal-screen-overlay{right:36px}body:not(.is-fullscreen-mode):not(.folded):not(.auto-fold) .page-template-modal-screen-overlay{right:160px}}body.admin-bar:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{top:46px}@media screen and (min-width:783px){body.admin-bar:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{top:32px}}.page-template-modal{width:100%;height:100vh;animation:none;box-shadow:none;border:none;top:0;right:0;left:0;bottom:0;transform:none;max-width:none;max-height:none;background-color:#eee}.page-template-modal .components-modal__header-heading-container{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.page-template-modal__close-button{display:block;position:absolute;z-index:20;top:9px;width:36px;height:36px;right:10px}.page-template-modal .components-modal__header:after{display:block;position:absolute;content:" ";border-left:1px solid #e2e4e7;height:100%;right:56px}.page-template-modal .components-modal__content{overflow-y:scroll;-webkit-overflow-scrolling:touch}.page-template-modal__inner{position:relative;margin:0 auto;padding:0 20px 40px}.page-template-modal__list{margin-bottom:20px}.page-template-modal__list .components-base-control__label{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.template-selector-control__options{display:grid;grid-template-columns:1fr;grid-gap:.75em}@media screen and (min-width:660px){.template-selector-control__options{margin-top:0;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}.template-selector-item__label{display:block;width:100%;font-size:14px;text-align:center;border:2px solid #e2e4e7;border-radius:6px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;overflow:hidden;background-color:#fff;position:relative;transform:translateZ(0)}.template-selector-item__label:focus{box-shadow:0 0 0 1px #fff,0 0 0 3px #00a0d2;outline:2px solid transparent}.template-selector-item__label:hover{border:2px solid #c9c9ca}.template-selector-item__label.is-selected{border:2px solid #555d66;outline:2px solid transparent;outline-offset:-2px}.template-selector-item__label.is-selected:focus{box-shadow:0 0 0 1px #fff,0 0 0 3px #00a0d2;border:2px solid #555d66;outline:4px solid transparent;outline-offset:-4px}.template-selector-item__preview-wrap{width:100%;display:block;margin:0 auto;background:#fff;border-radius:0;overflow:hidden;height:0;padding-top:120%;box-sizing:content-box;position:relative;pointer-events:none;opacity:1;transform:translateZ(0)}@media screen and (min-width:660px){.template-selector-item__preview-wrap{padding-top:100%}}.template-selector-item__preview-wrap.is-rendering{opacity:.5}.template-selector-item__media{width:100%;display:block;position:absolute;top:0;right:0}@media screen and (min-width:660px){.page-template-modal__form{max-width:20%}}@media screen and (min-width:783px){.page-template-modal__form{max-width:30%}}.page-template-modal__form-title{font-weight:700;margin-bottom:1em;text-align:center}@media screen and (min-width:660px){.page-template-modal__form-title{text-align:right}}.page-template-modal__buttons{position:absolute;left:0;top:0;z-index:10;height:56px;display:flex;align-items:center;padding-left:24px}@media screen and (min-width:660px){.page-template-modal__buttons{display:flex}}.page-template-modal__buttons.is-visually-hidden{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.page-template-modal__buttons .components-button{height:33px;line-height:32px}.template-selector-preview{display:none;position:fixed;top:157px;bottom:24px;right:calc(20% + 48px);left:24px;background:#fff;border-radius:2px;overflow:hidden;box-shadow:0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.12),0 1px 5px 0 rgba(0,0,0,.2)}@media screen and (min-width:660px){.template-selector-preview{display:block}.template-selector-preview.is-blank-preview{align-items:center;display:flex;justify-content:center}}@media screen and (min-width:783px){.template-selector-preview{top:143px;right:calc(30% + 72px)}body:not(.auto-fold):not(.folded) .template-selector-preview{right:calc(30% + 172px)}}@media screen and (min-width:961px){.template-selector-preview{right:calc(30% + 172px)}body.folded .template-selector-preview{right:calc(30% + 72px)}}body.is-fullscreen-mode .template-selector-preview{top:111px}@media screen and (min-width:783px){body.is-fullscreen-mode .template-selector-preview{right:calc(30% + 48px)!important}}.template-selector-preview .edit-post-visual-editor{margin:0;padding:0}.template-selector-preview.not-selected .editor-styles-wrapper{position:relative;width:100%;height:100%}.template-selector-preview.not-selected .editor-styles-wrapper .template-selector-preview__empty-state{position:absolute;width:100%;text-align:center;height:50px;line-height:50px;top:50%;margin:-25px 0 0}.page-template-modal__loading{position:absolute;top:50%;right:50%;transform:translate(50%,-50%);display:flex;align-items:flex-end}.page-template-modal__loading .components-spinner{float:none}.sidebar-modal-opener{display:flex;flex-direction:column;align-items:center;justify-content:center}.sidebar-modal-opener .template-selector-item__label{max-width:300px}.sidebar-modal-opener__button{margin-top:20px}.sidebar-modal-opener__warning-modal{display:flex;flex-direction:column;justify-content:center;align-items:center}.sidebar-modal-opener__warning-text{max-width:300px;font-size:1rem;line-height:1.5rem}.sidebar-modal-opener__warning-options{float:left;margin-top:20px}.sidebar-modal-opener__warning-options .components-button{margin-right:12px}.block-iframe-preview{position:absolute;top:0;right:0;transform-origin:top right;text-align:initial;margin:0;overflow:visible;min-height:auto;width:1440px}.block-iframe-preview-body{margin:0;padding:0;overflow-x:hidden;overflow-y:auto}.block-iframe-preview-body>.block-editor,.block-iframe-preview-body>.block-editor>.edit-post-visual-editor{padding:0;margin:0}.block-iframe-preview-body .block-editor-inserter,.block-iframe-preview-body .block-list-appender{display:none!important;visibility:hidden;position:absolute;right:-9999vw}.block-iframe-preview-body .editor-styles-wrapper .wp-block-cover{height:auto}.block-iframe-preview-body .editor-styles-wrapper .wp-block-embed__wrapper iframe{height:auto;min-height:400px}.block-iframe-preview-body [data-type="core/paragraph"] [data-rich-text-placeholder]{display:none}.block-iframe-preview-body .swiper-wrapper{display:flex}.block-iframe-preview-body .swiper-button-next,.block-iframe-preview-body .swiper-button-prev{display:none}.block-iframe-preview-body .swiper-pagination{text-align:center}.block-iframe-preview-body .swiper-pagination-bullet{border-radius:100%}.block-iframe-preview-body .editor-styles-wrapper [data-block][data-type="core/cover"]{margin-top:0;margin-bottom:0}
1
+ .page-template-modal-screen-overlay{animation:none;background-color:transparent;z-index:99}@media screen and (min-width:783px){body:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{right:36px}}@media screen and (min-width:961px){body:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{right:160px}}@media screen and (min-width:783px){body:not(.is-fullscreen-mode).folded .page-template-modal-screen-overlay{right:36px}body:not(.is-fullscreen-mode):not(.folded):not(.auto-fold) .page-template-modal-screen-overlay{right:160px}}body.admin-bar:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{top:46px}@media screen and (min-width:783px){body.admin-bar:not(.is-fullscreen-mode) .page-template-modal-screen-overlay{top:32px}}.page-template-modal{width:100%;height:100vh;animation:none;box-shadow:none;border:none;top:0;right:0;left:0;bottom:0;transform:none;max-width:none;max-height:none;background-color:#eee}.page-template-modal .components-modal__header-heading-container{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.page-template-modal__close-button{display:block;position:absolute;z-index:20;top:9px;width:36px;height:36px;right:10px}.page-template-modal .components-modal__header:after{display:block;position:absolute;content:" ";border-left:1px solid #e2e4e7;height:100%;right:56px}.page-template-modal .components-modal__content{overflow-y:scroll;-webkit-overflow-scrolling:touch}.page-template-modal__inner{position:relative;margin:0 auto;padding:0 20px 40px}.page-template-modal__list{margin-bottom:20px}.page-template-modal__list .components-base-control__label{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.template-selector-control__options{display:grid;grid-template-columns:1fr;grid-gap:.75em}@media screen and (min-width:660px){.template-selector-control__options{margin-top:0;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}}.template-selector-item__label{display:block;width:100%;font-size:14px;text-align:center;border:2px solid #e2e4e7;border-radius:6px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;overflow:hidden;background-color:#fff;position:relative;transform:translateZ(0)}.template-selector-item__label:focus{box-shadow:0 0 0 1px #fff,0 0 0 3px #00a0d2;outline:2px solid transparent}.template-selector-item__label:hover{border:2px solid #c9c9ca}.template-selector-item__label.is-selected{border:2px solid #555d66;outline:2px solid transparent;outline-offset:-2px}.template-selector-item__label.is-selected:focus{box-shadow:0 0 0 1px #fff,0 0 0 3px #00a0d2;border:2px solid #555d66;outline:4px solid transparent;outline-offset:-4px}.template-selector-item__preview-wrap{width:100%;display:block;margin:0 auto;background:#fff;border-radius:0;overflow:hidden;height:0;padding-top:120%;box-sizing:content-box;position:relative;pointer-events:none;opacity:1;transform:translateZ(0)}@media screen and (min-width:660px){.template-selector-item__preview-wrap{padding-top:100%}}.template-selector-item__preview-wrap.is-rendering{opacity:.5}.template-selector-item__media{width:100%;display:block;position:absolute;top:0;right:0}@media screen and (min-width:660px){.page-template-modal__form{max-width:20%}}@media screen and (min-width:783px){.page-template-modal__form{max-width:30%}}.page-template-modal__form-title{font-weight:700;margin-bottom:1em;text-align:center}@media screen and (min-width:660px){.page-template-modal__form-title{text-align:right}}.page-template-modal__buttons{position:absolute;left:0;top:0;z-index:10;height:56px;display:flex;align-items:center;padding-left:24px}@media screen and (min-width:660px){.page-template-modal__buttons{display:flex}}.page-template-modal__buttons.is-visually-hidden{border:0;clip:rect(1px,1px,1px,1px);-webkit-clip-path:inset(50%);clip-path:inset(50%);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;word-wrap:normal!important}.page-template-modal__buttons .components-button{height:33px;line-height:32px}.template-selector-preview{display:none;position:fixed;top:157px;bottom:24px;right:calc(20% + 48px);left:24px;background:#fff;border-radius:2px;overflow:hidden;box-shadow:0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.12),0 1px 5px 0 rgba(0,0,0,.2)}@media screen and (min-width:660px){.template-selector-preview{display:block}.template-selector-preview.is-blank-preview{align-items:center;display:flex;justify-content:center}}@media screen and (min-width:783px){.template-selector-preview{top:143px;right:calc(30% + 72px)}body:not(.auto-fold):not(.folded) .template-selector-preview{right:calc(30% + 172px)}}@media screen and (min-width:961px){.template-selector-preview{right:calc(30% + 172px)}body.folded .template-selector-preview{right:calc(30% + 72px)}}body.is-fullscreen-mode .template-selector-preview{top:111px}@media screen and (min-width:783px){body.is-fullscreen-mode .template-selector-preview{right:calc(30% + 48px)!important}}.template-selector-preview .edit-post-visual-editor{margin:0;padding:0}.template-selector-preview.not-selected .editor-styles-wrapper{position:relative;width:100%;height:100%}.template-selector-preview.not-selected .editor-styles-wrapper .template-selector-preview__empty-state{position:absolute;width:100%;text-align:center;height:50px;line-height:50px;top:50%;margin:-25px 0 0}.page-template-modal__loading{position:absolute;top:50%;right:50%;transform:translate(50%,-50%);display:flex;align-items:flex-end}.page-template-modal__loading .components-spinner{float:none}.sidebar-modal-opener{display:flex;flex-direction:column;align-items:center;justify-content:center}.sidebar-modal-opener .template-selector-item__label{max-width:300px}.sidebar-modal-opener__button{margin-top:20px}.sidebar-modal-opener__warning-modal{display:flex;flex-direction:column;justify-content:center;align-items:center}.sidebar-modal-opener__warning-text{max-width:300px;font-size:1rem;line-height:1.5rem}.sidebar-modal-opener__warning-options{float:left;margin-top:20px}.sidebar-modal-opener__warning-options .components-button{margin-right:12px}.block-iframe-preview{position:absolute;top:0;right:0;transform-origin:top right;text-align:initial;margin:0;overflow:visible;min-height:auto;width:1440px}.block-iframe-preview-body{margin:0;padding:0;overflow-x:hidden;overflow-y:auto}.block-iframe-preview-body>.block-editor,.block-iframe-preview-body>.block-editor>.edit-post-visual-editor{padding:0;margin:0}.block-iframe-preview-body .block-editor-inserter,.block-iframe-preview-body .block-list-appender{display:none!important;visibility:hidden;position:absolute;right:-9999vw}.block-iframe-preview-body .editor-styles-wrapper .wp-block-cover{height:auto}.block-iframe-preview-body .editor-styles-wrapper .wp-block-embed__wrapper iframe{height:auto;min-height:400px}.block-iframe-preview-body [data-type="core/paragraph"] [data-rich-text-placeholder]{display:none}.block-iframe-preview-body .swiper-wrapper{display:flex}.block-iframe-preview-body .swiper-button-next,.block-iframe-preview-body .swiper-button-prev{display:none}.block-iframe-preview-body .swiper-pagination{text-align:center}.block-iframe-preview-body .swiper-pagination-bullet{border-radius:100%}.block-iframe-preview-body .editor-styles-wrapper [data-block][data-type="core/cover"][data-align=full],.block-iframe-preview-body .editor-styles-wrapper [data-block][data-type="core/group"]{margin-top:0;margin-bottom:0}.block-iframe-preview-body .block-iframe-preview__template-title{padding-top:20px}
starter-page-templates/index.js CHANGED
@@ -25,27 +25,28 @@ const {
25
  screenAction,
26
  theme,
27
  isFrontPage,
 
28
  } = window.starterPageTemplatesConfig;
29
 
30
  if ( tracksUserData ) {
31
  initializeWithIdentity( tracksUserData );
32
  }
33
 
 
 
 
 
 
 
 
 
 
34
  // Open plugin only if we are creating new page.
35
  if ( screenAction === 'add' ) {
36
  registerPlugin( 'page-templates', {
37
- render: () => {
38
- return (
39
- <PageTemplatesPlugin
40
- isFrontPage={ isFrontPage }
41
- segment={ segment }
42
- shouldPrefetchAssets={ false }
43
- templates={ templates }
44
- theme={ theme }
45
- vertical={ vertical }
46
- />
47
- );
48
- },
49
  } );
50
  }
51
 
@@ -60,12 +61,8 @@ registerPlugin( 'page-templates-sidebar', {
60
  icon="none"
61
  >
62
  <SidebarTemplatesPlugin
63
- isFrontPage={ isFrontPage }
64
- segment={ segment }
65
  siteInformation={ siteInformation }
66
- templates={ templates }
67
- theme={ theme }
68
- vertical={ vertical }
69
  />
70
  </PluginDocumentSettingPanel>
71
  );
25
  screenAction,
26
  theme,
27
  isFrontPage,
28
+ hideFrontPageTitle,
29
  } = window.starterPageTemplatesConfig;
30
 
31
  if ( tracksUserData ) {
32
  initializeWithIdentity( tracksUserData );
33
  }
34
 
35
+ const templatesPluginSharedProps = {
36
+ segment,
37
+ templates,
38
+ theme,
39
+ vertical,
40
+ isFrontPage,
41
+ hidePageTitle: Boolean( isFrontPage && hideFrontPageTitle ),
42
+ };
43
+
44
  // Open plugin only if we are creating new page.
45
  if ( screenAction === 'add' ) {
46
  registerPlugin( 'page-templates', {
47
+ render: () => (
48
+ <PageTemplatesPlugin { ...templatesPluginSharedProps } shouldPrefetchAssets={ false } />
49
+ ),
 
 
 
 
 
 
 
 
 
50
  } );
51
  }
52
 
61
  icon="none"
62
  >
63
  <SidebarTemplatesPlugin
64
+ { ...templatesPluginSharedProps }
 
65
  siteInformation={ siteInformation }
 
 
 
66
  />
67
  </PluginDocumentSettingPanel>
68
  );
starter-page-templates/page-template-modal/components/block-iframe-preview.js CHANGED
@@ -84,6 +84,7 @@ const BlockFramePreview = ( {
84
  blocks,
85
  settings,
86
  setTimeout = noop,
 
87
  } ) => {
88
  const frameContainerRef = useRef();
89
  const renderedBlocksRef = useRef();
@@ -121,6 +122,33 @@ const BlockFramePreview = ( {
121
  } );
122
  }, [ viewportWidth ] );
123
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
124
  // Populate iFrame styles.
125
  useEffect( () => {
126
  setTimeout( () => {
@@ -183,17 +211,16 @@ const BlockFramePreview = ( {
183
  style={ style }
184
  />
185
 
186
- <div ref={ renderedBlocksRef } className="block-editor" id="rendered-blocks">
187
  <div className="edit-post-visual-editor">
188
  <div className="editor-styles-wrapper">
189
  <div className="editor-writing-flow">
190
- { blocks && blocks.length ? (
191
- <CustomBlockPreview
192
- blocks={ renderedBlocks }
193
- settings={ settings }
194
- recomputeBlockListKey={ recomputeBlockListKey }
195
- />
196
- ) : null }
197
  </div>
198
  </div>
199
  </div>
84
  blocks,
85
  settings,
86
  setTimeout = noop,
87
+ title,
88
  } ) => {
89
  const frameContainerRef = useRef();
90
  const renderedBlocksRef = useRef();
122
  } );
123
  }, [ viewportWidth ] );
124
 
125
+ /*
126
+ * Temporarily manually set the PostTitle from DOM.
127
+ * It isn't currently possible to manually force the `<PostTitle />` component
128
+ * to render a title provided as a prop. A Core PR will rectify this (see below).
129
+ * Until then we use direct DOM manipulation to set the post title.
130
+ *
131
+ * See: https://github.com/WordPress/gutenberg/pull/20609/
132
+ */
133
+ useEffect( () => {
134
+ if ( ! title ) return;
135
+
136
+ const iframeBody = get( iframeRef, [ 'current', 'contentDocument', 'body' ] );
137
+ if ( ! iframeBody ) {
138
+ return;
139
+ }
140
+
141
+ const templateTitle = iframeBody.querySelector(
142
+ '.editor-post-title .editor-post-title__input'
143
+ );
144
+
145
+ if ( ! templateTitle ) {
146
+ return;
147
+ }
148
+
149
+ templateTitle.value = title;
150
+ }, [ recomputeBlockListKey ] );
151
+
152
  // Populate iFrame styles.
153
  useEffect( () => {
154
  setTimeout( () => {
211
  style={ style }
212
  />
213
 
214
+ <div ref={ renderedBlocksRef } className="block-editor">
215
  <div className="edit-post-visual-editor">
216
  <div className="editor-styles-wrapper">
217
  <div className="editor-writing-flow">
218
+ <CustomBlockPreview
219
+ blocks={ renderedBlocks }
220
+ settings={ settings }
221
+ hidePageTitle={ ! title }
222
+ recomputeBlockListKey={ recomputeBlockListKey }
223
+ />
 
224
  </div>
225
  </div>
226
  </div>
starter-page-templates/page-template-modal/components/block-preview.js CHANGED
@@ -11,18 +11,26 @@
11
  */
12
  import { BlockEditorProvider, BlockList } from '@wordpress/block-editor';
13
  import { Disabled } from '@wordpress/components';
 
14
 
15
  // Exists as a pass through component to simplify automatted testing of
16
  // components which need to `BlockEditorProvider`. Setting up JSDom to handle
17
  // and mock the entire Block Editor isn't useful and is difficult for testing.
18
  // Therefore this component exists to simplify mocking out the Block Editor
19
  // when under test conditions.
20
- export default function( { blocks, settings, recomputeBlockListKey } ) {
 
21
  return (
22
  <BlockEditorProvider value={ blocks } settings={ settings }>
23
  <Disabled key={ recomputeBlockListKey }>
 
 
 
 
 
24
  <BlockList />
25
  </Disabled>
26
  </BlockEditorProvider>
27
  );
 
28
  }
11
  */
12
  import { BlockEditorProvider, BlockList } from '@wordpress/block-editor';
13
  import { Disabled } from '@wordpress/components';
14
+ import { PostTitle } from '@wordpress/editor';
15
 
16
  // Exists as a pass through component to simplify automatted testing of
17
  // components which need to `BlockEditorProvider`. Setting up JSDom to handle
18
  // and mock the entire Block Editor isn't useful and is difficult for testing.
19
  // Therefore this component exists to simplify mocking out the Block Editor
20
  // when under test conditions.
21
+ export default function( { blocks, settings, hidePageTitle, recomputeBlockListKey } ) {
22
+ /* eslint-disable wpcalypso/jsx-classname-namespace */
23
  return (
24
  <BlockEditorProvider value={ blocks } settings={ settings }>
25
  <Disabled key={ recomputeBlockListKey }>
26
+ { ! hidePageTitle && (
27
+ <div className="block-iframe-preview__template-title">
28
+ <PostTitle />
29
+ </div>
30
+ ) }
31
  <BlockList />
32
  </Disabled>
33
  </BlockEditorProvider>
34
  );
35
+ /* eslint-enable wpcalypso/jsx-classname-namespace */
36
  }
starter-page-templates/page-template-modal/components/sidebar-modal-opener.js CHANGED
@@ -53,7 +53,15 @@ class SidebarModalOpener extends Component {
53
 
54
  render() {
55
  const { slug, title, preview, previewAlt } = this.getLastTemplateUsed();
56
- const { isFrontPage, templates, theme, vertical, segment, siteInformation } = this.props;
 
 
 
 
 
 
 
 
57
 
58
  return (
59
  <div className="sidebar-modal-opener">
@@ -82,6 +90,7 @@ class SidebarModalOpener extends Component {
82
  vertical={ vertical }
83
  segment={ segment }
84
  toggleTemplateModal={ this.toggleTemplateModal }
 
85
  isFrontPage={ isFrontPage }
86
  isPromptedFromSidebar
87
  />
53
 
54
  render() {
55
  const { slug, title, preview, previewAlt } = this.getLastTemplateUsed();
56
+ const {
57
+ templates,
58
+ theme,
59
+ vertical,
60
+ segment,
61
+ siteInformation,
62
+ hidePageTitle,
63
+ isFrontPage,
64
+ } = this.props;
65
 
66
  return (
67
  <div className="sidebar-modal-opener">
90
  vertical={ vertical }
91
  segment={ segment }
92
  toggleTemplateModal={ this.toggleTemplateModal }
93
+ hidePageTitle={ hidePageTitle }
94
  isFrontPage={ isFrontPage }
95
  isPromptedFromSidebar
96
  />
starter-page-templates/page-template-modal/components/template-selector-preview.js CHANGED
@@ -10,7 +10,7 @@ import { __ } from '@wordpress/i18n';
10
  */
11
  import BlockIframePreview from './block-iframe-preview';
12
 
13
- const TemplateSelectorPreview = ( { blocks = [], viewportWidth } ) => {
14
  const noBlocks = ! blocks.length;
15
  return (
16
  /* eslint-disable wpcalypso/jsx-classname-namespace */
@@ -26,7 +26,7 @@ const TemplateSelectorPreview = ( { blocks = [], viewportWidth } ) => {
26
  { /* Always render preview iframe to ensure it's ready to populate with Blocks. */
27
  /* Without this some browsers will experience a noticavle delay
28
  /* before Blocks are populated into the iframe. */ }
29
- <BlockIframePreview blocks={ blocks } viewportWidth={ viewportWidth } />
30
  </div>
31
  /* eslint-enable wpcalypso/jsx-classname-namespace */
32
  );
10
  */
11
  import BlockIframePreview from './block-iframe-preview';
12
 
13
+ const TemplateSelectorPreview = ( { blocks = [], viewportWidth, title } ) => {
14
  const noBlocks = ! blocks.length;
15
  return (
16
  /* eslint-disable wpcalypso/jsx-classname-namespace */
26
  { /* Always render preview iframe to ensure it's ready to populate with Blocks. */
27
  /* Without this some browsers will experience a noticavle delay
28
  /* before Blocks are populated into the iframe. */ }
29
+ <BlockIframePreview blocks={ blocks } viewportWidth={ viewportWidth } title={ title } />
30
  </div>
31
  /* eslint-enable wpcalypso/jsx-classname-namespace */
32
  );
starter-page-templates/page-template-modal/index.js CHANGED
@@ -2,7 +2,18 @@
2
  /**
3
  * External dependencies
4
  */
5
- import { find, isEmpty, reduce, get, keyBy, mapValues, memoize, filter, sortBy } from 'lodash';
 
 
 
 
 
 
 
 
 
 
 
6
  import classnames from 'classnames';
7
  import '@wordpress/nux';
8
  import { __, sprintf } from '@wordpress/i18n';
@@ -10,7 +21,8 @@ import { compose } from '@wordpress/compose';
10
  import { Button, Modal, Spinner, IconButton } from '@wordpress/components';
11
  import { withDispatch, withSelect } from '@wordpress/data';
12
  import { Component } from '@wordpress/element';
13
- import { parse as parseBlocks, createBlock } from '@wordpress/blocks';
 
14
 
15
  /**
16
  * Internal dependencies
@@ -22,9 +34,12 @@ import { trackDismiss, trackSelection, trackView } from './utils/tracking';
22
  import replacePlaceholders from './utils/replace-placeholders';
23
  import ensureAssets from './utils/ensure-assets';
24
  import mapBlocksRecursively from './utils/map-blocks-recursively';
 
25
  /* eslint-enable import/no-extraneous-dependencies */
26
 
27
  const DEFAULT_HOMEPAGE_TEMPLATE = 'maywood';
 
 
28
 
29
  class PageTemplateModal extends Component {
30
  state = {
@@ -40,30 +55,41 @@ class PageTemplateModal extends Component {
40
  );
41
 
42
  // Parse templates blocks and memoize them.
43
- getBlocksByTemplateSlugs = memoize( templates =>
44
- reduce(
45
  templates,
46
- ( prev, { slug, content, title } ) => {
47
  prev[ slug ] = content
48
- ? [
49
- /*
50
- * Let's add the page title as a heading block.
51
- * It will be remove when inserting the template
52
- * blocks into the editor.
53
- */
54
- createBlock( 'core/heading', {
55
- content: title,
56
- align: 'center',
57
- level: 1,
58
- } ),
59
- ...parseBlocks( replacePlaceholders( content, this.props.siteInformation ) ),
60
- ]
61
  : [];
62
  return prev;
63
  },
64
  {}
65
- )
66
- );
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
67
 
68
  getBlocksForPreview = memoize( previewedTemplate => {
69
  const blocks = this.getBlocksByTemplateSlug( previewedTemplate );
@@ -116,7 +142,7 @@ class PageTemplateModal extends Component {
116
 
117
  componentDidMount() {
118
  if ( this.state.isOpen ) {
119
- trackView( this.props.segment.id, this.props.vertical.id );
120
  }
121
  }
122
 
@@ -124,7 +150,7 @@ class PageTemplateModal extends Component {
124
  // Only track when the modal is first displayed
125
  // and if it didn't already happen during componentDidMount.
126
  if ( ! prevState.isOpen && this.state.isOpen ) {
127
- trackView( this.props.segment.id, this.props.vertical.id );
128
  }
129
 
130
  // Disable welcome guide right away as it collides with the modal window.
@@ -133,11 +159,19 @@ class PageTemplateModal extends Component {
133
  }
134
  }
135
 
 
 
 
 
 
 
 
 
136
  static getDefaultSelectedTemplate = props => {
137
  const blankTemplate = get( props.templates, [ 0, 'slug' ] );
138
  let previouslyChosenTemplate = props._starter_page_template;
139
 
140
- // Usally the "new page" case.
141
  if ( ! props.isFrontPage && ! previouslyChosenTemplate ) {
142
  return blankTemplate;
143
  }
@@ -175,9 +209,6 @@ class PageTemplateModal extends Component {
175
  // Load content.
176
  const blocks = this.getBlocksForSelection( slug );
177
 
178
- // Let's pull the title before to insert blocks in the editor.
179
- blocks.shift();
180
-
181
  // Only overwrite the page title if the template is not one of the Homepage Layouts
182
  const title = isHomepageTemplate ? null : this.getTitleByTemplateSlug( slug );
183
 
@@ -285,7 +316,28 @@ class PageTemplateModal extends Component {
285
  };
286
 
287
  renderTemplatesList = ( templatesList, legendLabel ) => {
288
- if ( 0 === templatesList.length ) {
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
289
  return null;
290
  }
291
 
@@ -294,8 +346,8 @@ class PageTemplateModal extends Component {
294
  <legend className="page-template-modal__form-title">{ legendLabel }</legend>
295
  <TemplateSelectorControl
296
  label={ __( 'Layout', 'full-site-editing' ) }
297
- templates={ templatesList }
298
- blocksByTemplates={ this.getBlocksByTemplateSlugs( this.props.templates ) }
299
  onTemplateSelect={ this.previewTemplate }
300
  useDynamicPreview={ false }
301
  siteInformation={ this.props.siteInformation }
@@ -307,7 +359,7 @@ class PageTemplateModal extends Component {
307
 
308
  render() {
309
  const { previewedTemplate, isOpen, isLoading } = this.state;
310
- const { isPromptedFromSidebar } = this.props;
311
 
312
  if ( ! isOpen ) {
313
  return null;
@@ -424,7 +476,7 @@ class PageTemplateModal extends Component {
424
  <TemplateSelectorPreview
425
  blocks={ this.getBlocksForPreview( previewedTemplate ) }
426
  viewportWidth={ 1200 }
427
- title={ this.getTitleByTemplateSlug( previewedTemplate ) }
428
  />
429
  </>
430
  ) }
@@ -479,6 +531,9 @@ export const PageTemplatesPlugin = compose(
479
  } );
480
  },
481
  insertTemplate: ( title, blocks ) => {
 
 
 
482
  // Set post title.
483
  if ( title ) {
484
  editorDispatcher.editPost( { title } );
@@ -491,6 +546,9 @@ export const PageTemplatesPlugin = compose(
491
  blocks,
492
  false
493
  );
 
 
 
494
  },
495
  hideWelcomeGuide: () => {
496
  if ( ownProps.isWelcomeGuideActive ) {
2
  /**
3
  * External dependencies
4
  */
5
+ import {
6
+ find,
7
+ isEmpty,
8
+ reduce,
9
+ get,
10
+ keyBy,
11
+ mapValues,
12
+ memoize,
13
+ filter,
14
+ sortBy,
15
+ stubTrue,
16
+ } from 'lodash';
17
  import classnames from 'classnames';
18
  import '@wordpress/nux';
19
  import { __, sprintf } from '@wordpress/i18n';
21
  import { Button, Modal, Spinner, IconButton } from '@wordpress/components';
22
  import { withDispatch, withSelect } from '@wordpress/data';
23
  import { Component } from '@wordpress/element';
24
+ import { parse as parseBlocks } from '@wordpress/blocks';
25
+ import { addFilter, removeFilter } from '@wordpress/hooks';
26
 
27
  /**
28
  * Internal dependencies
34
  import replacePlaceholders from './utils/replace-placeholders';
35
  import ensureAssets from './utils/ensure-assets';
36
  import mapBlocksRecursively from './utils/map-blocks-recursively';
37
+ import containsMissingBlock from './utils/contains-missing-block';
38
  /* eslint-enable import/no-extraneous-dependencies */
39
 
40
  const DEFAULT_HOMEPAGE_TEMPLATE = 'maywood';
41
+ const INSERTING_HOOK_NAME = 'isInsertingPageTemplate';
42
+ const INSERTING_HOOK_NAMESPACE = 'automattic/full-site-editing/inserting-template';
43
 
44
  class PageTemplateModal extends Component {
45
  state = {
55
  );
56
 
57
  // Parse templates blocks and memoize them.
58
+ getBlocksByTemplateSlugs = memoize( templates => {
59
+ const blocksByTemplateSlugs = reduce(
60
  templates,
61
+ ( prev, { slug, content } ) => {
62
  prev[ slug ] = content
63
+ ? parseBlocks( replacePlaceholders( content, this.props.siteInformation ) )
 
 
 
 
 
 
 
 
 
 
 
 
64
  : [];
65
  return prev;
66
  },
67
  {}
68
+ );
69
+
70
+ // Remove templates that include a missing block
71
+ return this.filterTemplatesWithMissingBlocks( blocksByTemplateSlugs );
72
+ } );
73
+
74
+ filterTemplatesWithMissingBlocks( templates ) {
75
+ return reduce(
76
+ templates,
77
+ ( acc, templateBlocks, slug ) => {
78
+ // Does the template contain any missing blocks?
79
+ const templateHasMissingBlocks = containsMissingBlock( templateBlocks );
80
+
81
+ // Only retain the template in the collection if:
82
+ // 1. It does not contain any missing blocks
83
+ // 2. There are no blocks at all (likely the "blank" template placeholder)
84
+ if ( ! templateHasMissingBlocks || ! templateBlocks.length ) {
85
+ acc[ slug ] = templateBlocks;
86
+ }
87
+
88
+ return acc;
89
+ },
90
+ {}
91
+ );
92
+ }
93
 
94
  getBlocksForPreview = memoize( previewedTemplate => {
95
  const blocks = this.getBlocksByTemplateSlug( previewedTemplate );
142
 
143
  componentDidMount() {
144
  if ( this.state.isOpen ) {
145
+ this.trackCurrentView();
146
  }
147
  }
148
 
150
  // Only track when the modal is first displayed
151
  // and if it didn't already happen during componentDidMount.
152
  if ( ! prevState.isOpen && this.state.isOpen ) {
153
+ this.trackCurrentView();
154
  }
155
 
156
  // Disable welcome guide right away as it collides with the modal window.
159
  }
160
  }
161
 
162
+ trackCurrentView() {
163
+ trackView(
164
+ this.props.segment.id,
165
+ this.props.vertical.id,
166
+ this.props.isPromptedFromSidebar ? 'sidebar' : 'add-page'
167
+ );
168
+ }
169
+
170
  static getDefaultSelectedTemplate = props => {
171
  const blankTemplate = get( props.templates, [ 0, 'slug' ] );
172
  let previouslyChosenTemplate = props._starter_page_template;
173
 
174
+ // Usally the "new page" case
175
  if ( ! props.isFrontPage && ! previouslyChosenTemplate ) {
176
  return blankTemplate;
177
  }
209
  // Load content.
210
  const blocks = this.getBlocksForSelection( slug );
211
 
 
 
 
212
  // Only overwrite the page title if the template is not one of the Homepage Layouts
213
  const title = isHomepageTemplate ? null : this.getTitleByTemplateSlug( slug );
214
 
316
  };
317
 
318
  renderTemplatesList = ( templatesList, legendLabel ) => {
319
+ if ( ! templatesList.length ) {
320
+ return null;
321
+ }
322
+
323
+ // The raw `templates` prop is not filtered to remove Templates that
324
+ // contain missing Blocks. Therefore we compare with the keys of the
325
+ // filtered templates from `getBlocksByTemplateSlugs()` and filter this
326
+ // list to match. This ensures that the list of Template thumbnails is
327
+ // filtered so that it does not include Templates that have missing Blocks.
328
+ const blocksByTemplateSlug = this.getBlocksByTemplateSlugs( this.props.templates );
329
+ const templatesWithoutMissingBlocks = Object.keys( blocksByTemplateSlug );
330
+
331
+ const filterOutTemplatesWithMissingBlocks = ( templatesToFilter, filterIn ) => {
332
+ return templatesToFilter.filter( template => filterIn.includes( template.slug ) );
333
+ };
334
+
335
+ const filteredTemplatesList = filterOutTemplatesWithMissingBlocks(
336
+ templatesList,
337
+ templatesWithoutMissingBlocks
338
+ );
339
+
340
+ if ( ! filteredTemplatesList.length ) {
341
  return null;
342
  }
343
 
346
  <legend className="page-template-modal__form-title">{ legendLabel }</legend>
347
  <TemplateSelectorControl
348
  label={ __( 'Layout', 'full-site-editing' ) }
349
+ templates={ filteredTemplatesList }
350
+ blocksByTemplates={ blocksByTemplateSlug }
351
  onTemplateSelect={ this.previewTemplate }
352
  useDynamicPreview={ false }
353
  siteInformation={ this.props.siteInformation }
359
 
360
  render() {
361
  const { previewedTemplate, isOpen, isLoading } = this.state;
362
+ const { isPromptedFromSidebar, hidePageTitle } = this.props;
363
 
364
  if ( ! isOpen ) {
365
  return null;
476
  <TemplateSelectorPreview
477
  blocks={ this.getBlocksForPreview( previewedTemplate ) }
478
  viewportWidth={ 1200 }
479
+ title={ ! hidePageTitle && this.getTitleByTemplateSlug( previewedTemplate ) }
480
  />
481
  </>
482
  ) }
531
  } );
532
  },
533
  insertTemplate: ( title, blocks ) => {
534
+ // Add filter to let the tracking library know we are inserting a template.
535
+ addFilter( INSERTING_HOOK_NAME, INSERTING_HOOK_NAMESPACE, stubTrue );
536
+
537
  // Set post title.
538
  if ( title ) {
539
  editorDispatcher.editPost( { title } );
546
  blocks,
547
  false
548
  );
549
+
550
+ // Remove filter.
551
+ removeFilter( INSERTING_HOOK_NAME, INSERTING_HOOK_NAMESPACE );
552
  },
553
  hideWelcomeGuide: () => {
554
  if ( ownProps.isWelcomeGuideActive ) {
starter-page-templates/page-template-modal/styles/starter-page-templates-editor.scss CHANGED
@@ -466,10 +466,17 @@ body.admin-bar:not( .is-fullscreen-mode ) .page-template-modal-screen-overlay {
466
  border-radius: 100%;
467
  }
468
 
469
- // Fixes cover image spacing
470
- .editor-styles-wrapper [data-block][data-type='core/cover'] {
471
- margin-top: 0;
472
- margin-bottom: 0;
 
 
 
473
  }
474
 
 
 
 
 
475
  }
466
  border-radius: 100%;
467
  }
468
 
469
+ // Fixes cover image spacing and full-width group spacing
470
+ .editor-styles-wrapper [data-block] {
471
+ &[data-type='core/group'],
472
+ &[data-type='core/cover'][data-align='full'] {
473
+ margin-top: 0;
474
+ margin-bottom: 0;
475
+ }
476
  }
477
 
478
+ // Tweak template title (post-title) component.
479
+ .block-iframe-preview__template-title {
480
+ padding-top: 20px;
481
+ }
482
  }
starter-page-templates/page-template-modal/utils/contains-missing-block.js ADDED
@@ -0,0 +1,28 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ // Once parsed, missing Blocks have a name prop of `core/missing`.
2
+ // see: https://github.com/WordPress/gutenberg/tree/742dbf2ef0e37481a3c14c29f3688aa0cd3cf887/packages/block-library/src/missing
3
+ const MISSING_BLOCK_NAME = 'core/missing';
4
+
5
+ /**
6
+ * Determines whether the provided collection of Blocks contains any "missing"
7
+ * blocks as determined by the presence of the `core/missing` block type.
8
+ *
9
+ * @param {Array} blocks the collection of block objects to check for "missing" block .
10
+ * @returns {boolean} whether the collection blocks contains any missing blocks.
11
+ */
12
+ function containsMissingBlock( blocks ) {
13
+ return !! blocks.find( block => {
14
+ // If we found a missing block the bale out immediately
15
+ if ( block.name === MISSING_BLOCK_NAME ) {
16
+ return true;
17
+ }
18
+
19
+ // If there are innerblocks then recurse down into them...
20
+ if ( block.innerBlocks && block.innerBlocks.length ) {
21
+ return containsMissingBlock( block.innerBlocks );
22
+ }
23
+
24
+ return false;
25
+ } );
26
+ }
27
+
28
+ export default containsMissingBlock;
starter-page-templates/page-template-modal/utils/tracking.js CHANGED
@@ -6,13 +6,27 @@ let tracksIdentity = null;
6
  /**
7
  * Populate `identity` on WPCOM and ATOMIC to enable tracking.
8
  * Always disabled for regular self-hosted installations.
 
 
 
 
 
 
9
  */
10
  export const initializeWithIdentity = identity => {
11
  tracksIdentity = identity;
12
  window._tkq.push( [ 'identifyUser', identity.userid, identity.username ] );
13
  };
14
 
15
- export const trackView = ( segment_id, vertical_id ) => {
 
 
 
 
 
 
 
 
16
  if ( ! tracksIdentity ) {
17
  return;
18
  }
@@ -23,10 +37,18 @@ export const trackView = ( segment_id, vertical_id ) => {
23
  blog_id: tracksIdentity.blogid,
24
  segment_id,
25
  vertical_id,
 
26
  },
27
  ] );
28
  };
29
 
 
 
 
 
 
 
 
30
  export const trackDismiss = ( segment_id, vertical_id ) => {
31
  if ( ! tracksIdentity ) {
32
  return;
@@ -42,6 +64,14 @@ export const trackDismiss = ( segment_id, vertical_id ) => {
42
  ] );
43
  };
44
 
 
 
 
 
 
 
 
 
45
  export const trackSelection = ( segment_id, vertical_id, template ) => {
46
  if ( ! tracksIdentity ) {
47
  return;
6
  /**
7
  * Populate `identity` on WPCOM and ATOMIC to enable tracking.
8
  * Always disabled for regular self-hosted installations.
9
+ *
10
+ * @param {object} identity Info about identity.
11
+ * @param {number} identity.userid User ID.
12
+ * @param {string} identity.username Username.
13
+ * @param {number} identity.blogid Blog ID.
14
+ * @returns {void}
15
  */
16
  export const initializeWithIdentity = identity => {
17
  tracksIdentity = identity;
18
  window._tkq.push( [ 'identifyUser', identity.userid, identity.username ] );
19
  };
20
 
21
+ /**
22
+ * Track a view of the layout selector.
23
+ *
24
+ * @param {string} segment_id Segment ID.
25
+ * @param {string} vertical_id Vertical ID.
26
+ * @param {string} source Source triggering the view.
27
+ * @returns {void}
28
+ */
29
+ export const trackView = ( segment_id, vertical_id, source ) => {
30
  if ( ! tracksIdentity ) {
31
  return;
32
  }
37
  blog_id: tracksIdentity.blogid,
38
  segment_id,
39
  vertical_id,
40
+ source,
41
  },
42
  ] );
43
  };
44
 
45
+ /**
46
+ * Track closing of the layout selector.
47
+ *
48
+ * @param {string} segment_id Segment ID.
49
+ * @param {string} vertical_id Vertical ID.
50
+ * @returns {void}
51
+ */
52
  export const trackDismiss = ( segment_id, vertical_id ) => {
53
  if ( ! tracksIdentity ) {
54
  return;
64
  ] );
65
  };
66
 
67
+ /**
68
+ * Track layout selection.
69
+ *
70
+ * @param {string} segment_id Segment ID.
71
+ * @param {string} vertical_id Vertical ID.
72
+ * @param {string} template Template slug.
73
+ * @returns {void}
74
+ */
75
  export const trackSelection = ( segment_id, vertical_id, template ) => {
76
  if ( ! tracksIdentity ) {
77
  return;
wpcom-block-editor-nux/dist/wpcom-block-editor-nux.asset.php CHANGED
@@ -1 +1 @@
1
- <?php return array('dependencies' => array('wp-api-fetch', 'wp-components', 'wp-data', 'wp-element', 'wp-i18n', 'wp-nux', 'wp-plugins', 'wp-polyfill'), 'version' => 'cb5a85e4f3ad4ba8feb76c64518a48bc');
1
+ <?php return array('dependencies' => array('wp-api-fetch', 'wp-components', 'wp-data', 'wp-element', 'wp-i18n', 'wp-nux', 'wp-plugins', 'wp-polyfill'), 'version' => 'cbfb1b8612cd468daf70c2f561e00f29');
wpcom-block-editor-nux/dist/wpcom-block-editor-nux.js CHANGED
@@ -1 +1 @@
1
- !function(e,t){for(var n in t)e[n]=t[n]}(window,function(e){var t={};function n(r){if(t[r])return t[r].exports;var c=t[r]={i:r,l:!1,exports:{}};return e[r].call(c.exports,c,c.exports,n),c.l=!0,c.exports}return n.m=e,n.c=t,n.d=function(e,t,r){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:r})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var c in e)n.d(r,c,function(t){return e[t]}.bind(null,c));return r},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=10)}([function(e,t){!function(){e.exports=this.wp.data}()},function(e,t){!function(){e.exports=this.wp.element}()},function(e,t){!function(){e.exports=this.wp.i18n}()},function(e,t){!function(){e.exports=this.wp.components}()},function(e,t){!function(){e.exports=this.wp.apiFetch}()},function(e,t,n){var r=n(8);function c(e,t){var n=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),n.push.apply(n,r)}return n}e.exports=function(e){for(var t=1;t<arguments.length;t++){var n=null!=arguments[t]?arguments[t]:{};t%2?c(Object(n),!0).forEach((function(t){r(e,t,n[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(n)):c(Object(n)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(n,t))}))}return e}},function(e,t){function n(e,t,n,r,c,o,i){try{var a=e[o](i),u=a.value}catch(s){return void n(s)}a.done?t(u):Promise.resolve(u).then(r,c)}e.exports=function(e){return function(){var t=this,r=arguments;return new Promise((function(c,o){var i=e.apply(t,r);function a(e){n(i,c,o,a,u,"next",e)}function u(e){n(i,c,o,a,u,"throw",e)}a(void 0)}))}}},function(e,t){!function(){e.exports=this.wp.plugins}()},function(e,t){e.exports=function(e,t,n){return t in e?Object.defineProperty(e,t,{value:n,enumerable:!0,configurable:!0,writable:!0}):e[t]=n,e}},function(e,t){!function(){e.exports=this.wp.nux}()},function(e,t,n){"use strict";n.r(t);var r=n(5),c=n.n(r),o=n(4),i=n.n(o),a=n(0),u={setWpcomNuxStatus:function(e){var t=e.isNuxEnabled;return e.bypassApi||i()({path:"/wpcom/v2/block-editor/nux",method:"POST",data:{isNuxEnabled:t}}),{type:"WPCOM_BLOCK_EDITOR_NUX_SET_STATUS",isNuxEnabled:t}}};Object(a.registerStore)("automattic/nux",{reducer:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=arguments.length>1?arguments[1]:void 0,n=t.type,r=t.isNuxEnabled;return"WPCOM_BLOCK_EDITOR_NUX_SET_STATUS"===n?c()({},e,{isNuxEnabled:r}):e},actions:u,selectors:{isWpcomNuxEnabled:function(e){return e.isNuxEnabled}},persist:!0});n(9);var s=Object(a.subscribe)((function(){Object(a.dispatch)("core/nux").disableTips(),Object(a.select)("core/edit-post").isFeatureActive("welcomeGuide")&&Object(a.dispatch)("core/edit-post").toggleFeature("welcomeGuide"),s()}));Object(a.subscribe)((function(){Object(a.select)("core/nux").areTipsEnabled()&&(Object(a.dispatch)("core/nux").disableTips(),Object(a.dispatch)("automattic/nux").setWpcomNuxStatus({isNuxEnabled:!0})),Object(a.select)("core/edit-post").isFeatureActive("welcomeGuide")&&(Object(a.dispatch)("core/edit-post").toggleFeature("welcomeGuide"),Object(a.dispatch)("automattic/nux").setWpcomNuxStatus({isNuxEnabled:!0}))}));var l=n(6),d=n.n(l),p=n(1),b=n(3),f=n(2),m=n(7);function h(){var e=Object(a.useSelect)((function(e){return e("automattic/nux").isWpcomNuxEnabled()})),t=Object(a.useDispatch)("automattic/nux").setWpcomNuxStatus;if(Object(p.useEffect)((function(){void 0===e&&function(){var e=d()(regeneratorRuntime.mark((function e(){var n;return regeneratorRuntime.wrap((function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,i()({path:"/wpcom/v2/block-editor/nux"});case 2:n=e.sent,t({isNuxEnabled:n.is_nux_enabled,bypassApi:!0});case 4:case"end":return e.stop()}}),e)})));return function(){return e.apply(this,arguments)}}()()}),[e,t]),!e)return null;return Object(p.createElement)(b.Guide,{className:"edit-post-welcome-guide",finishButtonText:Object(f.__)("Get started"),onFinish:function(){return t({isNuxEnabled:!1})}},Object(p.createElement)(b.GuidePage,{className:"edit-post-welcome-guide__page"},Object(p.createElement)("h1",{className:"edit-post-welcome-guide__heading"},Object(f.__)("Welcome to the Block Editor")),Object(p.createElement)("p",{className:"edit-post-welcome-guide__text"},Object(f.__)("In the WordPress editor, each paragraph, image, or video is presented as a distinct “block” of content."))),Object(p.createElement)(b.GuidePage,{className:"edit-post-welcome-guide__page"},Object(p.createElement)("h1",{className:"edit-post-welcome-guide__heading"},Object(f.__)("Make each block your own")),Object(p.createElement)("p",{className:"edit-post-welcome-guide__text"},Object(f.__)("Each block comes with its own set of controls for changing things like color, width, and alignment. These will show and hide automatically when you have a block selected."))),Object(p.createElement)(b.GuidePage,{className:"edit-post-welcome-guide__page"},Object(p.createElement)("h1",{className:"edit-post-welcome-guide__heading"},Object(f.__)("Get to know the Block Library")),Object(p.createElement)("p",{className:"edit-post-welcome-guide__text"},Object(p.__experimentalCreateInterpolateElement)(Object(f.__)("All of the blocks available to you live in the Block Library. You’ll find it wherever you see the <InserterIconImage /> icon."),{InserterIconImage:Object(p.createElement)("img",{alt:Object(f.__)("inserter"),src:"data:image/svg+xml;charset=utf8,%3Csvg width='18' height='18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M8.824 0C3.97 0 0 3.97 0 8.824c0 4.853 3.97 8.824 8.824 8.824 4.853 0 8.824-3.971 8.824-8.824S13.677 0 8.824 0zM7.94 5.294v2.647H5.294v1.765h2.647v2.647h1.765V9.706h2.647V7.941H9.706V5.294H7.941zm-6.176 3.53c0 3.882 3.176 7.059 7.059 7.059 3.882 0 7.059-3.177 7.059-7.06 0-3.882-3.177-7.058-7.06-7.058-3.882 0-7.058 3.176-7.058 7.059z' fill='%234A4A4A'/%3E%3Cmask id='a' maskUnits='userSpaceOnUse' x='0' y='0' width='18' height='18'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M8.824 0C3.97 0 0 3.97 0 8.824c0 4.853 3.97 8.824 8.824 8.824 4.853 0 8.824-3.971 8.824-8.824S13.677 0 8.824 0zM7.94 5.294v2.647H5.294v1.765h2.647v2.647h1.765V9.706h2.647V7.941H9.706V5.294H7.941zm-6.176 3.53c0 3.882 3.176 7.059 7.059 7.059 3.882 0 7.059-3.177 7.059-7.06 0-3.882-3.177-7.058-7.06-7.058-3.882 0-7.058 3.176-7.058 7.059z' fill='%23fff'/%3E%3C/mask%3E%3Cg mask='url(%23a)'%3E%3Cpath fill='%23444' d='M0 0h17.644v17.644H0z'/%3E%3C/g%3E%3C/svg%3E",className:"edit-post-welcome-guide__inserter-icon"})}))))}Object(m.registerPlugin)("wpcom-block-editor-nux",{render:function(){return Object(p.createElement)(h,null)}})}]));
1
+ !function(A,Q){for(var E in Q)A[E]=Q[E]}(window,function(A){var Q={};function E(B){if(Q[B])return Q[B].exports;var I=Q[B]={i:B,l:!1,exports:{}};return A[B].call(I.exports,I,I.exports,E),I.l=!0,I.exports}return E.m=A,E.c=Q,E.d=function(A,Q,B){E.o(A,Q)||Object.defineProperty(A,Q,{enumerable:!0,get:B})},E.r=function(A){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(A,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(A,"__esModule",{value:!0})},E.t=function(A,Q){if(1&Q&&(A=E(A)),8&Q)return A;if(4&Q&&"object"==typeof A&&A&&A.__esModule)return A;var B=Object.create(null);if(E.r(B),Object.defineProperty(B,"default",{enumerable:!0,value:A}),2&Q&&"string"!=typeof A)for(var I in A)E.d(B,I,function(Q){return A[Q]}.bind(null,I));return B},E.n=function(A){var Q=A&&A.__esModule?function(){return A.default}:function(){return A};return E.d(Q,"a",Q),Q},E.o=function(A,Q){return Object.prototype.hasOwnProperty.call(A,Q)},E.p="",E(E.s=11)}([function(A,Q){!function(){A.exports=this.wp.element}()},function(A,Q){!function(){A.exports=this.wp.data}()},function(A,Q){!function(){A.exports=this.wp.i18n}()},function(A,Q){!function(){A.exports=this.wp.components}()},function(A,Q){function E(){return A.exports=E=Object.assign||function(A){for(var Q=1;Q<arguments.length;Q++){var E=arguments[Q];for(var B in E)Object.prototype.hasOwnProperty.call(E,B)&&(A[B]=E[B])}return A},E.apply(this,arguments)}A.exports=E},function(A,Q){!function(){A.exports=this.wp.apiFetch}()},function(A,Q,E){var B=E(9);function I(A,Q){var E=Object.keys(A);if(Object.getOwnPropertySymbols){var B=Object.getOwnPropertySymbols(A);Q&&(B=B.filter((function(Q){return Object.getOwnPropertyDescriptor(A,Q).enumerable}))),E.push.apply(E,B)}return E}A.exports=function(A){for(var Q=1;Q<arguments.length;Q++){var E=null!=arguments[Q]?arguments[Q]:{};Q%2?I(Object(E),!0).forEach((function(Q){B(A,Q,E[Q])})):Object.getOwnPropertyDescriptors?Object.defineProperties(A,Object.getOwnPropertyDescriptors(E)):I(Object(E)).forEach((function(Q){Object.defineProperty(A,Q,Object.getOwnPropertyDescriptor(E,Q))}))}return A}},function(A,Q){function E(A,Q,E,B,I,g,C){try{var e=A[g](C),t=e.value}catch(i){return void E(i)}e.done?Q(t):Promise.resolve(t).then(B,I)}A.exports=function(A){return function(){var Q=this,B=arguments;return new Promise((function(I,g){var C=A.apply(Q,B);function e(A){E(C,I,g,e,t,"next",A)}function t(A){E(C,I,g,e,t,"throw",A)}e(void 0)}))}}},function(A,Q){!function(){A.exports=this.wp.plugins}()},function(A,Q){A.exports=function(A,Q,E){return Q in A?Object.defineProperty(A,Q,{value:E,enumerable:!0,configurable:!0,writable:!0}):A[Q]=E,A}},function(A,Q){!function(){A.exports=this.wp.nux}()},function(A,Q,E){"use strict";E.r(Q);var B=E(6),I=E.n(B),g=E(5),C=E.n(g),e=E(1),t={setWpcomNuxStatus:function(A){var Q=A.isNuxEnabled;return A.bypassApi||C()({path:"/wpcom/v2/block-editor/nux",method:"POST",data:{isNuxEnabled:Q}}),{type:"WPCOM_BLOCK_EDITOR_NUX_SET_STATUS",isNuxEnabled:Q}}};Object(e.registerStore)("automattic/nux",{reducer:function(){var A=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},Q=arguments.length>1?arguments[1]:void 0,E=Q.type,B=Q.isNuxEnabled;return"WPCOM_BLOCK_EDITOR_NUX_SET_STATUS"===E?I()({},A,{isNuxEnabled:B}):A},actions:t,selectors:{isWpcomNuxEnabled:function(A){return A.isNuxEnabled}},persist:!0});E(10);var i=Object(e.subscribe)((function(){Object(e.dispatch)("core/nux").disableTips(),Object(e.select)("core/edit-post").isFeatureActive("welcomeGuide")&&Object(e.dispatch)("core/edit-post").toggleFeature("welcomeGuide"),i()}));Object(e.subscribe)((function(){Object(e.select)("core/nux").areTipsEnabled()&&(Object(e.dispatch)("core/nux").disableTips(),Object(e.dispatch)("automattic/nux").setWpcomNuxStatus({isNuxEnabled:!0})),Object(e.select)("core/edit-post").isFeatureActive("welcomeGuide")&&(Object(e.dispatch)("core/edit-post").toggleFeature("welcomeGuide"),Object(e.dispatch)("automattic/nux").setWpcomNuxStatus({isNuxEnabled:!0}))}));var o=E(7),r=E.n(o),n=E(0),a=E(3),c=E(2),d=E(8),l=E(4),u=E.n(l),s=function(A){return Object(n.createElement)("img",u()({alt:"",src:"'%3E%3C/image%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='173' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='137' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='191' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='245' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='155' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='209' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='263' width='106' height='13'%3E%3C/rect%3E%3C/g%3E%3C/g%3E%3C/svg%3E"},A))},b=function(A){return Object(n.createElement)("img",u()({alt:Object(c.__)("inserter"),src:"data:image/svg+xml;charset=utf8,%3Csvg width='18' height='18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M8.824 0C3.97 0 0 3.97 0 8.824c0 4.853 3.97 8.824 8.824 8.824 4.853 0 8.824-3.971 8.824-8.824S13.677 0 8.824 0zM7.94 5.294v2.647H5.294v1.765h2.647v2.647h1.765V9.706h2.647V7.941H9.706V5.294H7.941zm-6.176 3.53c0 3.882 3.176 7.059 7.059 7.059 3.882 0 7.059-3.177 7.059-7.06 0-3.882-3.177-7.058-7.06-7.058-3.882 0-7.058 3.176-7.058 7.059z' fill='%234A4A4A'/%3E%3Cmask id='a' maskUnits='userSpaceOnUse' x='0' y='0' width='18' height='18'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M8.824 0C3.97 0 0 3.97 0 8.824c0 4.853 3.97 8.824 8.824 8.824 4.853 0 8.824-3.971 8.824-8.824S13.677 0 8.824 0zM7.94 5.294v2.647H5.294v1.765h2.647v2.647h1.765V9.706h2.647V7.941H9.706V5.294H7.941zm-6.176 3.53c0 3.882 3.176 7.059 7.059 7.059 3.882 0 7.059-3.177 7.059-7.06 0-3.882-3.177-7.058-7.06-7.058-3.882 0-7.058 3.176-7.058 7.059z' fill='%23fff'/%3E%3C/mask%3E%3Cg mask='url(%23a)'%3E%3Cpath fill='%23444' d='M0 0h17.644v17.644H0z'/%3E%3C/g%3E%3C/svg%3E"},A))};function w(){var A=Object(e.useSelect)((function(A){return A("automattic/nux").isWpcomNuxEnabled()})),Q=Object(e.useDispatch)("automattic/nux").setWpcomNuxStatus;if(Object(n.useEffect)((function(){void 0===A&&function(){var A=r()(regeneratorRuntime.mark((function A(){var E;return regeneratorRuntime.wrap((function(A){for(;;)switch(A.prev=A.next){case 0:return A.next=2,C()({path:"/wpcom/v2/block-editor/nux"});case 2:E=A.sent,Q({isNuxEnabled:E.is_nux_enabled,bypassApi:!0});case 4:case"end":return A.stop()}}),A)})));return function(){return A.apply(this,arguments)}}()()}),[A,Q]),!A)return null;return Object(n.createElement)(a.Guide,{className:"edit-post-welcome-guide",contentLabel:Object(c.__)("Welcome to the WordPress editor"),finishButtonText:Object(c.__)("Get started"),onFinish:function(){return Q({isNuxEnabled:!1})}},Object(n.createElement)(a.GuidePage,{className:"edit-post-welcome-guide__page"},Object(n.createElement)("h1",{className:"edit-post-welcome-guide__heading"},Object(c.__)("Welcome to the WordPress editor")),Object(n.createElement)(s,{className:"edit-post-welcome-guide__image"}),Object(n.createElement)("p",{className:"edit-post-welcome-guide__text"},Object(c.__)("In the WordPress editor, each paragraph, image, or video is presented as a distinct “block” of content."))),Object(n.createElement)(a.GuidePage,{className:"edit-post-welcome-guide__page"},Object(n.createElement)("h1",{className:"edit-post-welcome-guide__heading"},Object(c.__)("Make each block your own")),Object(n.createElement)(f,{className:"edit-post-welcome-guide__image"}),Object(n.createElement)("p",{className:"edit-post-welcome-guide__text"},Object(c.__)("Each block comes with its own set of controls for changing things like color, width, and alignment. These will show and hide automatically when you have a block selected."))),Object(n.createElement)(a.GuidePage,{className:"edit-post-welcome-guide__page"},Object(n.createElement)("h1",{className:"edit-post-welcome-guide__heading"},Object(c.__)("Get to know the block library")),Object(n.createElement)(h,{className:"edit-post-welcome-guide__image"}),Object(n.createElement)("p",{className:"edit-post-welcome-guide__text"},Object(n.__experimentalCreateInterpolateElement)(Object(c.__)("All of the blocks available to you live in the block library. You’ll find it wherever you see the <InserterIconImage /> icon."),{InserterIconImage:Object(n.createElement)(b,{className:"edit-post-welcome-guide__inserter-icon"})}))),Object(n.createElement)(a.GuidePage,{className:"edit-post-welcome-guide__page"},Object(n.createElement)("h1",{className:"edit-post-welcome-guide__heading"},Object(c.__)("Learn how to use the WordPress editor")),Object(n.createElement)(p,{className:"edit-post-welcome-guide__image"}),Object(n.createElement)("p",{className:"edit-post-welcome-guide__text"},Object(c.__)("New to the WordPress editor? Want to learn more about using it? "),Object(n.createElement)(a.ExternalLink,{href:Object(c.__)("https://support.wordpress.com/wordpress-editor/")},Object(c.__)("Here's a detailed guide.")))))}Object(d.registerPlugin)("wpcom-block-editor-nux",{render:function(){return Object(n.createElement)(w,null)}})}]));
wpcom-block-editor-nux/src/images.js ADDED
@@ -0,0 +1,44 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import { __ } from '@wordpress/i18n';
5
+
6
+ export const CanvasImage = props => (
7
+ <img
8
+ alt=""
9
+ src="data:image/svg+xml,%3Csvg width='306' height='286' viewBox='0 0 306 286' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='306' height='286' rx='4' fill='%2366C6E4'/%3E%3Crect x='36' y='30' width='234' height='256' fill='white'/%3E%3Crect x='36' y='80' width='234' height='94' fill='%23E2E4E7'/%3E%3Cpath d='M140.237 121.47L142.109 125H157.255V133H140.237V121.47ZM159.382 119H155.128L157.255 123H154.064L151.937 119H149.809L151.937 123H148.746L146.618 119H144.491L146.618 123H143.428L141.3 119H140.237C139.067 119 138.12 119.9 138.12 121L138.109 133C138.109 134.1 139.067 135 140.237 135H157.255C158.425 135 159.382 134.1 159.382 133V119Z' fill='%23444444'/%3E%3Crect x='57' y='182' width='91.4727' height='59' fill='%23E2E4E7'/%3E%3Crect x='156.982' y='182' width='91.4727' height='59' fill='%23E2E4E7'/%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M112.309 203H93.1634C92.0998 203 91.0361 204 91.0361 205V219C91.0361 220.1 91.9934 221 93.1634 221H112.309C113.372 221 114.436 220 114.436 219V205C114.436 204 113.372 203 112.309 203ZM112.309 218.92C112.294 218.941 112.269 218.962 112.248 218.979L112.248 218.979C112.239 218.987 112.23 218.994 112.224 219H93.1634V205.08L93.2485 205H112.213C112.235 205.014 112.258 205.038 112.276 205.057C112.284 205.066 112.292 205.074 112.298 205.08V218.92H112.309ZM99.0134 212.5L101.672 215.51L105.395 211L110.182 217H95.2907L99.0134 212.5Z' fill='%2340464D'/%3E%3Cmask id='mask0' mask-type='alpha' maskUnits='userSpaceOnUse' x='91' y='203' width='24' height='18'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M112.309 203H93.1634C92.0998 203 91.0361 204 91.0361 205V219C91.0361 220.1 91.9934 221 93.1634 221H112.309C113.372 221 114.436 220 114.436 219V205C114.436 204 113.372 203 112.309 203ZM112.309 218.92C112.294 218.941 112.269 218.962 112.248 218.979L112.248 218.979C112.239 218.987 112.23 218.994 112.224 219H93.1634V205.08L93.2485 205H112.213C112.235 205.014 112.258 205.038 112.276 205.057C112.284 205.066 112.292 205.074 112.298 205.08V218.92H112.309ZM99.0134 212.5L101.672 215.51L105.395 211L110.182 217H95.2907L99.0134 212.5Z' fill='white'/%3E%3C/mask%3E%3Cg mask='url(%23mask0)'%3E%3Crect x='89.9727' y='200' width='25.5273' height='24' fill='%2340464D'/%3E%3C/g%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M212.291 203H193.145C192.082 203 191.018 204 191.018 205V219C191.018 220.1 191.975 221 193.145 221H212.291C213.354 221 214.418 220 214.418 219V205C214.418 204 213.354 203 212.291 203ZM212.291 218.92C212.276 218.941 212.251 218.962 212.23 218.979L212.23 218.979C212.221 218.987 212.212 218.994 212.206 219H193.145V205.08L193.23 205H212.195C212.217 205.014 212.24 205.038 212.258 205.057C212.266 205.066 212.274 205.074 212.28 205.08V218.92H212.291ZM198.995 212.5L201.654 215.51L205.377 211L210.164 217H195.273L198.995 212.5Z' fill='%2340464D'/%3E%3Cmask id='mask1' mask-type='alpha' maskUnits='userSpaceOnUse' x='191' y='203' width='24' height='18'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M212.291 203H193.145C192.082 203 191.018 204 191.018 205V219C191.018 220.1 191.975 221 193.145 221H212.291C213.354 221 214.418 220 214.418 219V205C214.418 204 213.354 203 212.291 203ZM212.291 218.92C212.276 218.941 212.251 218.962 212.23 218.979L212.23 218.979C212.221 218.987 212.212 218.994 212.206 219H193.145V205.08L193.23 205H212.195C212.217 205.014 212.24 205.038 212.258 205.057C212.266 205.066 212.274 205.074 212.28 205.08V218.92H212.291ZM198.995 212.5L201.654 215.51L205.377 211L210.164 217H195.273L198.995 212.5Z' fill='white'/%3E%3C/mask%3E%3Cg mask='url(%23mask1)'%3E%3Crect x='189.955' y='200' width='25.5273' height='24' fill='%2340464D'/%3E%3C/g%3E%3Crect x='57' y='38' width='191.455' height='34' fill='%23E2E4E7'/%3E%3Cpath d='M155.918 47.8V54.04H149.537V47.8H146.346V63.4H149.537V57.16H155.918V63.4H159.109V47.8' fill='%2340464D'/%3E%3Crect x='58' y='249' width='191' height='37' fill='%23E2E4E7'/%3E%3Cpath d='M160.127 261.4H150.606C149.546 261.4 148.576 261.64 147.696 262.12C146.802 262.612 146.1 263.272 145.59 264.1C145.066 264.928 144.811 265.84 144.811 266.824C144.811 267.808 145.066 268.72 145.59 269.548C146.1 270.376 146.802 271.036 147.696 271.516C148.576 272.008 149.546 272.248 150.606 272.248H151.155V279.4C151.155 279.724 151.282 280.012 151.525 280.252C151.78 280.48 152.086 280.6 152.431 280.6C152.788 280.6 153.082 280.48 153.337 280.252C153.592 280.012 153.72 279.724 153.72 279.4V265C153.72 264.676 153.835 264.388 154.09 264.148C154.345 263.92 154.652 263.8 154.996 263.8C155.341 263.8 155.647 263.92 155.903 264.148C156.145 264.388 156.273 264.676 156.273 265V279.4C156.273 279.724 156.4 280.012 156.656 280.252C156.911 280.48 157.205 280.6 157.562 280.6C157.907 280.6 158.213 280.48 158.468 280.252C158.711 280.012 158.838 279.724 158.838 279.4V263.8H160.127C160.472 263.8 160.766 263.68 161.021 263.44C161.276 263.212 161.404 262.924 161.404 262.6C161.404 262.276 161.276 261.988 161.021 261.748C160.766 261.52 160.472 261.4 160.127 261.4Z' fill='%2340464D'/%3E%3C/svg%3E%0A"
10
+ { ...props }
11
+ />
12
+ );
13
+
14
+ export const EditorImage = props => (
15
+ <img
16
+ alt=""
17
+ src="data:image/svg+xml,%3Csvg width='306' height='286' viewBox='0 0 306 286' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='306' height='286' rx='4' fill='%2366C6E4'/%3E%3Crect x='34.5' y='89.9424' width='237' height='113.423' fill='white' stroke='%238D96A0'/%3E%3Crect x='42.2383' y='98.5962' width='219.692' height='95.6618' fill='%23E2E4E7'/%3E%3Crect x='34.5' y='71.6346' width='27.0718' height='18.1324' fill='white' stroke='%238D96A0'/%3E%3Crect x='152.89' y='71.6346' width='18.5282' height='18.1324' fill='white' stroke='%238D96A0'/%3E%3Crect x='61.3516' y='71.6346' width='51.482' height='18.1324' fill='white' stroke='%238D96A0'/%3E%3Crect x='112.613' y='71.6346' width='40.4974' height='18.1324' fill='white' stroke='%238D96A0'/%3E%3Cpath d='M157.577 137.408H149.383C148.471 137.408 147.636 137.628 146.878 138.068C146.109 138.518 145.505 139.122 145.066 139.88C144.615 140.638 144.396 141.473 144.396 142.373C144.396 143.274 144.615 144.109 145.066 144.867C145.505 145.625 146.109 146.229 146.878 146.668C147.636 147.119 148.471 147.339 149.383 147.339H149.855V153.885C149.855 154.182 149.965 154.446 150.173 154.665C150.393 154.874 150.657 154.984 150.953 154.984C151.261 154.984 151.514 154.874 151.733 154.665C151.953 154.446 152.063 154.182 152.063 153.885V140.704C152.063 140.407 152.162 140.144 152.381 139.924C152.601 139.715 152.865 139.605 153.161 139.605C153.458 139.605 153.721 139.715 153.941 139.924C154.15 140.144 154.26 140.407 154.26 140.704V153.885C154.26 154.182 154.37 154.446 154.589 154.665C154.809 154.874 155.062 154.984 155.369 154.984C155.666 154.984 155.929 154.874 156.149 154.665C156.358 154.446 156.468 154.182 156.468 153.885V139.605H157.577C157.874 139.605 158.126 139.496 158.346 139.276C158.566 139.067 158.676 138.803 158.676 138.507C158.676 138.21 158.566 137.947 158.346 137.727C158.126 137.518 157.874 137.408 157.577 137.408Z' fill='%2340464D'/%3E%3Crect x='41.3232' y='77.1135' width='15.8667' height='7.17464' fill='%23E2E4E7'/%3E%3Crect x='66.9536' y='77.1135' width='7.32308' height='7.17464' fill='%23E2E4E7'/%3E%3Crect x='77.9385' y='77.1135' width='7.32308' height='7.17464' fill='%23E2E4E7'/%3E%3Crect x='88.9229' y='77.1135' width='7.32308' height='7.17464' fill='%23E2E4E7'/%3E%3Crect x='99.9077' y='77.1135' width='7.32308' height='7.17464' fill='%23E2E4E7'/%3E%3Crect x='118.215' y='77.1135' width='7.32308' height='7.17464' fill='%23E2E4E7'/%3E%3Crect x='129.2' y='77.1135' width='7.32308' height='7.17464' fill='%23E2E4E7'/%3E%3Crect x='140.185' y='77.1135' width='7.32308' height='7.17464' fill='%23E2E4E7'/%3E%3Crect x='158.492' y='77.1135' width='7.32308' height='7.17464' fill='%23E2E4E7'/%3E%3C/svg%3E%0A"
18
+ { ...props }
19
+ />
20
+ );
21
+
22
+ export const BlockLibraryImage = props => (
23
+ <img
24
+ alt=""
25
+ src="data:image/svg+xml,%3Csvg width='306' height='286' viewBox='0 0 306 286' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Crect width='306' height='286' rx='4' fill='%2366C6E4'/%3E%3Cmask id='mask0' mask-type='alpha' maskUnits='userSpaceOnUse' x='141' y='25' width='24' height='24'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M152.765 25C146.294 25 141 30.2943 141 36.7651C141 43.2359 146.294 48.5302 152.765 48.5302C159.236 48.5302 164.53 43.2359 164.53 36.7651C164.53 30.2943 159.236 25 152.765 25ZM151.589 32.0591V35.5886H148.059V37.9416H151.589V41.4711H153.942V37.9416H157.471V35.5886H153.942V32.0591H151.589ZM143.353 36.7651C143.353 41.9417 147.588 46.1772 152.765 46.1772C157.942 46.1772 162.177 41.9417 162.177 36.7651C162.177 31.5885 157.942 27.353 152.765 27.353C147.588 27.353 143.353 31.5885 143.353 36.7651Z' fill='white'/%3E%3C/mask%3E%3Cg mask='url(%23mask0)'%3E%3Crect x='141' y='25' width='23.5253' height='23.5253' fill='white'/%3E%3C/g%3E%3Cg filter='url(%23filter0_d)'%3E%3Crect x='48' y='63' width='210' height='190' fill='white'/%3E%3C/g%3E%3Cmask id='mask1' mask-type='alpha' maskUnits='userSpaceOnUse' x='143' y='139' width='20' height='16'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M143.75 141C143.75 140.17 144.42 139.5 145.25 139.5C146.08 139.5 146.75 140.17 146.75 141C146.75 141.83 146.08 142.5 145.25 142.5C144.42 142.5 143.75 141.83 143.75 141ZM143.75 147C143.75 146.17 144.42 145.5 145.25 145.5C146.08 145.5 146.75 146.17 146.75 147C146.75 147.83 146.08 148.5 145.25 148.5C144.42 148.5 143.75 147.83 143.75 147ZM145.25 151.5C144.42 151.5 143.75 152.18 143.75 153C143.75 153.82 144.43 154.5 145.25 154.5C146.07 154.5 146.75 153.82 146.75 153C146.75 152.18 146.08 151.5 145.25 151.5ZM162.25 154H148.25V152H162.25V154ZM148.25 148H162.25V146H148.25V148ZM148.25 142V140H162.25V142H148.25Z' fill='white'/%3E%3C/mask%3E%3Cg mask='url(%23mask1)'%3E%3Crect x='141' y='135' width='24' height='24' fill='%23444444'/%3E%3C/g%3E%3Cmask id='mask2' mask-type='alpha' maskUnits='userSpaceOnUse' x='139' y='54' width='28' height='11'%3E%3Crect x='139' y='54' width='28' height='11' fill='%23C4C4C4'/%3E%3C/mask%3E%3Cg mask='url(%23mask2)'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M139 67L153 54L167 67H139Z' fill='white'/%3E%3C/g%3E%3Crect x='59' y='74' width='188' height='28' rx='3' stroke='%231486B8' stroke-width='2'/%3E%3Cpath d='M211 207.47L212.76 211H227V219H211V207.47ZM229 205H225L227 209H224L222 205H220L222 209H219L217 205H215L217 209H214L212 205H211C209.9 205 209.01 205.9 209.01 207L209 219C209 220.1 209.9 221 211 221H227C228.1 221 229 220.1 229 219V205Z' fill='%23444444'/%3E%3Cpath d='M94.0001 136.4H85.0481C84.0521 136.4 83.1401 136.64 82.3121 137.12C81.4721 137.612 80.8121 138.272 80.3321 139.1C79.8401 139.928 79.6001 140.84 79.6001 141.824C79.6001 142.808 79.8401 143.72 80.3321 144.548C80.8121 145.376 81.4721 146.036 82.3121 146.516C83.1401 147.008 84.0521 147.248 85.0481 147.248H85.5641V154.4C85.5641 154.724 85.6841 155.012 85.9121 155.252C86.1521 155.48 86.4401 155.6 86.7641 155.6C87.1001 155.6 87.3761 155.48 87.6161 155.252C87.8561 155.012 87.9761 154.724 87.9761 154.4V140C87.9761 139.676 88.0841 139.388 88.3241 139.148C88.5641 138.92 88.8521 138.8 89.1761 138.8C89.5001 138.8 89.7881 138.92 90.0281 139.148C90.2561 139.388 90.3761 139.676 90.3761 140V154.4C90.3761 154.724 90.4961 155.012 90.7361 155.252C90.9761 155.48 91.2521 155.6 91.5881 155.6C91.9121 155.6 92.2001 155.48 92.4401 155.252C92.6681 155.012 92.7881 154.724 92.7881 154.4V138.8H94.0001C94.3241 138.8 94.6001 138.68 94.8401 138.44C95.0801 138.212 95.2001 137.924 95.2001 137.6C95.2001 137.276 95.0801 136.988 94.8401 136.748C94.6001 136.52 94.3241 136.4 94.0001 136.4Z' fill='%23444444'/%3E%3Cmask id='mask3' mask-type='alpha' maskUnits='userSpaceOnUse' x='76' y='204' width='22' height='18'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M96 204H78C77 204 76 205 76 206V220C76 221.1 76.9 222 78 222H96C97 222 98 221 98 220V206C98 205 97 204 96 204ZM96 219.92C95.9861 219.941 95.9624 219.962 95.9426 219.979C95.9339 219.987 95.9261 219.994 95.92 220H78V206.08L78.08 206H95.91C95.9309 206.014 95.9518 206.038 95.9694 206.057C95.977 206.066 95.9839 206.074 95.99 206.08V219.92H96ZM83.5 213.5L86 216.51L89.5 212L94 218H80L83.5 213.5Z' fill='white'/%3E%3C/mask%3E%3Cg mask='url(%23mask3)'%3E%3Crect x='75' y='201' width='24' height='24' fill='%23444444'/%3E%3C/g%3E%3Cpath d='M161 205V217H149V205H161ZM161 203H149C147.9 203 147 203.9 147 205V217C147 218.1 147.9 219 149 219H161C162.1 219 163 218.1 163 217V205C163 203.9 162.1 203 161 203ZM152.5 212.67L154.19 214.93L156.67 211.83L160 216H150L152.5 212.67ZM143 207V221C143 222.1 143.9 223 145 223H159V221H145V207H143Z' fill='%23444444'/%3E%3Cmask id='mask4' mask-type='alpha' maskUnits='userSpaceOnUse' x='210' y='140' width='18' height='12'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M215.62 152H210.38L212.38 148H210V140H218V147.24L215.62 152ZM220.38 152H225.62L228 147.24V140H220V148H222.38L220.38 152ZM224.38 150H223.62L225.62 146H222V142H226V146.76L224.38 150ZM214.38 150H213.62L215.62 146H212V142H216V146.76L214.38 150Z' fill='white'/%3E%3C/mask%3E%3Cg mask='url(%23mask4)'%3E%3Crect x='207' y='134' width='24' height='24' fill='%23444444'/%3E%3C/g%3E%3Cdefs%3E%3Cfilter id='filter0_d' x='18' y='36' width='270' height='250' filterUnits='userSpaceOnUse' color-interpolation-filters='sRGB'%3E%3CfeFlood flood-opacity='0' result='BackgroundImageFix'/%3E%3CfeColorMatrix in='SourceAlpha' type='matrix' values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0'/%3E%3CfeOffset dy='3'/%3E%3CfeGaussianBlur stdDeviation='15'/%3E%3CfeColorMatrix type='matrix' values='0 0 0 0 0.0980392 0 0 0 0 0.117647 0 0 0 0 0.137255 0 0 0 0.1 0'/%3E%3CfeBlend mode='normal' in2='BackgroundImageFix' result='effect1_dropShadow'/%3E%3CfeBlend mode='normal' in='SourceGraphic' in2='effect1_dropShadow' result='shape'/%3E%3C/filter%3E%3C/defs%3E%3C/svg%3E%0A"
26
+ { ...props }
27
+ />
28
+ );
29
+
30
+ export const DocumentationImage = props => (
31
+ <img
32
+ alt=""
33
+ src="'%3E%3C/image%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='173' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='137' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='191' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='245' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='155' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='209' width='106' height='13'%3E%3C/rect%3E%3Crect id='text' fill='%23E2E4E7' x='124' y='263' width='106' height='13'%3E%3C/rect%3E%3C/g%3E%3C/g%3E%3C/svg%3E"
34
+ { ...props }
35
+ />
36
+ );
37
+
38
+ export const InserterIconImage = props => (
39
+ <img
40
+ alt={ __( 'inserter' ) }
41
+ src="data:image/svg+xml;charset=utf8,%3Csvg width='18' height='18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M8.824 0C3.97 0 0 3.97 0 8.824c0 4.853 3.97 8.824 8.824 8.824 4.853 0 8.824-3.971 8.824-8.824S13.677 0 8.824 0zM7.94 5.294v2.647H5.294v1.765h2.647v2.647h1.765V9.706h2.647V7.941H9.706V5.294H7.941zm-6.176 3.53c0 3.882 3.176 7.059 7.059 7.059 3.882 0 7.059-3.177 7.059-7.06 0-3.882-3.177-7.058-7.06-7.058-3.882 0-7.058 3.176-7.058 7.059z' fill='%234A4A4A'/%3E%3Cmask id='a' maskUnits='userSpaceOnUse' x='0' y='0' width='18' height='18'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M8.824 0C3.97 0 0 3.97 0 8.824c0 4.853 3.97 8.824 8.824 8.824 4.853 0 8.824-3.971 8.824-8.824S13.677 0 8.824 0zM7.94 5.294v2.647H5.294v1.765h2.647v2.647h1.765V9.706h2.647V7.941H9.706V5.294H7.941zm-6.176 3.53c0 3.882 3.176 7.059 7.059 7.059 3.882 0 7.059-3.177 7.059-7.06 0-3.882-3.177-7.058-7.06-7.058-3.882 0-7.058 3.176-7.058 7.059z' fill='%23fff'/%3E%3C/mask%3E%3Cg mask='url(%23a)'%3E%3Cpath fill='%23444' d='M0 0h17.644v17.644H0z'/%3E%3C/g%3E%3C/svg%3E"
42
+ { ...props }
43
+ />
44
+ );
wpcom-block-editor-nux/src/wpcom-nux.js CHANGED
@@ -4,12 +4,23 @@
4
  * External dependencies
5
  */
6
  import apiFetch from '@wordpress/api-fetch';
7
- import { Guide, GuidePage } from '@wordpress/components';
8
  import { useDispatch, useSelect } from '@wordpress/data';
9
  import { useEffect, __experimentalCreateInterpolateElement } from '@wordpress/element';
10
  import { __ } from '@wordpress/i18n';
11
  import { registerPlugin } from '@wordpress/plugins';
12
 
 
 
 
 
 
 
 
 
 
 
 
13
  function WpcomNux() {
14
  const isWpcomNuxEnabled = useSelect( select => select( 'automattic/nux' ).isWpcomNuxEnabled() );
15
  const { setWpcomNuxStatus } = useDispatch( 'automattic/nux' );
@@ -32,51 +43,70 @@ function WpcomNux() {
32
 
33
  const dismissWpcomNux = () => setWpcomNuxStatus( { isNuxEnabled: false } );
34
 
 
 
 
 
35
  return (
36
  <Guide
37
  className="edit-post-welcome-guide"
 
38
  finishButtonText={ __( 'Get started' ) }
39
  onFinish={ dismissWpcomNux }
40
  >
41
  <GuidePage className="edit-post-welcome-guide__page">
42
  <h1 className="edit-post-welcome-guide__heading">
43
- { __( 'Welcome to the Block Editor' ) }
44
  </h1>
 
45
  <p className="edit-post-welcome-guide__text">
46
  { __(
47
  'In the WordPress editor, each paragraph, image, or video is presented as a distinct “block” of content.'
48
  ) }
49
  </p>
50
  </GuidePage>
 
51
  <GuidePage className="edit-post-welcome-guide__page">
52
  <h1 className="edit-post-welcome-guide__heading">{ __( 'Make each block your own' ) }</h1>
 
53
  <p className="edit-post-welcome-guide__text">
54
  { __(
55
  'Each block comes with its own set of controls for changing things like color, width, and alignment. These will show and hide automatically when you have a block selected.'
56
  ) }
57
  </p>
58
  </GuidePage>
 
59
  <GuidePage className="edit-post-welcome-guide__page">
60
  <h1 className="edit-post-welcome-guide__heading">
61
- { __( 'Get to know the Block Library' ) }
62
  </h1>
 
63
  <p className="edit-post-welcome-guide__text">
64
  { __experimentalCreateInterpolateElement(
65
  __(
66
- 'All of the blocks available to you live in the Block Library. You’ll find it wherever you see the <InserterIconImage /> icon.'
67
  ),
68
  {
69
  InserterIconImage: (
70
- <img
71
- alt={ __( 'inserter' ) }
72
- src="data:image/svg+xml;charset=utf8,%3Csvg width='18' height='18' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M8.824 0C3.97 0 0 3.97 0 8.824c0 4.853 3.97 8.824 8.824 8.824 4.853 0 8.824-3.971 8.824-8.824S13.677 0 8.824 0zM7.94 5.294v2.647H5.294v1.765h2.647v2.647h1.765V9.706h2.647V7.941H9.706V5.294H7.941zm-6.176 3.53c0 3.882 3.176 7.059 7.059 7.059 3.882 0 7.059-3.177 7.059-7.06 0-3.882-3.177-7.058-7.06-7.058-3.882 0-7.058 3.176-7.058 7.059z' fill='%234A4A4A'/%3E%3Cmask id='a' maskUnits='userSpaceOnUse' x='0' y='0' width='18' height='18'%3E%3Cpath fill-rule='evenodd' clip-rule='evenodd' d='M8.824 0C3.97 0 0 3.97 0 8.824c0 4.853 3.97 8.824 8.824 8.824 4.853 0 8.824-3.971 8.824-8.824S13.677 0 8.824 0zM7.94 5.294v2.647H5.294v1.765h2.647v2.647h1.765V9.706h2.647V7.941H9.706V5.294H7.941zm-6.176 3.53c0 3.882 3.176 7.059 7.059 7.059 3.882 0 7.059-3.177 7.059-7.06 0-3.882-3.177-7.058-7.06-7.058-3.882 0-7.058 3.176-7.058 7.059z' fill='%23fff'/%3E%3C/mask%3E%3Cg mask='url(%23a)'%3E%3Cpath fill='%23444' d='M0 0h17.644v17.644H0z'/%3E%3C/g%3E%3C/svg%3E"
73
- className="edit-post-welcome-guide__inserter-icon"
74
- />
75
  ),
76
  }
77
  ) }
78
  </p>
79
  </GuidePage>
 
 
 
 
 
 
 
 
 
 
 
 
 
80
  </Guide>
81
  );
82
  }
4
  * External dependencies
5
  */
6
  import apiFetch from '@wordpress/api-fetch';
7
+ import { ExternalLink, Guide, GuidePage } from '@wordpress/components';
8
  import { useDispatch, useSelect } from '@wordpress/data';
9
  import { useEffect, __experimentalCreateInterpolateElement } from '@wordpress/element';
10
  import { __ } from '@wordpress/i18n';
11
  import { registerPlugin } from '@wordpress/plugins';
12
 
13
+ /**
14
+ * Internal dependencies
15
+ */
16
+ import {
17
+ CanvasImage,
18
+ EditorImage,
19
+ BlockLibraryImage,
20
+ DocumentationImage,
21
+ InserterIconImage,
22
+ } from './images';
23
+
24
  function WpcomNux() {
25
  const isWpcomNuxEnabled = useSelect( select => select( 'automattic/nux' ).isWpcomNuxEnabled() );
26
  const { setWpcomNuxStatus } = useDispatch( 'automattic/nux' );
43
 
44
  const dismissWpcomNux = () => setWpcomNuxStatus( { isNuxEnabled: false } );
45
 
46
+ /**
47
+ * Currently, the Guide content is mostly copied from Gutenberg. This can be
48
+ * updated if/as we have new designs for the NUX on wpcom.
49
+ */
50
  return (
51
  <Guide
52
  className="edit-post-welcome-guide"
53
+ contentLabel={ __( 'Welcome to the WordPress editor' ) }
54
  finishButtonText={ __( 'Get started' ) }
55
  onFinish={ dismissWpcomNux }
56
  >
57
  <GuidePage className="edit-post-welcome-guide__page">
58
  <h1 className="edit-post-welcome-guide__heading">
59
+ { __( 'Welcome to the WordPress editor' ) }
60
  </h1>
61
+ <CanvasImage className="edit-post-welcome-guide__image" />
62
  <p className="edit-post-welcome-guide__text">
63
  { __(
64
  'In the WordPress editor, each paragraph, image, or video is presented as a distinct “block” of content.'
65
  ) }
66
  </p>
67
  </GuidePage>
68
+
69
  <GuidePage className="edit-post-welcome-guide__page">
70
  <h1 className="edit-post-welcome-guide__heading">{ __( 'Make each block your own' ) }</h1>
71
+ <EditorImage className="edit-post-welcome-guide__image" />
72
  <p className="edit-post-welcome-guide__text">
73
  { __(
74
  'Each block comes with its own set of controls for changing things like color, width, and alignment. These will show and hide automatically when you have a block selected.'
75
  ) }
76
  </p>
77
  </GuidePage>
78
+
79
  <GuidePage className="edit-post-welcome-guide__page">
80
  <h1 className="edit-post-welcome-guide__heading">
81
+ { __( 'Get to know the block library' ) }
82
  </h1>
83
+ <BlockLibraryImage className="edit-post-welcome-guide__image" />
84
  <p className="edit-post-welcome-guide__text">
85
  { __experimentalCreateInterpolateElement(
86
  __(
87
+ 'All of the blocks available to you live in the block library. You’ll find it wherever you see the <InserterIconImage /> icon.'
88
  ),
89
  {
90
  InserterIconImage: (
91
+ <InserterIconImage className="edit-post-welcome-guide__inserter-icon" />
 
 
 
 
92
  ),
93
  }
94
  ) }
95
  </p>
96
  </GuidePage>
97
+
98
+ <GuidePage className="edit-post-welcome-guide__page">
99
+ <h1 className="edit-post-welcome-guide__heading">
100
+ { __( 'Learn how to use the WordPress editor' ) }
101
+ </h1>
102
+ <DocumentationImage className="edit-post-welcome-guide__image" />
103
+ <p className="edit-post-welcome-guide__text">
104
+ { __( 'New to the WordPress editor? Want to learn more about using it? ' ) }
105
+ <ExternalLink href={ __( 'https://support.wordpress.com/wordpress-editor/' ) }>
106
+ { __( "Here's a detailed guide." ) }
107
+ </ExternalLink>
108
+ </p>
109
+ </GuidePage>
110
  </Guide>
111
  );
112
  }