File: //home/thestudentsunion.org.uk/public_html/wp-content/themes/customify/inc/admin/editor.php
<?php
/**
* Support Gutenberg Editor.
*
* @since 0.2.6
*/
class Customify_Editor {
private $action = 'customify_load_editor_style';
private $editor_file = 'assets/css/admin/editor.css';
public function __construct() {
$current_wp_version = $GLOBALS['wp_version'];
if ( version_compare( $current_wp_version, '5.8', '>=' ) ) {
add_filter( 'block_editor_settings_all', array( $this, 'editor_settings' ) );
} else {
add_filter( 'block_editor_settings', array( $this, 'editor_settings' ) );
}
// Add ajax action to load css file.
add_action( 'wp_ajax_' . $this->action, array( $this, 'css_file' ) );
// Add more editor assets.
add_action( 'enqueue_block_editor_assets', array( $this, 'assets' ) );
}
/**
* Add more editor styles and scripts
*
* @todo Add Custom Fonts and styling settings.
*
* @return void
*/
function assets() {
wp_enqueue_style( 'customify-editor-fonts', Customify_Customizer_Auto_CSS::get_instance()->get_font_url() );
wp_add_inline_style( 'wp-edit-post', $this->css() );
}
/**
* Add styling settings to editor.
*
* @return string CSS code.
*/
public function css() {
$fields = array();
$keys = array(
'container_width',
'site_content_styling',
'content_background',
'single_blog_post_content_width',
'global_typography_heading_h1',
'global_typography_base_heading',
'global_styling_color_heading',
);
foreach ( $keys as $k ) {
$f = Customify()->customizer->get_field_setting( $k );
if ( $f ) {
$fields[ $k ] = $f;
}
}
if ( $fields['global_styling_color_heading'] ) {
$fields['global_styling_color_heading']['selector'] = '.editor-styles-wrapper .editor-post-title .editor-post-title__input';
$fields['global_styling_color_heading']['css_format'] = 'color: {{value}};';
}
if ( $fields['container_width'] ) {
$fields['container_width']['selector'] = '.editor-styles-wrapper .wp-block[data-align="wide"]';
$fields['container_width']['css_format'] = 'width: calc( {{value}} - 4em ); max-width: 100%;';
}
if ( $fields['single_blog_post_content_width'] ) {
$fields['single_blog_post_content_width']['selector'] = '.editor-styles-wrapper .wp-block:not([data-align="full"]):not([data-align="wide"])';
$fields['single_blog_post_content_width']['css_format'] = 'max-width: {{value}};';
}
if ( $fields['global_typography_base_heading'] ) {
$fields['global_typography_base_heading']['selector'] = '.editor-post-title__block .editor-post-title__input';
}
if ( $fields['global_typography_heading_h1'] ) {
$fields['global_typography_heading_h1']['selector'] = ' .editor-post-title__block texarea.editor-post-title__input';
}
if ( $fields['site_content_styling'] ) {
$fields['site_content_styling']['selector'] = array(
'normal' => '.edit-post-visual-editor.editor-styles-wrapper',
);
}
if ( isset( $fields['content_background'] ) && $fields['content_background'] ) {
$fields['content_background']['selector'] = array(
'normal' => '.edit-post-layout__content',
);
}
$c = new Customify_Customizer_Auto_CSS();
$css = $c->render_css( $fields );
$css .= '.edit-post-layout__content .edit-post-layout__metaboxes { background: #FFF; }
.edit-post-layout__metaboxes:not(:empty) { margin-top: 0px; }
.editor-styles-wrapper textarea.editor-post-title__input { min-height: 0; }
.editor-styles-wrapper textarea.editor-post-title__input:focus,
.block-editor-page .editor-styles-wrapper button:not(.components-button) { background: none; }
';
$css .= 'pre{
background: #f2f2f2;
font-family: "Courier 10 Pitch", Courier, monospace;
margin-bottom: 2.2906835em;
padding: 1.618em;
overflow: auto;
margin-left: auto;
margin-right: auto;
}
.wp-block-preformatted {
white-space: pre-wrap;
}
#editor .editor-styles-wrapper pre{
max-width: 840px;
}
#editor ul, #editor ol {
margin: 1.5em auto;
list-style-position: outside;
}
#editor .wp-block-list,
#editor .wp-block-categories__list,
#editor .wp-block-archives-list {
padding-left: 2.5em;
}
#editor ul ul, #editor ol ol, #editor ul ol, #editor ol ul {
margin-bottom: 0px;
margin-top: 0px;
margin-left: 2.5em;
}
#editor table, #editor table tr, #editor table th, #editor table td {
border: 0;
}
#editor .editor-styles-wrapper blockquote.wp-block-quote {
border-left-width: 3px;
border-left-style: solid;
}
#editor .has-text-align-left .rich-text {
text-align: left;
}
#editor .wp-block-quote.is-large cite {
font-size: 1.125em;
}
#editor .editor-styles-wrapper .wp-block-pullquote {
margin-left: auto;
margin-right: auto;
}
#editor .wp-block-pullquote.alignleft {
margin: 0 1.41575em 1em 2.5em;
}
#editor .wp-block-pullquote.alignright {
margin: 0 2.5em 1em 1.41575em;
}
#editor .editor-styles-wrapper .wp-block-separator.is-style-dots {
max-width: 205px;
}
';
return $css;
}
/**
* Create a dymanic stylesheet url.
*
* @return string CSS URL
*/
public function editor_style_url() {
return add_query_arg(
array(
'action' => $this->action,
'nonce' => wp_create_nonce( $this->action ),
),
admin_url( 'admin-ajax.php' )
);
}
/**
* Add edditor settings.
*
* @see gutenberg_editor_scripts_and_styles
*
* @param array $editor_settings
* @return array
*/
public function editor_settings( $editor_settings ) {
$editor_settings['styles'][] = array(
'css' => $this->load_style(),
);
return $editor_settings;
}
/**
* Render dynamic CSS content.
*
* @return void
*/
public function css_file() {
header( 'Content-type: text/css; charset: UTF-8' );
echo $this->load_style();
}
/**
* Load CSS content.
*
* @return string CSS code.
*/
public function load_style() {
global $wp_filesystem;
WP_Filesystem();
$file = get_template_directory() . '/' . $this->editor_file;
$file_contents = '';
if ( file_exists( $file ) ) {
$file_contents .= $wp_filesystem->get_contents( $file );
}
/**
* Remove editor background
*
* @since 0.3.0
*/
$config_fields = Customify()->customizer->get_config();
$c = new Customify_Customizer_Auto_CSS();
$css_code = $c->render_css( $config_fields );
$file_contents .= $css_code;
return $file_contents;
}
}
new Customify_Editor();