Completed
Pull Request — master (#254)
by
unknown
01:50
created
classes/autoptimizeVersionUpdatesHandler.php 1 patch
Spacing   +62 added lines, -62 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Handles version updates and should only be instantiated in autoptimize.php if/when needed.
4 4
  */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) {
6
+if (!defined('ABSPATH')) {
7 7
     exit;
8 8
 }
9 9
 
@@ -16,9 +16,9 @@  discard block
 block discarded – undo
16 16
      */
17 17
     protected $current_major_version = null;
18 18
 
19
-    public function __construct( $current_version )
19
+    public function __construct($current_version)
20 20
     {
21
-        $this->current_major_version = substr( $current_version, 0, 3 );
21
+        $this->current_major_version = substr($current_version, 0, 3);
22 22
     }
23 23
 
24 24
     /**
@@ -29,7 +29,7 @@  discard block
 block discarded – undo
29 29
     {
30 30
         $major_update = false;
31 31
 
32
-        switch ( $this->current_major_version ) {
32
+        switch ($this->current_major_version) {
33 33
             case '1.6':
34 34
                 $this->upgrade_from_1_6();
35 35
                 $major_update = true;
@@ -47,7 +47,7 @@  discard block
 block discarded – undo
47 47
                 $major_update = true;
48 48
                 // No break, intentionally, so all upgrades are ran during a single request...
49 49
             case '2.4':
50
-                if ( autoptimizeOption::get_option( 'autoptimize_version', 'none' ) == '2.4.2' ) {
50
+                if (autoptimizeOption::get_option('autoptimize_version', 'none') == '2.4.2') {
51 51
                     $this->upgrade_from_2_4_2();
52 52
                 }
53 53
                 $this->upgrade_from_2_4();
@@ -55,7 +55,7 @@  discard block
 block discarded – undo
55 55
                 // No break, intentionally, so all upgrades are ran during a single request...
56 56
         }
57 57
 
58
-        if ( true === $major_update ) {
58
+        if (true === $major_update) {
59 59
             $this->on_major_version_update();
60 60
         }
61 61
     }
@@ -67,19 +67,19 @@  discard block
 block discarded – undo
67 67
      *
68 68
      * @param string $target Target version to check against (ie., the currently running one).
69 69
      */
70
-    public static function check_installed_and_update( $target )
70
+    public static function check_installed_and_update($target)
71 71
     {
72
-        $db_version = autoptimizeOption::get_option( 'autoptimize_version', 'none' );
73
-        if ( $db_version !== $target ) {
74
-            if ( 'none' === $db_version ) {
75
-                add_action( 'admin_notices', 'autoptimizeMain::notice_installed' );
72
+        $db_version = autoptimizeOption::get_option('autoptimize_version', 'none');
73
+        if ($db_version !== $target) {
74
+            if ('none' === $db_version) {
75
+                add_action('admin_notices', 'autoptimizeMain::notice_installed');
76 76
             } else {
77
-                $updater = new self( $db_version );
77
+                $updater = new self($db_version);
78 78
                 $updater->run_needed_major_upgrades();
79 79
             }
80 80
 
81 81
             // Versions differed, upgrades happened if needed, store the new version.
82
-            autoptimizeOption::update_option( 'autoptimize_version', $target );
82
+            autoptimizeOption::update_option('autoptimize_version', $target);
83 83
         }
84 84
     }
85 85
 
@@ -90,10 +90,10 @@  discard block
 block discarded – undo
90 90
     protected function on_major_version_update()
91 91
     {
92 92
         // The transients guard here prevents stale object caches from busting the cache on every request.
93
-        if ( false == get_transient( 'autoptimize_stale_option_buster' ) ) {
94
-            set_transient( 'autoptimize_stale_option_buster', 'Mamsie & Liessie zehhe: ZWIJH!', HOUR_IN_SECONDS );
93
+        if (false == get_transient('autoptimize_stale_option_buster')) {
94
+            set_transient('autoptimize_stale_option_buster', 'Mamsie & Liessie zehhe: ZWIJH!', HOUR_IN_SECONDS);
95 95
             autoptimizeCache::clearall();
96
-            add_action( 'admin_notices', 'autoptimizeMain::notice_updated' );
96
+            add_action('admin_notices', 'autoptimizeMain::notice_updated');
97 97
         }
98 98
     }
99 99
 
@@ -103,7 +103,7 @@  discard block
 block discarded – undo
103 103
     private function upgrade_from_1_6()
104 104
     {
105 105
         // If user was on version 1.6.x, force advanced options to be shown by default.
106
-        autoptimizeOption::update_option( 'autoptimize_show_adv', '1' );
106
+        autoptimizeOption::update_option('autoptimize_show_adv', '1');
107 107
 
108 108
         // And remove old options.
109 109
         $to_delete_options = array(
@@ -115,8 +115,8 @@  discard block
 block discarded – undo
115 115
             'autoptimize_cdn_img_url',
116 116
             'autoptimize_css_yui',
117 117
         );
118
-        foreach ( $to_delete_options as $del_opt ) {
119
-            delete_option( $del_opt );
118
+        foreach ($to_delete_options as $del_opt) {
119
+            delete_option($del_opt);
120 120
         }
121 121
     }
122 122
 
@@ -127,29 +127,29 @@  discard block
 block discarded – undo
127 127
      */
128 128
     private function upgrade_from_1_7()
129 129
     {
130
-        if ( ! is_multisite() ) {
131
-            $css_exclude = autoptimizeOption::get_option( 'autoptimize_css_exclude' );
132
-            if ( empty( $css_exclude ) ) {
130
+        if (!is_multisite()) {
131
+            $css_exclude = autoptimizeOption::get_option('autoptimize_css_exclude');
132
+            if (empty($css_exclude)) {
133 133
                 $css_exclude = 'admin-bar.min.css, dashicons.min.css';
134
-            } elseif ( false === strpos( $css_exclude, 'dashicons.min.css' ) ) {
134
+            } elseif (false === strpos($css_exclude, 'dashicons.min.css')) {
135 135
                 $css_exclude .= ', dashicons.min.css';
136 136
             }
137
-            autoptimizeOption::update_option( 'autoptimize_css_exclude', $css_exclude );
137
+            autoptimizeOption::update_option('autoptimize_css_exclude', $css_exclude);
138 138
         } else {
139 139
             global $wpdb;
140
-            $blog_ids         = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" );
140
+            $blog_ids         = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
141 141
             $original_blog_id = get_current_blog_id();
142
-            foreach ( $blog_ids as $blog_id ) {
143
-                switch_to_blog( $blog_id );
144
-                $css_exclude = autoptimizeOption::get_option( 'autoptimize_css_exclude' );
145
-                if ( empty( $css_exclude ) ) {
142
+            foreach ($blog_ids as $blog_id) {
143
+                switch_to_blog($blog_id);
144
+                $css_exclude = autoptimizeOption::get_option('autoptimize_css_exclude');
145
+                if (empty($css_exclude)) {
146 146
                     $css_exclude = 'admin-bar.min.css, dashicons.min.css';
147
-                } elseif ( false === strpos( $css_exclude, 'dashicons.min.css' ) ) {
147
+                } elseif (false === strpos($css_exclude, 'dashicons.min.css')) {
148 148
                     $css_exclude .= ', dashicons.min.css';
149 149
                 }
150
-                autoptimizeOption::update_option( 'autoptimize_css_exclude', $css_exclude );
150
+                autoptimizeOption::update_option('autoptimize_css_exclude', $css_exclude);
151 151
             }
152
-            switch_to_blog( $original_blog_id );
152
+            switch_to_blog($original_blog_id);
153 153
         }
154 154
     }
155 155
 
@@ -161,19 +161,19 @@  discard block
 block discarded – undo
161 161
      */
162 162
     private function upgrade_from_1_9()
163 163
     {
164
-        if ( ! is_multisite() ) {
165
-            autoptimizeOption::update_option( 'autoptimize_css_include_inline', 'on' );
166
-            autoptimizeOption::update_option( 'autoptimize_js_include_inline', 'on' );
164
+        if (!is_multisite()) {
165
+            autoptimizeOption::update_option('autoptimize_css_include_inline', 'on');
166
+            autoptimizeOption::update_option('autoptimize_js_include_inline', 'on');
167 167
         } else {
168 168
             global $wpdb;
169
-            $blog_ids         = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" );
169
+            $blog_ids         = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
170 170
             $original_blog_id = get_current_blog_id();
171
-            foreach ( $blog_ids as $blog_id ) {
172
-                switch_to_blog( $blog_id );
173
-                autoptimizeOption::update_option( 'autoptimize_css_include_inline', 'on' );
174
-                autoptimizeOption::update_option( 'autoptimize_js_include_inline', 'on' );
171
+            foreach ($blog_ids as $blog_id) {
172
+                switch_to_blog($blog_id);
173
+                autoptimizeOption::update_option('autoptimize_css_include_inline', 'on');
174
+                autoptimizeOption::update_option('autoptimize_js_include_inline', 'on');
175 175
             }
176
-            switch_to_blog( $original_blog_id );
176
+            switch_to_blog($original_blog_id);
177 177
         }
178 178
     }
179 179
 
@@ -184,17 +184,17 @@  discard block
 block discarded – undo
184 184
      */
185 185
     private function upgrade_from_2_2()
186 186
     {
187
-        if ( ! is_multisite() ) {
187
+        if (!is_multisite()) {
188 188
             $this->do_2_2_settings_update();
189 189
         } else {
190 190
             global $wpdb;
191
-            $blog_ids         = $wpdb->get_col( "SELECT blog_id FROM $wpdb->blogs" );
191
+            $blog_ids         = $wpdb->get_col("SELECT blog_id FROM $wpdb->blogs");
192 192
             $original_blog_id = get_current_blog_id();
193
-            foreach ( $blog_ids as $blog_id ) {
194
-                switch_to_blog( $blog_id );
193
+            foreach ($blog_ids as $blog_id) {
194
+                switch_to_blog($blog_id);
195 195
                 $this->do_2_2_settings_update();
196 196
             }
197
-            switch_to_blog( $original_blog_id );
197
+            switch_to_blog($original_blog_id);
198 198
         }
199 199
     }
200 200
 
@@ -203,12 +203,12 @@  discard block
 block discarded – undo
203 203
      */
204 204
     private function do_2_2_settings_update()
205 205
     {
206
-        $nogooglefont    = autoptimizeOption::get_option( 'autoptimize_css_nogooglefont', '' );
207
-        $ao_extrasetting = autoptimizeOption::get_option( 'autoptimize_extra_settings', '' );
208
-        if ( ( $nogooglefont ) && ( empty( $ao_extrasetting ) ) ) {
209
-            autoptimizeOption::update_option( 'autoptimize_extra_settings', autoptimizeConfig::get_ao_extra_default_options() );
206
+        $nogooglefont    = autoptimizeOption::get_option('autoptimize_css_nogooglefont', '');
207
+        $ao_extrasetting = autoptimizeOption::get_option('autoptimize_extra_settings', '');
208
+        if (($nogooglefont) && (empty($ao_extrasetting))) {
209
+            autoptimizeOption::update_option('autoptimize_extra_settings', autoptimizeConfig::get_ao_extra_default_options());
210 210
         }
211
-        delete_option( 'autoptimize_css_nogooglefont' );
211
+        delete_option('autoptimize_css_nogooglefont');
212 212
     }
213 213
 
214 214
     /**
@@ -220,33 +220,33 @@  discard block
 block discarded – undo
220 220
         $jobs = _get_cron_array();
221 221
 
222 222
         // Remove all ao_cachechecker cron jobs (for now).
223
-        foreach ( $jobs as $when => $job ) {
224
-            $name = key( $job );
223
+        foreach ($jobs as $when => $job) {
224
+            $name = key($job);
225 225
 
226
-            if ( false !== strpos( $name, 'ao_cachechecker' ) ) {
227
-                unset( $jobs[ $when ] );
226
+            if (false !== strpos($name, 'ao_cachechecker')) {
227
+                unset($jobs[$when]);
228 228
             }
229 229
         }
230 230
 
231 231
         // Save the data.
232
-        _set_cron_array( $jobs );
232
+        _set_cron_array($jobs);
233 233
     }
234 234
 
235 235
     /**
236 236
      * Migrate imgopt options from autoptimize_extra_settings to autoptimize_imgopt_settings
237 237
      */
238 238
     private function upgrade_from_2_4() {
239
-        $extra_settings  = autoptimizeOption::get_option( 'autoptimize_extra_settings', '' );
240
-        $imgopt_settings = autoptimizeOption::get_option( 'autoptimize_imgopt_settings', '' );
241
-        if ( empty( $imgopt_settings ) && ! empty( $extra_settings ) ) {
239
+        $extra_settings  = autoptimizeOption::get_option('autoptimize_extra_settings', '');
240
+        $imgopt_settings = autoptimizeOption::get_option('autoptimize_imgopt_settings', '');
241
+        if (empty($imgopt_settings) && !empty($extra_settings)) {
242 242
             $imgopt_settings = autoptimizeConfig::get_ao_imgopt_default_options();
243
-            if ( array_key_exists( 'autoptimize_extra_checkbox_field_5', $extra_settings ) ) {
243
+            if (array_key_exists('autoptimize_extra_checkbox_field_5', $extra_settings)) {
244 244
                 $imgopt_settings['autoptimize_imgopt_checkbox_field_1'] = $extra_settings['autoptimize_extra_checkbox_field_5'];
245 245
             }
246
-            if ( array_key_exists( 'autoptimize_extra_select_field_6', $extra_settings ) ) {
246
+            if (array_key_exists('autoptimize_extra_select_field_6', $extra_settings)) {
247 247
                 $imgopt_settings['autoptimize_imgopt_select_field_2'] = $extra_settings['autoptimize_extra_select_field_6'];
248 248
             }
249
-            autoptimizeOption::update_option( 'autoptimize_imgopt_settings', $imgopt_settings );
249
+            autoptimizeOption::update_option('autoptimize_imgopt_settings', $imgopt_settings);
250 250
         }
251 251
     }
252 252
 }
Please login to merge, or discard this patch.
classes/autoptimizeCacheChecker.php 1 patch
Spacing   +38 added lines, -38 removed lines patch added patch discarded remove patch
@@ -6,7 +6,7 @@  discard block
 block discarded – undo
6 6
  * Checks if cachesize is > 0.5GB (size is filterable), if so, an option is set which controls showing an admin notice.
7 7
  */
8 8
 
9
-if ( ! defined( 'ABSPATH' ) ) {
9
+if (!defined('ABSPATH')) {
10 10
     exit;
11 11
 }
12 12
 
@@ -25,51 +25,51 @@  discard block
 block discarded – undo
25 25
 
26 26
     public function add_hooks()
27 27
     {
28
-        if ( is_admin() ) {
29
-            add_action( 'plugins_loaded', array( $this, 'setup' ) );
28
+        if (is_admin()) {
29
+            add_action('plugins_loaded', array($this, 'setup'));
30 30
         }
31
-        add_action( self::SCHEDULE_HOOK, array( $this, 'cronjob' ) );
32
-        add_action( 'admin_notices', array( $this, 'show_admin_notice' ) );
31
+        add_action(self::SCHEDULE_HOOK, array($this, 'cronjob'));
32
+        add_action('admin_notices', array($this, 'show_admin_notice'));
33 33
     }
34 34
 
35 35
     public function setup()
36 36
     {
37
-        $do_cache_check = (bool) apply_filters( 'autoptimize_filter_cachecheck_do', true );
38
-        $schedule       = wp_get_schedule( self::SCHEDULE_HOOK );
39
-        $frequency      = apply_filters( 'autoptimize_filter_cachecheck_frequency', 'twicedaily' );
40
-        if ( ! in_array( $frequency, array( 'hourly', 'twicedaily', 'daily', 'weekly', 'monthly' ) ) ) {
37
+        $do_cache_check = (bool) apply_filters('autoptimize_filter_cachecheck_do', true);
38
+        $schedule       = wp_get_schedule(self::SCHEDULE_HOOK);
39
+        $frequency      = apply_filters('autoptimize_filter_cachecheck_frequency', 'twicedaily');
40
+        if (!in_array($frequency, array('hourly', 'twicedaily', 'daily', 'weekly', 'monthly'))) {
41 41
             $frequency = 'twicedaily';
42 42
         }
43
-        if ( $do_cache_check && ( ! $schedule || $schedule !== $frequency ) ) {
44
-            if ( $schedule ) {
45
-                wp_clear_scheduled_hook( self::SCHEDULE_HOOK );
43
+        if ($do_cache_check && (!$schedule || $schedule !== $frequency)) {
44
+            if ($schedule) {
45
+                wp_clear_scheduled_hook(self::SCHEDULE_HOOK);
46 46
             }
47
-            wp_schedule_event( time(), $frequency, self::SCHEDULE_HOOK );
48
-        } elseif ( $schedule && ! $do_cache_check ) {
49
-            wp_clear_scheduled_hook( self::SCHEDULE_HOOK );
47
+            wp_schedule_event(time(), $frequency, self::SCHEDULE_HOOK);
48
+        } elseif ($schedule && !$do_cache_check) {
49
+            wp_clear_scheduled_hook(self::SCHEDULE_HOOK);
50 50
         }
51 51
     }
52 52
 
53 53
     public function cronjob()
54 54
     {
55 55
         // Check cachesize and act accordingly.
56
-        $max_size       = (int) apply_filters( 'autoptimize_filter_cachecheck_maxsize', 536870912 );
57
-        $do_cache_check = (bool) apply_filters( 'autoptimize_filter_cachecheck_do', true );
56
+        $max_size       = (int) apply_filters('autoptimize_filter_cachecheck_maxsize', 536870912);
57
+        $do_cache_check = (bool) apply_filters('autoptimize_filter_cachecheck_do', true);
58 58
         $stat_array     = autoptimizeCache::stats();
59
-        $cache_size     = round( $stat_array[1] );
60
-        if ( ( $cache_size > $max_size ) && ( $do_cache_check ) ) {
61
-            autoptimizeOption::update_option( 'autoptimize_cachesize_notice', true );
62
-            if ( apply_filters( 'autoptimize_filter_cachecheck_sendmail', true ) ) {
63
-                $home_url  = esc_url( home_url() );
64
-                $ao_mailto = apply_filters( 'autoptimize_filter_cachecheck_mailto', autoptimizeOption::get_option( 'admin_email', '' ) );
65
-
66
-                $ao_mailsubject = __( 'Autoptimize cache size warning', 'autoptimize' ) . ' (' . $home_url . ')';
67
-                $ao_mailbody    = __( 'Autoptimize\'s cache size is getting big, consider purging the cache. Have a look at https://wordpress.org/plugins/autoptimize/faq/ to see how you can keep the cache size under control.', 'autoptimize' ) . ' (site: ' . $home_url . ')';
68
-
69
-                if ( ! empty( $ao_mailto ) ) {
70
-                    $ao_mailresult = wp_mail( $ao_mailto, $ao_mailsubject, $ao_mailbody );
71
-                    if ( ! $ao_mailresult ) {
72
-                        error_log( 'Autoptimize could not send cache size warning mail.' );
59
+        $cache_size     = round($stat_array[1]);
60
+        if (($cache_size > $max_size) && ($do_cache_check)) {
61
+            autoptimizeOption::update_option('autoptimize_cachesize_notice', true);
62
+            if (apply_filters('autoptimize_filter_cachecheck_sendmail', true)) {
63
+                $home_url  = esc_url(home_url());
64
+                $ao_mailto = apply_filters('autoptimize_filter_cachecheck_mailto', autoptimizeOption::get_option('admin_email', ''));
65
+
66
+                $ao_mailsubject = __('Autoptimize cache size warning', 'autoptimize').' ('.$home_url.')';
67
+                $ao_mailbody    = __('Autoptimize\'s cache size is getting big, consider purging the cache. Have a look at https://wordpress.org/plugins/autoptimize/faq/ to see how you can keep the cache size under control.', 'autoptimize').' (site: '.$home_url.')';
68
+
69
+                if (!empty($ao_mailto)) {
70
+                    $ao_mailresult = wp_mail($ao_mailto, $ao_mailsubject, $ao_mailbody);
71
+                    if (!$ao_mailresult) {
72
+                        error_log('Autoptimize could not send cache size warning mail.');
73 73
                     }
74 74
                 }
75 75
             }
@@ -87,16 +87,16 @@  discard block
 block discarded – undo
87 87
 
88 88
     public function show_admin_notice()
89 89
     {
90
-        if ( (bool) autoptimizeOption::get_option( 'autoptimize_cachesize_notice', false ) && current_user_can( 'manage_options' ) ) {
90
+        if ((bool) autoptimizeOption::get_option('autoptimize_cachesize_notice', false) && current_user_can('manage_options')) {
91 91
             echo '<div class="notice notice-warning"><p>';
92
-            _e( '<strong>Autoptimize\'s cache size is getting big</strong>, consider purging the cache. Have a look at <a href="https://wordpress.org/plugins/autoptimize/faq/" target="_blank" rel="noopener noreferrer">the Autoptimize FAQ</a> to see how you can keep the cache size under control.', 'autoptimize' );
92
+            _e('<strong>Autoptimize\'s cache size is getting big</strong>, consider purging the cache. Have a look at <a href="https://wordpress.org/plugins/autoptimize/faq/" target="_blank" rel="noopener noreferrer">the Autoptimize FAQ</a> to see how you can keep the cache size under control.', 'autoptimize');
93 93
             echo '</p></div>';
94
-            autoptimizeOption::update_option( 'autoptimize_cachesize_notice', false );
94
+            autoptimizeOption::update_option('autoptimize_cachesize_notice', false);
95 95
         }
96 96
 
97 97
         // Notice for image proxy usage.
98 98
         $_imgopt_notice = autoptimizeImages::instance()->get_status_notice();
99
-        if ( current_user_can( 'manage_options' ) && is_array( $_imgopt_notice ) && array_key_exists( 'status', $_imgopt_notice ) && in_array( $_imgopt_notice['status'], array( 1, -1, -2 ) ) ) {
99
+        if (current_user_can('manage_options') && is_array($_imgopt_notice) && array_key_exists('status', $_imgopt_notice) && in_array($_imgopt_notice['status'], array(1, -1, -2))) {
100 100
             $_dismissible = 'ao-img-opt-notice-';
101 101
             $_hide_notice = '7';
102 102
 
@@ -104,10 +104,10 @@  discard block
 block discarded – undo
104 104
                 $_hide_notice = '1';
105 105
             }
106 106
 
107
-            $_imgopt_notice_dismissible = apply_filters( 'autoptimize_filter_imgopt_notice_dismissable', $_dismissible . $_hide_notice );
107
+            $_imgopt_notice_dismissible = apply_filters('autoptimize_filter_imgopt_notice_dismissable', $_dismissible.$_hide_notice);
108 108
 
109
-            if ( $_imgopt_notice && PAnD::is_admin_notice_active( $_imgopt_notice_dismissible ) ) {
110
-                echo '<div class="notice notice-warning is-dismissible" data-dismissible="' . $_imgopt_notice_dismissible . '"><p>' . $_imgopt_notice['notice'] . '</p></div>';
109
+            if ($_imgopt_notice && PAnD::is_admin_notice_active($_imgopt_notice_dismissible)) {
110
+                echo '<div class="notice notice-warning is-dismissible" data-dismissible="'.$_imgopt_notice_dismissible.'"><p>'.$_imgopt_notice['notice'].'</p></div>';
111 111
             }
112 112
         }
113 113
     }
Please login to merge, or discard this patch.
classes/autoptimizePartners.php 2 patches
Indentation   +5 added lines, -5 removed lines patch added patch discarded remove patch
@@ -20,11 +20,11 @@
 block discarded – undo
20 20
         if ( $this->enabled() ) {
21 21
             add_filter( 'autoptimize_filter_settingsscreen_tabs', array( $this, 'add_partner_tabs' ), 10, 1 );
22 22
         }
23
-		if ( is_multisite() && is_plugin_active_for_network( 'autoptimize/autoptimize.php' ) ) {
24
-			add_action( 'network_admin_menu', array( $this, 'add_admin_menu' ) );
25
-		} else {
26
-			add_action( 'admin_menu', array( $this, 'add_admin_menu' ) );
27
-		}
23
+        if ( is_multisite() && is_plugin_active_for_network( 'autoptimize/autoptimize.php' ) ) {
24
+            add_action( 'network_admin_menu', array( $this, 'add_admin_menu' ) );
25
+        } else {
26
+            add_action( 'admin_menu', array( $this, 'add_admin_menu' ) );
27
+        }
28 28
     }
29 29
 
30 30
     protected function enabled()
Please login to merge, or discard this patch.
Spacing   +30 added lines, -30 removed lines patch added patch discarded remove patch
@@ -4,7 +4,7 @@  discard block
 block discarded – undo
4 4
  * addons and/or affiliate services.
5 5
  */
6 6
 
7
-if ( ! defined( 'ABSPATH' ) ) {
7
+if (!defined('ABSPATH')) {
8 8
     exit;
9 9
 }
10 10
 
@@ -17,68 +17,68 @@  discard block
 block discarded – undo
17 17
 
18 18
     public function run()
19 19
     {
20
-        if ( $this->enabled() ) {
21
-            add_filter( 'autoptimize_filter_settingsscreen_tabs', array( $this, 'add_partner_tabs' ), 10, 1 );
20
+        if ($this->enabled()) {
21
+            add_filter('autoptimize_filter_settingsscreen_tabs', array($this, 'add_partner_tabs'), 10, 1);
22 22
         }
23
-		if ( is_multisite() && is_plugin_active_for_network( 'autoptimize/autoptimize.php' ) ) {
24
-			add_action( 'network_admin_menu', array( $this, 'add_admin_menu' ) );
23
+		if (is_multisite() && is_plugin_active_for_network('autoptimize/autoptimize.php')) {
24
+			add_action('network_admin_menu', array($this, 'add_admin_menu'));
25 25
 		} else {
26
-			add_action( 'admin_menu', array( $this, 'add_admin_menu' ) );
26
+			add_action('admin_menu', array($this, 'add_admin_menu'));
27 27
 		}
28 28
     }
29 29
 
30 30
     protected function enabled()
31 31
     {
32
-        return apply_filters( 'autoptimize_filter_show_partner_tabs', true );
32
+        return apply_filters('autoptimize_filter_show_partner_tabs', true);
33 33
     }
34 34
 
35
-    public function add_partner_tabs( $in )
35
+    public function add_partner_tabs($in)
36 36
     {
37
-        $in = array_merge( $in, array(
38
-            'ao_partners' => __( 'Optimize More!', 'autoptimize' ),
39
-        ) );
37
+        $in = array_merge($in, array(
38
+            'ao_partners' => __('Optimize More!', 'autoptimize'),
39
+        ));
40 40
 
41 41
         return $in;
42 42
     }
43 43
 
44 44
     public function add_admin_menu()
45 45
     {
46
-        if ( $this->enabled() ) {
47
-            add_submenu_page( null, 'AO partner', 'AO partner', 'manage_options', 'ao_partners', array( $this, 'ao_partners_page' ) );
46
+        if ($this->enabled()) {
47
+            add_submenu_page(null, 'AO partner', 'AO partner', 'manage_options', 'ao_partners', array($this, 'ao_partners_page'));
48 48
         }
49 49
     }
50 50
 
51 51
     protected function get_ao_partner_feed_markup()
52 52
     {
53
-        $no_feed_text = __( 'Have a look at <a href="http://optimizingmatters.com/">optimizingmatters.com</a> for Autoptimize power-ups!', 'autoptimize' );
53
+        $no_feed_text = __('Have a look at <a href="http://optimizingmatters.com/">optimizingmatters.com</a> for Autoptimize power-ups!', 'autoptimize');
54 54
         $output       = '';
55
-        if ( apply_filters( 'autoptimize_settingsscreen_remotehttp', true ) ) {
56
-            $rss      = fetch_feed( 'http://feeds.feedburner.com/OptimizingMattersDownloads' );
55
+        if (apply_filters('autoptimize_settingsscreen_remotehttp', true)) {
56
+            $rss      = fetch_feed('http://feeds.feedburner.com/OptimizingMattersDownloads');
57 57
             $maxitems = 0;
58 58
 
59
-            if ( ! is_wp_error( $rss ) ) {
60
-                $maxitems  = $rss->get_item_quantity( 20 );
61
-                $rss_items = $rss->get_items( 0, $maxitems );
59
+            if (!is_wp_error($rss)) {
60
+                $maxitems  = $rss->get_item_quantity(20);
61
+                $rss_items = $rss->get_items(0, $maxitems);
62 62
             }
63 63
 
64
-            if ( 0 == $maxitems ) {
64
+            if (0 == $maxitems) {
65 65
                 $output .= $no_feed_text;
66 66
             } else {
67 67
                 $output .= '<ul>';
68
-                foreach ( $rss_items as $item ) {
69
-                    $item_url  = esc_url( $item->get_permalink() );
68
+                foreach ($rss_items as $item) {
69
+                    $item_url  = esc_url($item->get_permalink());
70 70
                     $enclosure = $item->get_enclosure();
71 71
 
72 72
                     $output .= '<li class="itemDetail">';
73
-                    $output .= '<h3 class="itemTitle"><a href="' . $item_url . '" target="_blank">' . esc_html( $item->get_title() ) . '</a></h3>';
73
+                    $output .= '<h3 class="itemTitle"><a href="'.$item_url.'" target="_blank">'.esc_html($item->get_title()).'</a></h3>';
74 74
 
75
-                    if ( $enclosure && ( false !== strpos( $enclosure->get_type(), 'image' ) ) ) {
76
-                        $img_url = esc_url( $enclosure->get_link() );
77
-                        $output .= '<div class="itemImage"><a href="' . $item_url . '" target="_blank"><img src="' . $img_url . '"></a></div>';
75
+                    if ($enclosure && (false !== strpos($enclosure->get_type(), 'image'))) {
76
+                        $img_url = esc_url($enclosure->get_link());
77
+                        $output .= '<div class="itemImage"><a href="'.$item_url.'" target="_blank"><img src="'.$img_url.'"></a></div>';
78 78
                     }
79 79
 
80
-                    $output .= '<div class="itemDescription">' . wp_kses_post( $item->get_description() ) . '</div>';
81
-                    $output .= '<div class="itemButtonRow"><div class="itemButton button-secondary"><a href="' . $item_url . '" target="_blank">' . __( 'More info', 'autoptimize' ) . '</a></div></div>';
80
+                    $output .= '<div class="itemDescription">'.wp_kses_post($item->get_description()).'</div>';
81
+                    $output .= '<div class="itemButtonRow"><div class="itemButton button-secondary"><a href="'.$item_url.'" target="_blank">'.__('More info', 'autoptimize').'</a></div></div>';
82 82
                     $output .= '</li>';
83 83
                 }
84 84
                 $output .= '</ul>';
@@ -137,9 +137,9 @@  discard block
 block discarded – undo
137 137
     }
138 138
     </style>
139 139
     <div class="wrap">
140
-        <h1><?php _e( 'Autoptimize Settings', 'autoptimize' ); ?></h1>
140
+        <h1><?php _e('Autoptimize Settings', 'autoptimize'); ?></h1>
141 141
         <?php echo autoptimizeConfig::ao_admin_tabs(); ?>
142
-        <?php echo '<h2>' . __( "These Autoptimize power-ups and related services will improve your site's performance even more!", 'autoptimize' ) . '</h2>'; ?>
142
+        <?php echo '<h2>'.__("These Autoptimize power-ups and related services will improve your site's performance even more!", 'autoptimize').'</h2>'; ?>
143 143
         <div>
144 144
             <?php echo $this->get_ao_partner_feed_markup(); ?>
145 145
         </div>
Please login to merge, or discard this patch.
autoptimize.php 1 patch
Spacing   +33 added lines, -33 removed lines patch added patch discarded remove patch
@@ -16,66 +16,66 @@  discard block
 block discarded – undo
16 16
  */
17 17
 
18 18
 
19
-if ( ! defined( 'ABSPATH' ) ) {
19
+if (!defined('ABSPATH')) {
20 20
     exit;
21 21
 }
22 22
 
23
-define( 'AUTOPTIMIZE_PLUGIN_VERSION', '2.5.1' );
23
+define('AUTOPTIMIZE_PLUGIN_VERSION', '2.5.1');
24 24
 
25 25
 // plugin_dir_path() returns the trailing slash!
26
-define( 'AUTOPTIMIZE_PLUGIN_DIR', plugin_dir_path( __FILE__ ) );
27
-define( 'AUTOPTIMIZE_PLUGIN_FILE', __FILE__ );
26
+define('AUTOPTIMIZE_PLUGIN_DIR', plugin_dir_path(__FILE__));
27
+define('AUTOPTIMIZE_PLUGIN_FILE', __FILE__);
28 28
 
29 29
 // Bail early if attempting to run on non-supported php versions.
30
-if ( version_compare( PHP_VERSION, '5.3', '<' ) ) {
30
+if (version_compare(PHP_VERSION, '5.3', '<')) {
31 31
     function autoptimize_incompatible_admin_notice() {
32
-        echo '<div class="error"><p>' . __( 'Autoptimize requires PHP 5.3 (or higher) to function properly. Please upgrade PHP. The Plugin has been auto-deactivated.', 'autoptimize' ) . '</p></div>';
33
-        if ( isset( $_GET['activate'] ) ) {
34
-            unset( $_GET['activate'] );
32
+        echo '<div class="error"><p>'.__('Autoptimize requires PHP 5.3 (or higher) to function properly. Please upgrade PHP. The Plugin has been auto-deactivated.', 'autoptimize').'</p></div>';
33
+        if (isset($_GET['activate'])) {
34
+            unset($_GET['activate']);
35 35
         }
36 36
     }
37 37
     function autoptimize_deactivate_self() {
38
-        deactivate_plugins( plugin_basename( AUTOPTIMIZE_PLUGIN_FILE ) );
38
+        deactivate_plugins(plugin_basename(AUTOPTIMIZE_PLUGIN_FILE));
39 39
     }
40
-    add_action( 'admin_notices', 'autoptimize_incompatible_admin_notice' );
41
-    add_action( 'admin_init', 'autoptimize_deactivate_self' );
40
+    add_action('admin_notices', 'autoptimize_incompatible_admin_notice');
41
+    add_action('admin_init', 'autoptimize_deactivate_self');
42 42
     return;
43 43
 }
44 44
 
45
-function autoptimize_autoload( $class_name ) {
46
-    if ( in_array( $class_name, array( 'Minify_HTML', 'JSMin' ) ) ) {
47
-        $file     = strtolower( $class_name );
48
-        $file     = str_replace( '_', '-', $file );
49
-        $path     = dirname( __FILE__ ) . '/classes/external/php/';
50
-        $filepath = $path . $file . '.php';
51
-    } elseif ( false !== strpos( $class_name, 'Autoptimize\\tubalmartin\\CssMin' ) ) {
52
-        $file     = str_replace( 'Autoptimize\\tubalmartin\\CssMin\\', '', $class_name );
53
-        $path     = dirname( __FILE__ ) . '/classes/external/php/yui-php-cssmin-bundled/';
54
-        $filepath = $path . $file . '.php';
55
-    } elseif ( 'autoptimize' === substr( $class_name, 0, 11 ) ) {
45
+function autoptimize_autoload($class_name) {
46
+    if (in_array($class_name, array('Minify_HTML', 'JSMin'))) {
47
+        $file     = strtolower($class_name);
48
+        $file     = str_replace('_', '-', $file);
49
+        $path     = dirname(__FILE__).'/classes/external/php/';
50
+        $filepath = $path.$file.'.php';
51
+    } elseif (false !== strpos($class_name, 'Autoptimize\\tubalmartin\\CssMin')) {
52
+        $file     = str_replace('Autoptimize\\tubalmartin\\CssMin\\', '', $class_name);
53
+        $path     = dirname(__FILE__).'/classes/external/php/yui-php-cssmin-bundled/';
54
+        $filepath = $path.$file.'.php';
55
+    } elseif ('autoptimize' === substr($class_name, 0, 11)) {
56 56
         // One of our "old" classes.
57 57
         $file     = $class_name;
58
-        $path     = dirname( __FILE__ ) . '/classes/';
59
-        $filepath = $path . $file . '.php';
60
-    } elseif ( 'PAnD' === $class_name ) {
58
+        $path     = dirname(__FILE__).'/classes/';
59
+        $filepath = $path.$file.'.php';
60
+    } elseif ('PAnD' === $class_name) {
61 61
         $file     = 'persist-admin-notices-dismissal';
62
-        $path     = dirname( __FILE__ ) . '/classes/external/php/persist-admin-notices-dismissal/';
63
-        $filepath = $path . $file . '.php';
62
+        $path     = dirname(__FILE__).'/classes/external/php/persist-admin-notices-dismissal/';
63
+        $filepath = $path.$file.'.php';
64 64
     }
65 65
 
66 66
     // If we didn't match one of our rules, bail!
67
-    if ( ! isset( $filepath ) ) {
67
+    if (!isset($filepath)) {
68 68
         return;
69 69
     }
70 70
 
71 71
     require $filepath;
72 72
 }
73 73
 
74
-spl_autoload_register( 'autoptimize_autoload' );
74
+spl_autoload_register('autoptimize_autoload');
75 75
 
76 76
 // Load WP CLI command(s) on demand.
77
-if ( defined( 'WP_CLI' ) && WP_CLI ) {
78
-    require AUTOPTIMIZE_PLUGIN_DIR . 'classes/autoptimizeCLI.php';
77
+if (defined('WP_CLI') && WP_CLI) {
78
+    require AUTOPTIMIZE_PLUGIN_DIR.'classes/autoptimizeCLI.php';
79 79
 }
80 80
 
81 81
 /**
@@ -86,8 +86,8 @@  discard block
 block discarded – undo
86 86
 function autoptimize() {
87 87
     static $plugin = null;
88 88
 
89
-    if ( null === $plugin ) {
90
-        $plugin = new autoptimizeMain( AUTOPTIMIZE_PLUGIN_VERSION, AUTOPTIMIZE_PLUGIN_FILE );
89
+    if (null === $plugin) {
90
+        $plugin = new autoptimizeMain(AUTOPTIMIZE_PLUGIN_VERSION, AUTOPTIMIZE_PLUGIN_FILE);
91 91
     }
92 92
 
93 93
     return $plugin;
Please login to merge, or discard this patch.
classes/autoptimizeImages.php 3 patches
Doc Comments   +10 added lines, -1 removed lines patch added patch discarded remove patch
@@ -358,6 +358,9 @@  discard block
 block discarded – undo
358 358
         }
359 359
     }
360 360
 
361
+    /**
362
+     * @return string
363
+     */
361 364
     private function get_imgopt_base_url()
362 365
     {
363 366
         static $imgopt_base_url = null;
@@ -693,6 +696,9 @@  discard block
 block discarded – undo
693 696
         return $out;
694 697
     }
695 698
 
699
+    /**
700
+     * @param string $tag
701
+     */
696 702
     public function add_lazyload( $tag, $placeholder = '' ) {
697 703
         // adds actual lazyload-attributes to an image node.
698 704
         if ( str_ireplace( $this->get_lazyload_exclusions(), '', $tag ) === $tag ) {
@@ -812,6 +818,9 @@  discard block
 block discarded – undo
812 818
         return $webp_return;
813 819
     }
814 820
 
821
+    /**
822
+     * @return string
823
+     */
815 824
     public function process_picture_tag( $in, $imgopt = false, $lazy = false ) {
816 825
         // check if "<picture" is present and if filter allows us to process <picture>.
817 826
         if ( strpos( $in, '<picture' ) === false || apply_filters( 'autoptimize_filter_imgopt_dopicture', true ) === false ) {
@@ -1143,7 +1152,7 @@  discard block
 block discarded – undo
1143 1152
     /**
1144 1153
      * Determines and returns the service launch status.
1145 1154
      *
1146
-     * @return bool
1155
+     * @return null|boolean
1147 1156
      */
1148 1157
     public function launch_ok()
1149 1158
     {
Please login to merge, or discard this patch.
Indentation   +9 added lines, -9 removed lines patch added patch discarded remove patch
@@ -97,12 +97,12 @@  discard block
 block discarded – undo
97 97
     public function run()
98 98
     {
99 99
         if ( is_admin() ) {
100
-			if ( is_plugin_active_for_network( 'autoptimize/autoptimize.php' ) ) {
101
-				add_action( 'network_admin_menu', array( $this, 'imgopt_admin_menu' ) );
102
-			} else {
103
-				add_action( 'admin_menu', array( $this, 'imgopt_admin_menu' ) );
104
-			}
105
-			add_action( 'admin_init', array( $this, 'registersettings' ) );
100
+            if ( is_plugin_active_for_network( 'autoptimize/autoptimize.php' ) ) {
101
+                add_action( 'network_admin_menu', array( $this, 'imgopt_admin_menu' ) );
102
+            } else {
103
+                add_action( 'admin_menu', array( $this, 'imgopt_admin_menu' ) );
104
+            }
105
+            add_action( 'admin_init', array( $this, 'registersettings' ) );
106 106
             add_filter( 'autoptimize_filter_settingsscreen_tabs', array( $this, 'add_imgopt_tab' ), 9 );
107 107
         } else {
108 108
             $this->run_on_frontend();
@@ -877,9 +877,9 @@  discard block
 block discarded – undo
877 877
         );
878 878
     }
879 879
 	
880
-	public function registersettings() {
881
-		register_setting( 'autoptimize_imgopt_settings', 'autoptimize_imgopt_settings' );
882
-	}
880
+    public function registersettings() {
881
+        register_setting( 'autoptimize_imgopt_settings', 'autoptimize_imgopt_settings' );
882
+    }
883 883
 
884 884
     public function add_imgopt_tab( $in )
885 885
     {
Please login to merge, or discard this patch.
Spacing   +314 added lines, -314 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Handles optimizing images.
4 4
  */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) {
6
+if (!defined('ABSPATH')) {
7 7
     exit;
8 8
 }
9 9
 
@@ -23,17 +23,17 @@  discard block
 block discarded – undo
23 23
      */
24 24
     protected static $instance = null;
25 25
 
26
-    public function __construct( array $options = array() )
26
+    public function __construct(array $options = array())
27 27
     {
28 28
         // If options are not provided, fetch them.
29
-        if ( empty( $options ) ) {
29
+        if (empty($options)) {
30 30
             $options = $this->fetch_options();
31 31
         }
32 32
 
33
-        $this->set_options( $options );
33
+        $this->set_options($options);
34 34
     }
35 35
 
36
-    public function set_options( array $options )
36
+    public function set_options(array $options)
37 37
     {
38 38
         $this->options = $options;
39 39
 
@@ -42,17 +42,17 @@  discard block
 block discarded – undo
42 42
 
43 43
     public static function fetch_options()
44 44
     {
45
-        $value = autoptimizeOption::get_option( 'autoptimize_imgopt_settings' );
46
-        if ( empty( $value ) ) {
45
+        $value = autoptimizeOption::get_option('autoptimize_imgopt_settings');
46
+        if (empty($value)) {
47 47
             // Fallback to returning defaults when no stored option exists yet.
48 48
             $value = autoptimizeConfig::get_ao_imgopt_default_options();
49 49
         }
50 50
 
51 51
         // get service availability and add it to the options-array.
52
-        $value['availabilities'] = autoptimizeOption::get_option( 'autoptimize_service_availablity' );
52
+        $value['availabilities'] = autoptimizeOption::get_option('autoptimize_service_availablity');
53 53
 
54
-        if ( empty( $value['availabilities'] ) ) {
55
-            $value['availabilities'] = autoptimizeUtils::check_service_availability( true );
54
+        if (empty($value['availabilities'])) {
55
+            $value['availabilities'] = autoptimizeUtils::check_service_availability(true);
56 56
         }
57 57
 
58 58
         return $value;
@@ -65,9 +65,9 @@  discard block
 block discarded – undo
65 65
         // and does not use/ request the availablity data (which could slow things down).
66 66
         static $imgopt_active = null;
67 67
 
68
-        if ( null === $imgopt_active ) {
69
-            $opts = autoptimizeOption::get_option( 'autoptimize_imgopt_settings', '' );
70
-            if ( ! empty( $opts ) && is_array( $opts ) && array_key_exists( 'autoptimize_imgopt_checkbox_field_1', $opts ) && ! empty( $opts['autoptimize_imgopt_checkbox_field_1'] ) && '1' === $opts['autoptimize_imgopt_checkbox_field_1'] ) {
68
+        if (null === $imgopt_active) {
69
+            $opts = autoptimizeOption::get_option('autoptimize_imgopt_settings', '');
70
+            if (!empty($opts) && is_array($opts) && array_key_exists('autoptimize_imgopt_checkbox_field_1', $opts) && !empty($opts['autoptimize_imgopt_checkbox_field_1']) && '1' === $opts['autoptimize_imgopt_checkbox_field_1']) {
71 71
                 $imgopt_active = true;
72 72
             } else {
73 73
                 $imgopt_active = false;
@@ -87,7 +87,7 @@  discard block
 block discarded – undo
87 87
      */
88 88
     public static function instance()
89 89
     {
90
-        if ( null === self::$instance ) {
90
+        if (null === self::$instance) {
91 91
             self::$instance = new self();
92 92
         }
93 93
 
@@ -96,31 +96,31 @@  discard block
 block discarded – undo
96 96
 
97 97
     public function run()
98 98
     {
99
-        if ( is_admin() ) {
100
-			if ( is_plugin_active_for_network( 'autoptimize/autoptimize.php' ) ) {
101
-				add_action( 'network_admin_menu', array( $this, 'imgopt_admin_menu' ) );
99
+        if (is_admin()) {
100
+			if (is_plugin_active_for_network('autoptimize/autoptimize.php')) {
101
+				add_action('network_admin_menu', array($this, 'imgopt_admin_menu'));
102 102
 			} else {
103
-				add_action( 'admin_menu', array( $this, 'imgopt_admin_menu' ) );
103
+				add_action('admin_menu', array($this, 'imgopt_admin_menu'));
104 104
 			}
105
-			add_action( 'admin_init', array( $this, 'registersettings' ) );
106
-            add_filter( 'autoptimize_filter_settingsscreen_tabs', array( $this, 'add_imgopt_tab' ), 9 );
105
+			add_action('admin_init', array($this, 'registersettings'));
106
+            add_filter('autoptimize_filter_settingsscreen_tabs', array($this, 'add_imgopt_tab'), 9);
107 107
         } else {
108 108
             $this->run_on_frontend();
109 109
         }
110 110
     }
111 111
 
112 112
     public function run_on_frontend() {
113
-        if ( ! $this->should_run() ) {
114
-            if ( $this->should_lazyload() ) {
113
+        if (!$this->should_run()) {
114
+            if ($this->should_lazyload()) {
115 115
                 add_filter(
116 116
                     'autoptimize_html_after_minify',
117
-                    array( $this, 'filter_lazyload_images' ),
117
+                    array($this, 'filter_lazyload_images'),
118 118
                     10,
119 119
                     1
120 120
                 );
121 121
                 add_action(
122 122
                     'wp_footer',
123
-                    array( $this, 'add_lazyload_js_footer' ),
123
+                    array($this, 'add_lazyload_js_footer'),
124 124
                     10,
125 125
                     0
126 126
                 );
@@ -130,39 +130,39 @@  discard block
 block discarded – undo
130 130
 
131 131
         $active = false;
132 132
 
133
-        if ( apply_filters( 'autoptimize_filter_imgopt_do', true ) ) {
133
+        if (apply_filters('autoptimize_filter_imgopt_do', true)) {
134 134
             add_filter(
135 135
                 'autoptimize_html_after_minify',
136
-                array( $this, 'filter_optimize_images' ),
136
+                array($this, 'filter_optimize_images'),
137 137
                 10,
138 138
                 1
139 139
             );
140 140
             $active = true;
141 141
         }
142 142
 
143
-        if ( apply_filters( 'autoptimize_filter_imgopt_do_css', true ) ) {
143
+        if (apply_filters('autoptimize_filter_imgopt_do_css', true)) {
144 144
             add_filter(
145 145
                 'autoptimize_filter_base_replace_cdn',
146
-                array( $this, 'filter_optimize_css_images' ),
146
+                array($this, 'filter_optimize_css_images'),
147 147
                 10,
148 148
                 1
149 149
             );
150 150
             $active = true;
151 151
         }
152 152
 
153
-        if ( $active ) {
153
+        if ($active) {
154 154
             add_filter(
155 155
                 'autoptimize_extra_filter_tobepreconn',
156
-                array( $this, 'filter_preconnect_imgopt_url' ),
156
+                array($this, 'filter_preconnect_imgopt_url'),
157 157
                 10,
158 158
                 1
159 159
             );
160 160
         }
161 161
 
162
-        if ( $this->should_lazyload() ) {
162
+        if ($this->should_lazyload()) {
163 163
             add_action(
164 164
                 'wp_footer',
165
-                array( $this, 'add_lazyload_js_footer' )
165
+                array($this, 'add_lazyload_js_footer')
166 166
             );
167 167
         }
168 168
     }
@@ -175,8 +175,8 @@  discard block
 block discarded – undo
175 175
     protected function should_run()
176 176
     {
177 177
         $opts              = $this->options;
178
-        $service_not_down  = ( 'down' !== $opts['availabilities']['extra_imgopt']['status'] );
179
-        $not_launch_status = ( 'launch' !== $opts['availabilities']['extra_imgopt']['status'] );
178
+        $service_not_down  = ('down' !== $opts['availabilities']['extra_imgopt']['status']);
179
+        $not_launch_status = ('launch' !== $opts['availabilities']['extra_imgopt']['status']);
180 180
 
181 181
         $do_cdn      = true;
182 182
         $_userstatus = $this->get_imgopt_provider_userstatus();
@@ -188,7 +188,7 @@  discard block
 block discarded – undo
188 188
             $this->imgopt_active()
189 189
             && $do_cdn
190 190
             && $service_not_down
191
-            && ( $not_launch_status || $this->launch_ok() )
191
+            && ($not_launch_status || $this->launch_ok())
192 192
         ) {
193 193
             return true;
194 194
         }
@@ -199,13 +199,13 @@  discard block
 block discarded – undo
199 199
     {
200 200
         static $imgopt_host = null;
201 201
 
202
-        if ( null === $imgopt_host ) {
202
+        if (null === $imgopt_host) {
203 203
             $imgopt_host  = 'https://cdn.shortpixel.ai/';
204 204
             $avail_imgopt = $this->options['availabilities']['extra_imgopt'];
205
-            if ( ! empty( $avail_imgopt ) && array_key_exists( 'hosts', $avail_imgopt ) && is_array( $avail_imgopt['hosts'] ) ) {
206
-                $imgopt_host = array_rand( array_flip( $avail_imgopt['hosts'] ) );
205
+            if (!empty($avail_imgopt) && array_key_exists('hosts', $avail_imgopt) && is_array($avail_imgopt['hosts'])) {
206
+                $imgopt_host = array_rand(array_flip($avail_imgopt['hosts']));
207 207
             }
208
-            $imgopt_host = apply_filters( 'autoptimize_filter_imgopt_host', $imgopt_host );
208
+            $imgopt_host = apply_filters('autoptimize_filter_imgopt_host', $imgopt_host);
209 209
         }
210 210
 
211 211
         return $imgopt_host;
@@ -220,7 +220,7 @@  discard block
 block discarded – undo
220 220
 
221 221
     public static function get_service_url_suffix()
222 222
     {
223
-        $suffix = '/af/GWRGFLW109483/' . AUTOPTIMIZE_SITE_DOMAIN;
223
+        $suffix = '/af/GWRGFLW109483/'.AUTOPTIMIZE_SITE_DOMAIN;
224 224
 
225 225
         return $suffix;
226 226
     }
@@ -229,12 +229,12 @@  discard block
 block discarded – undo
229 229
     {
230 230
         static $quality = null;
231 231
 
232
-        if ( null === $quality ) {
232
+        if (null === $quality) {
233 233
             $q_array = $this->get_img_quality_array();
234 234
             $setting = $this->get_img_quality_setting();
235 235
             $quality = apply_filters(
236 236
                 'autoptimize_filter_imgopt_quality',
237
-                'q_' . $q_array[ $setting ]
237
+                'q_'.$q_array[$setting]
238 238
             );
239 239
         }
240 240
 
@@ -245,7 +245,7 @@  discard block
 block discarded – undo
245 245
     {
246 246
         static $map = null;
247 247
 
248
-        if ( null === $map ) {
248
+        if (null === $map) {
249 249
             $map = array(
250 250
                 '1' => 'lossy',
251 251
                 '2' => 'glossy',
@@ -264,12 +264,12 @@  discard block
 block discarded – undo
264 264
     {
265 265
         static $q = null;
266 266
 
267
-        if ( null === $q ) {
268
-            if ( is_array( $this->options ) && array_key_exists( 'autoptimize_imgopt_select_field_2', $this->options ) ) {
267
+        if (null === $q) {
268
+            if (is_array($this->options) && array_key_exists('autoptimize_imgopt_select_field_2', $this->options)) {
269 269
                 $setting = $this->options['autoptimize_imgopt_select_field_2'];
270 270
             }
271 271
 
272
-            if ( ! isset( $setting ) || empty( $setting ) || ( '1' !== $setting && '3' !== $setting ) ) {
272
+            if (!isset($setting) || empty($setting) || ('1' !== $setting && '3' !== $setting)) {
273 273
                 // default image opt. value is 2 ("glossy").
274 274
                 $q = '2';
275 275
             } else {
@@ -280,10 +280,10 @@  discard block
 block discarded – undo
280 280
         return $q;
281 281
     }
282 282
 
283
-    public function filter_preconnect_imgopt_url( array $in )
283
+    public function filter_preconnect_imgopt_url(array $in)
284 284
     {
285
-        $url_parts = parse_url( $this->get_imgopt_base_url() );
286
-        $in[]      = $url_parts['scheme'] . '://' . $url_parts['host'];
285
+        $url_parts = parse_url($this->get_imgopt_base_url());
286
+        $in[]      = $url_parts['scheme'].'://'.$url_parts['host'];
287 287
 
288 288
         return $in;
289 289
     }
@@ -296,20 +296,20 @@  discard block
 block discarded – undo
296 296
      *
297 297
      * @return string
298 298
      */
299
-    private function normalize_img_url( $in )
299
+    private function normalize_img_url($in)
300 300
     {
301 301
         // Only parse the site url once.
302 302
         static $parsed_site_url = null;
303
-        if ( null === $parsed_site_url ) {
304
-            $parsed_site_url = parse_url( site_url() );
303
+        if (null === $parsed_site_url) {
304
+            $parsed_site_url = parse_url(site_url());
305 305
         }
306 306
 
307 307
         // get CDN domain once.
308 308
         static $cdn_domain = null;
309
-        if ( is_null( $cdn_domain ) ) {
310
-            $cdn_url = apply_filters( 'autoptimize_filter_base_cdnurl', autoptimizeOption::get_option( 'autoptimize_cdn_url', '' ) );
311
-            if ( ! empty( $cdn_url ) ) {
312
-                $cdn_domain = parse_url( $cdn_url, PHP_URL_HOST );
309
+        if (is_null($cdn_domain)) {
310
+            $cdn_url = apply_filters('autoptimize_filter_base_cdnurl', autoptimizeOption::get_option('autoptimize_cdn_url', ''));
311
+            if (!empty($cdn_url)) {
312
+                $cdn_domain = parse_url($cdn_url, PHP_URL_HOST);
313 313
             } else {
314 314
                 $cdn_domain = '';
315 315
             }
@@ -325,39 +325,39 @@  discard block
 block discarded – undo
325 325
          * identical string operations).
326 326
          */
327 327
         static $cache = null;
328
-        if ( null === $cache ) {
328
+        if (null === $cache) {
329 329
             $cache = array();
330 330
         }
331 331
 
332 332
         // Do the work on cache miss only.
333
-        if ( ! isset( $cache[ $in ] ) ) {
333
+        if (!isset($cache[$in])) {
334 334
             // Default to what was given to us.
335
-            $result = trim( $in );
336
-            if ( autoptimizeUtils::is_protocol_relative( $in ) ) {
337
-                $result = $parsed_site_url['scheme'] . ':' . $in;
338
-            } elseif ( 0 === strpos( $in, '/' ) ) {
335
+            $result = trim($in);
336
+            if (autoptimizeUtils::is_protocol_relative($in)) {
337
+                $result = $parsed_site_url['scheme'].':'.$in;
338
+            } elseif (0 === strpos($in, '/')) {
339 339
                 // Root-relative...
340
-                $result  = $parsed_site_url['scheme'] . '://' . $parsed_site_url['host'];
340
+                $result  = $parsed_site_url['scheme'].'://'.$parsed_site_url['host'];
341 341
                 $result .= $in;
342
-            } elseif ( ! empty( $cdn_domain ) && strpos( $in, $cdn_domain ) !== 0 ) {
343
-                $result = str_replace( $cdn_domain, $parsed_site_url['host'], $in );
342
+            } elseif (!empty($cdn_domain) && strpos($in, $cdn_domain) !== 0) {
343
+                $result = str_replace($cdn_domain, $parsed_site_url['host'], $in);
344 344
             }
345 345
 
346
-            $result = apply_filters( 'autoptimize_filter_imgopt_normalized_url', $result );
346
+            $result = apply_filters('autoptimize_filter_imgopt_normalized_url', $result);
347 347
 
348 348
             // Store in cache.
349
-            $cache[ $in ] = $result;
349
+            $cache[$in] = $result;
350 350
         }
351 351
 
352
-        return $cache[ $in ];
352
+        return $cache[$in];
353 353
     }
354 354
 
355
-    public function filter_optimize_css_images( $in )
355
+    public function filter_optimize_css_images($in)
356 356
     {
357
-        $in = $this->normalize_img_url( $in );
357
+        $in = $this->normalize_img_url($in);
358 358
 
359
-        if ( $this->can_optimize_image( $in ) ) {
360
-            return $this->build_imgopt_url( $in, '', '' );
359
+        if ($this->can_optimize_image($in)) {
360
+            return $this->build_imgopt_url($in, '', '');
361 361
         } else {
362 362
             return $in;
363 363
         }
@@ -367,50 +367,50 @@  discard block
 block discarded – undo
367 367
     {
368 368
         static $imgopt_base_url = null;
369 369
 
370
-        if ( null === $imgopt_base_url ) {
370
+        if (null === $imgopt_base_url) {
371 371
             $imgopt_host     = $this->get_imgopt_host();
372 372
             $quality         = $this->get_img_quality_string();
373
-            $ret_val         = apply_filters( 'autoptimize_filter_imgopt_wait', 'ret_img' ); // values: ret_wait, ret_img, ret_json, ret_blank.
374
-            $imgopt_base_url = $imgopt_host . 'client/' . $quality . ',' . $ret_val;
375
-            $imgopt_base_url = apply_filters( 'autoptimize_filter_imgopt_base_url', $imgopt_base_url );
373
+            $ret_val         = apply_filters('autoptimize_filter_imgopt_wait', 'ret_img'); // values: ret_wait, ret_img, ret_json, ret_blank.
374
+            $imgopt_base_url = $imgopt_host.'client/'.$quality.','.$ret_val;
375
+            $imgopt_base_url = apply_filters('autoptimize_filter_imgopt_base_url', $imgopt_base_url);
376 376
         }
377 377
 
378 378
         return $imgopt_base_url;
379 379
     }
380 380
 
381
-    private function can_optimize_image( $url )
381
+    private function can_optimize_image($url)
382 382
     {
383 383
         static $cdn_url      = null;
384 384
         static $nopti_images = null;
385 385
 
386
-        if ( null === $cdn_url ) {
386
+        if (null === $cdn_url) {
387 387
             $cdn_url = apply_filters(
388 388
                 'autoptimize_filter_base_cdnurl',
389
-                autoptimizeOption::get_option( 'autoptimize_cdn_url', '' )
389
+                autoptimizeOption::get_option('autoptimize_cdn_url', '')
390 390
             );
391 391
         }
392 392
 
393
-        if ( null === $nopti_images ) {
394
-            $nopti_images = apply_filters( 'autoptimize_filter_imgopt_noptimize', '' );
393
+        if (null === $nopti_images) {
394
+            $nopti_images = apply_filters('autoptimize_filter_imgopt_noptimize', '');
395 395
         }
396 396
 
397 397
         $site_host  = AUTOPTIMIZE_SITE_DOMAIN;
398
-        $url        = $this->normalize_img_url( $url );
399
-        $url_parsed = parse_url( $url );
398
+        $url        = $this->normalize_img_url($url);
399
+        $url_parsed = parse_url($url);
400 400
 
401
-        if ( array_key_exists( 'host', $url_parsed ) && $url_parsed['host'] !== $site_host && empty( $cdn_url ) ) {
401
+        if (array_key_exists('host', $url_parsed) && $url_parsed['host'] !== $site_host && empty($cdn_url)) {
402 402
             return false;
403
-        } elseif ( ! empty( $cdn_url ) && strpos( $url, $cdn_url ) === false && array_key_exists( 'host', $url_parsed ) && $url_parsed['host'] !== $site_host ) {
403
+        } elseif (!empty($cdn_url) && strpos($url, $cdn_url) === false && array_key_exists('host', $url_parsed) && $url_parsed['host'] !== $site_host) {
404 404
             return false;
405
-        } elseif ( strpos( $url, '.php' ) !== false ) {
405
+        } elseif (strpos($url, '.php') !== false) {
406 406
             return false;
407
-        } elseif ( str_ireplace( array( '.png', '.gif', '.jpg', '.jpeg', '.webp' ), '', $url_parsed['path'] ) === $url_parsed['path'] ) {
407
+        } elseif (str_ireplace(array('.png', '.gif', '.jpg', '.jpeg', '.webp'), '', $url_parsed['path']) === $url_parsed['path']) {
408 408
             // fixme: better check against end of string.
409 409
             return false;
410
-        } elseif ( ! empty( $nopti_images ) ) {
411
-            $nopti_images_array = array_filter( array_map( 'trim', explode( ',', $nopti_images ) ) );
412
-            foreach ( $nopti_images_array as $nopti_image ) {
413
-                if ( strpos( $url, $nopti_image ) !== false ) {
410
+        } elseif (!empty($nopti_images)) {
411
+            $nopti_images_array = array_filter(array_map('trim', explode(',', $nopti_images)));
412
+            foreach ($nopti_images_array as $nopti_image) {
413
+                if (strpos($url, $nopti_image) !== false) {
414 414
                     return false;
415 415
                 }
416 416
             }
@@ -418,13 +418,13 @@  discard block
 block discarded – undo
418 418
         return true;
419 419
     }
420 420
 
421
-    private function build_imgopt_url( $orig_url, $width = 0, $height = 0 )
421
+    private function build_imgopt_url($orig_url, $width = 0, $height = 0)
422 422
     {
423 423
         // sanitize width and height.
424
-        if ( strpos( $width, '%' ) !== false ) {
424
+        if (strpos($width, '%') !== false) {
425 425
             $width = 0;
426 426
         }
427
-        if ( strpos( $height, '%' ) !== false ) {
427
+        if (strpos($height, '%') !== false) {
428 428
             $height = 0;
429 429
         }
430 430
         $width  = (int) $width;
@@ -438,43 +438,43 @@  discard block
 block discarded – undo
438 438
         );
439 439
 
440 440
         // If filter modified the url, return that.
441
-        if ( $filtered_url !== $orig_url ) {
441
+        if ($filtered_url !== $orig_url) {
442 442
             return $filtered_url;
443 443
         }
444 444
 
445
-        $orig_url        = $this->normalize_img_url( $orig_url );
445
+        $orig_url        = $this->normalize_img_url($orig_url);
446 446
         $imgopt_base_url = $this->get_imgopt_base_url();
447 447
         $imgopt_size     = '';
448 448
 
449
-        if ( $width && 0 !== $width ) {
450
-            $imgopt_size = ',w_' . $width;
449
+        if ($width && 0 !== $width) {
450
+            $imgopt_size = ',w_'.$width;
451 451
         }
452 452
 
453
-        if ( $height && 0 !== $height ) {
454
-            $imgopt_size .= ',h_' . $height;
453
+        if ($height && 0 !== $height) {
454
+            $imgopt_size .= ',h_'.$height;
455 455
         }
456 456
 
457
-        $url = $imgopt_base_url . $imgopt_size . '/' . $orig_url;
457
+        $url = $imgopt_base_url.$imgopt_size.'/'.$orig_url;
458 458
 
459 459
         return $url;
460 460
     }
461 461
 
462
-    public function replace_data_thumbs( $matches )
462
+    public function replace_data_thumbs($matches)
463 463
     {
464
-        return $this->replace_img_callback( $matches, 150, 150 );
464
+        return $this->replace_img_callback($matches, 150, 150);
465 465
     }
466 466
 
467
-    public function replace_img_callback( $matches, $width = 0, $height = 0 )
467
+    public function replace_img_callback($matches, $width = 0, $height = 0)
468 468
     {
469
-        $_normalized_img_url = $this->normalize_img_url( $matches[1] );
470
-        if ( $this->can_optimize_image( $matches[1] ) ) {
471
-            return str_replace( $matches[1], $this->build_imgopt_url( $_normalized_img_url, $width, $height ), $matches[0] );
469
+        $_normalized_img_url = $this->normalize_img_url($matches[1]);
470
+        if ($this->can_optimize_image($matches[1])) {
471
+            return str_replace($matches[1], $this->build_imgopt_url($_normalized_img_url, $width, $height), $matches[0]);
472 472
         } else {
473 473
             return $matches[0];
474 474
         }
475 475
     }
476 476
 
477
-    public function filter_optimize_images( $in )
477
+    public function filter_optimize_images($in)
478 478
     {
479 479
         /*
480 480
          * potential future functional improvements:
@@ -484,7 +484,7 @@  discard block
 block discarded – undo
484 484
         $to_replace = array();
485 485
 
486 486
         // hide noscript tags to avoid nesting noscript tags (as lazyloaded images add noscript).
487
-        if ( $this->should_lazyload() ) {
487
+        if ($this->should_lazyload()) {
488 488
             $in = autoptimizeBase::replace_contents_with_marker_if_exists(
489 489
                 'SCRIPT',
490 490
                 '<script',
@@ -494,25 +494,25 @@  discard block
 block discarded – undo
494 494
         }
495 495
 
496 496
         // extract img tags.
497
-        if ( preg_match_all( '#<img[^>]*src[^>]*>#Usmi', $in, $matches ) ) {
498
-            foreach ( $matches[0] as $tag ) {
497
+        if (preg_match_all('#<img[^>]*src[^>]*>#Usmi', $in, $matches)) {
498
+            foreach ($matches[0] as $tag) {
499 499
                 $orig_tag = $tag;
500 500
                 $imgopt_w = '';
501 501
                 $imgopt_h = '';
502 502
 
503 503
                 // first do (data-)srcsets.
504
-                if ( preg_match_all( '#srcset=("|\')(.*)("|\')#Usmi', $tag, $allsrcsets, PREG_SET_ORDER ) ) {
505
-                    foreach ( $allsrcsets as $srcset ) {
504
+                if (preg_match_all('#srcset=("|\')(.*)("|\')#Usmi', $tag, $allsrcsets, PREG_SET_ORDER)) {
505
+                    foreach ($allsrcsets as $srcset) {
506 506
                         $srcset  = $srcset[2];
507
-                        $srcsets = explode( ',', $srcset );
508
-                        foreach ( $srcsets as $indiv_srcset ) {
509
-                            $indiv_srcset_parts = explode( ' ', trim( $indiv_srcset ) );
510
-                            if ( isset( $indiv_srcset_parts[1] ) && rtrim( $indiv_srcset_parts[1], 'w' ) !== $indiv_srcset_parts[1] ) {
511
-                                $imgopt_w = rtrim( $indiv_srcset_parts[1], 'w' );
507
+                        $srcsets = explode(',', $srcset);
508
+                        foreach ($srcsets as $indiv_srcset) {
509
+                            $indiv_srcset_parts = explode(' ', trim($indiv_srcset));
510
+                            if (isset($indiv_srcset_parts[1]) && rtrim($indiv_srcset_parts[1], 'w') !== $indiv_srcset_parts[1]) {
511
+                                $imgopt_w = rtrim($indiv_srcset_parts[1], 'w');
512 512
                             }
513
-                            if ( $this->can_optimize_image( $indiv_srcset_parts[0] ) ) {
514
-                                $imgopt_url = $this->build_imgopt_url( $indiv_srcset_parts[0], $imgopt_w, '' );
515
-                                $tag        = str_replace( $indiv_srcset_parts[0], $imgopt_url, $tag );
513
+                            if ($this->can_optimize_image($indiv_srcset_parts[0])) {
514
+                                $imgopt_url = $this->build_imgopt_url($indiv_srcset_parts[0], $imgopt_w, '');
515
+                                $tag        = str_replace($indiv_srcset_parts[0], $imgopt_url, $tag);
516 516
                             }
517 517
                         }
518 518
                     }
@@ -520,120 +520,120 @@  discard block
 block discarded – undo
520 520
 
521 521
                 // proceed with img src.
522 522
                 // get width and height and add to $imgopt_size.
523
-                $_get_size = $this->get_size_from_tag( $tag );
523
+                $_get_size = $this->get_size_from_tag($tag);
524 524
                 $imgopt_w  = $_get_size['width'];
525 525
                 $imgopt_h  = $_get_size['height'];
526 526
 
527 527
                 // then start replacing images src.
528
-                if ( preg_match_all( '#src=(?:"|\')(?!data)(.*)(?:"|\')#Usmi', $tag, $urls, PREG_SET_ORDER ) ) {
529
-                    foreach ( $urls as $url ) {
528
+                if (preg_match_all('#src=(?:"|\')(?!data)(.*)(?:"|\')#Usmi', $tag, $urls, PREG_SET_ORDER)) {
529
+                    foreach ($urls as $url) {
530 530
                         $full_src_orig = $url[0];
531 531
                         $url           = $url[1];
532
-                        if ( $this->can_optimize_image( $url ) ) {
533
-                            $imgopt_url      = $this->build_imgopt_url( $url, $imgopt_w, $imgopt_h );
534
-                            $full_imgopt_src = str_replace( $url, $imgopt_url, $full_src_orig );
535
-                            $tag             = str_replace( $full_src_orig, $full_imgopt_src, $tag );
532
+                        if ($this->can_optimize_image($url)) {
533
+                            $imgopt_url      = $this->build_imgopt_url($url, $imgopt_w, $imgopt_h);
534
+                            $full_imgopt_src = str_replace($url, $imgopt_url, $full_src_orig);
535
+                            $tag             = str_replace($full_src_orig, $full_imgopt_src, $tag);
536 536
                         }
537 537
                     }
538 538
                 }
539 539
 
540 540
                 // do lazyload stuff.
541
-                if ( $this->should_lazyload( $in ) ) {
541
+                if ($this->should_lazyload($in)) {
542 542
                     // first do lpiq placeholder logic.
543
-                    if ( strpos( $url, $this->get_imgopt_host() ) === 0 ) {
543
+                    if (strpos($url, $this->get_imgopt_host()) === 0) {
544 544
                         // if all img src have been replaced during srcset, we have to extract the
545 545
                         // origin url from the imgopt one to be able to set a lqip placeholder.
546
-                        $_url = substr( $url, strpos( $url, '/http' ) + 1 );
546
+                        $_url = substr($url, strpos($url, '/http') + 1);
547 547
                     } else {
548 548
                         $_url = $url;
549 549
                     }
550 550
 
551
-                    if ( $this->can_optimize_image( $_url ) && apply_filters( 'autoptimize_filter_imgopt_lazyload_dolqip', true ) ) {
551
+                    if ($this->can_optimize_image($_url) && apply_filters('autoptimize_filter_imgopt_lazyload_dolqip', true)) {
552 552
                         $lqip_w = '';
553 553
                         $lqip_h = '';
554
-                        if ( isset( $imgopt_w ) && ! empty( $imgopt_w ) ) {
555
-                            $lqip_w = ',w_' . $imgopt_w;
554
+                        if (isset($imgopt_w) && !empty($imgopt_w)) {
555
+                            $lqip_w = ',w_'.$imgopt_w;
556 556
                         }
557
-                        if ( isset( $imgopt_h ) && ! empty( $imgopt_h ) ) {
558
-                            $lqip_h = ',h_' . $imgopt_h;
557
+                        if (isset($imgopt_h) && !empty($imgopt_h)) {
558
+                            $lqip_h = ',h_'.$imgopt_h;
559 559
                         }
560
-                        $placeholder = $this->get_imgopt_host() . 'client/q_lqip,ret_wait' . $lqip_w . $lqip_h . '/' . $_url;
560
+                        $placeholder = $this->get_imgopt_host().'client/q_lqip,ret_wait'.$lqip_w.$lqip_h.'/'.$_url;
561 561
                     }
562 562
                     // then call add_lazyload-function with lpiq placeholder if set.
563
-                    $tag = $this->add_lazyload( $tag, $placeholder );
563
+                    $tag = $this->add_lazyload($tag, $placeholder);
564 564
                 }
565 565
 
566 566
                 // and add tag to array for later replacement.
567
-                if ( $tag !== $orig_tag ) {
568
-                    $to_replace[ $orig_tag ] = $tag;
567
+                if ($tag !== $orig_tag) {
568
+                    $to_replace[$orig_tag] = $tag;
569 569
                 }
570 570
             }
571 571
         }
572 572
 
573 573
         // and replace all.
574
-        $out = str_replace( array_keys( $to_replace ), array_values( $to_replace ), $in );
574
+        $out = str_replace(array_keys($to_replace), array_values($to_replace), $in);
575 575
 
576 576
         // img thumbnails in e.g. woocommerce.
577
-        if ( strpos( $out, 'data-thumb' ) !== false && apply_filters( 'autoptimize_filter_imgopt_datathumbs', true ) ) {
577
+        if (strpos($out, 'data-thumb') !== false && apply_filters('autoptimize_filter_imgopt_datathumbs', true)) {
578 578
             $out = preg_replace_callback(
579 579
                 '/\<div(?:[^>]?)\sdata-thumb\=(?:\"|\')(.+?)(?:\"|\')(?:[^>]*)?\>/s',
580
-                array( $this, 'replace_data_thumbs' ),
580
+                array($this, 'replace_data_thumbs'),
581 581
                 $out
582 582
             );
583 583
         }
584 584
 
585 585
         // background-image in inline style.
586
-        if ( strpos( $out, 'background-image:' ) !== false && apply_filters( 'autoptimize_filter_imgopt_backgroundimages', true ) ) {
586
+        if (strpos($out, 'background-image:') !== false && apply_filters('autoptimize_filter_imgopt_backgroundimages', true)) {
587 587
             $out = preg_replace_callback(
588 588
                 '/style=(?:"|\').*?background-image:\s?url\((?:"|\')?([^"\')]*)(?:"|\')?\)/',
589
-                array( $this, 'replace_img_callback' ),
589
+                array($this, 'replace_img_callback'),
590 590
                 $out
591 591
             );
592 592
         }
593 593
 
594 594
         // lazyload: restore noscript tags + lazyload picture source tags.
595
-        if ( $this->should_lazyload() ) {
595
+        if ($this->should_lazyload()) {
596 596
             $out = autoptimizeBase::restore_marked_content(
597 597
                 'SCRIPT',
598 598
                 $out
599 599
             );
600 600
 
601
-            $out = $this->process_picture_tag( $out, true, true );
601
+            $out = $this->process_picture_tag($out, true, true);
602 602
         } else {
603
-            $out = $this->process_picture_tag( $out, true, false );
603
+            $out = $this->process_picture_tag($out, true, false);
604 604
         }
605 605
 
606 606
         return $out;
607 607
     }
608 608
 
609
-    public function get_size_from_tag( $tag ) {
609
+    public function get_size_from_tag($tag) {
610 610
         // reusable function to extract widht and height from an image tag
611 611
         // enforcing a filterable maximum width and height (default 4999X4999).
612 612
         $width  = '';
613 613
         $height = '';
614 614
 
615
-        if ( preg_match( '#width=("|\')(.*)("|\')#Usmi', $tag, $_width ) ) {
616
-            if ( strpos( $_width[2], '%' ) === false ) {
615
+        if (preg_match('#width=("|\')(.*)("|\')#Usmi', $tag, $_width)) {
616
+            if (strpos($_width[2], '%') === false) {
617 617
                 $width = (int) $_width[2];
618 618
             }
619 619
         }
620
-        if ( preg_match( '#height=("|\')(.*)("|\')#Usmi', $tag, $_height ) ) {
621
-            if ( strpos( $_height[2], '%' ) === false ) {
620
+        if (preg_match('#height=("|\')(.*)("|\')#Usmi', $tag, $_height)) {
621
+            if (strpos($_height[2], '%') === false) {
622 622
                 $height = (int) $_height[2];
623 623
             }
624 624
         }
625 625
 
626 626
         // check for and enforce (filterable) max sizes.
627
-        $_max_width = apply_filters( 'autoptimize_filter_imgopt_max_width', 4999 );
628
-        if ( $width > $_max_width ) {
627
+        $_max_width = apply_filters('autoptimize_filter_imgopt_max_width', 4999);
628
+        if ($width > $_max_width) {
629 629
             $_width = $_max_width;
630
-            $height = $_width / $width * $height;
630
+            $height = $_width/$width*$height;
631 631
             $width  = $_width;
632 632
         }
633
-        $_max_height = apply_filters( 'autoptimize_filter_imgopt_max_height', 4999 );
634
-        if ( $height > $_max_height ) {
633
+        $_max_height = apply_filters('autoptimize_filter_imgopt_max_height', 4999);
634
+        if ($height > $_max_height) {
635 635
             $_height = $_max_height;
636
-            $width   = $_height / $height * $width;
636
+            $width   = $_height/$height*$width;
637 637
             $height  = $_height;
638 638
         }
639 639
 
@@ -652,18 +652,18 @@  discard block
 block discarded – undo
652 652
         return $self->should_lazyload();
653 653
     }
654 654
 
655
-    public function should_lazyload( $context = '' ) {
656
-        if ( ! empty( $this->options['autoptimize_imgopt_checkbox_field_3'] ) ) {
655
+    public function should_lazyload($context = '') {
656
+        if (!empty($this->options['autoptimize_imgopt_checkbox_field_3'])) {
657 657
             $lazyload_return = true;
658 658
         } else {
659 659
             $lazyload_return = false;
660 660
         }
661
-        $lazyload_return = apply_filters( 'autoptimize_filter_imgopt_should_lazyload', $lazyload_return, $context );
661
+        $lazyload_return = apply_filters('autoptimize_filter_imgopt_should_lazyload', $lazyload_return, $context);
662 662
 
663 663
         return $lazyload_return;
664 664
     }
665 665
 
666
-    public function filter_lazyload_images( $in )
666
+    public function filter_lazyload_images($in)
667 667
     {
668 668
         // only used is image optimization is NOT active but lazyload is.
669 669
         $to_replace = array();
@@ -677,17 +677,17 @@  discard block
 block discarded – undo
677 677
         );
678 678
 
679 679
         // extract img tags and add lazyload attribs.
680
-        if ( preg_match_all( '#<img[^>]*src[^>]*>#Usmi', $out, $matches ) ) {
681
-            foreach ( $matches[0] as $tag ) {
682
-                if ( $this->should_lazyload( $out ) ) {
683
-                    $to_replace[ $tag ] = $this->add_lazyload( $tag );
680
+        if (preg_match_all('#<img[^>]*src[^>]*>#Usmi', $out, $matches)) {
681
+            foreach ($matches[0] as $tag) {
682
+                if ($this->should_lazyload($out)) {
683
+                    $to_replace[$tag] = $this->add_lazyload($tag);
684 684
                 }
685 685
             }
686
-            $out = str_replace( array_keys( $to_replace ), array_values( $to_replace ), $out );
686
+            $out = str_replace(array_keys($to_replace), array_values($to_replace), $out);
687 687
         }
688 688
 
689 689
         // and also lazyload picture tag.
690
-        $out = $this->process_picture_tag( $out, false, true );
690
+        $out = $this->process_picture_tag($out, false, true);
691 691
 
692 692
         // restore noscript tags.
693 693
         $out = autoptimizeBase::restore_marked_content(
@@ -698,46 +698,46 @@  discard block
 block discarded – undo
698 698
         return $out;
699 699
     }
700 700
 
701
-    public function add_lazyload( $tag, $placeholder = '' ) {
701
+    public function add_lazyload($tag, $placeholder = '') {
702 702
         // adds actual lazyload-attributes to an image node.
703
-        if ( str_ireplace( $this->get_lazyload_exclusions(), '', $tag ) === $tag ) {
704
-            $tag = $this->maybe_fix_missing_quotes( $tag );
703
+        if (str_ireplace($this->get_lazyload_exclusions(), '', $tag) === $tag) {
704
+            $tag = $this->maybe_fix_missing_quotes($tag);
705 705
 
706 706
             // store original tag for use in noscript version.
707
-            $noscript_tag = '<noscript>' . $tag . '</noscript>';
707
+            $noscript_tag = '<noscript>'.$tag.'</noscript>';
708 708
 
709
-            $lazyload_class = apply_filters( 'autoptimize_filter_imgopt_lazyload_class', 'lazyload' );
709
+            $lazyload_class = apply_filters('autoptimize_filter_imgopt_lazyload_class', 'lazyload');
710 710
 
711 711
             // insert lazyload class.
712
-            $tag = $this->inject_classes_in_tag( $tag, "$lazyload_class " );
712
+            $tag = $this->inject_classes_in_tag($tag, "$lazyload_class ");
713 713
 
714
-            if ( ! $placeholder || empty( $placeholder ) ) {
714
+            if (!$placeholder || empty($placeholder)) {
715 715
                 // get image width & heigth for placeholder fun (and to prevent content reflow).
716
-                $_get_size = $this->get_size_from_tag( $tag );
716
+                $_get_size = $this->get_size_from_tag($tag);
717 717
                 $width     = $_get_size['width'];
718 718
                 $height    = $_get_size['height'];
719
-                if ( false === $width ) {
719
+                if (false === $width) {
720 720
                     $widht = 210; // default width for SVG placeholder.
721 721
                 }
722
-                if ( false === $height ) {
723
-                    $heigth = $width / 3 * 2; // if no height, base it on width using the 3/2 aspect ratio.
722
+                if (false === $height) {
723
+                    $heigth = $width/3*2; // if no height, base it on width using the 3/2 aspect ratio.
724 724
                 }
725 725
 
726 726
                 // insert the actual lazyload stuff.
727 727
                 // see https://css-tricks.com/preventing-content-reflow-from-lazy-loaded-images/ for great read on why we're using empty svg's.
728
-                $placeholder = apply_filters( 'autoptimize_filter_imgopt_lazyload_placeholder', $this->get_default_lazyload_placeholder( $width, $height ) );
728
+                $placeholder = apply_filters('autoptimize_filter_imgopt_lazyload_placeholder', $this->get_default_lazyload_placeholder($width, $height));
729 729
             }
730
-            $tag = str_replace( ' src=', ' src=\'' . $placeholder . '\' data-src=', $tag );
731
-            $tag = str_replace( ' srcset=', ' data-srcset=', $tag );
730
+            $tag = str_replace(' src=', ' src=\''.$placeholder.'\' data-src=', $tag);
731
+            $tag = str_replace(' srcset=', ' data-srcset=', $tag);
732 732
 
733 733
             // move sizes to data-sizes unless filter says no.
734
-            if ( apply_filters( 'autoptimize_filter_imgopt_lazyload_move_sizes', true ) ) {
735
-                $tag = str_replace( 'sizes=', 'data-sizes=', $tag );
734
+            if (apply_filters('autoptimize_filter_imgopt_lazyload_move_sizes', true)) {
735
+                $tag = str_replace('sizes=', 'data-sizes=', $tag);
736 736
             }
737 737
 
738 738
             // add the noscript-tag from earlier.
739
-            $tag = $noscript_tag . $tag;
740
-            $tag = apply_filters( 'autoptimize_filter_imgopt_lazyloaded_img', $tag );
739
+            $tag = $noscript_tag.$tag;
740
+            $tag = apply_filters('autoptimize_filter_imgopt_lazyloaded_img', $tag);
741 741
         }
742 742
 
743 743
         return $tag;
@@ -746,20 +746,20 @@  discard block
 block discarded – undo
746 746
     public function add_lazyload_js_footer() {
747 747
         // The JS will by default be excluded form autoptimization but this can be changed with a filter.
748 748
         $noptimize_flag = '';
749
-        if ( apply_filters( 'autoptimize_filter_imgopt_lazyload_js_noptimize', true ) ) {
749
+        if (apply_filters('autoptimize_filter_imgopt_lazyload_js_noptimize', true)) {
750 750
             $noptimize_flag = ' data-noptimize="1"';
751 751
         }
752 752
 
753 753
         // Adds lazyload CSS & JS to footer, using echo because wp_enqueue_script seems not to support pushing attributes (async).
754
-        echo apply_filters( 'autoptimize_filter_imgopt_lazyload_cssoutput', '<style>.lazyload,.lazyloading{opacity:0;}.lazyloaded{opacity:1;transition:opacity 300ms;}</style><noscript><style>.lazyload{display:none;}</style></noscript>' );
755
-        echo apply_filters( 'autoptimize_filter_imgopt_lazyload_jsconfig', '<script' . $noptimize_flag . '>window.lazySizesConfig=window.lazySizesConfig||{};window.lazySizesConfig.loadMode=1;</script>' );
756
-        echo apply_filters( 'autoptimize_filter_imgopt_lazyload_js', '<script async' . $noptimize_flag . ' src=\'' . plugins_url( 'external/js/lazysizes.min.js', __FILE__ ) . '\'></script>' );
754
+        echo apply_filters('autoptimize_filter_imgopt_lazyload_cssoutput', '<style>.lazyload,.lazyloading{opacity:0;}.lazyloaded{opacity:1;transition:opacity 300ms;}</style><noscript><style>.lazyload{display:none;}</style></noscript>');
755
+        echo apply_filters('autoptimize_filter_imgopt_lazyload_jsconfig', '<script'.$noptimize_flag.'>window.lazySizesConfig=window.lazySizesConfig||{};window.lazySizesConfig.loadMode=1;</script>');
756
+        echo apply_filters('autoptimize_filter_imgopt_lazyload_js', '<script async'.$noptimize_flag.' src=\''.plugins_url('external/js/lazysizes.min.js', __FILE__).'\'></script>');
757 757
 
758 758
         // And add webp detection and loading JS.
759
-        if ( $this->should_webp() ) {
759
+        if ($this->should_webp()) {
760 760
             $_webp_detect = "function c_webp(A){var n=new Image;n.onload=function(){var e=0<n.width&&0<n.height;A(e)},n.onerror=function(){A(!1)},n.src=''}function s_webp(e){window.supportsWebP=e}c_webp(s_webp);";
761 761
             $_webp_load   = "document.addEventListener('lazybeforeunveil',function({target:c}){supportsWebP&&['data-src','data-srcset'].forEach(function(a){attr=c.getAttribute(a),null!==attr&&c.setAttribute(a,attr.replace(/\/client\//,'/client/to_webp,'))})});";
762
-            echo apply_filters( 'autoptimize_filter_imgopt_webp_js', '<script' . $noptimize_flag . '>' . $_webp_detect . $_webp_load . '</script>' );
762
+            echo apply_filters('autoptimize_filter_imgopt_webp_js', '<script'.$noptimize_flag.'>'.$_webp_detect.$_webp_load.'</script>');
763 763
         }
764 764
     }
765 765
 
@@ -767,47 +767,47 @@  discard block
 block discarded – undo
767 767
         // returns array of strings that if found in an <img tag will stop the img from being lazy-loaded.
768 768
         static $exclude_lazyload_array = null;
769 769
 
770
-        if ( null === $exclude_lazyload_array ) {
770
+        if (null === $exclude_lazyload_array) {
771 771
             $options = $this->options;
772 772
 
773 773
             // set default exclusions.
774
-            $exclude_lazyload_array = array( 'skip-lazy', 'data-no-lazy', 'notlazy', 'data-src', 'data-srcset', 'data:image/', 'data-lazyload', 'rev-slidebg' );
774
+            $exclude_lazyload_array = array('skip-lazy', 'data-no-lazy', 'notlazy', 'data-src', 'data-srcset', 'data:image/', 'data-lazyload', 'rev-slidebg');
775 775
 
776 776
             // add from setting.
777
-            if ( array_key_exists( 'autoptimize_imgopt_text_field_5', $options ) ) {
777
+            if (array_key_exists('autoptimize_imgopt_text_field_5', $options)) {
778 778
                 $exclude_lazyload_option = $options['autoptimize_imgopt_text_field_5'];
779
-                if ( ! empty( $exclude_lazyload_option ) ) {
780
-                    $exclude_lazyload_array = array_merge( $exclude_lazyload_array, array_filter( array_map( 'trim', explode( ',', $options['autoptimize_imgopt_text_field_5'] ) ) ) );
779
+                if (!empty($exclude_lazyload_option)) {
780
+                    $exclude_lazyload_array = array_merge($exclude_lazyload_array, array_filter(array_map('trim', explode(',', $options['autoptimize_imgopt_text_field_5']))));
781 781
                 }
782 782
             }
783 783
 
784 784
             // and filter for developer-initiated changes.
785
-            $exclude_lazyload_array = apply_filters( 'autoptimize_filter_imgopt_lazyload_exclude_array', $exclude_lazyload_array );
785
+            $exclude_lazyload_array = apply_filters('autoptimize_filter_imgopt_lazyload_exclude_array', $exclude_lazyload_array);
786 786
         }
787 787
 
788 788
         return $exclude_lazyload_array;
789 789
     }
790 790
 
791
-    public function inject_classes_in_tag( $tag, $target_class ) {
792
-        if ( strpos( $tag, 'class=' ) !== false ) {
793
-            $tag = preg_replace( '/(\sclass\s?=\s?("|\'))/', '$1' . $target_class, $tag );
791
+    public function inject_classes_in_tag($tag, $target_class) {
792
+        if (strpos($tag, 'class=') !== false) {
793
+            $tag = preg_replace('/(\sclass\s?=\s?("|\'))/', '$1'.$target_class, $tag);
794 794
         } else {
795
-            $tag = str_replace( '<img ', '<img class="' . trim( $target_class ) . '" ', $tag );
795
+            $tag = str_replace('<img ', '<img class="'.trim($target_class).'" ', $tag);
796 796
         }
797 797
 
798 798
         return $tag;
799 799
     }
800 800
 
801
-    public function get_default_lazyload_placeholder( $imgopt_w, $imgopt_h ) {
802
-        return 'data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20viewBox=%220%200%20' . $imgopt_w . '%20' . $imgopt_h . '%22%3E%3C/svg%3E';
801
+    public function get_default_lazyload_placeholder($imgopt_w, $imgopt_h) {
802
+        return 'data:image/svg+xml,%3Csvg%20xmlns=%22http://www.w3.org/2000/svg%22%20viewBox=%220%200%20'.$imgopt_w.'%20'.$imgopt_h.'%22%3E%3C/svg%3E';
803 803
     }
804 804
 
805 805
     public function should_webp() {
806 806
         static $webp_return = null;
807 807
 
808
-        if ( is_null( $webp_return ) ) {
808
+        if (is_null($webp_return)) {
809 809
             // webp only works if imgopt and lazyload are also active.
810
-            if ( ! empty( $this->options['autoptimize_imgopt_checkbox_field_4'] ) && ! empty( $this->options['autoptimize_imgopt_checkbox_field_3'] ) && $this->imgopt_active() ) {
810
+            if (!empty($this->options['autoptimize_imgopt_checkbox_field_4']) && !empty($this->options['autoptimize_imgopt_checkbox_field_3']) && $this->imgopt_active()) {
811 811
                 $webp_return = true;
812 812
             } else {
813 813
                 $webp_return = false;
@@ -817,9 +817,9 @@  discard block
 block discarded – undo
817 817
         return $webp_return;
818 818
     }
819 819
 
820
-    public function process_picture_tag( $in, $imgopt = false, $lazy = false ) {
820
+    public function process_picture_tag($in, $imgopt = false, $lazy = false) {
821 821
         // check if "<picture" is present and if filter allows us to process <picture>.
822
-        if ( strpos( $in, '<picture' ) === false || apply_filters( 'autoptimize_filter_imgopt_dopicture', true ) === false ) {
822
+        if (strpos($in, '<picture') === false || apply_filters('autoptimize_filter_imgopt_dopicture', true) === false) {
823 823
             return $in;
824 824
         }
825 825
 
@@ -827,36 +827,36 @@  discard block
 block discarded – undo
827 827
         $to_replace_pict = array();
828 828
 
829 829
         // extract and process each picture-node.
830
-        preg_match_all( '#<picture.*</picture>#Usmi', $in, $_pictures, PREG_SET_ORDER );
831
-        foreach ( $_pictures as $_picture ) {
832
-            $_picture = $this->maybe_fix_missing_quotes( $_picture );
833
-            if ( strpos( $_picture[0], '<source ' ) !== false && preg_match_all( '#<source .*srcset=(?:"|\')(?!data)(.*)(?:"|\').*>#Usmi', $_picture[0], $_sources, PREG_SET_ORDER ) !== false ) {
834
-                foreach ( $_sources as $_source ) {
830
+        preg_match_all('#<picture.*</picture>#Usmi', $in, $_pictures, PREG_SET_ORDER);
831
+        foreach ($_pictures as $_picture) {
832
+            $_picture = $this->maybe_fix_missing_quotes($_picture);
833
+            if (strpos($_picture[0], '<source ') !== false && preg_match_all('#<source .*srcset=(?:"|\')(?!data)(.*)(?:"|\').*>#Usmi', $_picture[0], $_sources, PREG_SET_ORDER) !== false) {
834
+                foreach ($_sources as $_source) {
835 835
                     $_picture_replacement = $_source[0];
836 836
 
837 837
                     // should we optimize the image?
838
-                    if ( $imgopt && $this->can_optimize_image( $_source[1] ) ) {
839
-                        $_picture_replacement = str_replace( $_source[1], $this->build_imgopt_url( $_source[1] ), $_picture_replacement );
838
+                    if ($imgopt && $this->can_optimize_image($_source[1])) {
839
+                        $_picture_replacement = str_replace($_source[1], $this->build_imgopt_url($_source[1]), $_picture_replacement);
840 840
                     }
841 841
                     // should we lazy-load?
842
-                    if ( $lazy && $this->should_lazyload() && str_ireplace( $_exclusions, '', $_picture_replacement ) === $_picture_replacement ) {
843
-                        $_picture_replacement = str_replace( ' srcset=', ' data-srcset=', $_picture_replacement );
842
+                    if ($lazy && $this->should_lazyload() && str_ireplace($_exclusions, '', $_picture_replacement) === $_picture_replacement) {
843
+                        $_picture_replacement = str_replace(' srcset=', ' data-srcset=', $_picture_replacement);
844 844
                     }
845
-                    $to_replace_pict[ $_source[0] ] = $_picture_replacement;
845
+                    $to_replace_pict[$_source[0]] = $_picture_replacement;
846 846
                 }
847 847
             }
848 848
         }
849 849
 
850 850
         // and return the fully procesed $in.
851
-        $out = str_replace( array_keys( $to_replace_pict ), array_values( $to_replace_pict ), $in );
851
+        $out = str_replace(array_keys($to_replace_pict), array_values($to_replace_pict), $in);
852 852
 
853 853
         return $out;
854 854
     }
855 855
 
856
-    public function maybe_fix_missing_quotes( $tag_in ) {
856
+    public function maybe_fix_missing_quotes($tag_in) {
857 857
         // W3TC's Minify_HTML class removes quotes around attribute value, this re-adds them.
858
-        if ( file_exists( WP_PLUGIN_DIR . '/w3-total-cache/w3-total-cache.php' ) && class_exists( 'Minify_HTML' ) && apply_filters( 'autoptimize_filter_imgopt_fixquotes', true ) ) {
859
-            return preg_replace( '/=([^("|\')]*)(\s|>)/U', '=\'$1\'$2', $tag_in );
858
+        if (file_exists(WP_PLUGIN_DIR.'/w3-total-cache/w3-total-cache.php') && class_exists('Minify_HTML') && apply_filters('autoptimize_filter_imgopt_fixquotes', true)) {
859
+            return preg_replace('/=([^("|\')]*)(\s|>)/U', '=\'$1\'$2', $tag_in);
860 860
         } else {
861 861
             return $tag_in;
862 862
         }
@@ -873,17 +873,17 @@  discard block
 block discarded – undo
873 873
             'autoptimize_imgopt',
874 874
             'manage_options',
875 875
             'autoptimize_imgopt',
876
-            array( $this, 'imgopt_options_page' )
876
+            array($this, 'imgopt_options_page')
877 877
         );
878 878
     }
879 879
 	
880 880
 	public function registersettings() {
881
-		register_setting( 'autoptimize_imgopt_settings', 'autoptimize_imgopt_settings' );
881
+		register_setting('autoptimize_imgopt_settings', 'autoptimize_imgopt_settings');
882 882
 	}
883 883
 
884
-    public function add_imgopt_tab( $in )
884
+    public function add_imgopt_tab($in)
885 885
     {
886
-        $in = array_merge( $in, array( 'autoptimize_imgopt' => __( 'Images', 'autoptimize' ) ) );
886
+        $in = array_merge($in, array('autoptimize_imgopt' => __('Images', 'autoptimize')));
887 887
 
888 888
         return $in;
889 889
     }
@@ -891,7 +891,7 @@  discard block
 block discarded – undo
891 891
     public function imgopt_options_page()
892 892
     {
893 893
         // Check querystring for "refreshCacheChecker" and call cachechecker if so.
894
-        if ( array_key_exists( 'refreshImgProvStats', $_GET ) && 1 == $_GET['refreshImgProvStats'] ) {
894
+        if (array_key_exists('refreshImgProvStats', $_GET) && 1 == $_GET['refreshImgProvStats']) {
895 895
             $this->query_img_provider_stats();
896 896
         }
897 897
 
@@ -904,45 +904,45 @@  discard block
 block discarded – undo
904 904
         #autoptimize_imgopt_descr{font-size: 120%;}
905 905
     </style>
906 906
     <div class="wrap">
907
-    <h1><?php _e( 'Autoptimize Settings', 'autoptimize' ); ?></h1>
907
+    <h1><?php _e('Autoptimize Settings', 'autoptimize'); ?></h1>
908 908
         <?php echo autoptimizeConfig::ao_admin_tabs(); ?>
909
-        <?php if ( 'down' === $options['availabilities']['extra_imgopt']['status'] ) { ?>
909
+        <?php if ('down' === $options['availabilities']['extra_imgopt']['status']) { ?>
910 910
             <div class="notice-warning notice"><p>
911 911
             <?php
912 912
             // translators: "Autoptimize support forum" will appear in a "a href".
913
-            echo sprintf( __( 'The image optimization service is currently down, image optimization will be skipped until further notice. Check the %1$sAutoptimize support forum%2$s for more info.', 'autoptimize' ), '<a href="https://wordpress.org/support/plugin/autoptimize/" target="_blank">', '</a>' );
913
+            echo sprintf(__('The image optimization service is currently down, image optimization will be skipped until further notice. Check the %1$sAutoptimize support forum%2$s for more info.', 'autoptimize'), '<a href="https://wordpress.org/support/plugin/autoptimize/" target="_blank">', '</a>');
914 914
             ?>
915 915
             </p></div>
916 916
         <?php } ?>
917 917
 
918
-        <?php if ( 'launch' === $options['availabilities']['extra_imgopt']['status'] && ! autoptimizeImages::instance()->launch_ok() ) { ?>
918
+        <?php if ('launch' === $options['availabilities']['extra_imgopt']['status'] && !autoptimizeImages::instance()->launch_ok()) { ?>
919 919
             <div class="notice-warning notice"><p>
920
-            <?php _e( 'The image optimization service is launching, but not yet available for this domain, it should become available in the next couple of days.', 'autoptimize' ); ?>
920
+            <?php _e('The image optimization service is launching, but not yet available for this domain, it should become available in the next couple of days.', 'autoptimize'); ?>
921 921
             </p></div>
922 922
         <?php } ?>
923 923
 
924
-        <?php if ( class_exists( 'Jetpack' ) && method_exists( 'Jetpack', 'get_active_modules' ) && in_array( 'photon', Jetpack::get_active_modules() ) ) { ?>
924
+        <?php if (class_exists('Jetpack') && method_exists('Jetpack', 'get_active_modules') && in_array('photon', Jetpack::get_active_modules())) { ?>
925 925
             <div class="notice-warning notice"><p>
926 926
             <?php
927 927
             // translators: "disable  Jetpack's site accelerator for images" will appear in a "a href" linking to the jetpack settings page.
928
-            echo sprintf( __( 'Please %1$sdisable Jetpack\'s site accelerator for images%2$s to be able to use Autoptomize\'s advanced image optimization features below.', 'autoptimize' ), '<a href="admin.php?page=jetpack#/settings">', '</a>' );
928
+            echo sprintf(__('Please %1$sdisable Jetpack\'s site accelerator for images%2$s to be able to use Autoptomize\'s advanced image optimization features below.', 'autoptimize'), '<a href="admin.php?page=jetpack#/settings">', '</a>');
929 929
             ?>
930 930
             </p></div>
931 931
         <?php } ?>
932
-    <form id='ao_settings_form' action='<?php echo admin_url( 'options.php' ); ?>' method='post'>
933
-        <?php settings_fields( 'autoptimize_imgopt_settings' ); ?>
934
-        <h2><?php _e( 'Image optimization', 'autoptimize' ); ?></h2>
935
-        <span id='autoptimize_imgopt_descr'><?php _e( 'Make your site significantly faster by just ticking a couple of checkboxes to optimize and lazy load your images, WebP support included!', 'autoptimize' ); ?></span>
932
+    <form id='ao_settings_form' action='<?php echo admin_url('options.php'); ?>' method='post'>
933
+        <?php settings_fields('autoptimize_imgopt_settings'); ?>
934
+        <h2><?php _e('Image optimization', 'autoptimize'); ?></h2>
935
+        <span id='autoptimize_imgopt_descr'><?php _e('Make your site significantly faster by just ticking a couple of checkboxes to optimize and lazy load your images, WebP support included!', 'autoptimize'); ?></span>
936 936
         <table class="form-table">
937 937
             <tr>
938
-                <th scope="row"><?php _e( 'Optimize Images', 'autoptimize' ); ?></th>
938
+                <th scope="row"><?php _e('Optimize Images', 'autoptimize'); ?></th>
939 939
                 <td>
940
-                    <label><input id='autoptimize_imgopt_checkbox' type='checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_1]' <?php if ( ! empty( $options['autoptimize_imgopt_checkbox_field_1'] ) && '1' === $options['autoptimize_imgopt_checkbox_field_1'] ) { echo 'checked="checked"'; } ?> value='1'><?php _e( 'Optimize images on the fly and serve them from Shortpixel\'s global CDN.', 'autoptimize' ); ?></label>
940
+                    <label><input id='autoptimize_imgopt_checkbox' type='checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_1]' <?php if (!empty($options['autoptimize_imgopt_checkbox_field_1']) && '1' === $options['autoptimize_imgopt_checkbox_field_1']) { echo 'checked="checked"'; } ?> value='1'><?php _e('Optimize images on the fly and serve them from Shortpixel\'s global CDN.', 'autoptimize'); ?></label>
941 941
                     <?php
942 942
                     // show shortpixel status.
943 943
                     $_notice = autoptimizeImages::instance()->get_status_notice();
944
-                    if ( $_notice ) {
945
-                        switch ( $_notice['status'] ) {
944
+                    if ($_notice) {
945
+                        switch ($_notice['status']) {
946 946
                             case 2:
947 947
                                 $_notice_color = 'green';
948 948
                                 break;
@@ -958,28 +958,28 @@  discard block
 block discarded – undo
958 958
                             default:
959 959
                                 $_notice_color = 'green';
960 960
                         }
961
-                        echo apply_filters( 'autoptimize_filter_imgopt_settings_status', '<p><strong><span style="color:' . $_notice_color . ';">' . __( 'Shortpixel status: ', 'autoptimize' ) . '</span></strong>' . $_notice['notice'] . '</p>' );
961
+                        echo apply_filters('autoptimize_filter_imgopt_settings_status', '<p><strong><span style="color:'.$_notice_color.';">'.__('Shortpixel status: ', 'autoptimize').'</span></strong>'.$_notice['notice'].'</p>');
962 962
                     } else {
963 963
                         // translators: link points to shortpixel.
964
-                        $upsell_msg_1 = '<p>' . sprintf( __( 'Get more Google love and improve your website\'s loading speed by having the images optimized on the fly (also in the "next-gen" WebP image format) by %1$sShortPixel%2$s and then cached and served fast from Shortpixel\'s global CDN.', 'autoptimize' ), '<a href="https://shortpixel.com/aospai' . $sp_url_suffix . '" target="_blank">', '</a>' );
965
-                        if ( 'launch' === $options['availabilities']['extra_imgopt']['status'] ) {
966
-                            $upsell_msg_2 = __( 'For a limited time only, this service is offered free for all Autoptimize users, <b>don\'t miss the chance to test it</b> and see how much it could improve your site\'s speed.', 'autoptimize' );
964
+                        $upsell_msg_1 = '<p>'.sprintf(__('Get more Google love and improve your website\'s loading speed by having the images optimized on the fly (also in the "next-gen" WebP image format) by %1$sShortPixel%2$s and then cached and served fast from Shortpixel\'s global CDN.', 'autoptimize'), '<a href="https://shortpixel.com/aospai'.$sp_url_suffix.'" target="_blank">', '</a>');
965
+                        if ('launch' === $options['availabilities']['extra_imgopt']['status']) {
966
+                            $upsell_msg_2 = __('For a limited time only, this service is offered free for all Autoptimize users, <b>don\'t miss the chance to test it</b> and see how much it could improve your site\'s speed.', 'autoptimize');
967 967
                         } else {
968 968
                             // translators: link points to shortpixel.
969
-                            $upsell_msg_2 = sprintf( __( '%1$sSign-up now%2$s to receive a 1 000 bonus + 50&#37; more image optimization credits regardless of the traffic used. More image optimizations can be purchased starting with $4.99.', 'autoptimize' ), '<a href="https://shortpixel.com/aospai' . $sp_url_suffix . '" target="_blank">', '</a>' );
969
+                            $upsell_msg_2 = sprintf(__('%1$sSign-up now%2$s to receive a 1 000 bonus + 50&#37; more image optimization credits regardless of the traffic used. More image optimizations can be purchased starting with $4.99.', 'autoptimize'), '<a href="https://shortpixel.com/aospai'.$sp_url_suffix.'" target="_blank">', '</a>');
970 970
                         }
971
-                        echo apply_filters( 'autoptimize_imgopt_imgopt_settings_copy', $upsell_msg_1 . ' ' . $upsell_msg_2 . '</p>' );
971
+                        echo apply_filters('autoptimize_imgopt_imgopt_settings_copy', $upsell_msg_1.' '.$upsell_msg_2.'</p>');
972 972
                     }
973 973
                     // translators: link points to shortpixel FAQ.
974
-                    $faqcopy = sprintf( __( '<strong>Questions</strong>? Have a look at the %1$sShortPixel FAQ%2$s!', 'autoptimize' ), '<strong><a href="https://shortpixel.helpscoutdocs.com/category/60-shortpixel-ai-cdn" target="_blank">', '</strong></a>' );
974
+                    $faqcopy = sprintf(__('<strong>Questions</strong>? Have a look at the %1$sShortPixel FAQ%2$s!', 'autoptimize'), '<strong><a href="https://shortpixel.helpscoutdocs.com/category/60-shortpixel-ai-cdn" target="_blank">', '</strong></a>');
975 975
                     // translators: links points to shortpixel TOS & Privacy Policy.
976
-                    $toscopy = sprintf( __( 'Usage of this feature is subject to Shortpixel\'s %1$sTerms of Use%2$s and %3$sPrivacy policy%4$s.', 'autoptimize' ), '<a href="https://shortpixel.com/tos' . $sp_url_suffix . '" target="_blank">', '</a>', '<a href="https://shortpixel.com/pp' . $sp_url_suffix . '" target="_blank">', '</a>' );
977
-                    echo apply_filters( 'autoptimize_imgopt_imgopt_settings_tos', '<p>' . $faqcopy . ' ' . $toscopy . '</p>' );
976
+                    $toscopy = sprintf(__('Usage of this feature is subject to Shortpixel\'s %1$sTerms of Use%2$s and %3$sPrivacy policy%4$s.', 'autoptimize'), '<a href="https://shortpixel.com/tos'.$sp_url_suffix.'" target="_blank">', '</a>', '<a href="https://shortpixel.com/pp'.$sp_url_suffix.'" target="_blank">', '</a>');
977
+                    echo apply_filters('autoptimize_imgopt_imgopt_settings_tos', '<p>'.$faqcopy.' '.$toscopy.'</p>');
978 978
                     ?>
979 979
                 </td>
980 980
             </tr>
981
-            <tr id='autoptimize_imgopt_quality' <?php if ( ! array_key_exists( 'autoptimize_imgopt_checkbox_field_1', $options ) || ( isset( $options['autoptimize_imgopt_checkbox_field_1'] ) && '1' !== $options['autoptimize_imgopt_checkbox_field_1'] ) ) { echo 'class="hidden"'; } ?>>
982
-                <th scope="row"><?php _e( 'Image Optimization quality', 'autoptimize' ); ?></th>
981
+            <tr id='autoptimize_imgopt_quality' <?php if (!array_key_exists('autoptimize_imgopt_checkbox_field_1', $options) || (isset($options['autoptimize_imgopt_checkbox_field_1']) && '1' !== $options['autoptimize_imgopt_checkbox_field_1'])) { echo 'class="hidden"'; } ?>>
982
+                <th scope="row"><?php _e('Image Optimization quality', 'autoptimize'); ?></th>
983 983
                 <td>
984 984
                     <label>
985 985
                     <select name='autoptimize_imgopt_settings[autoptimize_imgopt_select_field_2]'>
@@ -987,12 +987,12 @@  discard block
 block discarded – undo
987 987
                         $_imgopt_array = autoptimizeImages::instance()->get_img_quality_array();
988 988
                         $_imgopt_val   = autoptimizeImages::instance()->get_img_quality_setting();
989 989
 
990
-                        foreach ( $_imgopt_array as $key => $value ) {
991
-                            echo '<option value="' . $key . '"';
992
-                            if ( $_imgopt_val == $key ) {
990
+                        foreach ($_imgopt_array as $key => $value) {
991
+                            echo '<option value="'.$key.'"';
992
+                            if ($_imgopt_val == $key) {
993 993
                                 echo ' selected';
994 994
                             }
995
-                            echo '>' . ucfirst( $value ) . '</option>';
995
+                            echo '>'.ucfirst($value).'</option>';
996 996
                         }
997 997
                         echo "\n";
998 998
                         ?>
@@ -1001,31 +1001,31 @@  discard block
 block discarded – undo
1001 1001
                     <p>
1002 1002
                         <?php
1003 1003
                             // translators: link points to shortpixel image test page.
1004
-                            echo apply_filters( 'autoptimize_imgopt_imgopt_quality_copy', sprintf( __( 'You can %1$stest compression levels here%2$s.', 'autoptimize' ), '<a href="https://shortpixel.com/oic' . $sp_url_suffix . '" target="_blank">', '</a>' ) );
1004
+                            echo apply_filters('autoptimize_imgopt_imgopt_quality_copy', sprintf(__('You can %1$stest compression levels here%2$s.', 'autoptimize'), '<a href="https://shortpixel.com/oic'.$sp_url_suffix.'" target="_blank">', '</a>'));
1005 1005
                         ?>
1006 1006
                     </p>
1007 1007
                 </td>
1008 1008
             </tr>
1009
-            <tr id='autoptimize_imgopt_webp' <?php if ( ! array_key_exists( 'autoptimize_imgopt_checkbox_field_1', $options ) || ( isset( $options['autoptimize_imgopt_checkbox_field_1'] ) && '1' !== $options['autoptimize_imgopt_checkbox_field_1'] ) ) { echo 'class="hidden"'; } ?>>
1010
-                <th scope="row"><?php _e( 'Load WebP in supported browsers?', 'autoptimize' ); ?></th>
1009
+            <tr id='autoptimize_imgopt_webp' <?php if (!array_key_exists('autoptimize_imgopt_checkbox_field_1', $options) || (isset($options['autoptimize_imgopt_checkbox_field_1']) && '1' !== $options['autoptimize_imgopt_checkbox_field_1'])) { echo 'class="hidden"'; } ?>>
1010
+                <th scope="row"><?php _e('Load WebP in supported browsers?', 'autoptimize'); ?></th>
1011 1011
                 <td>
1012
-                    <label><input type='checkbox' id='autoptimize_imgopt_webp_checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_4]' <?php if ( ! empty( $options['autoptimize_imgopt_checkbox_field_4'] ) && '1' === $options['autoptimize_imgopt_checkbox_field_3'] ) { echo 'checked="checked"'; } ?> value='1'><?php _e( 'Automatically serve "next-gen" WebP image format to any browser that supports it (requires lazy load to be active).', 'autoptimize' ); ?></label>
1012
+                    <label><input type='checkbox' id='autoptimize_imgopt_webp_checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_4]' <?php if (!empty($options['autoptimize_imgopt_checkbox_field_4']) && '1' === $options['autoptimize_imgopt_checkbox_field_3']) { echo 'checked="checked"'; } ?> value='1'><?php _e('Automatically serve "next-gen" WebP image format to any browser that supports it (requires lazy load to be active).', 'autoptimize'); ?></label>
1013 1013
                 </td>
1014 1014
             </tr>
1015 1015
             <tr>
1016
-                <th scope="row"><?php _e( 'Lazy-load images?', 'autoptimize' ); ?></th>
1016
+                <th scope="row"><?php _e('Lazy-load images?', 'autoptimize'); ?></th>
1017 1017
                 <td>
1018
-                    <label><input type='checkbox' id='autoptimize_imgopt_lazyload_checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_3]' <?php if ( ! empty( $options['autoptimize_imgopt_checkbox_field_3'] ) && '1' === $options['autoptimize_imgopt_checkbox_field_3'] ) { echo 'checked="checked"'; } ?> value='1'><?php _e( 'Image lazy-loading will delay the loading of non-visible images to allow the browser to optimally load all resources for the "above the fold"-page first.', 'autoptimize' ); ?></label>
1018
+                    <label><input type='checkbox' id='autoptimize_imgopt_lazyload_checkbox' name='autoptimize_imgopt_settings[autoptimize_imgopt_checkbox_field_3]' <?php if (!empty($options['autoptimize_imgopt_checkbox_field_3']) && '1' === $options['autoptimize_imgopt_checkbox_field_3']) { echo 'checked="checked"'; } ?> value='1'><?php _e('Image lazy-loading will delay the loading of non-visible images to allow the browser to optimally load all resources for the "above the fold"-page first.', 'autoptimize'); ?></label>
1019 1019
                 </td>
1020 1020
             </tr>
1021
-            <tr id='autoptimize_imgopt_lazyload_exclusions' <?php if ( ! array_key_exists( 'autoptimize_imgopt_checkbox_field_3', $options ) || ( isset( $options['autoptimize_imgopt_checkbox_field_3'] ) && '1' !== $options['autoptimize_imgopt_checkbox_field_3'] ) ) { echo 'class="hidden"'; } ?>>
1022
-                <th scope="row"><?php _e( 'Lazy-load exclusions', 'autoptimize' ); ?></th>
1021
+            <tr id='autoptimize_imgopt_lazyload_exclusions' <?php if (!array_key_exists('autoptimize_imgopt_checkbox_field_3', $options) || (isset($options['autoptimize_imgopt_checkbox_field_3']) && '1' !== $options['autoptimize_imgopt_checkbox_field_3'])) { echo 'class="hidden"'; } ?>>
1022
+                <th scope="row"><?php _e('Lazy-load exclusions', 'autoptimize'); ?></th>
1023 1023
                 <td>
1024
-                    <label><input type='text' style='width:80%' id='autoptimize_imgopt_lazyload_exclusions' name='autoptimize_imgopt_settings[autoptimize_imgopt_text_field_5]' value='<?php if ( ! empty( $options['autoptimize_imgopt_text_field_5'] ) ) { echo esc_attr( $options['autoptimize_imgopt_text_field_5'] ); } ?>'><br /><?php _e( 'Comma-separated list of to be excluded image classes or filenames.', 'autoptimize' ); ?></label>
1024
+                    <label><input type='text' style='width:80%' id='autoptimize_imgopt_lazyload_exclusions' name='autoptimize_imgopt_settings[autoptimize_imgopt_text_field_5]' value='<?php if (!empty($options['autoptimize_imgopt_text_field_5'])) { echo esc_attr($options['autoptimize_imgopt_text_field_5']); } ?>'><br /><?php _e('Comma-separated list of to be excluded image classes or filenames.', 'autoptimize'); ?></label>
1025 1025
                 </td>
1026 1026
             </tr>
1027 1027
         </table>
1028
-        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e( 'Save Changes', 'autoptimize' ); ?>" /></p>
1028
+        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e('Save Changes', 'autoptimize'); ?>" /></p>
1029 1029
     </form>
1030 1030
     <script>
1031 1031
         jQuery(document).ready(function() {
@@ -1061,37 +1061,37 @@  discard block
 block discarded – undo
1061 1061
      * Ïmg opt status as used on dashboard.
1062 1062
      */
1063 1063
     public function get_imgopt_status_notice() {
1064
-        if ( $this->imgopt_active() ) {
1064
+        if ($this->imgopt_active()) {
1065 1065
             $_imgopt_notice = '';
1066
-            $_stat          = autoptimizeOption::get_option( 'autoptimize_imgopt_provider_stat', '' );
1066
+            $_stat          = autoptimizeOption::get_option('autoptimize_imgopt_provider_stat', '');
1067 1067
             $_site_host     = AUTOPTIMIZE_SITE_DOMAIN;
1068
-            $_imgopt_upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/' . $_site_host;
1068
+            $_imgopt_upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/'.$_site_host;
1069 1069
 
1070
-            if ( is_array( $_stat ) ) {
1071
-                if ( 1 == $_stat['Status'] ) {
1070
+            if (is_array($_stat)) {
1071
+                if (1 == $_stat['Status']) {
1072 1072
                     // translators: "add more credits" will appear in a "a href".
1073
-                    $_imgopt_notice = sprintf( __( 'Your ShortPixel image optimization and CDN quota is almost used, make sure you %1$sadd more credits%2$s to avoid slowing down your website.', 'autoptimize' ), '<a href="' . $_imgopt_upsell . '" target="_blank">', '</a>' );
1073
+                    $_imgopt_notice = sprintf(__('Your ShortPixel image optimization and CDN quota is almost used, make sure you %1$sadd more credits%2$s to avoid slowing down your website.', 'autoptimize'), '<a href="'.$_imgopt_upsell.'" target="_blank">', '</a>');
1074 1074
                 } elseif ( -1 == $_stat['Status'] || -2 == $_stat['Status'] ) {
1075 1075
                     // translators: "add more credits" will appear in a "a href".
1076
-                    $_imgopt_notice            = sprintf( __( 'Your ShortPixel image optimization and CDN quota was used, %1$sadd more credits%2$s to keep fast serving optimized images on your site', 'autoptimize' ), '<a href="' . $_imgopt_upsell . '" target="_blank">', '</a>' );
1077
-                    $_imgopt_stats_refresh_url = add_query_arg( array(
1076
+                    $_imgopt_notice            = sprintf(__('Your ShortPixel image optimization and CDN quota was used, %1$sadd more credits%2$s to keep fast serving optimized images on your site', 'autoptimize'), '<a href="'.$_imgopt_upsell.'" target="_blank">', '</a>');
1077
+                    $_imgopt_stats_refresh_url = add_query_arg(array(
1078 1078
                         'page'                => 'autoptimize_imgopt',
1079 1079
                         'refreshImgProvStats' => '1',
1080
-                    ), admin_url( 'options-general.php' ) );
1081
-                    if ( $_stat && array_key_exists( 'timestamp', $_stat ) && ! empty( $_stat['timestamp'] ) ) {
1082
-                        $_imgopt_stats_last_run = __( 'based on status at ', 'autoptimize' ) . date_i18n( autoptimizeOption::get_option( 'time_format' ), $_stat['timestamp'] );
1080
+                    ), admin_url('options-general.php'));
1081
+                    if ($_stat && array_key_exists('timestamp', $_stat) && !empty($_stat['timestamp'])) {
1082
+                        $_imgopt_stats_last_run = __('based on status at ', 'autoptimize').date_i18n(autoptimizeOption::get_option('time_format'), $_stat['timestamp']);
1083 1083
                     } else {
1084
-                        $_imgopt_stats_last_run = __( 'based on previously fetched data', 'autoptimize' );
1084
+                        $_imgopt_stats_last_run = __('based on previously fetched data', 'autoptimize');
1085 1085
                     }
1086
-                    $_imgopt_notice .= ' (' . $_imgopt_stats_last_run . ', ';
1086
+                    $_imgopt_notice .= ' ('.$_imgopt_stats_last_run.', ';
1087 1087
                     // translators: "here to refresh" links to the Autoptimize Extra page and forces a refresh of the img opt stats.
1088
-                    $_imgopt_notice .= sprintf( __( 'click %1$shere to refresh%2$s', 'autoptimize' ), '<a href="' . $_imgopt_stats_refresh_url . '">', '</a>).' );
1088
+                    $_imgopt_notice .= sprintf(__('click %1$shere to refresh%2$s', 'autoptimize'), '<a href="'.$_imgopt_stats_refresh_url.'">', '</a>).');
1089 1089
                 } else {
1090 1090
                     $_imgopt_upsell = 'https://shortpixel.com/g/af/GWRGFLW109483';
1091 1091
                     // translators: "log in to check your account" will appear in a "a href".
1092
-                    $_imgopt_notice = sprintf( __( 'Your ShortPixel image optimization and CDN quota are in good shape, %1$slog in to check your account%2$s.', 'autoptimize' ), '<a href="' . $_imgopt_upsell . '" target="_blank">', '</a>' );
1092
+                    $_imgopt_notice = sprintf(__('Your ShortPixel image optimization and CDN quota are in good shape, %1$slog in to check your account%2$s.', 'autoptimize'), '<a href="'.$_imgopt_upsell.'" target="_blank">', '</a>');
1093 1093
                 }
1094
-                $_imgopt_notice = apply_filters( 'autoptimize_filter_imgopt_notice', $_imgopt_notice );
1094
+                $_imgopt_notice = apply_filters('autoptimize_filter_imgopt_notice', $_imgopt_notice);
1095 1095
 
1096 1096
                 return array(
1097 1097
                     'status' => $_stat['Status'],
@@ -1112,14 +1112,14 @@  discard block
 block discarded – undo
1112 1112
      * Get img provider stats (used to display notice).
1113 1113
      */
1114 1114
     public function query_img_provider_stats() {
1115
-        if ( ! empty( $this->options['autoptimize_imgopt_checkbox_field_1'] ) ) {
1115
+        if (!empty($this->options['autoptimize_imgopt_checkbox_field_1'])) {
1116 1116
             $url      = '';
1117
-            $endpoint = $this->get_imgopt_host() . 'read-domain/';
1117
+            $endpoint = $this->get_imgopt_host().'read-domain/';
1118 1118
             $domain   = AUTOPTIMIZE_SITE_DOMAIN;
1119 1119
 
1120 1120
             // make sure parse_url result makes sense, keeping $url empty if not.
1121
-            if ( $domain && ! empty( $domain ) ) {
1122
-                $url = $endpoint . $domain;
1121
+            if ($domain && !empty($domain)) {
1122
+                $url = $endpoint.$domain;
1123 1123
             }
1124 1124
 
1125 1125
             $url = apply_filters(
@@ -1129,12 +1129,12 @@  discard block
 block discarded – undo
1129 1129
 
1130 1130
             // only do the remote call if $url is not empty to make sure no parse_url
1131 1131
             // weirdness results in useless calls.
1132
-            if ( ! empty( $url ) ) {
1133
-                $response = wp_remote_get( $url );
1134
-                if ( ! is_wp_error( $response ) ) {
1135
-                    if ( '200' == wp_remote_retrieve_response_code( $response ) ) {
1136
-                        $stats = json_decode( wp_remote_retrieve_body( $response ), true );
1137
-                        autoptimizeOption::update_option( 'autoptimize_imgopt_provider_stat', $stats );
1132
+            if (!empty($url)) {
1133
+                $response = wp_remote_get($url);
1134
+                if (!is_wp_error($response)) {
1135
+                    if ('200' == wp_remote_retrieve_response_code($response)) {
1136
+                        $stats = json_decode(wp_remote_retrieve_body($response), true);
1137
+                        autoptimizeOption::update_option('autoptimize_imgopt_provider_stat', $stats);
1138 1138
                     }
1139 1139
                 }
1140 1140
             }
@@ -1157,15 +1157,15 @@  discard block
 block discarded – undo
1157 1157
     {
1158 1158
         static $launch_status = null;
1159 1159
 
1160
-        if ( null === $launch_status ) {
1160
+        if (null === $launch_status) {
1161 1161
             $avail_imgopt  = $this->options['availabilities']['extra_imgopt'];
1162
-            $magic_number  = intval( substr( md5( parse_url( AUTOPTIMIZE_WP_SITE_URL, PHP_URL_HOST ) ), 0, 3 ), 16 );
1163
-            $has_launched  = autoptimizeOption::get_option( 'autoptimize_imgopt_launched', '' );
1162
+            $magic_number  = intval(substr(md5(parse_url(AUTOPTIMIZE_WP_SITE_URL, PHP_URL_HOST)), 0, 3), 16);
1163
+            $has_launched  = autoptimizeOption::get_option('autoptimize_imgopt_launched', '');
1164 1164
             $launch_status = false;
1165
-            if ( $has_launched || ( is_array( $avail_imgopt ) && array_key_exists( 'launch-threshold', $avail_imgopt ) && $magic_number < $avail_imgopt['launch-threshold'] ) ) {
1165
+            if ($has_launched || (is_array($avail_imgopt) && array_key_exists('launch-threshold', $avail_imgopt) && $magic_number < $avail_imgopt['launch-threshold'])) {
1166 1166
                 $launch_status = true;
1167
-                if ( ! $has_launched ) {
1168
-                    autoptimizeOption::update_option( 'autoptimize_imgopt_launched', 'on' );
1167
+                if (!$has_launched) {
1168
+                    autoptimizeOption::update_option('autoptimize_imgopt_launched', 'on');
1169 1169
                 }
1170 1170
             }
1171 1171
         }
@@ -1182,16 +1182,16 @@  discard block
 block discarded – undo
1182 1182
     public function get_imgopt_provider_userstatus() {
1183 1183
         static $_provider_userstatus = null;
1184 1184
 
1185
-        if ( is_null( $_provider_userstatus ) ) {
1186
-            $_stat = autoptimizeOption::get_option( 'autoptimize_imgopt_provider_stat', '' );
1187
-            if ( is_array( $_stat ) ) {
1188
-                if ( array_key_exists( 'Status', $_stat ) ) {
1185
+        if (is_null($_provider_userstatus)) {
1186
+            $_stat = autoptimizeOption::get_option('autoptimize_imgopt_provider_stat', '');
1187
+            if (is_array($_stat)) {
1188
+                if (array_key_exists('Status', $_stat)) {
1189 1189
                     $_provider_userstatus['Status'] = $_stat['Status'];
1190 1190
                 } else {
1191 1191
                     // if no stats then we assume all is well.
1192 1192
                     $_provider_userstatus['Status'] = 2;
1193 1193
                 }
1194
-                if ( array_key_exists( 'timestamp', $_stat ) ) {
1194
+                if (array_key_exists('timestamp', $_stat)) {
1195 1195
                     $_provider_userstatus['timestamp'] = $_stat['timestamp'];
1196 1196
                 } else {
1197 1197
                     // if no timestamp then we return "".
@@ -1204,27 +1204,27 @@  discard block
 block discarded – undo
1204 1204
     }
1205 1205
 
1206 1206
     public function get_status_notice() {
1207
-        if ( $this->imgopt_active() ) {
1207
+        if ($this->imgopt_active()) {
1208 1208
             $notice = '';
1209 1209
             $stat   = $this->get_imgopt_provider_userstatus();
1210
-            $upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/' . AUTOPTIMIZE_SITE_DOMAIN;
1210
+            $upsell = 'https://shortpixel.com/aospai/af/GWRGFLW109483/'.AUTOPTIMIZE_SITE_DOMAIN;
1211 1211
             $assoc  = 'https://shortpixel.helpscoutdocs.com/article/94-how-to-associate-a-domain-to-my-account';
1212 1212
 
1213
-            if ( is_array( $stat ) ) {
1214
-                if ( 1 == $stat['Status'] ) {
1213
+            if (is_array($stat)) {
1214
+                if (1 == $stat['Status']) {
1215 1215
                     // translators: "add more credits" will appear in a "a href".
1216
-                    $notice = sprintf( __( 'Your ShortPixel image optimization and CDN quota is almost used, make sure you %1$sadd more credits%2$s to avoid slowing down your website.', 'autoptimize' ), '<a rel="noopener noreferrer" href="' . $upsell . '" target="_blank">', '</a>' );
1216
+                    $notice = sprintf(__('Your ShortPixel image optimization and CDN quota is almost used, make sure you %1$sadd more credits%2$s to avoid slowing down your website.', 'autoptimize'), '<a rel="noopener noreferrer" href="'.$upsell.'" target="_blank">', '</a>');
1217 1217
                 } elseif ( -1 == $stat['Status'] || -2 == $stat['Status'] ) {
1218 1218
                     // translators: "add more credits" will appear in a "a href".
1219
-                    $notice = sprintf( __( 'Your ShortPixel image optimization and CDN quota was used, %1$sadd more credits%2$s to keep fast serving optimized images on your site.', 'autoptimize' ), '<a rel="noopener noreferrer" href="' . $upsell . '" target="_blank">', '</a>' );
1219
+                    $notice = sprintf(__('Your ShortPixel image optimization and CDN quota was used, %1$sadd more credits%2$s to keep fast serving optimized images on your site.', 'autoptimize'), '<a rel="noopener noreferrer" href="'.$upsell.'" target="_blank">', '</a>');
1220 1220
                     // translators: "associate your domain" will appear in a "a href".
1221
-                    $notice = $notice . ' ' . sprintf( __( 'If you already have enough credits then you may need to %1$sassociate your domain%2$s to your Shortpixel account.', 'autoptimize' ), '<a rel="noopener noreferrer" href="' . $assoc . '" target="_blank">', '</a>' );
1221
+                    $notice = $notice.' '.sprintf(__('If you already have enough credits then you may need to %1$sassociate your domain%2$s to your Shortpixel account.', 'autoptimize'), '<a rel="noopener noreferrer" href="'.$assoc.'" target="_blank">', '</a>');
1222 1222
                 } else {
1223 1223
                     $upsell = 'https://shortpixel.com/g/af/GWRGFLW109483';
1224 1224
                     // translators: "log in to check your account" will appear in a "a href".
1225
-                    $notice = sprintf( __( 'Your ShortPixel image optimization and CDN quota are in good shape, %1$slog in to check your account%2$s.', 'autoptimize' ), '<a rel="noopener noreferrer" href="' . $upsell . '" target="_blank">', '</a>' );
1225
+                    $notice = sprintf(__('Your ShortPixel image optimization and CDN quota are in good shape, %1$slog in to check your account%2$s.', 'autoptimize'), '<a rel="noopener noreferrer" href="'.$upsell.'" target="_blank">', '</a>');
1226 1226
                 }
1227
-                $notice = apply_filters( 'autoptimize_filter_imgopt_notice', $notice );
1227
+                $notice = apply_filters('autoptimize_filter_imgopt_notice', $notice);
1228 1228
 
1229 1229
                 return array(
1230 1230
                     'status' => $stat['Status'],
Please login to merge, or discard this patch.
classes/autoptimizeToolbar.php 1 patch
Spacing   +49 added lines, -49 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Handles toolbar-related stuff.
4 4
  */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) {
6
+if (!defined('ABSPATH')) {
7 7
     exit;
8 8
 }
9 9
 
@@ -12,32 +12,32 @@  discard block
 block discarded – undo
12 12
     public function __construct()
13 13
     {
14 14
         // If Cache is not available we don't add the toolbar.
15
-        if ( ! autoptimizeCache::cacheavail() ) {
15
+        if (!autoptimizeCache::cacheavail()) {
16 16
             return;
17 17
         }
18 18
 
19 19
         // Load admin toolbar feature once WordPress, all plugins, and the theme are fully loaded and instantiated.
20
-        add_action( 'wp_loaded', array( $this, 'load_toolbar' ) );
20
+        add_action('wp_loaded', array($this, 'load_toolbar'));
21 21
     }
22 22
 
23 23
     public function load_toolbar()
24 24
     {
25 25
         // Check permissions and that toolbar is not hidden via filter.
26
-        if ( current_user_can( 'manage_options' ) && apply_filters( 'autoptimize_filter_toolbar_show', true ) ) {
26
+        if (current_user_can('manage_options') && apply_filters('autoptimize_filter_toolbar_show', true)) {
27 27
 
28 28
             // Create a handler for the AJAX toolbar requests.
29
-            add_action( 'wp_ajax_autoptimize_delete_cache', array( $this, 'delete_cache' ) );
29
+            add_action('wp_ajax_autoptimize_delete_cache', array($this, 'delete_cache'));
30 30
 
31 31
             // Load custom styles, scripts and menu only when needed.
32
-            if ( is_admin_bar_showing() ) {
33
-                if ( is_admin() ) {
34
-                    add_action( 'admin_enqueue_scripts', array( $this, 'enqueue_scripts' ) );
32
+            if (is_admin_bar_showing()) {
33
+                if (is_admin()) {
34
+                    add_action('admin_enqueue_scripts', array($this, 'enqueue_scripts'));
35 35
                 } else {
36
-                    add_action( 'wp_enqueue_scripts', array( $this, 'enqueue_scripts' ) );
36
+                    add_action('wp_enqueue_scripts', array($this, 'enqueue_scripts'));
37 37
                 }
38 38
 
39 39
                 // Add the Autoptimize Toolbar to the Admin bar.
40
-                add_action( 'admin_bar_menu', array( $this, 'add_toolbar' ), 100 );
40
+                add_action('admin_bar_menu', array($this, 'add_toolbar'), 100);
41 41
             }
42 42
         }
43 43
     }
@@ -50,17 +50,17 @@  discard block
 block discarded – undo
50 50
         $stats = autoptimizeCache::stats();
51 51
 
52 52
         // Set the Max Size recommended for cache files.
53
-        $max_size = apply_filters( 'autoptimize_filter_cachecheck_maxsize', 512 * 1024 * 1024 );
53
+        $max_size = apply_filters('autoptimize_filter_cachecheck_maxsize', 512*1024*1024);
54 54
 
55 55
         // Retrieve the current Total Files in cache.
56 56
         $files = $stats[0];
57 57
         // Retrieve the current Total Size of the cache.
58 58
         $bytes = $stats[1];
59
-        $size  = $this->format_filesize( $bytes );
59
+        $size  = $this->format_filesize($bytes);
60 60
 
61 61
         // Calculate the percentage of cache used.
62
-        $percentage = ceil( $bytes / $max_size * 100 );
63
-        if ( $percentage > 100 ) {
62
+        $percentage = ceil($bytes/$max_size*100);
63
+        if ($percentage > 100) {
64 64
             $percentage = 100;
65 65
         }
66 66
 
@@ -70,82 +70,82 @@  discard block
 block discarded – undo
70 70
          * - "orange" if over 80%.
71 71
          * - "red" if over 100%.
72 72
          */
73
-        $color = ( 100 == $percentage ) ? 'red' : ( ( $percentage > 80 ) ? 'orange' : 'green' );
73
+        $color = (100 == $percentage) ? 'red' : (($percentage > 80) ? 'orange' : 'green');
74 74
 
75 75
         // Create or add new items into the Admin Toolbar.
76 76
         // Main "Autoptimize" node.
77
-        $wp_admin_bar->add_node( array(
77
+        $wp_admin_bar->add_node(array(
78 78
             'id'    => 'autoptimize',
79
-            'title' => '<span class="ab-icon"></span><span class="ab-label">' . __( 'Autoptimize', 'autoptimize' ) . '</span>',
80
-            'href'  => admin_url( 'options-general.php?page=autoptimize' ),
81
-            'meta'  => array( 'class' => 'bullet-' . $color ),
79
+            'title' => '<span class="ab-icon"></span><span class="ab-label">'.__('Autoptimize', 'autoptimize').'</span>',
80
+            'href'  => admin_url('options-general.php?page=autoptimize'),
81
+            'meta'  => array('class' => 'bullet-'.$color),
82 82
         ));
83 83
 
84 84
         // "Cache Info" node.
85
-        $wp_admin_bar->add_node( array(
85
+        $wp_admin_bar->add_node(array(
86 86
             'id'     => 'autoptimize-cache-info',
87
-            'title'  => '<p>' . __( 'Cache Info', 'autoptimize' ) . '</p>' .
88
-                        '<div class="autoptimize-radial-bar" percentage="' . $percentage . '">' .
89
-                        '<div class="autoptimize-circle">' .
90
-                        '<div class="mask full"><div class="fill bg-' . $color . '"></div></div>' .
91
-                        '<div class="mask half"><div class="fill bg-' . $color . '"></div></div>' .
92
-                        '<div class="shadow"></div>' .
93
-                        '</div>' .
94
-                        '<div class="inset"><div class="percentage"><div class="numbers ' . $color . '">' . $percentage . '%</div></div></div>' .
95
-                        '</div>' .
96
-                        '<table>' .
97
-                        '<tr><td>' . __( 'Size', 'autoptimize' ) . ':</td><td class="size ' . $color . '">' . $size . '</td></tr>' .
98
-                        '<tr><td>' . __( 'Files', 'autoptimize' ) . ':</td><td class="files white">' . $files . '</td></tr>' .
87
+            'title'  => '<p>'.__('Cache Info', 'autoptimize').'</p>'.
88
+                        '<div class="autoptimize-radial-bar" percentage="'.$percentage.'">'.
89
+                        '<div class="autoptimize-circle">'.
90
+                        '<div class="mask full"><div class="fill bg-'.$color.'"></div></div>'.
91
+                        '<div class="mask half"><div class="fill bg-'.$color.'"></div></div>'.
92
+                        '<div class="shadow"></div>'.
93
+                        '</div>'.
94
+                        '<div class="inset"><div class="percentage"><div class="numbers '.$color.'">'.$percentage.'%</div></div></div>'.
95
+                        '</div>'.
96
+                        '<table>'.
97
+                        '<tr><td>'.__('Size', 'autoptimize').':</td><td class="size '.$color.'">'.$size.'</td></tr>'.
98
+                        '<tr><td>'.__('Files', 'autoptimize').':</td><td class="files white">'.$files.'</td></tr>'.
99 99
                         '</table>',
100 100
             'parent' => 'autoptimize',
101 101
         ));
102 102
 
103 103
         // "Delete Cache" node.
104
-        $wp_admin_bar->add_node( array(
104
+        $wp_admin_bar->add_node(array(
105 105
             'id'     => 'autoptimize-delete-cache',
106
-            'title'  => __( 'Delete Cache', 'autoptimize' ),
106
+            'title'  => __('Delete Cache', 'autoptimize'),
107 107
             'parent' => 'autoptimize',
108 108
         ));
109 109
     }
110 110
 
111 111
     public function delete_cache()
112 112
     {
113
-        check_ajax_referer( 'ao_delcache_nonce', 'nonce' );
113
+        check_ajax_referer('ao_delcache_nonce', 'nonce');
114 114
 
115 115
         $result = false;
116
-        if ( current_user_can( 'manage_options' ) ) {
116
+        if (current_user_can('manage_options')) {
117 117
             // We call the function for cleaning the Autoptimize cache.
118 118
             $result = autoptimizeCache::clearall();
119 119
         }
120 120
 
121
-        wp_send_json( $result );
121
+        wp_send_json($result);
122 122
     }
123 123
 
124 124
     public function enqueue_scripts()
125 125
     {
126 126
         // Autoptimize Toolbar Styles.
127
-        wp_enqueue_style( 'autoptimize-toolbar', plugins_url( '/static/toolbar.css', __FILE__ ), array(), AUTOPTIMIZE_PLUGIN_VERSION, 'all' );
127
+        wp_enqueue_style('autoptimize-toolbar', plugins_url('/static/toolbar.css', __FILE__), array(), AUTOPTIMIZE_PLUGIN_VERSION, 'all');
128 128
 
129 129
         // Autoptimize Toolbar Javascript.
130
-        wp_enqueue_script( 'autoptimize-toolbar', plugins_url( '/static/toolbar.js', __FILE__ ), array( 'jquery' ), AUTOPTIMIZE_PLUGIN_VERSION, true );
130
+        wp_enqueue_script('autoptimize-toolbar', plugins_url('/static/toolbar.js', __FILE__), array('jquery'), AUTOPTIMIZE_PLUGIN_VERSION, true);
131 131
 
132 132
         // Localizes a registered script with data for a JavaScript variable.
133 133
         // Needed for the AJAX to work properly on the frontend.
134
-        wp_localize_script( 'autoptimize-toolbar', 'autoptimize_ajax_object', array(
135
-            'ajaxurl'     => admin_url( 'admin-ajax.php' ),
134
+        wp_localize_script('autoptimize-toolbar', 'autoptimize_ajax_object', array(
135
+            'ajaxurl'     => admin_url('admin-ajax.php'),
136 136
             // translators: links to the Autoptimize settings page.
137
-            'error_msg'   => sprintf( __( 'Your Autoptimize cache might not have been purged successfully, please check on the <a href=%s>Autoptimize settings page</a>.', 'autoptimize' ), admin_url( 'options-general.php?page=autoptimize' ) . ' style="white-space:nowrap;"' ),
138
-            'dismiss_msg' => __( 'Dismiss this notice.' ),
139
-            'nonce'       => wp_create_nonce( 'ao_delcache_nonce' ),
140
-        ) );
137
+            'error_msg'   => sprintf(__('Your Autoptimize cache might not have been purged successfully, please check on the <a href=%s>Autoptimize settings page</a>.', 'autoptimize'), admin_url('options-general.php?page=autoptimize').' style="white-space:nowrap;"'),
138
+            'dismiss_msg' => __('Dismiss this notice.'),
139
+            'nonce'       => wp_create_nonce('ao_delcache_nonce'),
140
+        ));
141 141
     }
142 142
 
143
-    public function format_filesize( $bytes, $decimals = 2 )
143
+    public function format_filesize($bytes, $decimals = 2)
144 144
     {
145
-        $units = array( 'B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB' );
145
+        $units = array('B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB');
146 146
 
147
-        for ( $i = 0; ( $bytes / 1024) > 0.9; $i++, $bytes /= 1024 ) {} // @codingStandardsIgnoreLine
147
+        for ($i = 0; ($bytes/1024) > 0.9; $i++, $bytes /= 1024) {} // @codingStandardsIgnoreLine
148 148
 
149
-        return sprintf( "%1.{$decimals}f %s", round( $bytes, $decimals ), $units[ $i ] );
149
+        return sprintf("%1.{$decimals}f %s", round($bytes, $decimals), $units[$i]);
150 150
     }
151 151
 }
Please login to merge, or discard this patch.
classes/autoptimizeExtra.php 2 patches
Indentation   +9 added lines, -9 removed lines patch added patch discarded remove patch
@@ -33,12 +33,12 @@  discard block
 block discarded – undo
33 33
     public function run()
34 34
     {
35 35
         if ( is_admin() ) {
36
-			if ( is_plugin_active_for_network( 'autoptimize/autoptimize.php' ) ) {
37
-				add_action( 'network_admin_menu', array( $this, 'admin_menu' ) );
38
-			} else {
39
-				add_action( 'admin_menu', array( $this, 'admin_menu' ) );
40
-			}
41
-			add_action( 'admin_init', array( $this, 'registersettings' ) );
36
+            if ( is_plugin_active_for_network( 'autoptimize/autoptimize.php' ) ) {
37
+                add_action( 'network_admin_menu', array( $this, 'admin_menu' ) );
38
+            } else {
39
+                add_action( 'admin_menu', array( $this, 'admin_menu' ) );
40
+            }
41
+            add_action( 'admin_init', array( $this, 'registersettings' ) );
42 42
             add_filter( 'autoptimize_filter_settingsscreen_tabs', array( $this, 'add_extra_tab' ) );
43 43
         } else {
44 44
             $this->run_on_frontend();
@@ -342,9 +342,9 @@  discard block
 block discarded – undo
342 342
         );
343 343
     }
344 344
 	
345
-	public function registersettings() {
346
-		register_setting( 'autoptimize_extra_settings', 'autoptimize_extra_settings' );
347
-	}
345
+    public function registersettings() {
346
+        register_setting( 'autoptimize_extra_settings', 'autoptimize_extra_settings' );
347
+    }
348 348
 
349 349
     public function add_extra_tab( $in )
350 350
     {
Please login to merge, or discard this patch.
Spacing   +163 added lines, -163 removed lines patch added patch discarded remove patch
@@ -3,7 +3,7 @@  discard block
 block discarded – undo
3 3
  * Handles autoptimizeExtra frontend features + admin options page
4 4
  */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) {
6
+if (!defined('ABSPATH')) {
7 7
     exit;
8 8
 }
9 9
 
@@ -21,9 +21,9 @@  discard block
 block discarded – undo
21 21
      *
22 22
      * @param array $options Optional. Allows overriding options without having to specify them via admin options page.
23 23
      */
24
-    public function __construct( $options = array() )
24
+    public function __construct($options = array())
25 25
     {
26
-        if ( empty( $options ) ) {
26
+        if (empty($options)) {
27 27
             $options = self::fetch_options();
28 28
         }
29 29
 
@@ -32,14 +32,14 @@  discard block
 block discarded – undo
32 32
 
33 33
     public function run()
34 34
     {
35
-        if ( is_admin() ) {
36
-			if ( is_plugin_active_for_network( 'autoptimize/autoptimize.php' ) ) {
37
-				add_action( 'network_admin_menu', array( $this, 'admin_menu' ) );
35
+        if (is_admin()) {
36
+			if (is_plugin_active_for_network('autoptimize/autoptimize.php')) {
37
+				add_action('network_admin_menu', array($this, 'admin_menu'));
38 38
 			} else {
39
-				add_action( 'admin_menu', array( $this, 'admin_menu' ) );
39
+				add_action('admin_menu', array($this, 'admin_menu'));
40 40
 			}
41
-			add_action( 'admin_init', array( $this, 'registersettings' ) );
42
-            add_filter( 'autoptimize_filter_settingsscreen_tabs', array( $this, 'add_extra_tab' ) );
41
+			add_action('admin_init', array($this, 'registersettings'));
42
+            add_filter('autoptimize_filter_settingsscreen_tabs', array($this, 'add_extra_tab'));
43 43
         } else {
44 44
             $this->run_on_frontend();
45 45
         }
@@ -47,8 +47,8 @@  discard block
 block discarded – undo
47 47
 
48 48
     public static function fetch_options()
49 49
     {
50
-        $value = autoptimizeOption::get_option( 'autoptimize_extra_settings' );
51
-        if ( empty( $value ) ) {
50
+        $value = autoptimizeOption::get_option('autoptimize_extra_settings');
51
+        if (empty($value)) {
52 52
             // Fallback to returning defaults when no stored option exists yet.
53 53
             $value = autoptimizeConfig::get_ao_extra_default_options();
54 54
         }
@@ -59,55 +59,55 @@  discard block
 block discarded – undo
59 59
     public function disable_emojis()
60 60
     {
61 61
         // Removing all actions related to emojis!
62
-        remove_action( 'admin_print_styles', 'print_emoji_styles' );
63
-        remove_action( 'wp_head', 'print_emoji_detection_script', 7 );
64
-        remove_action( 'admin_print_scripts', 'print_emoji_detection_script' );
65
-        remove_action( 'wp_print_styles', 'print_emoji_styles' );
66
-        remove_filter( 'wp_mail', 'wp_staticize_emoji_for_email' );
67
-        remove_filter( 'the_content_feed', 'wp_staticize_emoji' );
68
-        remove_filter( 'comment_text_rss', 'wp_staticize_emoji' );
62
+        remove_action('admin_print_styles', 'print_emoji_styles');
63
+        remove_action('wp_head', 'print_emoji_detection_script', 7);
64
+        remove_action('admin_print_scripts', 'print_emoji_detection_script');
65
+        remove_action('wp_print_styles', 'print_emoji_styles');
66
+        remove_filter('wp_mail', 'wp_staticize_emoji_for_email');
67
+        remove_filter('the_content_feed', 'wp_staticize_emoji');
68
+        remove_filter('comment_text_rss', 'wp_staticize_emoji');
69 69
 
70 70
         // Removes TinyMCE emojis.
71
-        add_filter( 'tiny_mce_plugins', array( $this, 'filter_disable_emojis_tinymce' ) );
71
+        add_filter('tiny_mce_plugins', array($this, 'filter_disable_emojis_tinymce'));
72 72
 
73 73
         // Removes emoji dns-preftech.
74
-        add_filter( 'wp_resource_hints', array( $this, 'filter_remove_emoji_dns_prefetch' ), 10, 2 );
74
+        add_filter('wp_resource_hints', array($this, 'filter_remove_emoji_dns_prefetch'), 10, 2);
75 75
     }
76 76
 
77
-    public function filter_disable_emojis_tinymce( $plugins )
77
+    public function filter_disable_emojis_tinymce($plugins)
78 78
     {
79
-        if ( is_array( $plugins ) ) {
80
-            return array_diff( $plugins, array( 'wpemoji' ) );
79
+        if (is_array($plugins)) {
80
+            return array_diff($plugins, array('wpemoji'));
81 81
         } else {
82 82
             return array();
83 83
         }
84 84
     }
85 85
 
86
-    public function filter_remove_qs( $src )
86
+    public function filter_remove_qs($src)
87 87
     {
88
-        if ( strpos( $src, '?ver=' ) ) {
89
-            $src = remove_query_arg( 'ver', $src );
88
+        if (strpos($src, '?ver=')) {
89
+            $src = remove_query_arg('ver', $src);
90 90
         }
91 91
 
92 92
         return $src;
93 93
     }
94 94
 
95
-    public function extra_async_js( $in )
95
+    public function extra_async_js($in)
96 96
     {
97 97
         $exclusions = array();
98
-        if ( ! empty( $in ) ) {
99
-            $exclusions = array_fill_keys( array_filter( array_map( 'trim', explode( ',', $in ) ) ), '' );
98
+        if (!empty($in)) {
99
+            $exclusions = array_fill_keys(array_filter(array_map('trim', explode(',', $in))), '');
100 100
         }
101 101
 
102 102
         $settings = $this->options['autoptimize_extra_text_field_3'];
103
-        $async    = array_fill_keys( array_filter( array_map( 'trim', explode( ',', $settings ) ) ), '' );
104
-        $attr     = apply_filters( 'autoptimize_filter_extra_async', 'async' );
105
-        foreach ( $async as $k => $v ) {
106
-            $async[ $k ] = $attr;
103
+        $async    = array_fill_keys(array_filter(array_map('trim', explode(',', $settings))), '');
104
+        $attr     = apply_filters('autoptimize_filter_extra_async', 'async');
105
+        foreach ($async as $k => $v) {
106
+            $async[$k] = $attr;
107 107
         }
108 108
 
109 109
         // Merge exclusions & asyncs in one array and return to AO API.
110
-        $merged = array_merge( $exclusions, $async );
110
+        $merged = array_merge($exclusions, $async);
111 111
 
112 112
         return $merged;
113 113
     }
@@ -117,56 +117,56 @@  discard block
 block discarded – undo
117 117
         $options = $this->options;
118 118
 
119 119
         // Disable emojis if specified.
120
-        if ( ! empty( $options['autoptimize_extra_checkbox_field_1'] ) ) {
120
+        if (!empty($options['autoptimize_extra_checkbox_field_1'])) {
121 121
             $this->disable_emojis();
122 122
         }
123 123
 
124 124
         // Remove version query parameters.
125
-        if ( ! empty( $options['autoptimize_extra_checkbox_field_0'] ) ) {
126
-            add_filter( 'script_loader_src', array( $this, 'filter_remove_qs' ), 15, 1 );
127
-            add_filter( 'style_loader_src', array( $this, 'filter_remove_qs' ), 15, 1 );
125
+        if (!empty($options['autoptimize_extra_checkbox_field_0'])) {
126
+            add_filter('script_loader_src', array($this, 'filter_remove_qs'), 15, 1);
127
+            add_filter('style_loader_src', array($this, 'filter_remove_qs'), 15, 1);
128 128
         }
129 129
 
130 130
         // Avoiding conflicts of interest when async-javascript plugin is active!
131
-        $async_js_plugin_active = autoptimizeUtils::is_plugin_active( 'async-javascript/async-javascript.php' );
132
-        if ( ! empty( $options['autoptimize_extra_text_field_3'] ) && ! $async_js_plugin_active ) {
133
-            add_filter( 'autoptimize_filter_js_exclude', array( $this, 'extra_async_js' ), 10, 1 );
131
+        $async_js_plugin_active = autoptimizeUtils::is_plugin_active('async-javascript/async-javascript.php');
132
+        if (!empty($options['autoptimize_extra_text_field_3']) && !$async_js_plugin_active) {
133
+            add_filter('autoptimize_filter_js_exclude', array($this, 'extra_async_js'), 10, 1);
134 134
         }
135 135
 
136 136
         // Optimize google fonts!
137
-        if ( ! empty( $options['autoptimize_extra_radio_field_4'] ) && ( '1' !== $options['autoptimize_extra_radio_field_4'] ) ) {
138
-            add_filter( 'wp_resource_hints', array( $this, 'filter_remove_gfonts_dnsprefetch' ), 10, 2 );
139
-            add_filter( 'autoptimize_html_after_minify', array( $this, 'filter_optimize_google_fonts' ), 10, 1 );
140
-            add_filter( 'autoptimize_extra_filter_tobepreconn', array( $this, 'filter_preconnect_google_fonts' ), 10, 1 );
137
+        if (!empty($options['autoptimize_extra_radio_field_4']) && ('1' !== $options['autoptimize_extra_radio_field_4'])) {
138
+            add_filter('wp_resource_hints', array($this, 'filter_remove_gfonts_dnsprefetch'), 10, 2);
139
+            add_filter('autoptimize_html_after_minify', array($this, 'filter_optimize_google_fonts'), 10, 1);
140
+            add_filter('autoptimize_extra_filter_tobepreconn', array($this, 'filter_preconnect_google_fonts'), 10, 1);
141 141
         }
142 142
 
143 143
         // Preconnect!
144
-        if ( ! empty( $options['autoptimize_extra_text_field_2'] ) || has_filter( 'autoptimize_extra_filter_tobepreconn' ) ) {
145
-            add_filter( 'wp_resource_hints', array( $this, 'filter_preconnect' ), 10, 2 );
144
+        if (!empty($options['autoptimize_extra_text_field_2']) || has_filter('autoptimize_extra_filter_tobepreconn')) {
145
+            add_filter('wp_resource_hints', array($this, 'filter_preconnect'), 10, 2);
146 146
         }
147 147
     }
148 148
 
149
-    public function filter_remove_emoji_dns_prefetch( $urls, $relation_type )
149
+    public function filter_remove_emoji_dns_prefetch($urls, $relation_type)
150 150
     {
151
-        $emoji_svg_url = apply_filters( 'emoji_svg_url', 'https://s.w.org/images/core/emoji/' );
151
+        $emoji_svg_url = apply_filters('emoji_svg_url', 'https://s.w.org/images/core/emoji/');
152 152
 
153
-        return $this->filter_remove_dns_prefetch( $urls, $relation_type, $emoji_svg_url );
153
+        return $this->filter_remove_dns_prefetch($urls, $relation_type, $emoji_svg_url);
154 154
     }
155 155
 
156
-    public function filter_remove_gfonts_dnsprefetch( $urls, $relation_type )
156
+    public function filter_remove_gfonts_dnsprefetch($urls, $relation_type)
157 157
     {
158
-        return $this->filter_remove_dns_prefetch( $urls, $relation_type, 'fonts.googleapis.com' );
158
+        return $this->filter_remove_dns_prefetch($urls, $relation_type, 'fonts.googleapis.com');
159 159
     }
160 160
 
161
-    public function filter_remove_dns_prefetch( $urls, $relation_type, $url_to_remove )
161
+    public function filter_remove_dns_prefetch($urls, $relation_type, $url_to_remove)
162 162
     {
163 163
         $url_to_remove = (string) $url_to_remove;
164 164
 
165
-        if ( ! empty( $url_to_remove ) && 'dns-prefetch' === $relation_type ) {
165
+        if (!empty($url_to_remove) && 'dns-prefetch' === $relation_type) {
166 166
             $cnt = 0;
167
-            foreach ( $urls as $url ) {
168
-                if ( false !== strpos( $url, $url_to_remove ) ) {
169
-                    unset( $urls[ $cnt ] );
167
+            foreach ($urls as $url) {
168
+                if (false !== strpos($url, $url_to_remove)) {
169
+                    unset($urls[$cnt]);
170 170
                 }
171 171
                 $cnt++;
172 172
             }
@@ -175,131 +175,131 @@  discard block
 block discarded – undo
175 175
         return $urls;
176 176
     }
177 177
 
178
-    public function filter_optimize_google_fonts( $in )
178
+    public function filter_optimize_google_fonts($in)
179 179
     {
180 180
         // Extract fonts, partly based on wp rocket's extraction code.
181
-        $markup = preg_replace( '/<!--(.*)-->/Uis', '', $in );
182
-        preg_match_all( '#<link(?:\s+(?:(?!href\s*=\s*)[^>])+)?(?:\s+href\s*=\s*([\'"])((?:https?:)?\/\/fonts\.googleapis\.com\/css(?:(?!\1).)+)\1)(?:\s+[^>]*)?>#iU', $markup, $matches );
181
+        $markup = preg_replace('/<!--(.*)-->/Uis', '', $in);
182
+        preg_match_all('#<link(?:\s+(?:(?!href\s*=\s*)[^>])+)?(?:\s+href\s*=\s*([\'"])((?:https?:)?\/\/fonts\.googleapis\.com\/css(?:(?!\1).)+)\1)(?:\s+[^>]*)?>#iU', $markup, $matches);
183 183
 
184 184
         $fonts_collection = array();
185
-        if ( ! $matches[2] ) {
185
+        if (!$matches[2]) {
186 186
             return $in;
187 187
         }
188 188
 
189 189
         // Store them in $fonts array.
190 190
         $i = 0;
191
-        foreach ( $matches[2] as $font ) {
192
-            if ( ! preg_match( '/rel=["\']dns-prefetch["\']/', $matches[0][ $i ] ) ) {
191
+        foreach ($matches[2] as $font) {
192
+            if (!preg_match('/rel=["\']dns-prefetch["\']/', $matches[0][$i])) {
193 193
                 // Get fonts name.
194
-                $font = str_replace( array( '%7C', '%7c' ), '|', $font );
195
-                $font = explode( 'family=', $font );
196
-                $font = ( isset( $font[1] ) ) ? explode( '&', $font[1] ) : array();
194
+                $font = str_replace(array('%7C', '%7c'), '|', $font);
195
+                $font = explode('family=', $font);
196
+                $font = (isset($font[1])) ? explode('&', $font[1]) : array();
197 197
                 // Add font to $fonts[$i] but make sure not to pollute with an empty family!
198
-                $_thisfont = array_values( array_filter( explode( '|', reset( $font ) ) ) );
199
-                if ( ! empty( $_thisfont ) ) {
200
-                    $fonts_collection[ $i ]['fonts'] = $_thisfont;
198
+                $_thisfont = array_values(array_filter(explode('|', reset($font))));
199
+                if (!empty($_thisfont)) {
200
+                    $fonts_collection[$i]['fonts'] = $_thisfont;
201 201
                     // And add subset if any!
202
-                    $subset = ( is_array( $font ) ) ? end( $font ) : '';
203
-                    if ( false !== strpos( $subset, 'subset=' ) ) {
204
-                        $subset                            = str_replace( array( '%2C', '%2c' ), ',', $subset );
205
-                        $subset                            = explode( 'subset=', $subset );
206
-                        $fonts_collection[ $i ]['subsets'] = explode( ',', $subset[1] );
202
+                    $subset = (is_array($font)) ? end($font) : '';
203
+                    if (false !== strpos($subset, 'subset=')) {
204
+                        $subset                            = str_replace(array('%2C', '%2c'), ',', $subset);
205
+                        $subset                            = explode('subset=', $subset);
206
+                        $fonts_collection[$i]['subsets'] = explode(',', $subset[1]);
207 207
                     }
208 208
                 }
209 209
                 // And remove Google Fonts.
210
-                $in = str_replace( $matches[0][ $i ], '', $in );
210
+                $in = str_replace($matches[0][$i], '', $in);
211 211
             }
212 212
             $i++;
213 213
         }
214 214
 
215 215
         $options      = $this->options;
216 216
         $fonts_markup = '';
217
-        if ( '2' === $options['autoptimize_extra_radio_field_4'] ) {
217
+        if ('2' === $options['autoptimize_extra_radio_field_4']) {
218 218
             // Remove Google Fonts.
219
-            unset( $fonts_collection );
219
+            unset($fonts_collection);
220 220
             return $in;
221
-        } elseif ( '3' === $options['autoptimize_extra_radio_field_4'] || '5' === $options['autoptimize_extra_radio_field_4'] ) {
221
+        } elseif ('3' === $options['autoptimize_extra_radio_field_4'] || '5' === $options['autoptimize_extra_radio_field_4']) {
222 222
             // Aggregate & link!
223 223
             $fonts_string  = '';
224 224
             $subset_string = '';
225
-            foreach ( $fonts_collection as $font ) {
226
-                $fonts_string .= '|' . trim( implode( '|', $font['fonts'] ), '|' );
227
-                if ( ! empty( $font['subsets'] ) ) {
228
-                    $subset_string .= ',' . trim( implode( ',', $font['subsets'] ), ',' );
225
+            foreach ($fonts_collection as $font) {
226
+                $fonts_string .= '|'.trim(implode('|', $font['fonts']), '|');
227
+                if (!empty($font['subsets'])) {
228
+                    $subset_string .= ','.trim(implode(',', $font['subsets']), ',');
229 229
                 }
230 230
             }
231 231
 
232
-            if ( ! empty( $subset_string ) ) {
233
-                $subset_string = str_replace( ',', '%2C', ltrim( $subset_string, ',' ) );
234
-                $fonts_string  = $fonts_string . '&#038;subset=' . $subset_string;
232
+            if (!empty($subset_string)) {
233
+                $subset_string = str_replace(',', '%2C', ltrim($subset_string, ','));
234
+                $fonts_string  = $fonts_string.'&#038;subset='.$subset_string;
235 235
             }
236 236
 
237
-            $fonts_string = apply_filters( 'autoptimize_filter_extra_gfont_fontstring', str_replace( '|', '%7C', ltrim( $fonts_string, '|' ) ) );
237
+            $fonts_string = apply_filters('autoptimize_filter_extra_gfont_fontstring', str_replace('|', '%7C', ltrim($fonts_string, '|')));
238 238
 
239
-            if ( ! empty( $fonts_string ) ) {
240
-                if ( '5' === $options['autoptimize_extra_radio_field_4'] ) {
241
-                    $rel_string = 'rel="preload" as="style" onload="' . autoptimizeConfig::get_ao_css_preload_onload() . '"';
239
+            if (!empty($fonts_string)) {
240
+                if ('5' === $options['autoptimize_extra_radio_field_4']) {
241
+                    $rel_string = 'rel="preload" as="style" onload="'.autoptimizeConfig::get_ao_css_preload_onload().'"';
242 242
                 } else {
243 243
                     $rel_string = 'rel="stylesheet"';
244 244
                 }
245
-                $fonts_markup = '<link ' . $rel_string . ' id="ao_optimized_gfonts" href="https://fonts.googleapis.com/css?family=' . $fonts_string . '" />';
245
+                $fonts_markup = '<link '.$rel_string.' id="ao_optimized_gfonts" href="https://fonts.googleapis.com/css?family='.$fonts_string.'" />';
246 246
             }
247
-        } elseif ( '4' === $options['autoptimize_extra_radio_field_4'] ) {
247
+        } elseif ('4' === $options['autoptimize_extra_radio_field_4']) {
248 248
             // Aggregate & load async (webfont.js impl.)!
249 249
             $fonts_array = array();
250
-            foreach ( $fonts_collection as $_fonts ) {
251
-                if ( ! empty( $_fonts['subsets'] ) ) {
252
-                    $_subset = implode( ',', $_fonts['subsets'] );
253
-                    foreach ( $_fonts['fonts'] as $key => $_one_font ) {
254
-                        $_one_font               = $_one_font . ':' . $_subset;
255
-                        $_fonts['fonts'][ $key ] = $_one_font;
250
+            foreach ($fonts_collection as $_fonts) {
251
+                if (!empty($_fonts['subsets'])) {
252
+                    $_subset = implode(',', $_fonts['subsets']);
253
+                    foreach ($_fonts['fonts'] as $key => $_one_font) {
254
+                        $_one_font               = $_one_font.':'.$_subset;
255
+                        $_fonts['fonts'][$key] = $_one_font;
256 256
                     }
257 257
                 }
258
-                $fonts_array = array_merge( $fonts_array, $_fonts['fonts'] );
258
+                $fonts_array = array_merge($fonts_array, $_fonts['fonts']);
259 259
             }
260 260
 
261
-            $fonts_array          = array_map( 'urldecode', $fonts_array );
262
-            $fonts_markup         = '<script data-cfasync="false" id="ao_optimized_gfonts_config" type="text/javascript">WebFontConfig={google:{families:' . wp_json_encode( $fonts_array ) . ' },classes:false, events:false, timeout:1500};</script>';
261
+            $fonts_array          = array_map('urldecode', $fonts_array);
262
+            $fonts_markup         = '<script data-cfasync="false" id="ao_optimized_gfonts_config" type="text/javascript">WebFontConfig={google:{families:'.wp_json_encode($fonts_array).' },classes:false, events:false, timeout:1500};</script>';
263 263
             $fonts_library_markup = '<script data-cfasync="false" id="ao_optimized_gfonts_webfontloader" type="text/javascript">(function() {var wf = document.createElement(\'script\');wf.src=\'https://ajax.googleapis.com/ajax/libs/webfont/1/webfont.js\';wf.type=\'text/javascript\';wf.async=\'true\';var s=document.getElementsByTagName(\'script\')[0];s.parentNode.insertBefore(wf, s);})();</script>';
264
-            $in                   = substr_replace( $in, $fonts_library_markup . '</head>', strpos( $in, '</head>' ), strlen( '</head>' ) );
264
+            $in                   = substr_replace($in, $fonts_library_markup.'</head>', strpos($in, '</head>'), strlen('</head>'));
265 265
         }
266 266
 
267 267
         // Replace back in markup.
268
-        $inject_point = apply_filters( 'autoptimize_filter_extra_gfont_injectpoint', '<link' );
269
-        $out          = substr_replace( $in, $fonts_markup . $inject_point, strpos( $in, $inject_point ), strlen( $inject_point ) );
270
-        unset( $fonts_collection );
268
+        $inject_point = apply_filters('autoptimize_filter_extra_gfont_injectpoint', '<link');
269
+        $out          = substr_replace($in, $fonts_markup.$inject_point, strpos($in, $inject_point), strlen($inject_point));
270
+        unset($fonts_collection);
271 271
 
272 272
         // and insert preload polyfill if "link preload" and if the polyfill isn't there yet (courtesy of inline&defer).
273 273
         $preload_polyfill = autoptimizeConfig::get_ao_css_preload_polyfill();
274
-        if ( '5' === $options['autoptimize_extra_radio_field_4'] && strpos( $out, $preload_polyfill ) === false ) {
275
-            $out = str_replace( '</body>', $preload_polyfill . '</body>', $out );
274
+        if ('5' === $options['autoptimize_extra_radio_field_4'] && strpos($out, $preload_polyfill) === false) {
275
+            $out = str_replace('</body>', $preload_polyfill.'</body>', $out);
276 276
         }
277 277
         return $out;
278 278
     }
279 279
 
280
-    public function filter_preconnect( $hints, $relation_type )
280
+    public function filter_preconnect($hints, $relation_type)
281 281
     {
282 282
         $options = $this->options;
283 283
 
284 284
         // Get settings and store in array.
285
-        $preconns = array_filter( array_map( 'trim', explode( ',', $options['autoptimize_extra_text_field_2'] ) ) );
286
-        $preconns = apply_filters( 'autoptimize_extra_filter_tobepreconn', $preconns );
285
+        $preconns = array_filter(array_map('trim', explode(',', $options['autoptimize_extra_text_field_2'])));
286
+        $preconns = apply_filters('autoptimize_extra_filter_tobepreconn', $preconns);
287 287
 
288 288
         // Walk array, extract domain and add to new array with crossorigin attribute.
289
-        foreach ( $preconns as $preconn ) {
290
-            $parsed = parse_url( $preconn );
291
-            if ( is_array( $parsed ) && empty( $parsed['scheme'] ) ) {
292
-                $domain = '//' . $parsed['host'];
293
-            } elseif ( is_array( $parsed ) ) {
294
-                $domain = $parsed['scheme'] . '://' . $parsed['host'];
289
+        foreach ($preconns as $preconn) {
290
+            $parsed = parse_url($preconn);
291
+            if (is_array($parsed) && empty($parsed['scheme'])) {
292
+                $domain = '//'.$parsed['host'];
293
+            } elseif (is_array($parsed)) {
294
+                $domain = $parsed['scheme'].'://'.$parsed['host'];
295 295
             }
296 296
 
297
-            if ( ! empty( $domain ) ) {
298
-                $hint = array( 'href' => $domain );
297
+            if (!empty($domain)) {
298
+                $hint = array('href' => $domain);
299 299
                 // Fonts don't get preconnected unless crossorigin flag is set, non-fonts don't get preconnected if origin flag is set
300 300
                 // so hardcode fonts.gstatic.com to come with crossorigin and have filter to add other domains if needed.
301
-                $crossorigins = apply_filters( 'autoptimize_extra_filter_preconn_crossorigin', array( 'https://fonts.gstatic.com' ) );
302
-                if ( in_array( $domain, $crossorigins ) ) {
301
+                $crossorigins = apply_filters('autoptimize_extra_filter_preconn_crossorigin', array('https://fonts.gstatic.com'));
302
+                if (in_array($domain, $crossorigins)) {
303 303
                     $hint['crossorigin'] = 'anonymous';
304 304
                 }
305 305
                 $new_hints[] = $hint;
@@ -307,21 +307,21 @@  discard block
 block discarded – undo
307 307
         }
308 308
 
309 309
         // Merge in WP's preconnect hints.
310
-        if ( 'preconnect' === $relation_type && ! empty( $new_hints ) ) {
311
-            $hints = array_merge( $hints, $new_hints );
310
+        if ('preconnect' === $relation_type && !empty($new_hints)) {
311
+            $hints = array_merge($hints, $new_hints);
312 312
         }
313 313
 
314 314
         return $hints;
315 315
     }
316 316
 
317
-    public function filter_preconnect_google_fonts( $in )
317
+    public function filter_preconnect_google_fonts($in)
318 318
     {
319
-        if ( '2' !== $this->options['autoptimize_extra_radio_field_4'] ) {
319
+        if ('2' !== $this->options['autoptimize_extra_radio_field_4']) {
320 320
             // Preconnect to fonts.gstatic.com unless we remove gfonts.
321 321
             $in[] = 'https://fonts.gstatic.com';
322 322
         }
323 323
 
324
-        if ( '4' === $this->options['autoptimize_extra_radio_field_4'] ) {
324
+        if ('4' === $this->options['autoptimize_extra_radio_field_4']) {
325 325
             // Preconnect even more hosts for webfont.js!
326 326
             $in[] = 'https://ajax.googleapis.com';
327 327
             $in[] = 'https://fonts.googleapis.com';
@@ -338,17 +338,17 @@  discard block
 block discarded – undo
338 338
             'autoptimize_extra',
339 339
             'manage_options',
340 340
             'autoptimize_extra',
341
-            array( $this, 'options_page' )
341
+            array($this, 'options_page')
342 342
         );
343 343
     }
344 344
 	
345 345
 	public function registersettings() {
346
-		register_setting( 'autoptimize_extra_settings', 'autoptimize_extra_settings' );
346
+		register_setting('autoptimize_extra_settings', 'autoptimize_extra_settings');
347 347
 	}
348 348
 
349
-    public function add_extra_tab( $in )
349
+    public function add_extra_tab($in)
350 350
     {
351
-        $in = array_merge( $in, array( 'autoptimize_extra' => __( 'Extra', 'autoptimize' ) ) );
351
+        $in = array_merge($in, array('autoptimize_extra' => __('Extra', 'autoptimize')));
352 352
 
353 353
         return $in;
354 354
     }
@@ -368,87 +368,87 @@  discard block
 block discarded – undo
368 368
         #autoptimize_extra_descr{font-size: 120%;}
369 369
     </style>
370 370
     <div class="wrap">
371
-    <h1><?php _e( 'Autoptimize Settings', 'autoptimize' ); ?></h1>
371
+    <h1><?php _e('Autoptimize Settings', 'autoptimize'); ?></h1>
372 372
         <?php echo autoptimizeConfig::ao_admin_tabs(); ?>
373
-        <?php if ( 'on' !== autoptimizeOption::get_option( 'autoptimize_js' ) && 'on' !== autoptimizeOption::get_option( 'autoptimize_css' ) && 'on' !== autoptimizeOption::get_option( 'autoptimize_html' ) && ! autoptimizeImages::imgopt_active() ) { ?>
373
+        <?php if ('on' !== autoptimizeOption::get_option('autoptimize_js') && 'on' !== autoptimizeOption::get_option('autoptimize_css') && 'on' !== autoptimizeOption::get_option('autoptimize_html') && !autoptimizeImages::imgopt_active()) { ?>
374 374
             <div class="notice-warning notice"><p>
375
-            <?php _e( 'Most of below Extra optimizations require at least one of HTML, JS, CSS or Image autoptimizations being active.', 'autoptimize' ); ?>
375
+            <?php _e('Most of below Extra optimizations require at least one of HTML, JS, CSS or Image autoptimizations being active.', 'autoptimize'); ?>
376 376
             </p></div>
377 377
         <?php } ?>
378 378
 
379
-    <form id='ao_settings_form' action='<?php echo admin_url( 'options.php' ); ?>' method='post'>
380
-        <?php settings_fields( 'autoptimize_extra_settings' ); ?>
381
-        <h2><?php _e( 'Extra Auto-Optimizations', 'autoptimize' ); ?></h2>
382
-        <span id='autoptimize_extra_descr'><?php _e( 'The following settings can improve your site\'s performance even more.', 'autoptimize' ); ?></span>
379
+    <form id='ao_settings_form' action='<?php echo admin_url('options.php'); ?>' method='post'>
380
+        <?php settings_fields('autoptimize_extra_settings'); ?>
381
+        <h2><?php _e('Extra Auto-Optimizations', 'autoptimize'); ?></h2>
382
+        <span id='autoptimize_extra_descr'><?php _e('The following settings can improve your site\'s performance even more.', 'autoptimize'); ?></span>
383 383
         <table class="form-table">
384 384
             <tr>
385
-                <th scope="row"><?php _e( 'Google Fonts', 'autoptimize' ); ?></th>
385
+                <th scope="row"><?php _e('Google Fonts', 'autoptimize'); ?></th>
386 386
                 <td>
387
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="1" <?php if ( ! in_array( $gfonts, array( 2, 3, 4, 5 ) ) ) { echo 'checked'; } ?> ><?php _e( 'Leave as is', 'autoptimize' ); ?><br/>
388
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="2" <?php checked( 2, $gfonts, true ); ?> ><?php _e( 'Remove Google Fonts', 'autoptimize' ); ?><br/>
389
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="3" <?php checked( 3, $gfonts, true ); ?> ><?php _e( 'Combine and link in head (fonts load fast but are render-blocking)', 'autoptimize' ); ?><br/>
390
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="5" <?php checked( 5, $gfonts, true ); ?> ><?php _e( 'Combine and preload in head (fonts load late, but are not render-blocking)', 'autoptimize' ); ?><br/>
391
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="4" <?php checked( 4, $gfonts, true ); ?> ><?php _e( 'Combine and load fonts asynchronously with <a href="https://github.com/typekit/webfontloader#readme" target="_blank">webfont.js</a>', 'autoptimize' ); ?><br/>
387
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="1" <?php if (!in_array($gfonts, array(2, 3, 4, 5))) { echo 'checked'; } ?> ><?php _e('Leave as is', 'autoptimize'); ?><br/>
388
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="2" <?php checked(2, $gfonts, true); ?> ><?php _e('Remove Google Fonts', 'autoptimize'); ?><br/>
389
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="3" <?php checked(3, $gfonts, true); ?> ><?php _e('Combine and link in head (fonts load fast but are render-blocking)', 'autoptimize'); ?><br/>
390
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="5" <?php checked(5, $gfonts, true); ?> ><?php _e('Combine and preload in head (fonts load late, but are not render-blocking)', 'autoptimize'); ?><br/>
391
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="4" <?php checked(4, $gfonts, true); ?> ><?php _e('Combine and load fonts asynchronously with <a href="https://github.com/typekit/webfontloader#readme" target="_blank">webfont.js</a>', 'autoptimize'); ?><br/>
392 392
                 </td>
393 393
             </tr>
394 394
             <tr>
395
-                <th scope="row"><?php _e( 'Remove emojis', 'autoptimize' ); ?></th>
395
+                <th scope="row"><?php _e('Remove emojis', 'autoptimize'); ?></th>
396 396
                 <td>
397
-                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_1]' <?php if ( ! empty( $options['autoptimize_extra_checkbox_field_1'] ) && '1' === $options['autoptimize_extra_checkbox_field_1'] ) { echo 'checked="checked"'; } ?> value='1'><?php _e( 'Removes WordPress\' core emojis\' inline CSS, inline JavaScript, and an otherwise un-autoptimized JavaScript file.', 'autoptimize' ); ?></label>
397
+                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_1]' <?php if (!empty($options['autoptimize_extra_checkbox_field_1']) && '1' === $options['autoptimize_extra_checkbox_field_1']) { echo 'checked="checked"'; } ?> value='1'><?php _e('Removes WordPress\' core emojis\' inline CSS, inline JavaScript, and an otherwise un-autoptimized JavaScript file.', 'autoptimize'); ?></label>
398 398
                 </td>
399 399
             </tr>
400 400
             <tr>
401
-                <th scope="row"><?php _e( 'Remove query strings from static resources', 'autoptimize' ); ?></th>
401
+                <th scope="row"><?php _e('Remove query strings from static resources', 'autoptimize'); ?></th>
402 402
                 <td>
403
-                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_0]' <?php if ( ! empty( $options['autoptimize_extra_checkbox_field_0'] ) && '1' === $options['autoptimize_extra_checkbox_field_0'] ) { echo 'checked="checked"'; } ?> value='1'><?php _e( 'Removing query strings (or more specifically the <code>ver</code> parameter) will not improve load time, but might improve performance scores.', 'autoptimize' ); ?></label>
403
+                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_0]' <?php if (!empty($options['autoptimize_extra_checkbox_field_0']) && '1' === $options['autoptimize_extra_checkbox_field_0']) { echo 'checked="checked"'; } ?> value='1'><?php _e('Removing query strings (or more specifically the <code>ver</code> parameter) will not improve load time, but might improve performance scores.', 'autoptimize'); ?></label>
404 404
                 </td>
405 405
             </tr>
406 406
             <tr>
407
-                <th scope="row"><?php _e( 'Preconnect to 3rd party domains <em>(advanced users)</em>', 'autoptimize' ); ?></th>
407
+                <th scope="row"><?php _e('Preconnect to 3rd party domains <em>(advanced users)</em>', 'autoptimize'); ?></th>
408 408
                 <td>
409
-                    <label><input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_2]' value='<?php if ( array_key_exists( 'autoptimize_extra_text_field_2', $options ) ) { echo esc_attr( $options['autoptimize_extra_text_field_2'] ); } ?>'><br /><?php _e( 'Add 3rd party domains you want the browser to <a href="https://www.keycdn.com/support/preconnect/#primary" target="_blank">preconnect</a> to, separated by comma\'s. Make sure to include the correct protocol (HTTP or HTTPS).', 'autoptimize' ); ?></label>
409
+                    <label><input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_2]' value='<?php if (array_key_exists('autoptimize_extra_text_field_2', $options)) { echo esc_attr($options['autoptimize_extra_text_field_2']); } ?>'><br /><?php _e('Add 3rd party domains you want the browser to <a href="https://www.keycdn.com/support/preconnect/#primary" target="_blank">preconnect</a> to, separated by comma\'s. Make sure to include the correct protocol (HTTP or HTTPS).', 'autoptimize'); ?></label>
410 410
                 </td>
411 411
             </tr>
412 412
             <tr>
413
-                <th scope="row"><?php _e( 'Async Javascript-files <em>(advanced users)</em>', 'autoptimize' ); ?></th>
413
+                <th scope="row"><?php _e('Async Javascript-files <em>(advanced users)</em>', 'autoptimize'); ?></th>
414 414
                 <td>
415 415
                     <?php
416
-                    if ( autoptimizeUtils::is_plugin_active( 'async-javascript/async-javascript.php' ) ) {
416
+                    if (autoptimizeUtils::is_plugin_active('async-javascript/async-javascript.php')) {
417 417
                         // translators: link points Async Javascript settings page.
418
-                        printf( __( 'You have "Async JavaScript" installed, %1$sconfiguration of async javascript is best done there%2$s.', 'autoptimize' ), '<a href="' . 'options-general.php?page=async-javascript' . '">', '</a>' );
418
+                        printf(__('You have "Async JavaScript" installed, %1$sconfiguration of async javascript is best done there%2$s.', 'autoptimize'), '<a href="'.'options-general.php?page=async-javascript'.'">', '</a>');
419 419
                     } else {
420 420
                     ?>
421
-                        <input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_3]' value='<?php if ( array_key_exists( 'autoptimize_extra_text_field_3', $options ) ) { echo esc_attr( $options['autoptimize_extra_text_field_3'] ); } ?>'>
421
+                        <input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_3]' value='<?php if (array_key_exists('autoptimize_extra_text_field_3', $options)) { echo esc_attr($options['autoptimize_extra_text_field_3']); } ?>'>
422 422
                         <br />
423 423
                         <?php
424
-                            _e( 'Comma-separated list of local or 3rd party JS-files that should loaded with the <code>async</code> flag. JS-files from your own site will be automatically excluded if added here. ', 'autoptimize' );
424
+                            _e('Comma-separated list of local or 3rd party JS-files that should loaded with the <code>async</code> flag. JS-files from your own site will be automatically excluded if added here. ', 'autoptimize');
425 425
                             // translators: %s will be replaced by a link to the "async javascript" plugin.
426
-                            echo sprintf( __( 'Configuration of async javascript is easier and more flexible using the %s plugin.', 'autoptimize' ), '"<a href="https://wordpress.org/plugins/async-javascript" target="_blank">Async Javascript</a>"' );
427
-                            $asj_install_url = network_admin_url() . 'plugin-install.php?s=async+javascript&tab=search&type=term';
428
-                            echo sprintf( ' <a href="' . $asj_install_url . '">%s</a>', __( 'Click here to install and activate it.', 'autoptimize' ) );
426
+                            echo sprintf(__('Configuration of async javascript is easier and more flexible using the %s plugin.', 'autoptimize'), '"<a href="https://wordpress.org/plugins/async-javascript" target="_blank">Async Javascript</a>"');
427
+                            $asj_install_url = network_admin_url().'plugin-install.php?s=async+javascript&tab=search&type=term';
428
+                            echo sprintf(' <a href="'.$asj_install_url.'">%s</a>', __('Click here to install and activate it.', 'autoptimize'));
429 429
                     }
430 430
                     ?>
431 431
                 </td>
432 432
             </tr>
433 433
             <tr>
434
-                <th scope="row"><?php _e( 'Optimize YouTube videos', 'autoptimize' ); ?></th>
434
+                <th scope="row"><?php _e('Optimize YouTube videos', 'autoptimize'); ?></th>
435 435
                 <td>
436 436
                     <?php
437
-                    if ( autoptimizeUtils::is_plugin_active( 'wp-youtube-lyte/wp-youtube-lyte.php' ) ) {
438
-                        _e( 'Great, you have WP YouTube Lyte installed.', 'autoptimize' );
437
+                    if (autoptimizeUtils::is_plugin_active('wp-youtube-lyte/wp-youtube-lyte.php')) {
438
+                        _e('Great, you have WP YouTube Lyte installed.', 'autoptimize');
439 439
                         $lyte_config_url = 'options-general.php?page=lyte_settings_page';
440
-                        echo sprintf( ' <a href="' . $lyte_config_url . '">%s</a>', __( 'Click here to configure it.', 'autoptimize' ) );
440
+                        echo sprintf(' <a href="'.$lyte_config_url.'">%s</a>', __('Click here to configure it.', 'autoptimize'));
441 441
                     } else {
442 442
                         // translators: %s will be replaced by a link to "wp youtube lyte" plugin.
443
-                        echo sprintf( __( '%s allows you to “lazy load” your videos, by inserting responsive “Lite YouTube Embeds". ', 'autoptimize' ), '<a href="https://wordpress.org/plugins/wp-youtube-lyte" target="_blank">WP YouTube Lyte</a>' );
444
-                        $lyte_install_url = network_admin_url() . 'plugin-install.php?s=lyte&tab=search&type=term';
445
-                        echo sprintf( ' <a href="' . $lyte_install_url . '">%s</a>', __( 'Click here to install and activate it.', 'autoptimize' ) );
443
+                        echo sprintf(__('%s allows you to “lazy load” your videos, by inserting responsive “Lite YouTube Embeds". ', 'autoptimize'), '<a href="https://wordpress.org/plugins/wp-youtube-lyte" target="_blank">WP YouTube Lyte</a>');
444
+                        $lyte_install_url = network_admin_url().'plugin-install.php?s=lyte&tab=search&type=term';
445
+                        echo sprintf(' <a href="'.$lyte_install_url.'">%s</a>', __('Click here to install and activate it.', 'autoptimize'));
446 446
                     }
447 447
                     ?>
448 448
                 </td>
449 449
             </tr>
450 450
         </table>
451
-        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e( 'Save Changes', 'autoptimize' ); ?>" /></p>
451
+        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e('Save Changes', 'autoptimize'); ?>" /></p>
452 452
     </form>
453 453
         <?php
454 454
     }
Please login to merge, or discard this patch.