Version Description
Download this release
Release Info
Developer | hallsofmontezuma |
Plugin | All in One SEO Pack |
Version | 2.4 |
Comparing to | |
See all releases |
Code changes from version 2.3.16 to 2.4
- admin/aioseop_module_class.php +7 -4
- aioseop_class.php +41 -21
- all_in_one_seo_pack.php +4 -4
- css/modules/aioseop_module-rtl.css +1 -2
- css/modules/aioseop_module.css +155 -87
- inc/commonstrings.php +22 -5
- inc/sitemap-xsl.php +5 -1
- modules/aioseop_sitemap.php +143 -19
- public/google-analytics.php +90 -122
- readme.txt +3 -2
admin/aioseop_module_class.php
CHANGED
@@ -1338,8 +1338,12 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Module' ) ) {
|
|
1338 |
}
|
1339 |
|
1340 |
/**
|
1341 |
-
*
|
1342 |
-
*
|
|
|
|
|
|
|
|
|
1343 |
*
|
1344 |
* @return array
|
1345 |
*/
|
@@ -1386,10 +1390,9 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Module' ) ) {
|
|
1386 |
}
|
1387 |
|
1388 |
if ( ! empty( $meta_key ) && ! empty( $post ) ) {
|
1389 |
-
$meta_key = explode( ',', $meta_key );
|
1390 |
$image = $this->get_the_image_by_meta_key( array(
|
1391 |
'post_id' => $post->ID,
|
1392 |
-
'meta_key' => $meta_key,
|
1393 |
) );
|
1394 |
if ( ! empty( $image ) ) {
|
1395 |
$img[] = array( 'type' => 'meta_key', 'id' => $meta_key, 'link' => $image );
|
1338 |
}
|
1339 |
|
1340 |
/**
|
1341 |
+
* Returns available social seo images.
|
1342 |
+
*
|
1343 |
+
* @since 2.4 #1079 Fixes array_flip warning on opengraph module.
|
1344 |
+
*
|
1345 |
+
* @param array $options Plugin/module options.
|
1346 |
+
* @param object $p Post.
|
1347 |
*
|
1348 |
* @return array
|
1349 |
*/
|
1390 |
}
|
1391 |
|
1392 |
if ( ! empty( $meta_key ) && ! empty( $post ) ) {
|
|
|
1393 |
$image = $this->get_the_image_by_meta_key( array(
|
1394 |
'post_id' => $post->ID,
|
1395 |
+
'meta_key' => explode( ',', $meta_key ),
|
1396 |
) );
|
1397 |
if ( ! empty( $image ) ) {
|
1398 |
$img[] = array( 'type' => 'meta_key', 'id' => $meta_key, 'link' => $image );
|
aioseop_class.php
CHANGED
@@ -54,6 +54,8 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
54 |
|
55 |
/**
|
56 |
* All_in_One_SEO_Pack constructor.
|
|
|
|
|
57 |
*/
|
58 |
function __construct() {
|
59 |
global $aioseop_options;
|
@@ -1161,6 +1163,8 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
1161 |
/**
|
1162 |
* Use custom callback for outputting snippet
|
1163 |
*
|
|
|
|
|
1164 |
* @param $buf
|
1165 |
* @param $args
|
1166 |
*
|
@@ -1178,10 +1182,16 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
1178 |
}
|
1179 |
|
1180 |
if ( $this->strlen( $title ) > 70 ) {
|
1181 |
-
$title = $this->trim_excerpt_without_filters(
|
|
|
|
|
|
|
1182 |
}
|
1183 |
if ( $this->strlen( $description ) > 156 ) {
|
1184 |
-
$description = $this->trim_excerpt_without_filters(
|
|
|
|
|
|
|
1185 |
}
|
1186 |
$extra_title_len = 0;
|
1187 |
if ( empty( $title_format ) ) {
|
@@ -1263,12 +1273,11 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
1263 |
|
1264 |
$title_format = preg_replace( '/%([^%]*?)%/', '', $title_format );
|
1265 |
$title = $title_format;
|
1266 |
-
$extra_title_len = strlen( str_replace( $replace_title, '', $title_format ) );
|
1267 |
}
|
1268 |
|
1269 |
$args['value'] = sprintf( $args['value'], $title, esc_url( $url ), esc_attr( $description ) );
|
1270 |
-
$
|
1271 |
-
$args['value'] .= "<script>var aiosp_title_extra = {$extra_title_len};</script>";
|
1272 |
$buf = $this->get_option_row( $args['name'], $args['options'], $args );
|
1273 |
|
1274 |
return $buf;
|
@@ -2425,6 +2434,7 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
2425 |
|
2426 |
/**
|
2427 |
* @since 2.3.14 #932 Adds filter "aioseop_description", removes extra filtering.
|
|
|
2428 |
*
|
2429 |
* @param null $post
|
2430 |
*
|
@@ -2460,11 +2470,12 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
2460 |
}
|
2461 |
$description = $this->internationalize( $description );
|
2462 |
}
|
2463 |
-
if ( empty( $aioseop_options['aiosp_dont_truncate_descriptions'] ) ) {
|
2464 |
-
$description = $this->trim_excerpt_without_filters( $description );
|
2465 |
-
}
|
2466 |
|
2467 |
-
return apply_filters(
|
|
|
|
|
|
|
|
|
2468 |
}
|
2469 |
|
2470 |
/**
|
@@ -2525,6 +2536,7 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
2525 |
*
|
2526 |
* @since 2.3.13 #899 Fixes non breacking space, applies filter "aioseop_description".
|
2527 |
* @since 2.3.14 #932 Removes filter "aioseop_description".
|
|
|
2528 |
*
|
2529 |
* @param object $post Post object.
|
2530 |
*
|
@@ -2549,8 +2561,7 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
2549 |
if ( ! empty( $aioseop_options['aiosp_run_shortcodes'] ) ) {
|
2550 |
$content = do_shortcode( $content );
|
2551 |
}
|
2552 |
-
$
|
2553 |
-
$description = $this->trim_excerpt_without_filters( $this->internationalize( $content ) );
|
2554 |
}
|
2555 |
}
|
2556 |
|
@@ -3283,6 +3294,8 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
3283 |
}
|
3284 |
|
3285 |
/**
|
|
|
|
|
3286 |
* @param $settings
|
3287 |
* @param $location
|
3288 |
* @param $current
|
@@ -3331,8 +3344,8 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
3331 |
global $post;
|
3332 |
$info = $this->get_page_snippet_info();
|
3333 |
extract( $info );
|
3334 |
-
$settings["{$prefix}title"]['placeholder'] = $title;
|
3335 |
-
$settings["{$prefix}description"]['placeholder'] = $description;
|
3336 |
$settings["{$prefix}keywords"]['placeholder'] = $keywords;
|
3337 |
}
|
3338 |
|
@@ -3573,6 +3586,7 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
3573 |
*
|
3574 |
* @since 2.3.13 #899 Adds filter:aioseop_description.
|
3575 |
* @since 2.3.14 #593 Adds filter:aioseop_title.
|
|
|
3576 |
*/
|
3577 |
function add_hooks() {
|
3578 |
global $aioseop_options, $aioseop_update_checker;
|
@@ -3615,7 +3629,7 @@ class All_in_One_SEO_Pack extends All_in_One_SEO_Pack_Module {
|
|
3615 |
add_action( 'amp_post_template_head', array( $this, 'amp_head' ), 11 );
|
3616 |
add_action( 'template_redirect', array( $this, 'template_redirect' ), 0 );
|
3617 |
}
|
3618 |
-
add_filter( 'aioseop_description', array( &$this, 'filter_description' ) );
|
3619 |
add_filter( 'aioseop_title', array( &$this, 'filter_title' ) );
|
3620 |
}
|
3621 |
|
@@ -4891,12 +4905,14 @@ EOF;
|
|
4891 |
* @since 2.3.14 Strips excerpt anchor texts.
|
4892 |
* @since 2.3.14 Encodes to SEO ready HTML entities.
|
4893 |
* @since 2.3.14 #593 encode/decode refactored.
|
|
|
4894 |
*
|
4895 |
-
* @param string $value
|
|
|
4896 |
*
|
4897 |
* @return string
|
4898 |
*/
|
4899 |
-
public function filter_description( $value) {
|
4900 |
if ( preg_match( '/5.2[\s\S]+/', PHP_VERSION ) )
|
4901 |
$value = htmlspecialchars( wp_strip_all_tags( htmlspecialchars_decode( $value ) ) );
|
4902 |
// Decode entities
|
@@ -4914,12 +4930,15 @@ EOF;
|
|
4914 |
);
|
4915 |
// Strip html
|
4916 |
$value = wp_strip_all_tags( $value );
|
4917 |
-
//
|
4918 |
-
$value =
|
4919 |
// Internal whitespace trim.
|
4920 |
$value = preg_replace( '/\s\s+/u', ' ', $value );
|
4921 |
-
//
|
4922 |
-
|
|
|
|
|
|
|
4923 |
}
|
4924 |
|
4925 |
/**
|
@@ -4928,6 +4947,7 @@ EOF;
|
|
4928 |
*
|
4929 |
* @since 2.3.14
|
4930 |
* @since 2.3.14.2 Hot fix on apostrophes.
|
|
|
4931 |
*
|
4932 |
* @param string $value Value to decode.
|
4933 |
*
|
@@ -4939,7 +4959,7 @@ EOF;
|
|
4939 |
array(
|
4940 |
'/\“|\”|&#[xX]00022;|"|&[lLrRbB](dquo|DQUO)(?:[rR])?;|&#[xX]0201[dDeE];'
|
4941 |
.'|&[OoCc](pen|lose)[Cc]urly[Dd]ouble[Qq]uote;|̶[012];|&#[xX]27;/', // Double quotes
|
4942 |
-
'/’|'/', // Apostrophes
|
4943 |
),
|
4944 |
array(
|
4945 |
'"', // Double quotes
|
54 |
|
55 |
/**
|
56 |
* All_in_One_SEO_Pack constructor.
|
57 |
+
*
|
58 |
+
* @since 2.3.14 #921 More google analytics options added.
|
59 |
*/
|
60 |
function __construct() {
|
61 |
global $aioseop_options;
|
1163 |
/**
|
1164 |
* Use custom callback for outputting snippet
|
1165 |
*
|
1166 |
+
* @since 2.3.16 Decodes HTML entities on title, description and title length count.
|
1167 |
+
*
|
1168 |
* @param $buf
|
1169 |
* @param $args
|
1170 |
*
|
1182 |
}
|
1183 |
|
1184 |
if ( $this->strlen( $title ) > 70 ) {
|
1185 |
+
$title = $this->trim_excerpt_without_filters(
|
1186 |
+
$this->html_entity_decode( $title ),
|
1187 |
+
70
|
1188 |
+
) . '...';
|
1189 |
}
|
1190 |
if ( $this->strlen( $description ) > 156 ) {
|
1191 |
+
$description = $this->trim_excerpt_without_filters(
|
1192 |
+
$this->html_entity_decode( $description ),
|
1193 |
+
156
|
1194 |
+
) . '...';
|
1195 |
}
|
1196 |
$extra_title_len = 0;
|
1197 |
if ( empty( $title_format ) ) {
|
1273 |
|
1274 |
$title_format = preg_replace( '/%([^%]*?)%/', '', $title_format );
|
1275 |
$title = $title_format;
|
1276 |
+
$extra_title_len = strlen( $this->html_entity_decode( str_replace( $replace_title, '', $title_format ) ) );
|
1277 |
}
|
1278 |
|
1279 |
$args['value'] = sprintf( $args['value'], $title, esc_url( $url ), esc_attr( $description ) );
|
1280 |
+
$args['value'] .= '<script>var aiosp_title_extra = '. (int) $extra_title_len . ';</script>';
|
|
|
1281 |
$buf = $this->get_option_row( $args['name'], $args['options'], $args );
|
1282 |
|
1283 |
return $buf;
|
2434 |
|
2435 |
/**
|
2436 |
* @since 2.3.14 #932 Adds filter "aioseop_description", removes extra filtering.
|
2437 |
+
* @since 2.4 #951 Trim/truncates occurs inside filter "aioseop_description".
|
2438 |
*
|
2439 |
* @param null $post
|
2440 |
*
|
2470 |
}
|
2471 |
$description = $this->internationalize( $description );
|
2472 |
}
|
|
|
|
|
|
|
2473 |
|
2474 |
+
return apply_filters(
|
2475 |
+
'aioseop_description',
|
2476 |
+
$description,
|
2477 |
+
empty( $aioseop_options['aiosp_dont_truncate_descriptions'] )
|
2478 |
+
);
|
2479 |
}
|
2480 |
|
2481 |
/**
|
2536 |
*
|
2537 |
* @since 2.3.13 #899 Fixes non breacking space, applies filter "aioseop_description".
|
2538 |
* @since 2.3.14 #932 Removes filter "aioseop_description".
|
2539 |
+
* @since 2.4 #951 Removes "wp_strip_all_tags" and "trim_excerpt_without_filters", they are done later in filter.
|
2540 |
*
|
2541 |
* @param object $post Post object.
|
2542 |
*
|
2561 |
if ( ! empty( $aioseop_options['aiosp_run_shortcodes'] ) ) {
|
2562 |
$content = do_shortcode( $content );
|
2563 |
}
|
2564 |
+
$description =$this->internationalize( $content );
|
|
|
2565 |
}
|
2566 |
}
|
2567 |
|
3294 |
}
|
3295 |
|
3296 |
/**
|
3297 |
+
* @since 2.3.16 Forces HTML entity decode on placeholder values.
|
3298 |
+
*
|
3299 |
* @param $settings
|
3300 |
* @param $location
|
3301 |
* @param $current
|
3344 |
global $post;
|
3345 |
$info = $this->get_page_snippet_info();
|
3346 |
extract( $info );
|
3347 |
+
$settings["{$prefix}title"]['placeholder'] = $this->html_entity_decode( $title );
|
3348 |
+
$settings["{$prefix}description"]['placeholder'] = $this->html_entity_decode( $description );
|
3349 |
$settings["{$prefix}keywords"]['placeholder'] = $keywords;
|
3350 |
}
|
3351 |
|
3586 |
*
|
3587 |
* @since 2.3.13 #899 Adds filter:aioseop_description.
|
3588 |
* @since 2.3.14 #593 Adds filter:aioseop_title.
|
3589 |
+
* @since 2.4 #951 Increases filter:aioseop_description arguments number.
|
3590 |
*/
|
3591 |
function add_hooks() {
|
3592 |
global $aioseop_options, $aioseop_update_checker;
|
3629 |
add_action( 'amp_post_template_head', array( $this, 'amp_head' ), 11 );
|
3630 |
add_action( 'template_redirect', array( $this, 'template_redirect' ), 0 );
|
3631 |
}
|
3632 |
+
add_filter( 'aioseop_description', array( &$this, 'filter_description' ), 10, 2 );
|
3633 |
add_filter( 'aioseop_title', array( &$this, 'filter_title' ) );
|
3634 |
}
|
3635 |
|
4905 |
* @since 2.3.14 Strips excerpt anchor texts.
|
4906 |
* @since 2.3.14 Encodes to SEO ready HTML entities.
|
4907 |
* @since 2.3.14 #593 encode/decode refactored.
|
4908 |
+
* @since 2.4 #951 Reorders filters/encodings/decondings applied and adds additional param.
|
4909 |
*
|
4910 |
+
* @param string $value Value to filter.
|
4911 |
+
* @param bool $truncate Flag that indicates if value should be truncated/cropped.
|
4912 |
*
|
4913 |
* @return string
|
4914 |
*/
|
4915 |
+
public function filter_description( $value, $truncate = false ) {
|
4916 |
if ( preg_match( '/5.2[\s\S]+/', PHP_VERSION ) )
|
4917 |
$value = htmlspecialchars( wp_strip_all_tags( htmlspecialchars_decode( $value ) ) );
|
4918 |
// Decode entities
|
4930 |
);
|
4931 |
// Strip html
|
4932 |
$value = wp_strip_all_tags( $value );
|
4933 |
+
// External trim
|
4934 |
+
$value = trim( $value );
|
4935 |
// Internal whitespace trim.
|
4936 |
$value = preg_replace( '/\s\s+/u', ' ', $value );
|
4937 |
+
// Truncate / crop
|
4938 |
+
if ( ! empty( $truncate ) )
|
4939 |
+
$value = $this->trim_excerpt_without_filters( $value );
|
4940 |
+
// Encode to valid SEO html entities
|
4941 |
+
return $this->seo_entity_encode( $value );
|
4942 |
}
|
4943 |
|
4944 |
/**
|
4947 |
*
|
4948 |
* @since 2.3.14
|
4949 |
* @since 2.3.14.2 Hot fix on apostrophes.
|
4950 |
+
* @since 2.3.16 ' Added to the list of apostrophes.
|
4951 |
*
|
4952 |
* @param string $value Value to decode.
|
4953 |
*
|
4959 |
array(
|
4960 |
'/\“|\”|&#[xX]00022;|"|&[lLrRbB](dquo|DQUO)(?:[rR])?;|&#[xX]0201[dDeE];'
|
4961 |
.'|&[OoCc](pen|lose)[Cc]urly[Dd]ouble[Qq]uote;|̶[012];|&#[xX]27;/', // Double quotes
|
4962 |
+
'/'|’|'/', // Apostrophes
|
4963 |
),
|
4964 |
array(
|
4965 |
'"', // Double quotes
|
all_in_one_seo_pack.php
CHANGED
@@ -3,7 +3,7 @@
|
|
3 |
Plugin Name: All In One SEO Pack
|
4 |
Plugin URI: https://semperplugins.com/all-in-one-seo-pack-pro-version/
|
5 |
Description: Out-of-the-box SEO for your WordPress blog. Features like XML Sitemaps, SEO for custom post types, SEO for blogs or business sites, SEO for ecommerce sites, and much more. More than 30 million downloads since 2007.
|
6 |
-
Version: 2.
|
7 |
Author: Michael Torbert
|
8 |
Author URI: https://semperplugins.com/all-in-one-seo-pack-pro-version/
|
9 |
Text Domain: all-in-one-seo-pack
|
@@ -31,14 +31,14 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
31 |
* The original WordPress SEO plugin.
|
32 |
*
|
33 |
* @package All-in-One-SEO-Pack
|
34 |
-
* @version 2.
|
35 |
*/
|
36 |
|
37 |
if ( ! defined( 'AIOSEOPPRO' ) ) {
|
38 |
define( 'AIOSEOPPRO', false );
|
39 |
}
|
40 |
if ( ! defined( 'AIOSEOP_VERSION' ) ) {
|
41 |
-
define( 'AIOSEOP_VERSION', '2.
|
42 |
}
|
43 |
global $aioseop_plugin_name;
|
44 |
$aioseop_plugin_name = 'All in One SEO Pack';
|
@@ -233,7 +233,7 @@ if ( AIOSEOPPRO ) {
|
|
233 |
$aioseop_update_checker->license_key = '';
|
234 |
}
|
235 |
$aioseop_update_checker->options_page = AIOSEOP_PLUGIN_DIRNAME . "/aioseop_class.php";
|
236 |
-
$aioseop_update_checker->renewal_page = 'https://semperplugins.com/all-in-one-seo-pack-pro-
|
237 |
|
238 |
$aioseop_update_checker->addQueryArgFilter( array( $aioseop_update_checker, 'add_secret_key' ) );
|
239 |
}
|
3 |
Plugin Name: All In One SEO Pack
|
4 |
Plugin URI: https://semperplugins.com/all-in-one-seo-pack-pro-version/
|
5 |
Description: Out-of-the-box SEO for your WordPress blog. Features like XML Sitemaps, SEO for custom post types, SEO for blogs or business sites, SEO for ecommerce sites, and much more. More than 30 million downloads since 2007.
|
6 |
+
Version: 2.4
|
7 |
Author: Michael Torbert
|
8 |
Author URI: https://semperplugins.com/all-in-one-seo-pack-pro-version/
|
9 |
Text Domain: all-in-one-seo-pack
|
31 |
* The original WordPress SEO plugin.
|
32 |
*
|
33 |
* @package All-in-One-SEO-Pack
|
34 |
+
* @version 2.4
|
35 |
*/
|
36 |
|
37 |
if ( ! defined( 'AIOSEOPPRO' ) ) {
|
38 |
define( 'AIOSEOPPRO', false );
|
39 |
}
|
40 |
if ( ! defined( 'AIOSEOP_VERSION' ) ) {
|
41 |
+
define( 'AIOSEOP_VERSION', '2.4' );
|
42 |
}
|
43 |
global $aioseop_plugin_name;
|
44 |
$aioseop_plugin_name = 'All in One SEO Pack';
|
233 |
$aioseop_update_checker->license_key = '';
|
234 |
}
|
235 |
$aioseop_update_checker->options_page = AIOSEOP_PLUGIN_DIRNAME . "/aioseop_class.php";
|
236 |
+
$aioseop_update_checker->renewal_page = 'https://semperplugins.com/all-in-one-seo-pack-pro-version/';
|
237 |
|
238 |
$aioseop_update_checker->addQueryArgFilter( array( $aioseop_update_checker, 'add_secret_key' ) );
|
239 |
}
|
css/modules/aioseop_module-rtl.css
CHANGED
@@ -46,7 +46,6 @@
|
|
46 |
}
|
47 |
|
48 |
.aioseop input[type="text"] {
|
49 |
-
height: 35px;
|
50 |
padding: 2px 10px 2px 0
|
51 |
}
|
52 |
|
@@ -317,4 +316,4 @@ form#aiosp_settings_form,
|
|
317 |
|
318 |
#aioseop-about .aioseop_metabox_text ul {
|
319 |
padding-right: 15px;
|
320 |
-
}
|
46 |
}
|
47 |
|
48 |
.aioseop input[type="text"] {
|
|
|
49 |
padding: 2px 10px 2px 0
|
50 |
}
|
51 |
|
316 |
|
317 |
#aioseop-about .aioseop_metabox_text ul {
|
318 |
padding-right: 15px;
|
319 |
+
}
|
css/modules/aioseop_module.css
CHANGED
@@ -32,23 +32,18 @@
|
|
32 |
padding-top: 2px;
|
33 |
outline: none;
|
34 |
color: #888;
|
35 |
-
border: 2px solid #888;
|
36 |
-
border-radius: 33px;
|
37 |
-
width: 22px;
|
38 |
-
height: 20px;
|
39 |
font-family: sans-serif;
|
40 |
}
|
41 |
|
42 |
.aioseop_help_text_link span {
|
43 |
-
position: absolute;
|
44 |
-
left: 21px;
|
45 |
font-size: 14px;
|
46 |
}
|
47 |
|
48 |
.aioseop_help_text_link:before {
|
49 |
-
|
50 |
-
|
51 |
-
|
|
|
52 |
}
|
53 |
|
54 |
#aioseop-support .aioseop_metabox_text,
|
@@ -92,10 +87,6 @@
|
|
92 |
background-image: url();
|
93 |
}
|
94 |
|
95 |
-
.aioseop_help_text_link.aioseop_meta_box_help:before {
|
96 |
-
font-size: 14px;
|
97 |
-
}
|
98 |
-
|
99 |
.aioseop_meta_box_help > label {
|
100 |
position: absolute;
|
101 |
margin-left: 8px;
|
@@ -136,11 +127,16 @@ div.aioseop_tip_icon:before {
|
|
136 |
position: relative;
|
137 |
}
|
138 |
|
|
|
|
|
|
|
|
|
|
|
|
|
139 |
.aioseop_label {
|
140 |
color: #5F5F5F;
|
141 |
font-weight: bold;
|
142 |
line-height: 19px;
|
143 |
-
padding-left: 10px; /*changed from 20px to 10px for certain language support*/
|
144 |
display: inline-block;
|
145 |
text-align: left;
|
146 |
position: absolute;
|
@@ -152,7 +148,7 @@ div.aioseop_tip_icon:before {
|
|
152 |
|
153 |
.aioseop_option_div {
|
154 |
max-height: 360px;
|
155 |
-
min-height:
|
156 |
width: 95%;
|
157 |
overflow-y: auto;
|
158 |
}
|
@@ -163,6 +159,7 @@ div.aioseop_tip_icon:before {
|
|
163 |
|
164 |
.aioseop input[type="text"] {
|
165 |
color: #515151;
|
|
|
166 |
padding: 10px 0 10px 10px;
|
167 |
font-size: 14px;
|
168 |
width: 95%;
|
@@ -182,7 +179,7 @@ div.aioseop_tip_icon:before {
|
|
182 |
.aioseop_help_text_div {
|
183 |
text-align: left;
|
184 |
width: 100%;
|
185 |
-
margin:
|
186 |
}
|
187 |
|
188 |
.aioseop_help_text {
|
@@ -290,9 +287,6 @@ div.aioseop_tip_icon:before {
|
|
290 |
clear: left;
|
291 |
}
|
292 |
|
293 |
-
.aioseop_options_wrapper {
|
294 |
-
}
|
295 |
-
|
296 |
.aioseop_options_wrapper .hndle {
|
297 |
font-size: 15px;
|
298 |
font-family: Georgia,
|
@@ -816,51 +810,6 @@ div.aioseop_feature#aioseop_coming_soon2 .aioseop_featured_image {
|
|
816 |
/* max-width: 900px; */
|
817 |
}
|
818 |
|
819 |
-
#aiosp div.preview_snippet {
|
820 |
-
border: 1px solid #ebebeb;
|
821 |
-
padding: 15px 15px 20px 7px;
|
822 |
-
background-color: #fff;
|
823 |
-
}
|
824 |
-
|
825 |
-
div#aioseop_snippet {
|
826 |
-
font-family: arial, sans-serif;
|
827 |
-
font-size: 13px;
|
828 |
-
}
|
829 |
-
|
830 |
-
div#aioseop_snippet > h3 {
|
831 |
-
font-size: 16px;
|
832 |
-
padding: 8px 0;
|
833 |
-
border: 0;
|
834 |
-
background: inherit;
|
835 |
-
}
|
836 |
-
|
837 |
-
div#aioseop_snippet > h3 > a {
|
838 |
-
color: #12c;
|
839 |
-
text-decoration: none;
|
840 |
-
cursor: pointer;
|
841 |
-
}
|
842 |
-
|
843 |
-
div#aioseop_snippet > div {
|
844 |
-
color: #222;
|
845 |
-
max-width: 42em;
|
846 |
-
}
|
847 |
-
|
848 |
-
div#aioseop_snippet > div > div {
|
849 |
-
display: block;
|
850 |
-
margin-bottom: 1px;
|
851 |
-
}
|
852 |
-
|
853 |
-
div#aioseop_snippet > div > div > cite {
|
854 |
-
color: #093;
|
855 |
-
font-style: normal;
|
856 |
-
}
|
857 |
-
|
858 |
-
div#aioseop_snippet > div > span {
|
859 |
-
margin: 0;
|
860 |
-
padding: 0;
|
861 |
-
border: 0;
|
862 |
-
}
|
863 |
-
|
864 |
#aiosp_sitemap_addl_pages,
|
865 |
#aiosp_video_sitemap_addl_pages {
|
866 |
clear: left;
|
@@ -1029,6 +978,11 @@ table.aioseop_table td, table.aioseop_table th {
|
|
1029 |
height: 0;
|
1030 |
}
|
1031 |
|
|
|
|
|
|
|
|
|
|
|
1032 |
.aioseop_module.error.below-h2 {
|
1033 |
padding: 5px 0;
|
1034 |
margin: 0 477px 15px 0 !important;
|
@@ -1036,7 +990,6 @@ table.aioseop_table td, table.aioseop_table th {
|
|
1036 |
|
1037 |
#aioseop_opengraph_settings .inside {
|
1038 |
margin: 0;
|
1039 |
-
padding: 0;
|
1040 |
}
|
1041 |
|
1042 |
#aioseop_opengraph_settings_image_wrapper img {
|
@@ -1061,7 +1014,7 @@ table.aioseop_table td, table.aioseop_table th {
|
|
1061 |
}
|
1062 |
|
1063 |
#aiosp {
|
1064 |
-
width:
|
1065 |
}
|
1066 |
|
1067 |
.aioseop_input.aioseop_top_label .aioseop_option_input {
|
@@ -1199,37 +1152,21 @@ div.aioseop_notice a.aioseop_dismiss_link {
|
|
1199 |
}
|
1200 |
|
1201 |
.aioseop_header_tabs li a.aioseop_header_tab {
|
1202 |
-
|
1203 |
-
|
1204 |
-
Helvetica,
|
1205 |
-
sans-serif normal;
|
1206 |
text-decoration: none;
|
1207 |
margin: 5px 5px 0 0;
|
1208 |
-
padding:
|
1209 |
cursor: pointer;
|
1210 |
-webkit-border-top-right-radius: 3px;
|
1211 |
-webkit-border-top-left-radius: 3px;
|
1212 |
border-top-right-radius: 3px;
|
1213 |
border-top-left-radius: 3px;
|
1214 |
-
background-color:
|
1215 |
-
background-color: rgba(255, 255, 255, 0.5);
|
1216 |
border: 1px solid #ccc;
|
1217 |
color: #5F5F5F;
|
1218 |
}
|
1219 |
|
1220 |
-
/* Fix for Chrome */
|
1221 |
-
@media screen and (-webkit-min-device-pixel-ratio:0) {
|
1222 |
-
|
1223 |
-
.aioseop_header_tabs li a.aioseop_header_tab {
|
1224 |
-
padding-bottom: 0;
|
1225 |
-
}
|
1226 |
-
}
|
1227 |
-
|
1228 |
-
/* Fix for Safari */
|
1229 |
-
_:-webkit-full-screen:not(:root:root), .aioseop_header_tabs li a.aioseop_header_tab {
|
1230 |
-
padding-bottom: 2px;
|
1231 |
-
}
|
1232 |
-
|
1233 |
.aioseop_header_tabs li:first-child a.aioseop_header_tab {
|
1234 |
border-left: solid 1px #CCC;
|
1235 |
margin-left: 5px;
|
@@ -1239,7 +1176,7 @@ _:-webkit-full-screen:not(:root:root), .aioseop_header_tabs li a.aioseop_header_
|
|
1239 |
border: solid 1px #CCC;
|
1240 |
background-color: rgb(255, 255, 255);
|
1241 |
background-color: rgba(255, 255, 255, 0.5);
|
1242 |
-
padding
|
1243 |
}
|
1244 |
|
1245 |
.aioseop_loading {
|
@@ -1335,3 +1272,134 @@ div.sfwd_debug_error {
|
|
1335 |
margin-left: 20px !important;
|
1336 |
margin-bottom: 10px !important;
|
1337 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
32 |
padding-top: 2px;
|
33 |
outline: none;
|
34 |
color: #888;
|
|
|
|
|
|
|
|
|
35 |
font-family: sans-serif;
|
36 |
}
|
37 |
|
38 |
.aioseop_help_text_link span {
|
|
|
|
|
39 |
font-size: 14px;
|
40 |
}
|
41 |
|
42 |
.aioseop_help_text_link:before {
|
43 |
+
content: "\f223";
|
44 |
+
font-size: 27px;
|
45 |
+
font-family: dashicons;
|
46 |
+
vertical-align: middle;
|
47 |
}
|
48 |
|
49 |
#aioseop-support .aioseop_metabox_text,
|
87 |
background-image: url();
|
88 |
}
|
89 |
|
|
|
|
|
|
|
|
|
90 |
.aioseop_meta_box_help > label {
|
91 |
position: absolute;
|
92 |
margin-left: 8px;
|
127 |
position: relative;
|
128 |
}
|
129 |
|
130 |
+
.aioseop_tabs .aioseop_meta_box_help,
|
131 |
+
.aioseop_tabs .aioseop_meta_box_help:active {
|
132 |
+
margin-top: 4px;
|
133 |
+
margin-right: 45px;
|
134 |
+
}
|
135 |
+
|
136 |
.aioseop_label {
|
137 |
color: #5F5F5F;
|
138 |
font-weight: bold;
|
139 |
line-height: 19px;
|
|
|
140 |
display: inline-block;
|
141 |
text-align: left;
|
142 |
position: absolute;
|
148 |
|
149 |
.aioseop_option_div {
|
150 |
max-height: 360px;
|
151 |
+
min-height: 37px;
|
152 |
width: 95%;
|
153 |
overflow-y: auto;
|
154 |
}
|
159 |
|
160 |
.aioseop input[type="text"] {
|
161 |
color: #515151;
|
162 |
+
height: 35px;
|
163 |
padding: 10px 0 10px 10px;
|
164 |
font-size: 14px;
|
165 |
width: 95%;
|
179 |
.aioseop_help_text_div {
|
180 |
text-align: left;
|
181 |
width: 100%;
|
182 |
+
margin: 0;
|
183 |
}
|
184 |
|
185 |
.aioseop_help_text {
|
287 |
clear: left;
|
288 |
}
|
289 |
|
|
|
|
|
|
|
290 |
.aioseop_options_wrapper .hndle {
|
291 |
font-size: 15px;
|
292 |
font-family: Georgia,
|
810 |
/* max-width: 900px; */
|
811 |
}
|
812 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
813 |
#aiosp_sitemap_addl_pages,
|
814 |
#aiosp_video_sitemap_addl_pages {
|
815 |
clear: left;
|
978 |
height: 0;
|
979 |
}
|
980 |
|
981 |
+
#aiosp_title_metabox #aiosp_force_rewrites_wrapper {
|
982 |
+
display: none;
|
983 |
+
height: 0;
|
984 |
+
}
|
985 |
+
|
986 |
.aioseop_module.error.below-h2 {
|
987 |
padding: 5px 0;
|
988 |
margin: 0 477px 15px 0 !important;
|
990 |
|
991 |
#aioseop_opengraph_settings .inside {
|
992 |
margin: 0;
|
|
|
993 |
}
|
994 |
|
995 |
#aioseop_opengraph_settings_image_wrapper img {
|
1014 |
}
|
1015 |
|
1016 |
#aiosp {
|
1017 |
+
width: auto;
|
1018 |
}
|
1019 |
|
1020 |
.aioseop_input.aioseop_top_label .aioseop_option_input {
|
1152 |
}
|
1153 |
|
1154 |
.aioseop_header_tabs li a.aioseop_header_tab {
|
1155 |
+
font-size: 14px;
|
1156 |
+
line-height: 37px;
|
|
|
|
|
1157 |
text-decoration: none;
|
1158 |
margin: 5px 5px 0 0;
|
1159 |
+
padding: 10px;
|
1160 |
cursor: pointer;
|
1161 |
-webkit-border-top-right-radius: 3px;
|
1162 |
-webkit-border-top-left-radius: 3px;
|
1163 |
border-top-right-radius: 3px;
|
1164 |
border-top-left-radius: 3px;
|
1165 |
+
background-color: #e5e5e5;
|
|
|
1166 |
border: 1px solid #ccc;
|
1167 |
color: #5F5F5F;
|
1168 |
}
|
1169 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1170 |
.aioseop_header_tabs li:first-child a.aioseop_header_tab {
|
1171 |
border-left: solid 1px #CCC;
|
1172 |
margin-left: 5px;
|
1176 |
border: solid 1px #CCC;
|
1177 |
background-color: rgb(255, 255, 255);
|
1178 |
background-color: rgba(255, 255, 255, 0.5);
|
1179 |
+
padding: 10px;
|
1180 |
}
|
1181 |
|
1182 |
.aioseop_loading {
|
1272 |
margin-left: 20px !important;
|
1273 |
margin-bottom: 10px !important;
|
1274 |
}
|
1275 |
+
|
1276 |
+
/**
|
1277 |
+
* Edit Post screen specific styling
|
1278 |
+
*
|
1279 |
+
*/
|
1280 |
+
.postbox-container .aioseop_option_div {
|
1281 |
+
width: 100%;
|
1282 |
+
}
|
1283 |
+
|
1284 |
+
.postbox-container .aioseop_option_div input[type="text"],
|
1285 |
+
.postbox-container .aioseop_option_div textarea {
|
1286 |
+
width: 99%;
|
1287 |
+
max-width: 900px;
|
1288 |
+
}
|
1289 |
+
|
1290 |
+
.postbox-container .aioseop_option_label {
|
1291 |
+
max-width: none;
|
1292 |
+
height: auto !important;
|
1293 |
+
}
|
1294 |
+
|
1295 |
+
.postbox-container .aioseop_wrapper {
|
1296 |
+
padding: 0;
|
1297 |
+
}
|
1298 |
+
|
1299 |
+
.postbox-container .aioseop_input {
|
1300 |
+
display: block;
|
1301 |
+
margin-bottom: 10px;
|
1302 |
+
padding: 0;
|
1303 |
+
}
|
1304 |
+
|
1305 |
+
.postbox-container .aioseop_option_input {
|
1306 |
+
width: 63%;
|
1307 |
+
padding: 0;
|
1308 |
+
}
|
1309 |
+
|
1310 |
+
.postbox-container div#aiosp_upgrade_wrapper {
|
1311 |
+
float: none;
|
1312 |
+
width: auto;
|
1313 |
+
margin: 0;
|
1314 |
+
padding: 0;
|
1315 |
+
}
|
1316 |
+
|
1317 |
+
.postbox-container div#aiosp_upgrade_wrapper .aioseop_input {
|
1318 |
+
display: block;
|
1319 |
+
padding: 0;
|
1320 |
+
}
|
1321 |
+
|
1322 |
+
.postbox-container div#aiosp_upgrade_wrapper .aioseop_input .aioseop_option_input {
|
1323 |
+
float: none;
|
1324 |
+
width: auto;
|
1325 |
+
padding: 0;
|
1326 |
+
}
|
1327 |
+
|
1328 |
+
.postbox-container div#aiosp_upgrade_wrapper .aioseop_input .aioseop_option_input .aioseop_option_div {
|
1329 |
+
width: auto;
|
1330 |
+
min-height: 0;
|
1331 |
+
padding: 10px 0;
|
1332 |
+
}
|
1333 |
+
|
1334 |
+
.aioseop_tabs .aioseop_options {
|
1335 |
+
margin: 0;
|
1336 |
+
}
|
1337 |
+
|
1338 |
+
#aioseop_opengraph_settings .aioseop_options {
|
1339 |
+
clear: both;
|
1340 |
+
margin-top: 35px;
|
1341 |
+
}
|
1342 |
+
|
1343 |
+
#aioseop_opengraph_settings .aioseop_option_input {
|
1344 |
+
width: 70%;
|
1345 |
+
}
|
1346 |
+
|
1347 |
+
/**
|
1348 |
+
* Preview Snippet styling
|
1349 |
+
*
|
1350 |
+
*/
|
1351 |
+
div#aiosp_snippet_wrapper {
|
1352 |
+
border: 1px solid #888;
|
1353 |
+
clear: both;
|
1354 |
+
padding: 10px 10px 0;
|
1355 |
+
max-width: 97%;
|
1356 |
+
margin-bottom: 15px;
|
1357 |
+
}
|
1358 |
+
|
1359 |
+
div#aiosp_snippet_wrapper .aioseop_option_label {
|
1360 |
+
height: auto !important;
|
1361 |
+
}
|
1362 |
+
|
1363 |
+
div#aiosp_snippet_wrapper .aioseop_input.aioseop_top_label .aioseop_option_input {
|
1364 |
+
margin: 0;
|
1365 |
+
}
|
1366 |
+
|
1367 |
+
div#aioseop_snippet {
|
1368 |
+
font-family: arial, sans-serif;
|
1369 |
+
font-size: 13px;
|
1370 |
+
}
|
1371 |
+
|
1372 |
+
div#aioseop_snippet > h3 {
|
1373 |
+
margin: 10px 0 5px;
|
1374 |
+
font-size: 18px;
|
1375 |
+
border: 0;
|
1376 |
+
background: inherit;
|
1377 |
+
font-weight: normal;
|
1378 |
+
}
|
1379 |
+
|
1380 |
+
div#aioseop_snippet > h3 > a {
|
1381 |
+
color: #12c;
|
1382 |
+
text-decoration: none;
|
1383 |
+
cursor: pointer;
|
1384 |
+
}
|
1385 |
+
|
1386 |
+
div#aioseop_snippet > div {
|
1387 |
+
color: #545454;
|
1388 |
+
max-width: 48em;
|
1389 |
+
}
|
1390 |
+
|
1391 |
+
div#aioseop_snippet > div > div {
|
1392 |
+
display: block;
|
1393 |
+
margin-bottom: 1px;
|
1394 |
+
}
|
1395 |
+
|
1396 |
+
div#aioseop_snippet > div > div > cite {
|
1397 |
+
color: #093;
|
1398 |
+
font-style: normal;
|
1399 |
+
}
|
1400 |
+
|
1401 |
+
div#aioseop_snippet > div > span {
|
1402 |
+
margin: 0;
|
1403 |
+
padding: 0;
|
1404 |
+
border: 0;
|
1405 |
+
}
|
inc/commonstrings.php
CHANGED
@@ -34,6 +34,7 @@ class AIOSP_Common_Strings {
|
|
34 |
// Update checker strings (incomplete... need to separate out html).
|
35 |
__( 'Purchase one now', 'all-in-one-seo-pack' );
|
36 |
__( 'License Key is not set yet or invalid. ', 'all-in-one-seo-pack' );
|
|
|
37 |
__( ' Need a license key?', 'all-in-one-seo-pack' );
|
38 |
__( 'Notice: ', 'all-in-one-seo-pack' );
|
39 |
__( 'Manage Licenses', 'all-in-one-seo-pack' );
|
@@ -47,12 +48,28 @@ class AIOSP_Common_Strings {
|
|
47 |
__( 'Check this to move the All in One SEO Pack menu item to the top of your WordPress Dashboard menu.', 'all-in-one-seo-pack' );
|
48 |
__('%s is almost ready.', 'all-in-one-seo-pack' );
|
49 |
__('You must <a href="%s">enter a valid License Key</a> for it to work.', 'all-in-one-seo-pack' );
|
50 |
-
__( ' Need a license key?', 'all-in-one-seo-pack' );
|
51 |
-
__( 'Purchase one now', 'all-in-one-seo-pack' );
|
52 |
__( "There is a new version of %s available. Go to <a href='%s'>the plugins page</a> for details.", 'all-in-one-seo-pack' );
|
53 |
sprintf( __( 'Your license has expired. Please %1$s click here %2$s to purchase a new one.', 'all-in-one-seo-pack' ), '<a href="https://semperplugins.com/all-in-one-seo-pack-pro-version/" target="_blank">', '</a>' );
|
54 |
-
__( '
|
55 |
-
__( '
|
56 |
-
__( '
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
57 |
}
|
58 |
}
|
34 |
// Update checker strings (incomplete... need to separate out html).
|
35 |
__( 'Purchase one now', 'all-in-one-seo-pack' );
|
36 |
__( 'License Key is not set yet or invalid. ', 'all-in-one-seo-pack' );
|
37 |
+
/* translators: Please mind the space at the beginning of the string. */
|
38 |
__( ' Need a license key?', 'all-in-one-seo-pack' );
|
39 |
__( 'Notice: ', 'all-in-one-seo-pack' );
|
40 |
__( 'Manage Licenses', 'all-in-one-seo-pack' );
|
48 |
__( 'Check this to move the All in One SEO Pack menu item to the top of your WordPress Dashboard menu.', 'all-in-one-seo-pack' );
|
49 |
__('%s is almost ready.', 'all-in-one-seo-pack' );
|
50 |
__('You must <a href="%s">enter a valid License Key</a> for it to work.', 'all-in-one-seo-pack' );
|
|
|
|
|
51 |
__( "There is a new version of %s available. Go to <a href='%s'>the plugins page</a> for details.", 'all-in-one-seo-pack' );
|
52 |
sprintf( __( 'Your license has expired. Please %1$s click here %2$s to purchase a new one.', 'all-in-one-seo-pack' ), '<a href="https://semperplugins.com/all-in-one-seo-pack-pro-version/" target="_blank">', '</a>' );
|
53 |
+
__( 'Track Outbound Forms:', 'all-in-one-seo-pack' );
|
54 |
+
__( 'Track Events:', 'all-in-one-seo-pack' );
|
55 |
+
__( 'Track URL Changes:', 'all-in-one-seo-pack' );
|
56 |
+
__( 'Track Page Visibility:', 'all-in-one-seo-pack' );
|
57 |
+
__( 'Track Media Query:', 'all-in-one-seo-pack' );
|
58 |
+
__( 'Track Elements Visibility:', 'all-in-one-seo-pack' );
|
59 |
+
__( 'Track Page Scrolling:', 'all-in-one-seo-pack' );
|
60 |
+
__( 'Track Facebook and Twitter:', 'all-in-one-seo-pack' );
|
61 |
+
__( 'Ensure URL Consistency:', 'all-in-one-seo-pack' );
|
62 |
+
__( 'Check this if you want to track outbound forms with Google Analytics.', 'all-in-one-seo-pack' );
|
63 |
+
__( 'Check this if you want to track events with Google Analytics.', 'all-in-one-seo-pack' );
|
64 |
+
__( 'Check this if you want to track URL changes for single pages with Google Analytics.', 'all-in-one-seo-pack' );
|
65 |
+
__( 'Check this if you want to track how long pages are in visible state with Google Analytics.', 'all-in-one-seo-pack' );
|
66 |
+
/* translators: 'This option allows users to track media queries, allowing them to find out if users are viewing a responsive layout or not and which layout changes
|
67 |
+
have been applied if the browser window has been resized by the user, see https://github.com/googleanalytics/autotrack/blob/master/docs/plugins/media-query-tracker.md. */
|
68 |
+
__( 'Check this if you want to track media query matching and queries with Google Analytics.', 'all-in-one-seo-pack' );
|
69 |
+
/* translators: The term 'viewport' refers to the area of the page that is visible to the user, see https://www.w3schools.com/css/css_rwd_viewport.asp. */
|
70 |
+
__( 'Check this if you want to track when elements are visible within the viewport with Google Analytics.', 'all-in-one-seo-pack' );
|
71 |
+
__( 'Check this if you want to ensure consistency in URL paths reported to Google Analytics.', 'all-in-one-seo-pack' );
|
72 |
+
__( 'Check this if you want to track how far down a user scrolls a page with Google Analytics.', 'all-in-one-seo-pack' );
|
73 |
+
__( 'Check this if you want to track interactions with the official Facebook and Twitter widgets with Google Analytics.', 'all-in-one-seo-pack' );
|
74 |
}
|
75 |
}
|
inc/sitemap-xsl.php
CHANGED
@@ -143,9 +143,10 @@ echo '<?xml version="1.0" encoding="UTF-8"?>';
|
|
143 |
<thead>
|
144 |
<tr>
|
145 |
<th width="50%">URL</th>
|
|
|
146 |
<th>Priority</th>
|
147 |
<th>Change Frequency</th>
|
148 |
-
<th>
|
149 |
</tr>
|
150 |
</thead>
|
151 |
<tbody>
|
@@ -175,6 +176,9 @@ echo '<?xml version="1.0" encoding="UTF-8"?>';
|
|
175 |
</xsl:if>
|
176 |
</xsl:for-each>
|
177 |
</td>
|
|
|
|
|
|
|
178 |
<td>
|
179 |
<xsl:if test="string(number(sitemap:priority))!='NaN'">
|
180 |
<xsl:value-of select="concat(sitemap:priority*100,'%')"/>
|
143 |
<thead>
|
144 |
<tr>
|
145 |
<th width="50%">URL</th>
|
146 |
+
<th>Images</th>
|
147 |
<th>Priority</th>
|
148 |
<th>Change Frequency</th>
|
149 |
+
<th>Last Change</th>
|
150 |
</tr>
|
151 |
</thead>
|
152 |
<tbody>
|
176 |
</xsl:if>
|
177 |
</xsl:for-each>
|
178 |
</td>
|
179 |
+
<td>
|
180 |
+
<xsl:value-of select="count(image:image)"/>
|
181 |
+
</td>
|
182 |
<td>
|
183 |
<xsl:if test="string(number(sitemap:priority))!='NaN'">
|
184 |
<xsl:value-of select="concat(sitemap:priority*100,'%')"/>
|
modules/aioseop_sitemap.php
CHANGED
@@ -10,6 +10,9 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Sitemap' ) ) {
|
|
10 |
|
11 |
/**
|
12 |
* Class All_in_One_SEO_Pack_Sitemap
|
|
|
|
|
|
|
13 |
*/
|
14 |
class All_in_One_SEO_Pack_Sitemap extends All_in_One_SEO_Pack_Module {
|
15 |
var $cache_struct = null;
|
@@ -621,14 +624,10 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Sitemap' ) ) {
|
|
621 |
$url = aioseop_home_url( '/' . $options[ $this->prefix . 'filename' ] . '.xml' );
|
622 |
|
623 |
$options[ $this->prefix . 'link' ] = sprintf( __( 'Click here to %s.', 'all-in-one-seo-pack' ), '<a href="' . esc_url( $url ) . '" target="_blank">' . __( 'view your sitemap', 'all-in-one-seo-pack' ) . '</a>' );
|
624 |
-
$options[ $this->prefix . 'link' ] .= __( ' Your sitemap has been created', 'all-in-one-seo-pack' );
|
625 |
if ( '0' !== get_option( 'blog_public' ) ){
|
626 |
-
$options[ $this->prefix . 'link' ] .= __( '
|
627 |
}
|
628 |
-
$options[ $this->prefix . 'link' ] .= '.';
|
629 |
-
|
630 |
-
|
631 |
-
|
632 |
|
633 |
if ( $this->option_isset( 'rewrite' ) ) {
|
634 |
$rule = $this->get_rewrite_url( $url );
|
@@ -1651,6 +1650,8 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Sitemap' ) ) {
|
|
1651 |
);
|
1652 |
}
|
1653 |
|
|
|
|
|
1654 |
return $files;
|
1655 |
}
|
1656 |
|
@@ -1818,13 +1819,14 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Sitemap' ) ) {
|
|
1818 |
}
|
1819 |
$prio = $this->get_all_post_priority_data( $options["{$this->prefix}posttypes"] );
|
1820 |
|
1821 |
-
$
|
1822 |
-
'loc' => aioseop_home_url(),
|
1823 |
-
'priority' => $this->get_default_priority( 'homepage' ),
|
1824 |
-
'changefreq' => $this->get_default_frequency( 'homepage' ),
|
1825 |
-
);
|
1826 |
|
1827 |
-
$
|
|
|
|
|
|
|
|
|
|
|
1828 |
|
1829 |
$this->paginate = false;
|
1830 |
if ( $posts ) {
|
@@ -1949,7 +1951,10 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Sitemap' ) ) {
|
|
1949 |
|
1950 |
$xml_header = '<?xml-stylesheet type="text/xsl" href="' . $xsl_url . '"?>' . "\r\n"
|
1951 |
. '<urlset ';
|
1952 |
-
$namespaces = apply_filters( $this->prefix . 'xml_namespace', array(
|
|
|
|
|
|
|
1953 |
if ( ! empty( $namespaces ) ) {
|
1954 |
$ns = array();
|
1955 |
foreach ( $namespaces as $k => $v ) {
|
@@ -2105,7 +2110,9 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Sitemap' ) ) {
|
|
2105 |
} else {
|
2106 |
$pr_info['changefreq'] = $def_freq;
|
2107 |
}
|
2108 |
-
|
|
|
|
|
2109 |
}
|
2110 |
}
|
2111 |
|
@@ -2293,11 +2300,13 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Sitemap' ) ) {
|
|
2293 |
function get_addl_pages() {
|
2294 |
$home = array();
|
2295 |
$home = array(
|
2296 |
-
'loc'
|
2297 |
-
'priority'
|
2298 |
-
'changefreq'
|
|
|
2299 |
);
|
2300 |
-
|
|
|
2301 |
if ( $posts ) {
|
2302 |
$posts = $this->get_permalink( $posts );
|
2303 |
if ( $posts == $home['loc'] ) {
|
@@ -2551,12 +2560,15 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Sitemap' ) ) {
|
|
2551 |
}
|
2552 |
if ( is_array( $posts ) ) {
|
2553 |
foreach ( $posts as $post ) {
|
|
|
|
|
2554 |
$url = '';
|
2555 |
$post->filter = 'sample';
|
2556 |
if ( 'get_permalink' === $linkfunc ) {
|
2557 |
$url = $this->get_permalink( $post );
|
2558 |
} else {
|
2559 |
$url = call_user_func( $linkfunc, $post );
|
|
|
2560 |
}
|
2561 |
$date = $post->post_modified;
|
2562 |
if ( '0000-00-00 00:00:00' === $date ) {
|
@@ -2596,7 +2608,10 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Sitemap' ) ) {
|
|
2596 |
$pr_info['changefreq'] = $this->options[ $this->prefix . 'freq_post_' . $post->post_type ];
|
2597 |
}
|
2598 |
}
|
2599 |
-
$pr_info = array(
|
|
|
|
|
|
|
2600 |
if ( is_float( $pr_info['priority'] ) ) {
|
2601 |
$pr_info['priority'] = sprintf( '%0.1F', $pr_info['priority'] );
|
2602 |
}
|
@@ -2609,6 +2624,115 @@ if ( ! class_exists( 'All_in_One_SEO_Pack_Sitemap' ) ) {
|
|
2609 |
|
2610 |
return $prio;
|
2611 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2612 |
|
2613 |
/**
|
2614 |
* Return excluded categories for taxonomy queries.
|
10 |
|
11 |
/**
|
12 |
* Class All_in_One_SEO_Pack_Sitemap
|
13 |
+
*
|
14 |
+
* @since ?
|
15 |
+
* @since 2.4 Include images in sitemap.
|
16 |
*/
|
17 |
class All_in_One_SEO_Pack_Sitemap extends All_in_One_SEO_Pack_Module {
|
18 |
var $cache_struct = null;
|
624 |
$url = aioseop_home_url( '/' . $options[ $this->prefix . 'filename' ] . '.xml' );
|
625 |
|
626 |
$options[ $this->prefix . 'link' ] = sprintf( __( 'Click here to %s.', 'all-in-one-seo-pack' ), '<a href="' . esc_url( $url ) . '" target="_blank">' . __( 'view your sitemap', 'all-in-one-seo-pack' ) . '</a>' );
|
627 |
+
$options[ $this->prefix . 'link' ] .= __( ' Your sitemap has been created with content and images.', 'all-in-one-seo-pack' );
|
628 |
if ( '0' !== get_option( 'blog_public' ) ){
|
629 |
+
$options[ $this->prefix . 'link' ] .= ' ' . __( 'Changes are automatically submitted to search engines.', 'all-in-one-seo-pack' );
|
630 |
}
|
|
|
|
|
|
|
|
|
631 |
|
632 |
if ( $this->option_isset( 'rewrite' ) ) {
|
633 |
$rule = $this->get_rewrite_url( $url );
|
1650 |
);
|
1651 |
}
|
1652 |
|
1653 |
+
$files = apply_filters( 'aioseop_sitemap_index_filenames', $files, $prefix, $suffix );
|
1654 |
+
|
1655 |
return $files;
|
1656 |
}
|
1657 |
|
1819 |
}
|
1820 |
$prio = $this->get_all_post_priority_data( $options["{$this->prefix}posttypes"] );
|
1821 |
|
1822 |
+
$posts = $postspageid = (int) get_option( 'page_for_posts' ); // It's 0 if posts are on homepage, otherwise it's the id of the posts page.
|
|
|
|
|
|
|
|
|
1823 |
|
1824 |
+
$home = array(
|
1825 |
+
'loc' => aioseop_home_url(),
|
1826 |
+
'priority' => $this->get_default_priority( 'homepage' ),
|
1827 |
+
'changefreq' => $this->get_default_frequency( 'homepage' ),
|
1828 |
+
'image:image' => $this->get_images_from_post( (int) get_option( 'page_on_front' ) ),
|
1829 |
+
);
|
1830 |
|
1831 |
$this->paginate = false;
|
1832 |
if ( $posts ) {
|
1951 |
|
1952 |
$xml_header = '<?xml-stylesheet type="text/xsl" href="' . $xsl_url . '"?>' . "\r\n"
|
1953 |
. '<urlset ';
|
1954 |
+
$namespaces = apply_filters( $this->prefix . 'xml_namespace', array(
|
1955 |
+
'xmlns' => 'http://www.sitemaps.org/schemas/sitemap/0.9',
|
1956 |
+
'xmlns:image' => 'http://www.google.com/schemas/sitemap-image/1.1',
|
1957 |
+
) );
|
1958 |
if ( ! empty( $namespaces ) ) {
|
1959 |
$ns = array();
|
1960 |
foreach ( $namespaces as $k => $v ) {
|
2110 |
} else {
|
2111 |
$pr_info['changefreq'] = $def_freq;
|
2112 |
}
|
2113 |
+
|
2114 |
+
$pr_info['image:image'] = $this->get_images_from_term( $term );
|
2115 |
+
$prio[] = $pr_info;
|
2116 |
}
|
2117 |
}
|
2118 |
|
2300 |
function get_addl_pages() {
|
2301 |
$home = array();
|
2302 |
$home = array(
|
2303 |
+
'loc' => aioseop_home_url(),
|
2304 |
+
'priority' => $this->get_default_priority( 'homepage' ),
|
2305 |
+
'changefreq' => $this->get_default_frequency( 'homepage' ),
|
2306 |
+
'image:image' => $this->get_images_from_post( (int) get_option( 'page_on_front' ) ),
|
2307 |
);
|
2308 |
+
|
2309 |
+
$posts = (int) get_option( 'page_for_posts' );
|
2310 |
if ( $posts ) {
|
2311 |
$posts = $this->get_permalink( $posts );
|
2312 |
if ( $posts == $home['loc'] ) {
|
2560 |
}
|
2561 |
if ( is_array( $posts ) ) {
|
2562 |
foreach ( $posts as $post ) {
|
2563 |
+
// Determine if we check the post for images.
|
2564 |
+
$is_single = true;
|
2565 |
$url = '';
|
2566 |
$post->filter = 'sample';
|
2567 |
if ( 'get_permalink' === $linkfunc ) {
|
2568 |
$url = $this->get_permalink( $post );
|
2569 |
} else {
|
2570 |
$url = call_user_func( $linkfunc, $post );
|
2571 |
+
$is_single = false;
|
2572 |
}
|
2573 |
$date = $post->post_modified;
|
2574 |
if ( '0000-00-00 00:00:00' === $date ) {
|
2608 |
$pr_info['changefreq'] = $this->options[ $this->prefix . 'freq_post_' . $post->post_type ];
|
2609 |
}
|
2610 |
}
|
2611 |
+
$pr_info = array(
|
2612 |
+
'loc' => $url,
|
2613 |
+
'image:image' => $is_single ? $this->get_images_from_post( $post ) : null,
|
2614 |
+
) + $pr_info; // Prepend loc to the array.
|
2615 |
if ( is_float( $pr_info['priority'] ) ) {
|
2616 |
$pr_info['priority'] = sprintf( '%0.1F', $pr_info['priority'] );
|
2617 |
}
|
2624 |
|
2625 |
return $prio;
|
2626 |
}
|
2627 |
+
|
2628 |
+
/**
|
2629 |
+
* Return the images attached to the term.
|
2630 |
+
*
|
2631 |
+
* @param WP_Term $term the term object.
|
2632 |
+
*
|
2633 |
+
* @since 2.4
|
2634 |
+
*
|
2635 |
+
* @return array
|
2636 |
+
*/
|
2637 |
+
private function get_images_from_term( $term ) {
|
2638 |
+
|
2639 |
+
if ( false === apply_filters( 'aioseo_include_images_in_sitemap', true ) ) {
|
2640 |
+
return array();
|
2641 |
+
}
|
2642 |
+
|
2643 |
+
$images = array();
|
2644 |
+
$thumbnail_id = get_term_meta( $term->term_id, 'thumbnail_id', true );
|
2645 |
+
if ( $thumbnail_id ) {
|
2646 |
+
$image = wp_get_attachment_url( $thumbnail_id );
|
2647 |
+
if ( $image ) {
|
2648 |
+
$images['image:image'] = array(
|
2649 |
+
'image:loc' => $image,
|
2650 |
+
);
|
2651 |
+
}
|
2652 |
+
}
|
2653 |
+
|
2654 |
+
return $images;
|
2655 |
+
}
|
2656 |
+
|
2657 |
+
/**
|
2658 |
+
* Return the images from the post.
|
2659 |
+
*
|
2660 |
+
* @param WP_Post $post the post object.
|
2661 |
+
*
|
2662 |
+
* @since 2.4
|
2663 |
+
*
|
2664 |
+
* @return array
|
2665 |
+
*/
|
2666 |
+
private function get_images_from_post( $post ) {
|
2667 |
+
|
2668 |
+
if ( false === apply_filters( 'aioseo_include_images_in_sitemap', true ) ) {
|
2669 |
+
return array();
|
2670 |
+
}
|
2671 |
+
|
2672 |
+
$images = array();
|
2673 |
+
|
2674 |
+
if ( is_numeric( $post ) ) {
|
2675 |
+
if ( 0 === $post ) {
|
2676 |
+
return null;
|
2677 |
+
}
|
2678 |
+
$post = get_post( $post );
|
2679 |
+
}
|
2680 |
+
|
2681 |
+
if ( 'attachment' === $post->post_type ) {
|
2682 |
+
if ( false === strpos( $post->post_mime_type, 'image/' ) ) {
|
2683 |
+
// Ignore all attachments except images.
|
2684 |
+
return null;
|
2685 |
+
}
|
2686 |
+
$attributes = wp_get_attachment_image_src( $post->ID );
|
2687 |
+
if ( $attributes ) {
|
2688 |
+
$images[] = array(
|
2689 |
+
'image:loc' => $attributes[0],
|
2690 |
+
);
|
2691 |
+
}
|
2692 |
+
|
2693 |
+
return $images;
|
2694 |
+
}
|
2695 |
+
|
2696 |
+
// Check featured image.
|
2697 |
+
$attached_url = get_the_post_thumbnail_url( $post->ID );
|
2698 |
+
if ( false !== $attached_url ) {
|
2699 |
+
$images[] = $attached_url;
|
2700 |
+
}
|
2701 |
+
|
2702 |
+
// Check images in the content.
|
2703 |
+
$content = $post->post_content;
|
2704 |
+
$total = substr_count( $content, '<img ' ) + substr_count( $content, '<IMG ' );
|
2705 |
+
if ( $total > 0 ) {
|
2706 |
+
$dom = new domDocument();
|
2707 |
+
// Non-compliant HTML might give errors, so ignore them.
|
2708 |
+
libxml_use_internal_errors( true );
|
2709 |
+
$dom->loadHTML( $content );
|
2710 |
+
libxml_clear_errors();
|
2711 |
+
// @codingStandardsIgnoreStart
|
2712 |
+
$dom->preserveWhiteSpace = false;
|
2713 |
+
// @codingStandardsIgnoreEnd
|
2714 |
+
$matches = $dom->getElementsByTagName( 'img' );
|
2715 |
+
foreach ( $matches as $match ) {
|
2716 |
+
$images[] = $match->getAttribute( 'src' );
|
2717 |
+
}
|
2718 |
+
}
|
2719 |
+
|
2720 |
+
if ( $images ) {
|
2721 |
+
$tmp = $images;
|
2722 |
+
if ( 1 < count( $images ) ) {
|
2723 |
+
// Filter out duplicates.
|
2724 |
+
$tmp = array_unique( $images );
|
2725 |
+
}
|
2726 |
+
$images = array();
|
2727 |
+
foreach ( $tmp as $image ) {
|
2728 |
+
$images[] = array(
|
2729 |
+
'image:loc' => $image,
|
2730 |
+
);
|
2731 |
+
}
|
2732 |
+
}
|
2733 |
+
|
2734 |
+
return $images;
|
2735 |
+
}
|
2736 |
|
2737 |
/**
|
2738 |
* Return excluded categories for taxonomy queries.
|
public/google-analytics.php
CHANGED
@@ -3,18 +3,45 @@
|
|
3 |
if ( ! class_exists( 'aioseop_google_analytics' ) ) {
|
4 |
|
5 |
require_once( AIOSEOP_PLUGIN_DIR . 'admin/aioseop_module_class.php' ); // Include the module base class.
|
6 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
7 |
class aioseop_google_analytics extends All_in_One_SEO_Pack_Module {
|
8 |
-
// TODO Rather than extending the module base class, we should find a better way for the shared functions like moving them to our common functions class.
|
9 |
|
10 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
11 |
$this->google_analytics();
|
12 |
}
|
13 |
|
14 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
15 |
global $aioseop_options;
|
16 |
-
|
17 |
-
if ( ! empty( $aioseop_options['aiosp_ga_advanced_options'] )
|
|
|
|
|
|
|
18 |
global $current_user;
|
19 |
if ( empty( $current_user ) ) {
|
20 |
wp_get_current_user();
|
@@ -30,64 +57,17 @@ if ( ! class_exists( 'aioseop_google_analytics' ) ) {
|
|
30 |
ob_start();
|
31 |
$analytics = $this->universal_analytics();
|
32 |
echo $analytics;
|
33 |
-
|
34 |
-
|
35 |
-
|
36 |
-
|
37 |
-
|
38 |
-
|
39 |
-
|
40 |
-
|
41 |
-
|
42 |
-
|
43 |
-
|
44 |
-
function getAttr(ele, attr) {
|
45 |
-
var result = (ele.getAttribute && ele.getAttribute(attr)) || null;
|
46 |
-
if (!result) {
|
47 |
-
var attrs = ele.attributes;
|
48 |
-
var length = attrs.length;
|
49 |
-
for (var i = 0; i < length; i++)
|
50 |
-
if (attr[i].nodeName === attr) result = attr[i].nodeValue;
|
51 |
-
}
|
52 |
-
return result;
|
53 |
-
}
|
54 |
-
|
55 |
-
function aiosp_addLoadEvent(func) {
|
56 |
-
var oldonload = window.onload;
|
57 |
-
if (typeof window.onload != 'function') {
|
58 |
-
window.onload = func;
|
59 |
-
} else {
|
60 |
-
window.onload = function () {
|
61 |
-
if (oldonload) {
|
62 |
-
oldonload();
|
63 |
-
}
|
64 |
-
func();
|
65 |
-
}
|
66 |
-
}
|
67 |
-
}
|
68 |
-
|
69 |
-
function aiosp_addEvent(element, evnt, funct) {
|
70 |
-
if (element.attachEvent)
|
71 |
-
return element.attachEvent('on' + evnt, funct);
|
72 |
-
else
|
73 |
-
return element.addEventListener(evnt, funct, false);
|
74 |
-
}
|
75 |
-
|
76 |
-
aiosp_addLoadEvent(function () {
|
77 |
-
var links = document.getElementsByTagName('a');
|
78 |
-
for (var x = 0; x < links.length; x++) {
|
79 |
-
if (typeof links[x] == 'undefined') continue;
|
80 |
-
aiosp_addEvent(links[x], 'onclick', function () {
|
81 |
-
var mydomain = new RegExp(document.domain, 'i');
|
82 |
-
href = getAttr(this, 'href');
|
83 |
-
if (href && href.toLowerCase().indexOf('http') === 0 && !mydomain.test(href)) {
|
84 |
-
recordOutboundLink(this, 'Outbound Links', href);
|
85 |
-
}
|
86 |
-
});
|
87 |
-
}
|
88 |
-
});
|
89 |
-
</script>
|
90 |
-
<?php
|
91 |
}
|
92 |
$analytics = ob_get_clean();
|
93 |
}
|
@@ -97,29 +77,31 @@ if ( ! class_exists( 'aioseop_google_analytics' ) ) {
|
|
97 |
}
|
98 |
|
99 |
/**
|
100 |
-
|
|
|
101 |
*
|
102 |
-
* @since ?
|
103 |
* @since 2.3.15 Added aioseop_ga_attributes filter hook for attributes.
|
|
|
104 |
*
|
105 |
-
* @
|
106 |
*/
|
107 |
-
function universal_analytics() {
|
108 |
global $aioseop_options;
|
109 |
-
$analytics = '';
|
110 |
$allow_linker = $cookie_domain = $domain = $addl_domains = $domain_list = '';
|
111 |
if ( ! empty( $aioseop_options['aiosp_ga_advanced_options'] ) ) {
|
112 |
$cookie_domain = $this->get_analytics_domain();
|
113 |
}
|
114 |
if ( ! empty( $cookie_domain ) ) {
|
115 |
$cookie_domain = esc_js( $cookie_domain );
|
116 |
-
$cookie_domain =
|
117 |
}
|
118 |
if ( empty( $cookie_domain ) ) {
|
119 |
-
$domain =
|
120 |
}
|
121 |
-
if ( ! empty( $aioseop_options['aiosp_ga_advanced_options'] )
|
122 |
-
|
|
|
|
|
123 |
if ( ! empty( $aioseop_options['aiosp_ga_addl_domains'] ) ) {
|
124 |
$addl_domains = trim( $aioseop_options['aiosp_ga_addl_domains'] );
|
125 |
$addl_domains = preg_split( '/[\s,]+/', $addl_domains );
|
@@ -130,72 +112,59 @@ if ( ! class_exists( 'aioseop_google_analytics' ) ) {
|
|
130 |
if ( ! empty( $domain_list ) ) {
|
131 |
$domain_list .= ', ';
|
132 |
}
|
133 |
-
$domain_list .=
|
134 |
}
|
135 |
}
|
136 |
}
|
137 |
}
|
138 |
}
|
139 |
-
$extra_options =
|
140 |
-
if ( ! empty( $
|
141 |
-
$extra_options
|
|
|
142 |
}
|
143 |
-
if ( ! empty( $aioseop_options['aiosp_ga_advanced_options'] )
|
144 |
-
if ( ! empty( $
|
145 |
-
$extra_options
|
146 |
}
|
147 |
-
|
148 |
-
|
149 |
-
if ( ! empty( $domain_list ) ) {
|
150 |
-
if ( ! empty( $extra_options ) ) {
|
151 |
-
$extra_options .= "\n\t\t\t";
|
152 |
}
|
153 |
-
|
154 |
-
|
155 |
-
if ( ! empty( $aioseop_options['aiosp_ga_advanced_options'] ) && ! empty( $aioseop_options['aiosp_ga_link_attribution'] ) ) {
|
156 |
-
if ( ! empty( $extra_options ) ) {
|
157 |
-
$extra_options .= "\n\t\t\t";
|
158 |
}
|
159 |
-
|
160 |
-
|
161 |
-
|
162 |
-
|
163 |
-
|
164 |
-
$extra_options .= "\n\t\t\t";
|
165 |
}
|
166 |
-
$extra_options .= "ga('set', 'anonymizeIp', true);";
|
167 |
}
|
|
|
168 |
$js_options = array();
|
169 |
foreach ( array( 'cookie_domain', 'allow_linker' ) as $opts ) {
|
170 |
if ( ! empty( $$opts ) ) {
|
171 |
$js_options[] = $$opts;
|
172 |
}
|
173 |
}
|
174 |
-
|
175 |
-
|
176 |
-
|
177 |
-
|
178 |
-
|
179 |
-
|
180 |
-
|
181 |
-
|
182 |
-
|
183 |
-
|
184 |
-
|
185 |
-
|
186 |
-
|
187 |
-
|
188 |
-
m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
|
189 |
-
})(window,document,'script','//www.google-analytics.com/analytics.js','ga');
|
190 |
-
|
191 |
-
ga('create', '{$analytics_id}'{$domain}{$js_options});
|
192 |
-
{$extra_options}
|
193 |
-
ga('send', 'pageview');
|
194 |
</script>
|
195 |
-
|
196 |
-
|
197 |
-
|
198 |
-
return $analytics;
|
199 |
}
|
200 |
|
201 |
/**
|
@@ -206,7 +175,6 @@ EOF;
|
|
206 |
if ( ! empty( $aioseop_options['aiosp_ga_domain'] ) ) {
|
207 |
return $this->sanitize_domain( $aioseop_options['aiosp_ga_domain'] );
|
208 |
}
|
209 |
-
|
210 |
return '';
|
211 |
}
|
212 |
|
3 |
if ( ! class_exists( 'aioseop_google_analytics' ) ) {
|
4 |
|
5 |
require_once( AIOSEOP_PLUGIN_DIR . 'admin/aioseop_module_class.php' ); // Include the module base class.
|
6 |
+
/**
|
7 |
+
* Google Analytics module.
|
8 |
+
* TODO: Rather than extending the module base class, we should find a better way
|
9 |
+
* for the shared functions like moving them to our common functions class.
|
10 |
+
*
|
11 |
+
* @since 2.3.14 #921 Autotrack added and class refactored.
|
12 |
+
*/
|
13 |
class aioseop_google_analytics extends All_in_One_SEO_Pack_Module {
|
|
|
14 |
|
15 |
+
/**
|
16 |
+
* @todo Rather than extending the module base class,
|
17 |
+
* we should find a better way for the shared functions
|
18 |
+
* like moving them to our common functions class.
|
19 |
+
*/
|
20 |
+
|
21 |
+
/**
|
22 |
+
* Default module constructor.
|
23 |
+
*/
|
24 |
+
public function __construct() {
|
25 |
$this->google_analytics();
|
26 |
}
|
27 |
|
28 |
+
/**
|
29 |
+
* Inits Google Analytics.
|
30 |
+
*
|
31 |
+
* @since 2.3.14 Refactored to work with autotrack.js.
|
32 |
+
*
|
33 |
+
* @link https://github.com/googleanalytics/autotrack
|
34 |
+
*
|
35 |
+
* @global array $aioseop_options All-in-on-seo saved settings/options.
|
36 |
+
* @global object $current_user Current logged in WP user.
|
37 |
+
*/
|
38 |
+
public function google_analytics() {
|
39 |
global $aioseop_options;
|
40 |
+
// Exclude tracking for users?
|
41 |
+
if ( ! empty( $aioseop_options['aiosp_ga_advanced_options'] )
|
42 |
+
&& ! empty( $aioseop_options['aiosp_ga_exclude_users'] )
|
43 |
+
&& is_user_logged_in()
|
44 |
+
) {
|
45 |
global $current_user;
|
46 |
if ( empty( $current_user ) ) {
|
47 |
wp_get_current_user();
|
57 |
ob_start();
|
58 |
$analytics = $this->universal_analytics();
|
59 |
echo $analytics;
|
60 |
+
if ( apply_filters(
|
61 |
+
'aioseop_ga_enable_autotrack',
|
62 |
+
! empty( $aioseop_options['aiosp_ga_advanced_options'] ) && $aioseop_options['aiosp_ga_track_outbound_links'],
|
63 |
+
$aioseop_options
|
64 |
+
) ) {
|
65 |
+
$autotrack = apply_filters(
|
66 |
+
'aiosp_google_autotrack',
|
67 |
+
'https://cdnjs.cloudflare.com/ajax/libs/autotrack/2.4.0/autotrack.js'
|
68 |
+
);
|
69 |
+
?><script async src="<?php echo $autotrack ?>"></script>
|
70 |
+
<?php // Requested indent #921
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
71 |
}
|
72 |
$analytics = ob_get_clean();
|
73 |
}
|
77 |
}
|
78 |
|
79 |
/**
|
80 |
+
* Handle Universal Analytics.
|
81 |
+
* Adds analytics.
|
82 |
*
|
|
|
83 |
* @since 2.3.15 Added aioseop_ga_attributes filter hook for attributes.
|
84 |
+
* @since 2.3.14 Refactored to work with autotrack.js and code optimized.
|
85 |
*
|
86 |
+
* @global array $aioseop_options All-in-on-seo saved settings/options.
|
87 |
*/
|
88 |
+
public function universal_analytics() {
|
89 |
global $aioseop_options;
|
|
|
90 |
$allow_linker = $cookie_domain = $domain = $addl_domains = $domain_list = '';
|
91 |
if ( ! empty( $aioseop_options['aiosp_ga_advanced_options'] ) ) {
|
92 |
$cookie_domain = $this->get_analytics_domain();
|
93 |
}
|
94 |
if ( ! empty( $cookie_domain ) ) {
|
95 |
$cookie_domain = esc_js( $cookie_domain );
|
96 |
+
$cookie_domain = '\'cookieDomain\': \'' . $cookie_domain . '\'';
|
97 |
}
|
98 |
if ( empty( $cookie_domain ) ) {
|
99 |
+
$domain = ', \'auto\'';
|
100 |
}
|
101 |
+
if ( ! empty( $aioseop_options['aiosp_ga_advanced_options'] )
|
102 |
+
&& ! empty( $aioseop_options['aiosp_ga_multi_domain'] )
|
103 |
+
) {
|
104 |
+
$allow_linker = '\'allowLinker\': true';
|
105 |
if ( ! empty( $aioseop_options['aiosp_ga_addl_domains'] ) ) {
|
106 |
$addl_domains = trim( $aioseop_options['aiosp_ga_addl_domains'] );
|
107 |
$addl_domains = preg_split( '/[\s,]+/', $addl_domains );
|
112 |
if ( ! empty( $domain_list ) ) {
|
113 |
$domain_list .= ', ';
|
114 |
}
|
115 |
+
$domain_list .= '\'' . $d . '\'';
|
116 |
}
|
117 |
}
|
118 |
}
|
119 |
}
|
120 |
}
|
121 |
+
$extra_options = array();
|
122 |
+
if ( ! empty( $domain_list ) ) {
|
123 |
+
$extra_options[] = 'ga(\'require\', \'linker\');';
|
124 |
+
$extra_options[] = 'ga(\'linker:autoLink\', ['. $domain_list . '] );';
|
125 |
}
|
126 |
+
if ( ! empty( $aioseop_options['aiosp_ga_advanced_options'] ) ) {
|
127 |
+
if ( ! empty( $aioseop_options['aiosp_ga_display_advertising'] ) ) {
|
128 |
+
$extra_options[] = 'ga(\'require\', \'displayfeatures\');';
|
129 |
}
|
130 |
+
if ( ! empty( $aioseop_options['aiosp_ga_enhanced_ecommerce'] ) ) {
|
131 |
+
$extra_options[] = 'ga(\'require\', \'ec\');';
|
|
|
|
|
|
|
132 |
}
|
133 |
+
if ( ! empty( $aioseop_options['aiosp_ga_link_attribution'] ) ) {
|
134 |
+
$extra_options[] = 'ga(\'require\', \'linkid\', \'linkid.js\');';
|
|
|
|
|
|
|
135 |
}
|
136 |
+
if ( ! empty( $aioseop_options['aiosp_ga_anonymize_ip'] ) ) {
|
137 |
+
$extra_options[] = 'ga(\'set\', \'anonymizeIp\', true);';
|
138 |
+
}
|
139 |
+
if ( ! empty( $aioseop_options['aiosp_ga_track_outbound_links'] ) ) {
|
140 |
+
$extra_options[] = 'ga(\'require\', \'outboundLinkTracker\');';
|
|
|
141 |
}
|
|
|
142 |
}
|
143 |
+
$extra_options = apply_filters( 'aioseop_ga_extra_options', $extra_options, $aioseop_options );
|
144 |
$js_options = array();
|
145 |
foreach ( array( 'cookie_domain', 'allow_linker' ) as $opts ) {
|
146 |
if ( ! empty( $$opts ) ) {
|
147 |
$js_options[] = $$opts;
|
148 |
}
|
149 |
}
|
150 |
+
$js_options = empty( $js_options )
|
151 |
+
? ''
|
152 |
+
: ', { ' . implode( ',', $js_options ) . ' } ';
|
153 |
+
// Prepare analytics
|
154 |
+
$analytics_id = esc_js( $aioseop_options['aiosp_google_analytics_id'] );
|
155 |
+
ob_start()
|
156 |
+
?>
|
157 |
+
<script type="text/javascript" <?php echo preg_replace( '/\s+/', ' ', apply_filters( 'aioseop_ga_attributes', '' ) ) ?>>
|
158 |
+
window.ga=window.ga||function(){(ga.q=ga.q||[]).push(arguments)};ga.l=+new Date;
|
159 |
+
ga('create', '<?php echo $analytics_id ?>'<?php echo $domain ?><?php echo $js_options ?>);
|
160 |
+
// Plugins
|
161 |
+
<?php foreach ( $extra_options as $option ) : ?><?php echo $option ?><?php endforeach ?>
|
162 |
+
|
163 |
+
ga('send', 'pageview');
|
|
|
|
|
|
|
|
|
|
|
|
|
164 |
</script>
|
165 |
+
<script async src="https://www.google-analytics.com/analytics.js"></script>
|
166 |
+
<?php
|
167 |
+
return ob_get_clean();
|
|
|
168 |
}
|
169 |
|
170 |
/**
|
175 |
if ( ! empty( $aioseop_options['aiosp_ga_domain'] ) ) {
|
176 |
return $this->sanitize_domain( $aioseop_options['aiosp_ga_domain'] );
|
177 |
}
|
|
|
178 |
return '';
|
179 |
}
|
180 |
|
readme.txt
CHANGED
@@ -4,7 +4,7 @@ Donate link: https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=mrtor
|
|
4 |
Tags: seo, all in one seo, google, twitter, page, image seo, social, search engine optimization, sitemap, WordPress SEO, meta, meta description, xml sitemap, google sitemap, sitemaps, robots meta, yahoo, bing, news sitemaps, multisite, canonical, nofollow, noindex, keywords, description, webmaster tools, google webmaster tools, google analytics
|
5 |
Requires at least: 4.0
|
6 |
Tested up to: 4.8
|
7 |
-
Stable tag: 2.
|
8 |
License: GPLv2 or later
|
9 |
License URI: http://www.gnu.org/licenses/gpl-2.0.html
|
10 |
|
@@ -21,6 +21,7 @@ Use **All in One SEO Pack** to optimize your WordPress site for SEO. It's easy a
|
|
21 |
First created in 2007, see why AIOSEO is one of the all time most downloaded plugins for WordPress.
|
22 |
|
23 |
* XML Sitemap support - submit your sitemap to Google and Bing and improve your SEO
|
|
|
24 |
* Google AMP support (Accelerated Mobile Pages)
|
25 |
* Google Analytics support
|
26 |
* Support for SEO on Custom Post Types
|
@@ -82,7 +83,7 @@ https://www.youtube.com/watch?v=A0VKinM5s00
|
|
82 |
6. **Additional Pages for XML Sitemap** You can easily configure any additional pages to be added to the sitemap in addition to the dynamically generated WordPress pages. This ensures that search engines like Google will see ALL of your website's content.
|
83 |
7. **Quick-Edit** Quickly edit your WordPress SEO data without having to go back and forth between different screens.
|
84 |
8. **SEO Menu** All in One offers an extensive array of premium SEO features for free. Perfect for the novice or advanced user.
|
85 |
-
|
86 |
|
87 |
== Upgrade Notice ==
|
88 |
|
4 |
Tags: seo, all in one seo, google, twitter, page, image seo, social, search engine optimization, sitemap, WordPress SEO, meta, meta description, xml sitemap, google sitemap, sitemaps, robots meta, yahoo, bing, news sitemaps, multisite, canonical, nofollow, noindex, keywords, description, webmaster tools, google webmaster tools, google analytics
|
5 |
Requires at least: 4.0
|
6 |
Tested up to: 4.8
|
7 |
+
Stable tag: 2.4
|
8 |
License: GPLv2 or later
|
9 |
License URI: http://www.gnu.org/licenses/gpl-2.0.html
|
10 |
|
21 |
First created in 2007, see why AIOSEO is one of the all time most downloaded plugins for WordPress.
|
22 |
|
23 |
* XML Sitemap support - submit your sitemap to Google and Bing and improve your SEO
|
24 |
+
* Image XML Sitemap submitted to Google and Bing to improve your Image SEO
|
25 |
* Google AMP support (Accelerated Mobile Pages)
|
26 |
* Google Analytics support
|
27 |
* Support for SEO on Custom Post Types
|
83 |
6. **Additional Pages for XML Sitemap** You can easily configure any additional pages to be added to the sitemap in addition to the dynamically generated WordPress pages. This ensures that search engines like Google will see ALL of your website's content.
|
84 |
7. **Quick-Edit** Quickly edit your WordPress SEO data without having to go back and forth between different screens.
|
85 |
8. **SEO Menu** All in One offers an extensive array of premium SEO features for free. Perfect for the novice or advanced user.
|
86 |
+
9. **Google XML Sitemap** Automatically sent to Google and other search engines. Include images in your sitemap!
|
87 |
|
88 |
== Upgrade Notice ==
|
89 |
|