From 180a56e59dd30a06ed4a2bb9e838b8109c2add4e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Thomas=20Kr=C3=A4ftner?= Date: Fri, 25 Aug 2017 13:36:46 +0200 Subject: [PATCH 1/3] only enqueue js for post edit when Yoast SEO Metabox is active --- inc/class-yoast-acf-analysis-assets.php | 47 +++++++++++++++++++++++-- 1 file changed, 44 insertions(+), 3 deletions(-) diff --git a/inc/class-yoast-acf-analysis-assets.php b/inc/class-yoast-acf-analysis-assets.php index 6b5c4aa2..2ffb37db 100755 --- a/inc/class-yoast-acf-analysis-assets.php +++ b/inc/class-yoast-acf-analysis-assets.php @@ -28,12 +28,13 @@ public function enqueue_scripts() { $config = Yoast_ACF_Analysis_Facade::get_registry()->get( 'config' ); // Post page enqueue. - if ( 'post.php' === $pagenow || 'post-new.php' === $pagenow ) { + if ( $this->is_metabox_active() ) { wp_enqueue_script( 'yoast-acf-analysis-post', plugins_url( '/js/yoast-acf-analysis.js', AC_SEO_ACF_ANALYSIS_PLUGIN_FILE ), array( 'jquery', 'yoast-seo-post-scraper', 'underscore' ), - $this->plugin_data['Version'] + $this->plugin_data['Version'], + true ); wp_localize_script( 'yoast-acf-analysis-post', 'YoastACFAnalysisConfig', $config->to_array() ); @@ -45,10 +46,50 @@ public function enqueue_scripts() { 'yoast-acf-analysis-term', plugins_url( '/js/yoast-acf-analysis.js', AC_SEO_ACF_ANALYSIS_PLUGIN_FILE ), array( 'jquery', 'yoast-seo-term-scraper' ), - $this->plugin_data['Version'] + $this->plugin_data['Version'], + true ); wp_localize_script( 'yoast-acf-analysis-term', 'YoastACFAnalysisConfig', $config->to_array() ); } } + + /** + * Test if the Metabox is actually active for the edit screen we are at. + * + * Adapted from Yoast SEO. + * + * @see WPSEO_Metabox::enqueue() + */ + public function is_metabox_active() { + + global $pagenow; + + // This is just an additional security net to ensure the global var is present. + if ( empty( $GLOBALS['wpseo_metabox'] ) || ! ( $GLOBALS['wpseo_metabox'] instanceof WPSEO_Metabox ) ) { + return false; + } + + /* @var $wpseo_metabox WPSEO_Metabox */ + $wpseo_metabox = $GLOBALS['wpseo_metabox']; + + $is_editor = WPSEO_Metabox::is_post_edit( $pagenow ); + + if ( + ( + ! $is_editor + && + /* Filter 'wpseo_always_register_metaboxes_on_admin' documented in wpseo-main.php */ + apply_filters( 'wpseo_always_register_metaboxes_on_admin', false ) === false + ) + || + $wpseo_metabox->is_metabox_hidden() === true + ) { + return false; + } + + return true; + + } + } From fddebb346c830206d52f8e32bf9caf4106366119 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Thomas=20Kr=C3=A4ftner?= Date: Tue, 12 Sep 2017 15:23:51 +0200 Subject: [PATCH 2/3] directly use jQuery ready (as this is all acf.add_action('ready') does anyway) and this also fires in case document.ready has already been fired which is likely now that this is running from the footer --- js/src/app.js | 2 +- js/yoast-acf-analysis.js | 7 ++++--- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/js/src/app.js b/js/src/app.js index 7a6c7747..01b6f678 100644 --- a/js/src/app.js +++ b/js/src/app.js @@ -19,7 +19,7 @@ App.prototype.bindListeners = function(){ if(helper.acf_version >= 5){ var _self = this; - acf.add_action('ready', function () { + jQuery(function(){ _self.replaceVars = replaceVars.createReplaceVars(collect); acf.add_action('change remove append sortstop', _self.maybeRefresh); acf.add_action('change remove append sortstop', replaceVars.updateReplaceVars.bind(_self, collect, _self.replaceVars)); diff --git a/js/yoast-acf-analysis.js b/js/yoast-acf-analysis.js index 42c06a60..3321ea3b 100644 --- a/js/yoast-acf-analysis.js +++ b/js/yoast-acf-analysis.js @@ -20,7 +20,7 @@ App.prototype.bindListeners = function(){ if(helper.acf_version >= 5){ var _self = this; - acf.add_action('ready', function () { + jQuery(function(){ _self.replaceVars = replaceVars.createReplaceVars(collect); acf.add_action('change remove append sortstop', _self.maybeRefresh); acf.add_action('change remove append sortstop', replaceVars.updateReplaceVars.bind(_self, collect, _self.replaceVars)); @@ -235,8 +235,10 @@ Collect.prototype.getFieldData = function () { var used_types = _.uniq(_.pluck(field_data, 'type')); if(config.debug) { + console.log('Used types:') console.log(used_types); + } _.each(used_types, function(type){ @@ -838,5 +840,4 @@ var isTinyMCEAvailable = function(editorID) { }; module.exports = Scraper; -},{"./../scraper-store.js":11}]},{},[9]) -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","js/src/app.js","js/src/cache/cache.attachments.js","js/src/cache/cache.js","js/src/collect/collect-v4.js","js/src/collect/collect-v5.js","js/src/collect/collect.js","js/src/config/config.js","js/src/helper.js","js/src/main.js","js/src/replacevars.js","js/src/scraper-store.js","js/src/scraper/scraper.email.js","js/src/scraper/scraper.gallery.js","js/src/scraper/scraper.image.js","js/src/scraper/scraper.taxonomy.js","js/src/scraper/scraper.text.js","js/src/scraper/scraper.textarea.js","js/src/scraper/scraper.url.js","js/src/scraper/scraper.wysiwyg.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACtFA;;ACAA;AACA;AACA;AACA;AACA;;ACJA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzDA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1DA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACvBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/* global YoastSEO */\nvar config = require( \"./config/config.js\" );\nvar helper = require( \"./helper.js\" );\nvar collect = require( \"./collect/collect.js\" );\nvar replaceVars = require( \"./replacevars.js\" );\n\nvar analysisTimeout = 0;\n\nvar App = function(){\n\n    YoastSEO.app.registerPlugin(config.pluginName, {status: 'ready'});\n\n    YoastSEO.app.registerModification('content', collect.append.bind(collect), config.pluginName);\n\n    this.bindListeners();\n};\n\nApp.prototype.bindListeners = function(){\n\n    if(helper.acf_version >= 5){\n        this.replaceVars = replaceVars.createReplaceVars(collect);\n        acf.add_action('change remove append sortstop', this.maybeRefresh);\n        acf.add_action('change remove append sortstop', replaceVars.updateReplaceVars.bind(this, collect, this.replaceVars));\n    }else{\n        var fieldSelectors = config.fieldSelectors.slice(0);\n\n        // Ignore Wysiwyg fields because they trigger a refresh in Yoast SEO itself\n        fieldSelectors = _.without(fieldSelectors, 'textarea[id^=wysiwyg-acf]');\n\n        var _self = this;\n\n        jQuery(document).on('acf/setup_fields', function(){\n            this.replaceVars = replaceVars.createReplaceVars(collect);\n            var fields = jQuery('#post-body, #edittag').find(fieldSelectors.join(','));\n            //This would cause faster updates while typing\n            //fields.on('change input', _self.maybeRefresh.bind(_self) );\n            fields.on('change', _self.maybeRefresh.bind(_self) );\n            fields.on('change', replaceVars.updateReplaceVars.bind(_self, collect, _self.replaceVars));\n\n            // Do not ignore Wysiwyg fields for the purpose of Replace Vars.\n            jQuery('textarea[id^=wysiwyg-acf]').on('change', replaceVars.updateReplaceVars.bind(_self, collect, _self.replaceVars));\n            if (YoastSEO.wp._tinyMCEHelper) {\n                jQuery('textarea[id^=wysiwyg-acf]').each( function () {\n                    YoastSEO.wp._tinyMCEHelper.addEventHandler(this.id, [ 'input', 'change', 'cut', 'paste' ],\n                        replaceVars.updateReplaceVars.bind(_self, collect, _self.replaceVars));\n                });\n            }\n\n\n            //Also refresh on media close as attachment data might have changed\n            wp.media.frame.on('close', _self.maybeRefresh.bind(_self) );\n        });\n    }\n\n}\n\nApp.prototype.maybeRefresh = function(){\n\n    if ( analysisTimeout ) {\n        window.clearTimeout(analysisTimeout);\n    }\n\n    analysisTimeout = window.setTimeout( function() {\n\n        if(config.debug){\n            console.log('Recalculate...' + new Date() + '(Internal)');\n        }\n\n        YoastSEO.app.pluginReloaded(config.pluginName);\n    }, config.refreshRate );\n\n};\n\nmodule.exports = App;\n","/* global _ */\nvar cache = require( \"./cache.js\" );\n\nvar refresh = function(attachment_ids){\n\n    var uncached = cache.getUncached(attachment_ids, 'attachment');\n\n    if (uncached.length === 0){\n        return;\n    }\n\n    window.wp.ajax.post('query-attachments', {\n        'query': {\n            'post__in': uncached\n        }\n    }).done(function (attachments) {\n\n        _.each(attachments, function (attachment) {\n            cache.set(attachment.id, attachment, 'attachment');\n            YoastACFAnalysis.maybeRefresh();\n        });\n\n    });\n\n};\n\nvar get = function( id ){\n\n    var attachment = cache.get(id, 'attachment');\n\n    if(!attachment) return false;\n\n    var changedAttachment = wp.media.attachment( id );\n\n    if( changedAttachment.has('alt') ){\n        attachment.alt = changedAttachment.get('alt');\n    }\n\n    if( changedAttachment.has('title') ){\n        attachment.title = changedAttachment.get('title');\n    }\n\n    return attachment;\n};\n\nmodule.exports = {\n    refresh: refresh,\n    get: get\n};","/* global _ */\nvar Cache = function() {\n    this.clear('all');\n};\n\nvar _cache;\n\nCache.prototype.set = function( id, value, store ) {\n\n    store = typeof store !== 'undefined' ? store : 'default';\n\n    if( !(store in _cache) ){\n        _cache[store] = {};\n    }\n\n    _cache[ store ][ id ] = value;\n};\n\nCache.prototype.get =  function( id, store ){\n\n    store = typeof store !== 'undefined' ? store : 'default';\n\n    if ( store in _cache && id in _cache[ store ] ) {\n        return _cache[ store ][ id ];\n    }else{\n        return false;\n    }\n\n};\n\nCache.prototype.getUncached =  function(ids, store){\n\n    store = typeof store !== 'undefined' ? store : 'default';\n\n    var that = this;\n\n    ids = _.uniq(ids);\n\n    return ids.filter(function(id){\n        var value = that.get(id, store);\n        return value === false;\n    });\n\n};\n\nCache.prototype.clear =  function(store){\n\n    store = typeof store !== 'undefined' ? store : 'default';\n\n    if(store === 'all'){\n        _cache = {};\n    }else{\n        _cache[store] = {};\n    }\n\n};\n\nmodule.exports = new Cache();","var config = require( \"./../config/config.js\" );\nvar fieldSelectors = config.fieldSelectors;\n\nvar field_data = [];\n\nvar fields = jQuery('#post-body, #edittag').find(fieldSelectors.join(','));\n\nfields.each(function() {\n\n    var $el = jQuery(this).parents('.field').last();\n\n    field_data.push({\n        $el     : $el,\n        key     : $el.data('field_key'),\n        name    : $el.data('field_name'),\n        type    : $el.data('field_type')\n    });\n\n});\n\nmodule.exports = field_data;","module.exports = function(){\n    return _.map(acf.get_fields(), function(field){\n\n        var field_data = jQuery.extend( true, {}, acf.get_data(jQuery(field)) );\n        field_data.$el = jQuery(field);\n        return field_data;\n\n    });\n};","/* global acf, _ */\n\nvar config = require( \"./../config/config.js\" );\nvar helper = require( \"./../helper.js\" );\nvar scraper_store = require( \"./../scraper-store.js\" );\n\nvar Collect = function(){\n\n};\n\nCollect.prototype.getFieldData = function () {\n    var field_data = this.filterBroken(this.filterBlacklistName(this.filterBlacklistType(this.getData())));\n\n    var used_types = _.uniq(_.pluck(field_data, 'type'));\n\n    if(config.debug) {\n\n        console.log('Used types:')\n        console.log(used_types);\n\n    }\n\n    _.each(used_types, function(type){\n        field_data = scraper_store.getScraper(type).scrape(field_data);\n    });\n\n    return field_data;\n};\n\nCollect.prototype.append = function(data){\n\n    if(config.debug){\n        console.log('Recalculate...' + new Date());\n    }\n\n    var field_data = this.getFieldData();\n\n    _.each(field_data, function(field){\n\n        if(typeof field.content !== 'undefined' && field.content !== ''){\n            data += '\\n' + field.content;\n        }\n\n    });\n\n    if(config.debug){\n        console.log('Field data:')\n        console.table(field_data);\n\n        console.log('Data:')\n        console.log(data);\n    }\n\n    return data;\n\n};\n\nCollect.prototype.getData = function(){\n\n    if(helper.acf_version >= 5){\n        return require( \"./collect-v5.js\" )();\n    }else{\n        return require( \"./collect-v4.js\" );\n    }\n\n};\n\nCollect.prototype.filterBlacklistType = function(field_data){\n    return _.filter(field_data, function(field){\n        return !_.contains(config.blacklistType, field.type);\n    });\n};\n\nCollect.prototype.filterBlacklistName = function(field_data){\n    return _.filter(field_data, function(field){\n        return !_.contains(config.blacklistName, field.name);\n    });\n};\n\nCollect.prototype.filterBroken = function(field_data){\n    return _.filter(field_data, function(field){\n        return ('key' in field);\n    });\n};\n\nmodule.exports = new Collect();\n","module.exports = YoastACFAnalysisConfig;","var config = require( \"./config/config.js\" );\n\nmodule.exports = {\n    acf_version: parseInt(config.acfVersion, 10)\n};","/* global jQuery, YoastACFAnalysis: true */\n\nvar App = require( \"./app.js\" );\n\n(function($) {\n\n    $(document).ready(function() {\n\n        if( \"undefined\" !== typeof YoastSEO){\n\n            YoastACFAnalysis = new App();\n\n        }\n\n    });\n\n}(jQuery));","/* global _, jQuery, YoastSEO, YoastReplaceVarPlugin */\n\nvar config = require( \"./config/config.js\" );\n\nvar ReplaceVar = YoastReplaceVarPlugin.ReplaceVar;\n\nvar supportedTypes = ['email', 'text', 'textarea', 'url', 'wysiwyg'];\n\nvar createReplaceVars = function (collect) {\n    if (ReplaceVar === undefined) {\n        if (config.debug) {\n            console.log('Replacing ACF variables in the Snippet Window requires the latest version of wordpress-seo.');\n        }\n        return;\n    }\n\n    fieldData   = _.filter(collect.getFieldData(), function (field) { return _.contains(supportedTypes, field.type) });\n    replaceVars = {}\n\n    _.each(fieldData, function(field) {\n        // Remove HTML tags using jQuery in case of a wysiwyg field.\n        var content = (field.type === 'wysiwyg') ? jQuery( jQuery.parseHTML( field.content) ).text() : field.content;\n\n        replaceVars[field.name] = new ReplaceVar( '%%cf_'+field.name+'%%', content, { source: 'direct' } );\n        YoastSEO.wp.replaceVarsPlugin.addReplacement( replaceVars[field.name] );\n        if (config.debug) {\n            console.log(\"Created ReplaceVar for: \", field.name, \" with: \", content, replaceVars[field.name]);\n        }\n    });\n\n    return replaceVars;\n};\n\nvar updateReplaceVars = function (collect, replace_vars) {\n    if (ReplaceVar === undefined) {\n        if (config.debug) {\n            console.log('Replacing ACF variables in the Snippet Window requires the latest version of wordpress-seo.');\n        }\n        return;\n    }\n\n    fieldData = _.filter(collect.getFieldData(), function (field) { return _.contains(supportedTypes, field.type) });\n    _.each(fieldData, function(field) {\n        // Remove HTML tags using jQuery in case of a wysiwyg field.\n        var content = (field.type === 'wysiwyg') ? jQuery(jQuery.parseHTML(field.content)).text() : field.content;\n\n        replaceVars[field.name].replacement = content;\n        if (config.debug) {\n            console.log(\"Updated ReplaceVar for: \", field.name, \" with: \", content, replaceVars[field.name]);\n        }\n    });\n};\n\nmodule.exports = {\n    createReplaceVars: createReplaceVars,\n    updateReplaceVars: updateReplaceVars\n};\n","/* global _ */\nvar config = require( \"./config/config.js\" );\n\nvar scraperObjects = {\n\n    //Basic\n    'text':         require( \"./scraper/scraper.text.js\" ),\n    'textarea':     require( \"./scraper/scraper.textarea.js\" ),\n    'email':        require( \"./scraper/scraper.email.js\" ),\n    'url':          require( \"./scraper/scraper.url.js\" ),\n\n    //Content\n    'wysiwyg':      require( \"./scraper/scraper.wysiwyg.js\" ),\n    //TODO: Add oembed handler\n    'image':        require( \"./scraper/scraper.image.js\" ),\n    'gallery':      require( \"./scraper/scraper.gallery.js\" ),\n\n    //Choice\n    //TODO: select, checkbox, radio\n\n    //Relational\n    'taxonomy':     require( \"./scraper/scraper.taxonomy.js\" )\n\n    //jQuery\n    //TODO: google_map, date_picker, color_picker\n\n};\n\nvar scrapers = {};\n\n/**\n * Set a scraper object on the store. Existing scrapers will be overwritten.\n *\n * @param {Object} scraper\n * @param {string} type\n */\nvar setScraper = function(scraper, type){\n\n    if(config.debug && hasScraper(type)){\n        console.warn('Scraper for \"' + type + '\" already exists and will be overwritten.' );\n    }\n\n    scrapers[type] = scraper;\n\n    return scraper;\n};\n\n/**\n * Returns the scraper object for a field type.\n * If there is no scraper object for this field type a no-op scraper is returned.\n *\n * @param {string} type\n * @returns {Object}\n */\nvar getScraper = function(type){\n\n    if(hasScraper(type)){\n        return scrapers[type];\n    }else if(type in scraperObjects){\n        return setScraper(new scraperObjects[type](), type);\n    }else{\n        //If we do not have a scraper just pass the fields through so it will be filtered out by the app.\n        return {\n            scrape: function(fields){\n                if(config.debug){\n                    console.warn('No Scraper for field type: ' + type );\n                }\n                return fields;\n            }\n        };\n    }\n}\n\n/**\n * Checks if there already is a scraper for a field type in the store.\n *\n * @param {string} type\n * @returns {boolean}\n */\nvar hasScraper = function(type){\n\n    return (type in scrapers);\n\n};\n\nmodule.exports = {\n\n    setScraper: setScraper,\n    getScraper: getScraper\n\n};","var scrapers = require( \"./../scraper-store.js\" );\n\nvar Scraper = function() {};\n\nScraper.prototype.scrape = function(fields){\n\n    var that = this;\n\n    fields = _.map(fields, function(field){\n\n        if(field.type !== 'email'){\n            return field;\n        }\n\n        field.content = field.$el.find('input[type=email][id^=acf]').val();\n\n        return field;\n    });\n\n    return fields;\n\n};\n\nmodule.exports = Scraper;","var attachmentCache = require( \"./../cache/cache.attachments.js\" );\nvar scrapers = require( \"./../scraper-store.js\" );\n\nvar Scraper = function() {};\n\nScraper.prototype.scrape = function(fields){\n\n    var that = this;\n\n    var attachment_ids = [];\n\n    fields = _.map(fields, function(field){\n\n        if(field.type !== 'gallery'){\n            return field;\n        }\n\n        field.content = '';\n\n        field.$el.find('.acf-gallery-attachment input[type=hidden]').each( function (index, element){\n\n            //TODO: Is this the best way to get the attachment id?\n            var attachment_id = jQuery( this ).val();\n\n            //Collect all attachment ids for cache refresh\n            attachment_ids.push(attachment_id);\n\n            //If we have the attachment data in the cache we can return a useful value\n            if(attachmentCache.get(attachment_id, 'attachment')){\n\n                var attachment = attachmentCache.get(attachment_id, 'attachment');\n\n                field.content += '<img src=\"' + attachment.url + '\" alt=\"' + attachment.alt + '\" title=\"' + attachment.title + '\">';\n\n            }\n\n        });\n\n        return field;\n    });\n\n    attachmentCache.refresh(attachment_ids);\n\n    return fields;\n\n};\n\nmodule.exports = Scraper;","var attachmentCache = require( \"./../cache/cache.attachments.js\" );\nvar scrapers = require( \"./../scraper-store.js\" );\n\nvar Scraper = function() {};\n\nScraper.prototype.scrape = function(fields){\n\n    var that = this;\n\n    var attachment_ids = [];\n\n    fields = _.map(fields, function(field){\n\n        if(field.type !== 'image'){\n            return field;\n        }\n\n        field.content = '';\n\n        var attachment_id = field.$el.find('input[type=hidden]').val();\n\n        attachment_ids.push(attachment_id);\n\n        if(attachmentCache.get(attachment_id, 'attachment')){\n\n            var attachment = attachmentCache.get(attachment_id, 'attachment');\n\n            field.content += '<img src=\"' + attachment.url + '\" alt=\"' + attachment.alt + '\" title=\"' + attachment.title + '\">';\n\n        }\n\n\n        return field;\n    });\n\n    attachmentCache.refresh(attachment_ids);\n\n    return fields;\n\n};\n\nmodule.exports = Scraper;","var scrapers = require( \"./../scraper-store.js\" );\n\nvar Scraper = function() {};\n\nScraper.prototype.scrape = function(fields){\n\n    var that = this;\n\n    fields = _.map(fields, function(field){\n\n        if(field.type !== 'taxonomy'){\n            return field;\n        }\n\n        var terms = [];\n\n        if( field.$el.find('.acf-taxonomy-field[data-type=\"multi_select\"]').length > 0 ){\n\n            terms = _.pluck(\n                field.$el.find('.acf-taxonomy-field[data-type=\"multi_select\"] input')\n                    .select2('data')\n                , 'text'\n            );\n\n        }else if( field.$el.find('.acf-taxonomy-field[data-type=\"checkbox\"]').length > 0 ){\n\n            terms = _.pluck(\n                field.$el.find('.acf-taxonomy-field[data-type=\"checkbox\"] input[type=\"checkbox\"]:checked')\n                    .next(),\n                'textContent'\n            );\n\n        }else if( field.$el.find('input[type=checkbox]:checked').length > 0 ){\n\n            terms = _.pluck(\n                field.$el.find('input[type=checkbox]:checked')\n                    .parent(),\n                'textContent'\n            );\n\n        }else if( field.$el.find('select option:checked').length > 0 ){\n\n            terms = _.pluck(\n                field.$el.find('select option:checked'),\n                'textContent'\n            );\n\n        }\n\n        terms = _.map( terms, function(term){ return term.trim(); } );\n\n        if(terms.length>0){\n            field.content = '<ul>\\n<li>' + terms.join('</li>\\n<li>') + '</li>\\n</ul>';\n        }\n\n        return field;\n    });\n\n    return fields;\n\n};\n\nmodule.exports = Scraper;","var config = require( \"./../config/config.js\" );\nvar scrapers = require( \"./../scraper-store.js\" );\n\nvar Scraper = function() {};\n\nScraper.prototype.scrape = function(fields){\n\n    var that = this;\n\n    fields = _.map(fields, function(field){\n\n        if(field.type !== 'text'){\n            return field;\n        }\n\n        field.content = field.$el.find('input[type=text][id^=acf]').val();\n\n        field = that.wrapInHeadline(field);\n\n        return field;\n    });\n\n    return fields;\n\n};\n\nScraper.prototype.wrapInHeadline = function(field){\n\n    var level = this.isHeadline(field);\n    if(level){\n        field.content = '<h' + level + '>' + field.content + '</h' + level + '>';\n    }\n\n    return field;\n};\n\nScraper.prototype.isHeadline = function(field){\n\n    var level = false;\n\n    var level = _.find(config.scraper.text.headlines, function(value, key){\n        return field.key === key;\n    });\n\n    //It has to be an integer\n    if(level){\n        level = parseInt(level, 10);\n    }\n\n    //Headlines only exist from h1 to h6\n    if(level<1 || level>6){\n        level = false;\n    }\n\n    return level;\n\n};\n\nmodule.exports = Scraper;","var scrapers = require( \"./../scraper-store.js\" );\n\nvar Scraper = function() {};\n\nScraper.prototype.scrape = function(fields){\n\n    var that = this;\n\n    fields = _.map(fields, function(field){\n\n        if(field.type !== 'textarea'){\n            return field;\n        }\n\n        field.content = field.$el.find('textarea[id^=acf]').val();\n\n        return field;\n    });\n\n    return fields;\n\n};\n\nmodule.exports = Scraper;","var scrapers = require( \"./../scraper-store.js\" );\n\nvar Scraper = function() {};\n\nScraper.prototype.scrape = function(fields){\n\n    var that = this;\n\n    fields = _.map(fields, function(field){\n\n        if(field.type !== 'url'){\n            return field;\n        }\n\n        field.content = field.$el.find('input[type=url][id^=acf]').val();\n\n        return field;\n    });\n\n    return fields;\n\n};\n\nmodule.exports = Scraper;","var scrapers = require( \"./../scraper-store.js\" );\n\nvar Scraper = function() {};\n\nScraper.prototype.scrape = function(fields){\n\n    var that = this;\n\n    fields = _.map(fields, function(field){\n\n        if(field.type !== 'wysiwyg'){\n            return field;\n        }\n\n        field.content = getContentTinyMCE(field);\n\n        return field;\n    });\n\n    return fields;\n\n};\n\n/**\n * Adapted from wp-seo-shortcode-plugin-305.js:115-126\n *\n * @returns {string}\n */\nvar getContentTinyMCE = function(field) {\n    var textarea = field.$el.find('textarea')[0];\n\n    var editorID = textarea.id;\n\n    var val = textarea.value;\n\n    if ( isTinyMCEAvailable(editorID) ) {\n        val = tinyMCE.get( editorID ) && tinyMCE.get( editorID ).getContent() || '';\n    }\n\n    return val;\n};\n\n/**\n * Adapted from wp-seo-post-scraper-plugin-310.js:196-210\n *\n *\n * @param editorID\n * @returns {boolean}\n */\nvar isTinyMCEAvailable = function(editorID) {\n    if ( typeof tinyMCE === 'undefined' ||\n        typeof tinyMCE.editors === 'undefined' ||\n        tinyMCE.editors.length === 0 ||\n        tinyMCE.get( editorID ) === null ||\n        tinyMCE.get( editorID ).isHidden() ) {\n        return false;\n    }\n\n    return true;\n};\n\nmodule.exports = Scraper;"]} +},{"./../scraper-store.js":11}]},{},[9]); From 16d6b8807e292cb1feacf1ecc36303943a3e4656 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Thomas=20Kr=C3=A4ftner?= Date: Tue, 12 Sep 2017 15:44:39 +0200 Subject: [PATCH 3/3] simplify checks by just checking if the scraper JS is enqueued --- inc/class-yoast-acf-analysis-assets.php | 48 +++---------------------- 1 file changed, 5 insertions(+), 43 deletions(-) diff --git a/inc/class-yoast-acf-analysis-assets.php b/inc/class-yoast-acf-analysis-assets.php index 2ffb37db..975c6881 100755 --- a/inc/class-yoast-acf-analysis-assets.php +++ b/inc/class-yoast-acf-analysis-assets.php @@ -15,7 +15,7 @@ class Yoast_ACF_Analysis_Assets { public function init() { $this->plugin_data = get_plugin_data( dirname( AC_SEO_ACF_ANALYSIS_PLUGIN_FILE ) ); - add_filter( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ) ); + add_filter( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ), 11 ); } /** @@ -28,11 +28,11 @@ public function enqueue_scripts() { $config = Yoast_ACF_Analysis_Facade::get_registry()->get( 'config' ); // Post page enqueue. - if ( $this->is_metabox_active() ) { + if ( wp_script_is( WPSEO_Admin_Asset_Manager::PREFIX . 'post-scraper' ) ) { wp_enqueue_script( 'yoast-acf-analysis-post', plugins_url( '/js/yoast-acf-analysis.js', AC_SEO_ACF_ANALYSIS_PLUGIN_FILE ), - array( 'jquery', 'yoast-seo-post-scraper', 'underscore' ), + array( 'jquery', WPSEO_Admin_Asset_Manager::PREFIX . 'post-scraper', 'underscore' ), $this->plugin_data['Version'], true ); @@ -41,11 +41,11 @@ public function enqueue_scripts() { } // Term page enqueue. - if ( 'term.php' === $pagenow ) { + if ( wp_script_is( WPSEO_Admin_Asset_Manager::PREFIX . 'term-scraper' ) ) { wp_enqueue_script( 'yoast-acf-analysis-term', plugins_url( '/js/yoast-acf-analysis.js', AC_SEO_ACF_ANALYSIS_PLUGIN_FILE ), - array( 'jquery', 'yoast-seo-term-scraper' ), + array( 'jquery', WPSEO_Admin_Asset_Manager::PREFIX . 'term-scraper' ), $this->plugin_data['Version'], true ); @@ -54,42 +54,4 @@ public function enqueue_scripts() { } } - /** - * Test if the Metabox is actually active for the edit screen we are at. - * - * Adapted from Yoast SEO. - * - * @see WPSEO_Metabox::enqueue() - */ - public function is_metabox_active() { - - global $pagenow; - - // This is just an additional security net to ensure the global var is present. - if ( empty( $GLOBALS['wpseo_metabox'] ) || ! ( $GLOBALS['wpseo_metabox'] instanceof WPSEO_Metabox ) ) { - return false; - } - - /* @var $wpseo_metabox WPSEO_Metabox */ - $wpseo_metabox = $GLOBALS['wpseo_metabox']; - - $is_editor = WPSEO_Metabox::is_post_edit( $pagenow ); - - if ( - ( - ! $is_editor - && - /* Filter 'wpseo_always_register_metaboxes_on_admin' documented in wpseo-main.php */ - apply_filters( 'wpseo_always_register_metaboxes_on_admin', false ) === false - ) - || - $wpseo_metabox->is_metabox_hidden() === true - ) { - return false; - } - - return true; - - } - }