Completed
Pull Request — master (#184)
by
unknown
01:40
created
classes/autoptimizeConfig.php 1 patch
Spacing   +182 added lines, -182 removed lines patch added patch discarded remove patch
@@ -1,5 +1,5 @@  discard block
 block discarded – undo
1 1
 <?php
2
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
2
+if (!defined('ABSPATH')) exit; // Exit if accessed directly
3 3
 
4 4
 class autoptimizeConfig {
5 5
     private $config = null;
@@ -7,25 +7,25 @@  discard block
 block discarded – undo
7 7
 
8 8
     //Singleton: private construct
9 9
     private function __construct() {
10
-        if( is_admin() ) {
10
+        if (is_admin()) {
11 11
             //Add the admin page and settings
12
-            add_action('admin_menu',array($this,'addmenu'));
13
-            add_action('admin_init',array($this,'registersettings'));
12
+            add_action('admin_menu', array($this, 'addmenu'));
13
+            add_action('admin_init', array($this, 'registersettings'));
14 14
 
15 15
             //Set meta info
16
-            if(function_exists('plugin_row_meta')) {
16
+            if (function_exists('plugin_row_meta')) {
17 17
                 //2.8+
18
-                add_filter('plugin_row_meta',array($this,'setmeta'),10,2);
19
-            } elseif(function_exists('post_class')) {
18
+                add_filter('plugin_row_meta', array($this, 'setmeta'), 10, 2);
19
+            } elseif (function_exists('post_class')) {
20 20
                 //2.7
21 21
                 $plugin = plugin_basename(AUTOPTIMIZE_PLUGIN_DIR.'autoptimize.php');
22
-                add_filter('plugin_action_links_'.$plugin,array($this,'setmeta'));
22
+                add_filter('plugin_action_links_'.$plugin, array($this, 'setmeta'));
23 23
             }
24 24
 
25 25
             //Clean cache?
26
-            if(get_option('autoptimize_cache_clean')) {
26
+            if (get_option('autoptimize_cache_clean')) {
27 27
                 autoptimizeCache::clearall();
28
-                update_option('autoptimize_cache_clean',0);
28
+                update_option('autoptimize_cache_clean', 0);
29 29
             }
30 30
         }
31 31
 
@@ -159,31 +159,31 @@  discard block
 block discarded – undo
159 159
 <div class="wrap">
160 160
 
161 161
 <?php if (version_compare(PHP_VERSION, '5.3.0') < 0) { ?>
162
-<div class="notice-error notice"><?php echo '<p>' . sprintf( __('<strong>You are using a very old version of PHP</strong> which will not be supported as from the upcoming Autoptimize 2.4 any more, cfr. <a href=%s>this blogpost for more info</a>. please ask your hoster to provide you with an upgrade path to 7.x.','autoptimize'), '"https://blog.futtta.be/2018/02/13/introducing-zytzagoos-major-changes-for-autoptimize-2-4/" target="_blank"' ) . '</p>'; ?></div>
162
+<div class="notice-error notice"><?php echo '<p>'.sprintf(__('<strong>You are using a very old version of PHP</strong> which will not be supported as from the upcoming Autoptimize 2.4 any more, cfr. <a href=%s>this blogpost for more info</a>. please ask your hoster to provide you with an upgrade path to 7.x.', 'autoptimize'), '"https://blog.futtta.be/2018/02/13/introducing-zytzagoos-major-changes-for-autoptimize-2-4/" target="_blank"').'</p>'; ?></div>
163 163
 <?php } ?>
164 164
 
165 165
 <?php if (defined('AUTOPTIMIZE_LEGACY_MINIFIERS')) { ?>
166
-<div class="notice-error notice"><?php echo '<p>' . sprintf( __('You are forcing Autoptimize to use the "legacy minifiers" by setting the AUTOPTIMIZE_LEGACY_MINIFIERS constant in /wp-config.php. The "legacy minifiers" will not be supported as from the upcoming Autoptimize 2.4 any more, cfr. <a href=%s>this blogpost for more info</a>.','autoptimize'), '"https://blog.futtta.be/2018/02/13/introducing-zytzagoos-major-changes-for-autoptimize-2-4/" target="_blank"') . '</p>'; ?></div>
166
+<div class="notice-error notice"><?php echo '<p>'.sprintf(__('You are forcing Autoptimize to use the "legacy minifiers" by setting the AUTOPTIMIZE_LEGACY_MINIFIERS constant in /wp-config.php. The "legacy minifiers" will not be supported as from the upcoming Autoptimize 2.4 any more, cfr. <a href=%s>this blogpost for more info</a>.', 'autoptimize'), '"https://blog.futtta.be/2018/02/13/introducing-zytzagoos-major-changes-for-autoptimize-2-4/" target="_blank"').'</p>'; ?></div>
167 167
 <?php } ?>
168 168
 
169 169
 <div id="autoptimize_main">
170 170
 <div id="ao_title_and_button">
171
-    <h1 id="ao_title"><?php _e('Autoptimize Settings','autoptimize'); ?>
171
+    <h1 id="ao_title"><?php _e('Autoptimize Settings', 'autoptimize'); ?>
172 172
     <span id="ao_adv_button">
173 173
     <?php 
174
-    if (get_option('autoptimize_show_adv','0')=='1') {
174
+    if (get_option('autoptimize_show_adv', '0') == '1') {
175 175
         ?>
176
-        <a href="javascript:void(0);" id="ao_show_adv" class="button" style="display:none;"><span><?php _e("Show advanced settings","autoptimize") ?></span></a>
177
-        <a href="javascript:void(0);" id="ao_hide_adv" class="button"><span><?php _e("Hide advanced settings","autoptimize") ?></span></a>
176
+        <a href="javascript:void(0);" id="ao_show_adv" class="button" style="display:none;"><span><?php _e("Show advanced settings", "autoptimize") ?></span></a>
177
+        <a href="javascript:void(0);" id="ao_hide_adv" class="button"><span><?php _e("Hide advanced settings", "autoptimize") ?></span></a>
178 178
         <style>tr.ao_adv{display:table-row;} li.ao_adv{display:list-item;}</style>
179 179
         <?php
180
-        $hiddenClass="";
180
+        $hiddenClass = "";
181 181
     } else {
182 182
         ?>
183
-        <a href="javascript:void(0);" id="ao_show_adv" class="button"><span><?php _e("Show advanced settings","autoptimize") ?></span></a>
184
-        <a href="javascript:void(0);" id="ao_hide_adv" class="button" style="display:none;"><span><?php _e("Hide advanced settings","autoptimize") ?></span></a>
183
+        <a href="javascript:void(0);" id="ao_show_adv" class="button"><span><?php _e("Show advanced settings", "autoptimize") ?></span></a>
184
+        <a href="javascript:void(0);" id="ao_hide_adv" class="button" style="display:none;"><span><?php _e("Hide advanced settings", "autoptimize") ?></span></a>
185 185
         <?php
186
-        $hiddenClass="hidden ";
186
+        $hiddenClass = "hidden ";
187 187
     }
188 188
     ?>
189 189
     </span>
@@ -198,158 +198,158 @@  discard block
 block discarded – undo
198 198
 <ul>
199 199
 
200 200
 <li class="itemDetail">
201
-<h2 class="itemTitle"><?php _e('HTML Options','autoptimize'); ?></h2>
201
+<h2 class="itemTitle"><?php _e('HTML Options', 'autoptimize'); ?></h2>
202 202
 <table class="form-table">
203 203
 <tr valign="top">
204
-<th scope="row"><?php _e('Optimize HTML Code?','autoptimize'); ?></th>
205
-<td><input type="checkbox" id="autoptimize_html" name="autoptimize_html" <?php echo get_option('autoptimize_html')?'checked="checked" ':''; ?>/></td>
204
+<th scope="row"><?php _e('Optimize HTML Code?', 'autoptimize'); ?></th>
205
+<td><input type="checkbox" id="autoptimize_html" name="autoptimize_html" <?php echo get_option('autoptimize_html') ? 'checked="checked" ' : ''; ?>/></td>
206 206
 </tr>
207
-<tr class="<?php echo $hiddenClass;?>html_sub ao_adv" valign="top">
208
-<th scope="row"><?php _e('Keep HTML comments?','autoptimize'); ?></th>
209
-<td><label class="cb_label"><input type="checkbox" name="autoptimize_html_keepcomments" <?php echo get_option('autoptimize_html_keepcomments')?'checked="checked" ':''; ?>/>
210
-<?php _e('Enable this if you want HTML comments to remain in the page.','autoptimize'); ?></label></td>
207
+<tr class="<?php echo $hiddenClass; ?>html_sub ao_adv" valign="top">
208
+<th scope="row"><?php _e('Keep HTML comments?', 'autoptimize'); ?></th>
209
+<td><label class="cb_label"><input type="checkbox" name="autoptimize_html_keepcomments" <?php echo get_option('autoptimize_html_keepcomments') ? 'checked="checked" ' : ''; ?>/>
210
+<?php _e('Enable this if you want HTML comments to remain in the page.', 'autoptimize'); ?></label></td>
211 211
 </tr>
212 212
 </table>
213 213
 </li>
214 214
 
215 215
 <li class="itemDetail">
216
-<h2 class="itemTitle"><?php _e('JavaScript Options','autoptimize'); ?></h2>
216
+<h2 class="itemTitle"><?php _e('JavaScript Options', 'autoptimize'); ?></h2>
217 217
 <table class="form-table"> 
218 218
 <tr valign="top">
219
-<th scope="row"><?php _e('Optimize JavaScript Code?','autoptimize'); ?></th>
220
-<td><input type="checkbox" id="autoptimize_js" name="autoptimize_js" <?php echo get_option('autoptimize_js')?'checked="checked" ':''; ?>/></td>
219
+<th scope="row"><?php _e('Optimize JavaScript Code?', 'autoptimize'); ?></th>
220
+<td><input type="checkbox" id="autoptimize_js" name="autoptimize_js" <?php echo get_option('autoptimize_js') ? 'checked="checked" ' : ''; ?>/></td>
221 221
 </tr>
222
-<tr valign="top" class="<?php echo $hiddenClass;?>js_sub ao_adv">
223
-<th scope="row"><?php _e('Force JavaScript in &lt;head&gt;?','autoptimize'); ?></th>
224
-<td><label class="cb_label"><input type="checkbox" name="autoptimize_js_forcehead" <?php echo get_option('autoptimize_js_forcehead')?'checked="checked" ':''; ?>/>
225
-<?php _e('Load JavaScript early, this can potentially fix some JS-errors, but makes the JS render blocking.','autoptimize'); ?></label></td>
222
+<tr valign="top" class="<?php echo $hiddenClass; ?>js_sub ao_adv">
223
+<th scope="row"><?php _e('Force JavaScript in &lt;head&gt;?', 'autoptimize'); ?></th>
224
+<td><label class="cb_label"><input type="checkbox" name="autoptimize_js_forcehead" <?php echo get_option('autoptimize_js_forcehead') ? 'checked="checked" ' : ''; ?>/>
225
+<?php _e('Load JavaScript early, this can potentially fix some JS-errors, but makes the JS render blocking.', 'autoptimize'); ?></label></td>
226 226
 </tr>
227 227
 <?php if (get_option('autoptimize_js_justhead')) { ?>
228
-<tr valign="top" class="<?php echo $hiddenClass;?>js_sub ao_adv">
229
-<th scope="row"><?php _e('Look for scripts only in &lt;head&gt;?','autoptimize'); echo ' <i>'. __('(deprecated)','autoptimize') . '</i>'; ?></th>
230
-<td><label class="cb_label"><input type="checkbox" name="autoptimize_js_justhead" <?php echo get_option('autoptimize_js_justhead')?'checked="checked" ':''; ?>/>
231
-<?php _e('Mostly useful in combination with previous option when using jQuery-based templates, but might help keeping cache size under control.','autoptimize'); ?></label></td>
228
+<tr valign="top" class="<?php echo $hiddenClass; ?>js_sub ao_adv">
229
+<th scope="row"><?php _e('Look for scripts only in &lt;head&gt;?', 'autoptimize'); echo ' <i>'.__('(deprecated)', 'autoptimize').'</i>'; ?></th>
230
+<td><label class="cb_label"><input type="checkbox" name="autoptimize_js_justhead" <?php echo get_option('autoptimize_js_justhead') ? 'checked="checked" ' : ''; ?>/>
231
+<?php _e('Mostly useful in combination with previous option when using jQuery-based templates, but might help keeping cache size under control.', 'autoptimize'); ?></label></td>
232 232
 </tr>
233 233
 <?php } ?>
234
-<tr valign="top" class="<?php echo $hiddenClass;?>js_sub ao_adv">
235
-<th scope="row"><?php _e('Also aggregate inline JS?','autoptimize'); ?></th>
236
-<td><label class="cb_label"><input type="checkbox" name="autoptimize_js_include_inline" <?php echo get_option('autoptimize_js_include_inline')?'checked="checked" ':''; ?>/>
237
-<?php _e('Let Autoptimize also extract JS from the HTML. <strong>Warning</strong>: this can make Autoptimize\'s cache size grow quickly, so only enable this if you know what you\'re doing.','autoptimize'); ?></label></td>
234
+<tr valign="top" class="<?php echo $hiddenClass; ?>js_sub ao_adv">
235
+<th scope="row"><?php _e('Also aggregate inline JS?', 'autoptimize'); ?></th>
236
+<td><label class="cb_label"><input type="checkbox" name="autoptimize_js_include_inline" <?php echo get_option('autoptimize_js_include_inline') ? 'checked="checked" ' : ''; ?>/>
237
+<?php _e('Let Autoptimize also extract JS from the HTML. <strong>Warning</strong>: this can make Autoptimize\'s cache size grow quickly, so only enable this if you know what you\'re doing.', 'autoptimize'); ?></label></td>
238 238
 </tr>
239
-<tr valign="top" class="<?php echo $hiddenClass;?>js_sub ao_adv">
240
-<th scope="row"><?php _e('Exclude scripts from Autoptimize:','autoptimize'); ?></th>
241
-<td><label><input type="text" style="width:100%;" name="autoptimize_js_exclude" value="<?php echo get_option('autoptimize_js_exclude',"seal.js, js/jquery/jquery.js"); ?>"/><br />
242
-<?php _e('A comma-separated list of scripts you want to exclude from being optimized, for example \'whatever.js, another.js\' (without the quotes) to exclude those scripts from being aggregated and minimized by Autoptimize.','autoptimize'); ?></label></td>
239
+<tr valign="top" class="<?php echo $hiddenClass; ?>js_sub ao_adv">
240
+<th scope="row"><?php _e('Exclude scripts from Autoptimize:', 'autoptimize'); ?></th>
241
+<td><label><input type="text" style="width:100%;" name="autoptimize_js_exclude" value="<?php echo get_option('autoptimize_js_exclude', "seal.js, js/jquery/jquery.js"); ?>"/><br />
242
+<?php _e('A comma-separated list of scripts you want to exclude from being optimized, for example \'whatever.js, another.js\' (without the quotes) to exclude those scripts from being aggregated and minimized by Autoptimize.', 'autoptimize'); ?></label></td>
243 243
 </tr>
244
-<tr valign="top" class="<?php echo $hiddenClass;?>js_sub ao_adv">
245
-<th scope="row"><?php _e('Add try-catch wrapping?','autoptimize'); ?></th>
246
-<td><label class="cb_label"><input type="checkbox" name="autoptimize_js_trycatch" <?php echo get_option('autoptimize_js_trycatch')?'checked="checked" ':''; ?>/>
247
-<?php _e('If your scripts break because of a JS-error, you might want to try this.','autoptimize'); ?></label></td>
244
+<tr valign="top" class="<?php echo $hiddenClass; ?>js_sub ao_adv">
245
+<th scope="row"><?php _e('Add try-catch wrapping?', 'autoptimize'); ?></th>
246
+<td><label class="cb_label"><input type="checkbox" name="autoptimize_js_trycatch" <?php echo get_option('autoptimize_js_trycatch') ? 'checked="checked" ' : ''; ?>/>
247
+<?php _e('If your scripts break because of a JS-error, you might want to try this.', 'autoptimize'); ?></label></td>
248 248
 </tr>
249 249
 </table>
250 250
 </li>
251 251
 
252 252
 <li class="itemDetail">
253
-<h2 class="itemTitle"><?php _e('CSS Options','autoptimize'); ?></h2>
253
+<h2 class="itemTitle"><?php _e('CSS Options', 'autoptimize'); ?></h2>
254 254
 <table class="form-table"> 
255 255
 <tr valign="top">
256
-<th scope="row"><?php _e('Optimize CSS Code?','autoptimize'); ?></th>
257
-<td><input type="checkbox" id="autoptimize_css" name="autoptimize_css" <?php echo get_option('autoptimize_css')?'checked="checked" ':''; ?>/></td>
256
+<th scope="row"><?php _e('Optimize CSS Code?', 'autoptimize'); ?></th>
257
+<td><input type="checkbox" id="autoptimize_css" name="autoptimize_css" <?php echo get_option('autoptimize_css') ? 'checked="checked" ' : ''; ?>/></td>
258 258
 </tr>
259
-<tr class="<?php echo $hiddenClass;?>css_sub ao_adv" valign="top">
260
-<th scope="row"><?php _e('Generate data: URIs for images?','autoptimize'); ?></th>
261
-<td><label class="cb_label"><input type="checkbox" name="autoptimize_css_datauris" <?php echo get_option('autoptimize_css_datauris')?'checked="checked" ':''; ?>/>
262
-<?php _e('Enable this to include small background-images in the CSS itself instead of as separate downloads.','autoptimize'); ?></label></td>
259
+<tr class="<?php echo $hiddenClass; ?>css_sub ao_adv" valign="top">
260
+<th scope="row"><?php _e('Generate data: URIs for images?', 'autoptimize'); ?></th>
261
+<td><label class="cb_label"><input type="checkbox" name="autoptimize_css_datauris" <?php echo get_option('autoptimize_css_datauris') ? 'checked="checked" ' : ''; ?>/>
262
+<?php _e('Enable this to include small background-images in the CSS itself instead of as separate downloads.', 'autoptimize'); ?></label></td>
263 263
 </tr>
264 264
 <?php if (get_option('autoptimize_css_justhead')) { ?>
265
-<tr valign="top" class="<?php echo $hiddenClass;?>css_sub ao_adv">
266
-<th scope="row"><?php _e('Look for styles only in &lt;head&gt;?','autoptimize'); echo ' <i>'. __('(deprecated)','autoptimize') . '</i>'; ?></th>
267
-<td><label class="cb_label"><input type="checkbox" name="autoptimize_css_justhead" <?php echo get_option('autoptimize_css_justhead')?'checked="checked" ':''; ?>/>
268
-<?php _e('Don\'t autoptimize CSS outside the head-section. If the cache gets big, you might want to enable this.','autoptimize'); ?></label></td>
265
+<tr valign="top" class="<?php echo $hiddenClass; ?>css_sub ao_adv">
266
+<th scope="row"><?php _e('Look for styles only in &lt;head&gt;?', 'autoptimize'); echo ' <i>'.__('(deprecated)', 'autoptimize').'</i>'; ?></th>
267
+<td><label class="cb_label"><input type="checkbox" name="autoptimize_css_justhead" <?php echo get_option('autoptimize_css_justhead') ? 'checked="checked" ' : ''; ?>/>
268
+<?php _e('Don\'t autoptimize CSS outside the head-section. If the cache gets big, you might want to enable this.', 'autoptimize'); ?></label></td>
269 269
 </tr>
270 270
 <?php } ?>
271
-<tr valign="top" class="<?php echo $hiddenClass;?>css_sub ao_adv">
272
-<th scope="row"><?php _e('Also aggregate inline CSS?','autoptimize'); ?></th>
273
-<td><label class="cb_label"><input type="checkbox" name="autoptimize_css_include_inline" <?php echo get_option('autoptimize_css_include_inline','1')?'checked="checked" ':''; ?>/>
274
-<?php _e('Check this option for Autoptimize to also aggregate CSS in the HTML.','autoptimize'); ?></label></td>
271
+<tr valign="top" class="<?php echo $hiddenClass; ?>css_sub ao_adv">
272
+<th scope="row"><?php _e('Also aggregate inline CSS?', 'autoptimize'); ?></th>
273
+<td><label class="cb_label"><input type="checkbox" name="autoptimize_css_include_inline" <?php echo get_option('autoptimize_css_include_inline', '1') ? 'checked="checked" ' : ''; ?>/>
274
+<?php _e('Check this option for Autoptimize to also aggregate CSS in the HTML.', 'autoptimize'); ?></label></td>
275 275
 </tr>
276
-<tr valign="top" class="<?php echo $hiddenClass;?>css_sub ao_adv">
277
-<th scope="row"><?php _e('Inline and Defer CSS?','autoptimize'); ?></th>
278
-<td><label class="cb_label"><input type="checkbox" name="autoptimize_css_defer" id="autoptimize_css_defer" <?php echo get_option('autoptimize_css_defer')?'checked="checked" ':''; ?>/>
279
-<?php _e('Inline "above the fold CSS" while loading the main autoptimized CSS only after page load. <a href="http://wordpress.org/plugins/autoptimize/faq/" target="_blank">Check the FAQ</a> before activating this option!','autoptimize'); ?></label></td>
276
+<tr valign="top" class="<?php echo $hiddenClass; ?>css_sub ao_adv">
277
+<th scope="row"><?php _e('Inline and Defer CSS?', 'autoptimize'); ?></th>
278
+<td><label class="cb_label"><input type="checkbox" name="autoptimize_css_defer" id="autoptimize_css_defer" <?php echo get_option('autoptimize_css_defer') ? 'checked="checked" ' : ''; ?>/>
279
+<?php _e('Inline "above the fold CSS" while loading the main autoptimized CSS only after page load. <a href="http://wordpress.org/plugins/autoptimize/faq/" target="_blank">Check the FAQ</a> before activating this option!', 'autoptimize'); ?></label></td>
280 280
 </tr>
281
-<tr valign="top" class="<?php echo $hiddenClass;?>css_sub ao_adv" id="autoptimize_css_defer_inline">
281
+<tr valign="top" class="<?php echo $hiddenClass; ?>css_sub ao_adv" id="autoptimize_css_defer_inline">
282 282
 <th scope="row"></th>
283
-<td><label><textarea rows="10" cols="10" style="width:100%;" placeholder="<?php _e('Paste the above the fold CSS here.','autoptimize'); ?>" name="autoptimize_css_defer_inline"><?php echo get_option('autoptimize_css_defer_inline'); ?></textarea></label></td>
283
+<td><label><textarea rows="10" cols="10" style="width:100%;" placeholder="<?php _e('Paste the above the fold CSS here.', 'autoptimize'); ?>" name="autoptimize_css_defer_inline"><?php echo get_option('autoptimize_css_defer_inline'); ?></textarea></label></td>
284 284
 </tr>
285
-<tr valign="top" class="<?php echo $hiddenClass;?>ao_adv css_sub">
286
-<th scope="row"><?php _e('Inline all CSS?','autoptimize'); ?></th>
287
-<td><label class="cb_label"><input type="checkbox" id="autoptimize_css_inline" name="autoptimize_css_inline" <?php echo get_option('autoptimize_css_inline')?'checked="checked" ':''; ?>/>
288
-<?php _e('Inlining all CSS can improve performance for sites with a low pageviews/ visitor-rate, but may slow down performance otherwise.','autoptimize'); ?></label></td>
285
+<tr valign="top" class="<?php echo $hiddenClass; ?>ao_adv css_sub">
286
+<th scope="row"><?php _e('Inline all CSS?', 'autoptimize'); ?></th>
287
+<td><label class="cb_label"><input type="checkbox" id="autoptimize_css_inline" name="autoptimize_css_inline" <?php echo get_option('autoptimize_css_inline') ? 'checked="checked" ' : ''; ?>/>
288
+<?php _e('Inlining all CSS can improve performance for sites with a low pageviews/ visitor-rate, but may slow down performance otherwise.', 'autoptimize'); ?></label></td>
289 289
 </tr>
290
-<tr valign="top" class="<?php echo $hiddenClass;?>ao_adv css_sub">
291
-<th scope="row"><?php _e('Exclude CSS from Autoptimize:','autoptimize'); ?></th>
292
-<td><label><input type="text" style="width:100%;" name="autoptimize_css_exclude" value="<?php echo get_option('autoptimize_css_exclude','wp-content/cache/, wp-content/uploads/, admin-bar.min.css, dashicons.min.css'); ?>"/><br />
293
-<?php _e('A comma-separated list of CSS you want to exclude from being optimized.','autoptimize'); ?></label></td>
290
+<tr valign="top" class="<?php echo $hiddenClass; ?>ao_adv css_sub">
291
+<th scope="row"><?php _e('Exclude CSS from Autoptimize:', 'autoptimize'); ?></th>
292
+<td><label><input type="text" style="width:100%;" name="autoptimize_css_exclude" value="<?php echo get_option('autoptimize_css_exclude', 'wp-content/cache/, wp-content/uploads/, admin-bar.min.css, dashicons.min.css'); ?>"/><br />
293
+<?php _e('A comma-separated list of CSS you want to exclude from being optimized.', 'autoptimize'); ?></label></td>
294 294
 </tr>
295 295
 </table>
296 296
 </li>
297 297
 
298 298
 <li class="itemDetail">
299
-<h2 class="itemTitle"><?php _e('CDN Options','autoptimize'); ?></h2>
299
+<h2 class="itemTitle"><?php _e('CDN Options', 'autoptimize'); ?></h2>
300 300
 <table class="form-table"> 
301 301
 <tr valign="top">
302
-<th scope="row"><?php _e('CDN Base URL','autoptimize'); ?></th>
303
-<td><label><input id="cdn_url" type="text" name="autoptimize_cdn_url" pattern="^(https?:)?\/\/([\da-z\.-]+)\.([\da-z\.]{2,6})([\/\w \.-]*)*(:\d{2,5})?\/?$" style="width:100%" value="<?php echo esc_url(get_option('autoptimize_cdn_url',''),array("http","https")); ?>" /><br />
304
-<?php _e('Enter your CDN root URL to enable CDN for Autoptimized files. The URL can be http, https or protocol-relative (e.g. <code>//cdn.example.com/</code>). This is not needed for Cloudflare.','autoptimize'); ?></label></td>
302
+<th scope="row"><?php _e('CDN Base URL', 'autoptimize'); ?></th>
303
+<td><label><input id="cdn_url" type="text" name="autoptimize_cdn_url" pattern="^(https?:)?\/\/([\da-z\.-]+)\.([\da-z\.]{2,6})([\/\w \.-]*)*(:\d{2,5})?\/?$" style="width:100%" value="<?php echo esc_url(get_option('autoptimize_cdn_url', ''), array("http", "https")); ?>" /><br />
304
+<?php _e('Enter your CDN root URL to enable CDN for Autoptimized files. The URL can be http, https or protocol-relative (e.g. <code>//cdn.example.com/</code>). This is not needed for Cloudflare.', 'autoptimize'); ?></label></td>
305 305
 </tr>
306 306
 </table>
307 307
 </li>
308 308
 
309
-<li class="<?php echo $hiddenClass;?>itemDetail ao_adv">
310
-<h2 class="itemTitle"><?php _e('Cache Info','autoptimize'); ?></h2>
309
+<li class="<?php echo $hiddenClass; ?>itemDetail ao_adv">
310
+<h2 class="itemTitle"><?php _e('Cache Info', 'autoptimize'); ?></h2>
311 311
 <table class="form-table" > 
312
-<tr valign="top" class="<?php echo $hiddenClass;?>ao_adv">
313
-<th scope="row"><?php _e('Cache folder','autoptimize'); ?></th>
312
+<tr valign="top" class="<?php echo $hiddenClass; ?>ao_adv">
313
+<th scope="row"><?php _e('Cache folder', 'autoptimize'); ?></th>
314 314
 <td><?php echo htmlentities(AUTOPTIMIZE_CACHE_DIR); ?></td>
315 315
 </tr>
316
-<tr valign="top" class="<?php echo $hiddenClass;?>ao_adv">
317
-<th scope="row"><?php _e('Can we write?','autoptimize'); ?></th>
318
-<td><?php echo (autoptimizeCache::cacheavail() ? __('Yes','autoptimize') : __('No','autoptimize')); ?></td>
316
+<tr valign="top" class="<?php echo $hiddenClass; ?>ao_adv">
317
+<th scope="row"><?php _e('Can we write?', 'autoptimize'); ?></th>
318
+<td><?php echo (autoptimizeCache::cacheavail() ? __('Yes', 'autoptimize') : __('No', 'autoptimize')); ?></td>
319 319
 </tr>
320
-<tr valign="top" class="<?php echo $hiddenClass;?>ao_adv">
321
-<th scope="row"><?php _e('Cached styles and scripts','autoptimize'); ?></th>
320
+<tr valign="top" class="<?php echo $hiddenClass; ?>ao_adv">
321
+<th scope="row"><?php _e('Cached styles and scripts', 'autoptimize'); ?></th>
322 322
 <td><?php
323
-    $AOstatArr=autoptimizeCache::stats(); 
324
-    $AOcacheSize=round($AOstatArr[1]/1024);
325
-    printf( __( '%1$s files, totalling %2$s Kbytes (calculated at %3$s)', 'autoptimize'), $AOstatArr[0], $AOcacheSize, date("H:i e", $AOstatArr[2]) );
323
+    $AOstatArr = autoptimizeCache::stats(); 
324
+    $AOcacheSize = round($AOstatArr[1]/1024);
325
+    printf(__('%1$s files, totalling %2$s Kbytes (calculated at %3$s)', 'autoptimize'), $AOstatArr[0], $AOcacheSize, date("H:i e", $AOstatArr[2]));
326 326
 ?></td>
327 327
 </tr>
328 328
 </table>
329 329
 </li>
330 330
 
331
-<li class="<?php echo $hiddenClass;?>itemDetail ao_adv">
332
-<h2 class="itemTitle"><?php _e('Misc Options','autoptimize'); ?></h2>
331
+<li class="<?php echo $hiddenClass; ?>itemDetail ao_adv">
332
+<h2 class="itemTitle"><?php _e('Misc Options', 'autoptimize'); ?></h2>
333 333
 <table class="form-table"> 
334
-	<tr valign="top" class="<?php echo $hiddenClass;?>ao_adv">
335
-		<th scope="row"><?php _e('Save aggregated script/css as static files?','autoptimize'); ?></th>
336
-		<td><label class="cb_label"><input type="checkbox" name="autoptimize_cache_nogzip" <?php echo get_option('autoptimize_cache_nogzip','1')?'checked="checked" ':''; ?>/>
337
-			<?php _e('By default files saved are static css/js, uncheck this option if your webserver doesn\'t properly handle the compression and expiry.','autoptimize'); ?></label>
334
+	<tr valign="top" class="<?php echo $hiddenClass; ?>ao_adv">
335
+		<th scope="row"><?php _e('Save aggregated script/css as static files?', 'autoptimize'); ?></th>
336
+		<td><label class="cb_label"><input type="checkbox" name="autoptimize_cache_nogzip" <?php echo get_option('autoptimize_cache_nogzip', '1') ? 'checked="checked" ' : ''; ?>/>
337
+			<?php _e('By default files saved are static css/js, uncheck this option if your webserver doesn\'t properly handle the compression and expiry.', 'autoptimize'); ?></label>
338 338
 		</td>
339 339
 	</tr>
340
-	<tr valign="top" class="<?php echo $hiddenClass;?>ao_adv">
341
-		<th scope="row"><?php _e('Also optimize for logged in users?','autoptimize'); ?></th>
342
-		<td><label class="cb_label"><input type="checkbox" name="autoptimize_optimize_logged" <?php echo get_option('autoptimize_optimize_logged','1')?'checked="checked" ':''; ?>/>
343
-			<?php _e('By default Autoptimize is also active for logged on users, uncheck not to optimize when logged in e.g. to use a pagebuilder.','autoptimize'); ?></label>
340
+	<tr valign="top" class="<?php echo $hiddenClass; ?>ao_adv">
341
+		<th scope="row"><?php _e('Also optimize for logged in users?', 'autoptimize'); ?></th>
342
+		<td><label class="cb_label"><input type="checkbox" name="autoptimize_optimize_logged" <?php echo get_option('autoptimize_optimize_logged', '1') ? 'checked="checked" ' : ''; ?>/>
343
+			<?php _e('By default Autoptimize is also active for logged on users, uncheck not to optimize when logged in e.g. to use a pagebuilder.', 'autoptimize'); ?></label>
344 344
 		</td>
345 345
 	</tr>
346 346
 	<?php
347
-		if ( function_exists("is_checkout") || function_exists("is_cart") || function_exists("edd_is_checkout") || function_exists("wpsc_is_cart") || function_exists("wpsc_is_checkout") ) {
347
+		if (function_exists("is_checkout") || function_exists("is_cart") || function_exists("edd_is_checkout") || function_exists("wpsc_is_cart") || function_exists("wpsc_is_checkout")) {
348 348
 			?>
349
-				<tr valign="top" class="<?php echo $hiddenClass;?>ao_adv">
350
-					<th scope="row"><?php _e('Also optimize shop cart/ checkout?','autoptimize'); ?></th>
351
-					<td><label class="cb_label"><input type="checkbox" name="autoptimize_optimize_checkout" <?php echo get_option('autoptimize_optimize_checkout','1')?'checked="checked" ':''; ?>/>
352
-						<?php _e('By default Autoptimize is also active on your shop\'s cart/ checkout, uncheck not to optimize those.','autoptimize'); ?></label>
349
+				<tr valign="top" class="<?php echo $hiddenClass; ?>ao_adv">
350
+					<th scope="row"><?php _e('Also optimize shop cart/ checkout?', 'autoptimize'); ?></th>
351
+					<td><label class="cb_label"><input type="checkbox" name="autoptimize_optimize_checkout" <?php echo get_option('autoptimize_optimize_checkout', '1') ? 'checked="checked" ' : ''; ?>/>
352
+						<?php _e('By default Autoptimize is also active on your shop\'s cart/ checkout, uncheck not to optimize those.', 'autoptimize'); ?></label>
353 353
 					</td>
354 354
 				</tr>
355 355
 			<?php
@@ -360,11 +360,11 @@  discard block
 block discarded – undo
360 360
 
361 361
 </ul>
362 362
 
363
-<input type="hidden" id="autoptimize_show_adv" name="autoptimize_show_adv" value="<?php echo get_option('autoptimize_show_adv','0'); ?>">
363
+<input type="hidden" id="autoptimize_show_adv" name="autoptimize_show_adv" value="<?php echo get_option('autoptimize_show_adv', '0'); ?>">
364 364
 
365 365
 <p class="submit">
366
-<input type="submit" class="button-secondary" value="<?php _e('Save Changes','autoptimize') ?>" />
367
-<input type="submit" class="button-primary" name="autoptimize_cache_clean" value="<?php _e('Save Changes and Empty Cache','autoptimize') ?>" />
366
+<input type="submit" class="button-secondary" value="<?php _e('Save Changes', 'autoptimize') ?>" />
367
+<input type="submit" class="button-primary" name="autoptimize_cache_clean" value="<?php _e('Save Changes and Empty Cache', 'autoptimize') ?>" />
368 368
 </p>
369 369
 
370 370
 </form>
@@ -373,31 +373,31 @@  discard block
 block discarded – undo
373 373
     <div class="autoptimize_banner hidden">
374 374
         <ul>
375 375
         <?php
376
-        if (apply_filters('autoptimize_settingsscreen_remotehttp',true)) {
377
-            $AO_banner=get_transient("autoptimize_banner");
376
+        if (apply_filters('autoptimize_settingsscreen_remotehttp', true)) {
377
+            $AO_banner = get_transient("autoptimize_banner");
378 378
             if (empty($AO_banner)) {
379 379
                 $banner_resp = wp_remote_get("http://misc.optimizingmatters.com/autoptimize_news.html");
380 380
                 if (!is_wp_error($banner_resp)) {
381
-                    if (wp_remote_retrieve_response_code($banner_resp)=="200") {
381
+                    if (wp_remote_retrieve_response_code($banner_resp) == "200") {
382 382
                         $AO_banner = wp_kses_post(wp_remote_retrieve_body($banner_resp));
383
-                        set_transient("autoptimize_banner",$AO_banner,DAY_IN_SECONDS);
383
+                        set_transient("autoptimize_banner", $AO_banner, DAY_IN_SECONDS);
384 384
                     }
385 385
                 }
386 386
             }
387 387
             echo $AO_banner;
388 388
         }
389 389
         ?>
390
-        <li><?php _e("Need help? <a href='https://wordpress.org/plugins/autoptimize/faq/'>Check out the FAQ here</a>.","autoptimize"); ?></li>
391
-        <li><?php _e("Happy with Autoptimize?","autoptimize"); ?><br /><a href="<?php echo network_admin_url(); ?>plugin-install.php?tab=search&type=author&s=optimizingmatters"><?php _e("Try my other plugins!","autoptimize"); ?></a></li>
390
+        <li><?php _e("Need help? <a href='https://wordpress.org/plugins/autoptimize/faq/'>Check out the FAQ here</a>.", "autoptimize"); ?></li>
391
+        <li><?php _e("Happy with Autoptimize?", "autoptimize"); ?><br /><a href="<?php echo network_admin_url(); ?>plugin-install.php?tab=search&type=author&s=optimizingmatters"><?php _e("Try my other plugins!", "autoptimize"); ?></a></li>
392 392
         </ul>
393 393
     </div>
394 394
     <div style="margin-left:10px;margin-top:-5px;">
395 395
         <h2>
396
-            <?php _e("futtta about","autoptimize") ?>
396
+            <?php _e("futtta about", "autoptimize") ?>
397 397
             <select id="feed_dropdown" >
398
-                <option value="1"><?php _e("Autoptimize","autoptimize") ?></option>
399
-                <option value="2"><?php _e("WordPress","autoptimize") ?></option>
400
-                <option value="3"><?php _e("Web Technology","autoptimize") ?></option>
398
+                <option value="1"><?php _e("Autoptimize", "autoptimize") ?></option>
399
+                <option value="2"><?php _e("WordPress", "autoptimize") ?></option>
400
+                <option value="3"><?php _e("Web Technology", "autoptimize") ?></option>
401 401
             </select>
402 402
         </h2>
403 403
         <div id="futtta_feed">
@@ -412,7 +412,7 @@  discard block
 block discarded – undo
412 412
             </div>
413 413
         </div>
414 414
     </div>
415
-    <div style="float:right;margin:50px 15px;"><a href="http://blog.futtta.be/2013/10/21/do-not-donate-to-me/" target="_blank"><img width="100px" height="85px" src="<?php echo plugins_url().'/'.plugin_basename(dirname(__FILE__)).'/external/do_not_donate_smallest.png'; ?>" title="<?php _e("Do not donate for this plugin!","autoptimize"); ?>"></a></div>
415
+    <div style="float:right;margin:50px 15px;"><a href="http://blog.futtta.be/2013/10/21/do-not-donate-to-me/" target="_blank"><img width="100px" height="85px" src="<?php echo plugins_url().'/'.plugin_basename(dirname(__FILE__)).'/external/do_not_donate_smallest.png'; ?>" title="<?php _e("Do not donate for this plugin!", "autoptimize"); ?>"></a></div>
416 416
 </div>
417 417
 
418 418
 <script type="text/javascript">
@@ -551,14 +551,14 @@  discard block
 block discarded – undo
551 551
     }
552 552
 
553 553
     public function addmenu() {
554
-        $hook=add_options_page(__('Autoptimize Options','autoptimize'),'Autoptimize','manage_options','autoptimize',array($this,'show'));
555
-        add_action( 'admin_print_scripts-'.$hook,array($this,'autoptimize_admin_scripts'));
556
-        add_action( 'admin_print_styles-'.$hook,array($this,'autoptimize_admin_styles'));
554
+        $hook = add_options_page(__('Autoptimize Options', 'autoptimize'), 'Autoptimize', 'manage_options', 'autoptimize', array($this, 'show'));
555
+        add_action('admin_print_scripts-'.$hook, array($this, 'autoptimize_admin_scripts'));
556
+        add_action('admin_print_styles-'.$hook, array($this, 'autoptimize_admin_styles'));
557 557
     }
558 558
 
559 559
     public function autoptimize_admin_scripts() {
560
-        wp_enqueue_script('jqcookie', plugins_url('/external/js/jquery.cookie.min.js', __FILE__), array('jquery'),null,true);
561
-        wp_enqueue_script('unslider', plugins_url('/external/js/unslider-min.js', __FILE__), array('jquery'),null,true);
560
+        wp_enqueue_script('jqcookie', plugins_url('/external/js/jquery.cookie.min.js', __FILE__), array('jquery'), null, true);
561
+        wp_enqueue_script('unslider', plugins_url('/external/js/unslider-min.js', __FILE__), array('jquery'), null, true);
562 562
     }
563 563
 
564 564
     public function autoptimize_admin_styles() {
@@ -567,47 +567,47 @@  discard block
 block discarded – undo
567 567
     }
568 568
 
569 569
     public function registersettings() {
570
-        register_setting('autoptimize','autoptimize_html');
571
-        register_setting('autoptimize','autoptimize_html_keepcomments');
572
-        register_setting('autoptimize','autoptimize_js');
573
-        register_setting('autoptimize','autoptimize_js_exclude');
574
-        register_setting('autoptimize','autoptimize_js_trycatch');
575
-        register_setting('autoptimize','autoptimize_js_justhead');
576
-        register_setting('autoptimize','autoptimize_js_forcehead');
577
-        register_setting('autoptimize','autoptimize_js_include_inline');
578
-        register_setting('autoptimize','autoptimize_css');
579
-        register_setting('autoptimize','autoptimize_css_exclude');
580
-        register_setting('autoptimize','autoptimize_css_justhead');
581
-        register_setting('autoptimize','autoptimize_css_datauris');
582
-        register_setting('autoptimize','autoptimize_css_defer');
583
-        register_setting('autoptimize','autoptimize_css_defer_inline');
584
-        register_setting('autoptimize','autoptimize_css_inline');
585
-        register_setting('autoptimize','autoptimize_css_include_inline');
586
-        register_setting('autoptimize','autoptimize_cdn_url');
587
-        register_setting('autoptimize','autoptimize_cache_clean');
588
-        register_setting('autoptimize','autoptimize_cache_nogzip');
589
-        register_setting('autoptimize','autoptimize_show_adv');
590
-        register_setting('autoptimize','autoptimize_optimize_logged');
591
-        register_setting('autoptimize','autoptimize_optimize_checkout');
570
+        register_setting('autoptimize', 'autoptimize_html');
571
+        register_setting('autoptimize', 'autoptimize_html_keepcomments');
572
+        register_setting('autoptimize', 'autoptimize_js');
573
+        register_setting('autoptimize', 'autoptimize_js_exclude');
574
+        register_setting('autoptimize', 'autoptimize_js_trycatch');
575
+        register_setting('autoptimize', 'autoptimize_js_justhead');
576
+        register_setting('autoptimize', 'autoptimize_js_forcehead');
577
+        register_setting('autoptimize', 'autoptimize_js_include_inline');
578
+        register_setting('autoptimize', 'autoptimize_css');
579
+        register_setting('autoptimize', 'autoptimize_css_exclude');
580
+        register_setting('autoptimize', 'autoptimize_css_justhead');
581
+        register_setting('autoptimize', 'autoptimize_css_datauris');
582
+        register_setting('autoptimize', 'autoptimize_css_defer');
583
+        register_setting('autoptimize', 'autoptimize_css_defer_inline');
584
+        register_setting('autoptimize', 'autoptimize_css_inline');
585
+        register_setting('autoptimize', 'autoptimize_css_include_inline');
586
+        register_setting('autoptimize', 'autoptimize_cdn_url');
587
+        register_setting('autoptimize', 'autoptimize_cache_clean');
588
+        register_setting('autoptimize', 'autoptimize_cache_nogzip');
589
+        register_setting('autoptimize', 'autoptimize_show_adv');
590
+        register_setting('autoptimize', 'autoptimize_optimize_logged');
591
+        register_setting('autoptimize', 'autoptimize_optimize_checkout');
592 592
     }
593 593
 
594
-    public function setmeta($links,$file=null) {
594
+    public function setmeta($links, $file = null) {
595 595
         //Inspired on http://wpengineer.com/meta-links-for-wordpress-plugins/
596 596
         //Do it only once - saves time
597 597
         static $plugin;
598
-        if(empty($plugin))
598
+        if (empty($plugin))
599 599
             $plugin = plugin_basename(AUTOPTIMIZE_PLUGIN_DIR.'autoptimize.php');
600 600
         
601
-        if($file===null) {
601
+        if ($file === null) {
602 602
             //2.7
603 603
             $settings_link = sprintf('<a href="options-general.php?page=autoptimize">%s</a>', __('Settings'));
604
-            array_unshift($links,$settings_link);
604
+            array_unshift($links, $settings_link);
605 605
         } else {
606 606
             //2.8
607 607
             //If it's us, add the link
608
-            if($file === $plugin) {
609
-                $newlink = array(sprintf('<a href="options-general.php?page=autoptimize">%s</a>',__('Settings')));
610
-                $links = array_merge($links,$newlink);
608
+            if ($file === $plugin) {
609
+                $newlink = array(sprintf('<a href="options-general.php?page=autoptimize">%s</a>', __('Settings')));
610
+                $links = array_merge($links, $newlink);
611 611
             }
612 612
         }
613 613
 
@@ -615,7 +615,7 @@  discard block
 block discarded – undo
615 615
     }
616 616
 
617 617
     public function get($key) {        
618
-        if(!is_array($this->config)) {
618
+        if (!is_array($this->config)) {
619 619
             //Default config
620 620
             $config = array('autoptimize_html' => 0,
621 621
                 'autoptimize_html_keepcomments' => 0,
@@ -641,43 +641,43 @@  discard block
 block discarded – undo
641 641
                 );
642 642
 
643 643
             //Override with user settings
644
-            foreach(array_keys($config) as $name) {
644
+            foreach (array_keys($config) as $name) {
645 645
                 $conf = get_option($name);
646
-                if($conf!==false) {
646
+                if ($conf !== false) {
647 647
                     //It was set before!
648 648
                     $config[$name] = $conf;
649 649
                 }
650 650
             }
651 651
 
652 652
             //Save for next question
653
-            $this->config = apply_filters( 'autoptimize_filter_get_config', $config );
653
+            $this->config = apply_filters('autoptimize_filter_get_config', $config);
654 654
         }
655 655
 
656
-        if(isset($this->config[$key]))
656
+        if (isset($this->config[$key]))
657 657
             return $this->config[$key];
658 658
 
659 659
         return false;
660 660
     }
661 661
 
662 662
     private function getFutttaFeeds($url) {
663
-        if (apply_filters('autoptimize_settingsscreen_remotehttp',true)) {
664
-            $rss = fetch_feed( $url );
663
+        if (apply_filters('autoptimize_settingsscreen_remotehttp', true)) {
664
+            $rss = fetch_feed($url);
665 665
             $maxitems = 0;
666 666
 
667
-            if ( ! is_wp_error( $rss ) ) {
668
-                $maxitems = $rss->get_item_quantity( 7 ); 
669
-                $rss_items = $rss->get_items( 0, $maxitems );
667
+            if (!is_wp_error($rss)) {
668
+                $maxitems = $rss->get_item_quantity(7); 
669
+                $rss_items = $rss->get_items(0, $maxitems);
670 670
             }
671 671
             ?>
672 672
             <ul>
673
-                <?php if ( $maxitems == 0 ) : ?>
674
-                    <li><?php _e( 'No items', 'autoptimize' ); ?></li>
673
+                <?php if ($maxitems == 0) : ?>
674
+                    <li><?php _e('No items', 'autoptimize'); ?></li>
675 675
                 <?php else : ?>
676
-                    <?php foreach ( $rss_items as $item ) : ?>
676
+                    <?php foreach ($rss_items as $item) : ?>
677 677
                         <li>
678
-                            <a href="<?php echo esc_url( $item->get_permalink() ); ?>"
679
-                                title="<?php printf( __( 'Posted %s', 'autoptimize' ), $item->get_date('j F Y | g:i a') ); ?>">
680
-                                <?php echo esc_html( $item->get_title() ); ?>
678
+                            <a href="<?php echo esc_url($item->get_permalink()); ?>"
679
+                                title="<?php printf(__('Posted %s', 'autoptimize'), $item->get_date('j F Y | g:i a')); ?>">
680
+                                <?php echo esc_html($item->get_title()); ?>
681 681
                             </a>
682 682
                         </li>
683 683
                     <?php endforeach; ?>
@@ -688,20 +688,20 @@  discard block
 block discarded – undo
688 688
     }
689 689
 
690 690
     // based on http://wordpress.stackexchange.com/a/58826
691
-    static function ao_admin_tabs(){
692
-        $tabs = apply_filters('autoptimize_filter_settingsscreen_tabs',array('autoptimize' => __('Main','autoptimize')));
693
-        $tabContent="";
694
-        if (count($tabs)>1) {
695
-            if(isset($_GET['page'])){
691
+    static function ao_admin_tabs() {
692
+        $tabs = apply_filters('autoptimize_filter_settingsscreen_tabs', array('autoptimize' => __('Main', 'autoptimize')));
693
+        $tabContent = "";
694
+        if (count($tabs) > 1) {
695
+            if (isset($_GET['page'])) {
696 696
                 $currentId = $_GET['page'];
697 697
             } else {
698 698
                 $currentId = "autoptimize";
699 699
             }
700 700
             $tabContent .= "<h2 class=\"nav-tab-wrapper\">";
701
-            foreach($tabs as $tabId => $tabName){
702
-                if($currentId == $tabId){
701
+            foreach ($tabs as $tabId => $tabName) {
702
+                if ($currentId == $tabId) {
703 703
                     $class = " nav-tab-active";
704
-                } else{
704
+                } else {
705 705
                     $class = "";
706 706
                 }
707 707
                 $tabContent .= '<a class="nav-tab'.$class.'" href="?page='.$tabId.'">'.$tabName.'</a>';
Please login to merge, or discard this patch.
classlesses/autoptimizePartners.php 1 patch
Spacing   +23 added lines, -23 removed lines patch added patch discarded remove patch
@@ -3,24 +3,24 @@  discard block
 block discarded – undo
3 3
 Classlessly add a "more tools" tab to promote (future) AO addons and/ or affiliate services
4 4
 */
5 5
 
6
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
6
+if (!defined('ABSPATH')) exit; // Exit if accessed directly
7 7
 
8 8
 add_action('admin_init', 'ao_partner_tabs_preinit');
9 9
 function ao_partner_tabs_preinit() {
10
-    if (apply_filters('autoptimize_filter_show_partner_tabs',true)) {
11
-        add_filter('autoptimize_filter_settingsscreen_tabs','ao_add_partner_tabs');
10
+    if (apply_filters('autoptimize_filter_show_partner_tabs', true)) {
11
+        add_filter('autoptimize_filter_settingsscreen_tabs', 'ao_add_partner_tabs');
12 12
     }
13 13
 }
14 14
 
15 15
 function ao_add_partner_tabs($in) {
16
-    $in=array_merge($in,array('ao_partners' => __('Optimize More!','autoptimize')));
16
+    $in = array_merge($in, array('ao_partners' => __('Optimize More!', 'autoptimize')));
17 17
     return $in;
18 18
 }
19 19
 
20
-add_action('admin_menu','ao_partners_init');
20
+add_action('admin_menu', 'ao_partners_init');
21 21
 function ao_partners_init() {
22
-    if (apply_filters('autoptimize_filter_show_partner_tabs',true)) {
23
-        $hook=add_submenu_page(NULL,'AO partner','AO partner','manage_options','ao_partners','ao_partners');
22
+    if (apply_filters('autoptimize_filter_show_partner_tabs', true)) {
23
+        $hook = add_submenu_page(NULL, 'AO partner', 'AO partner', 'manage_options', 'ao_partners', 'ao_partners');
24 24
         // register_settings here as well if needed
25 25
     }
26 26
 }
@@ -71,10 +71,10 @@  discard block
 block discarded – undo
71 71
     }    
72 72
     </style>
73 73
     <div class="wrap">
74
-        <h1><?php _e('Autoptimize Settings','autoptimize'); ?></h1>
74
+        <h1><?php _e('Autoptimize Settings', 'autoptimize'); ?></h1>
75 75
         <?php echo autoptimizeConfig::ao_admin_tabs(); ?>
76 76
         <?php
77
-            echo '<h2>'. __("These Autoptimize power-ups and related services will improve your site's performance even more!",'autoptimize') . '</h2>';
77
+            echo '<h2>'.__("These Autoptimize power-ups and related services will improve your site's performance even more!", 'autoptimize').'</h2>';
78 78
         ?>
79 79
         <div>
80 80
             <?php getAOPartnerFeed(); ?>
@@ -84,33 +84,33 @@  discard block
 block discarded – undo
84 84
 }
85 85
 
86 86
 function getAOPartnerFeed() {
87
-    $noFeedText=__( 'Have a look at <a href="http://optimizingmatters.com/">optimizingmatters.com</a> for Autoptimize power-ups!', 'autoptimize' );
87
+    $noFeedText = __('Have a look at <a href="http://optimizingmatters.com/">optimizingmatters.com</a> for Autoptimize power-ups!', 'autoptimize');
88 88
 
89
-    if (apply_filters('autoptimize_settingsscreen_remotehttp',true)) {
90
-        $rss = fetch_feed( "http://feeds.feedburner.com/OptimizingMattersDownloads" );
89
+    if (apply_filters('autoptimize_settingsscreen_remotehttp', true)) {
90
+        $rss = fetch_feed("http://feeds.feedburner.com/OptimizingMattersDownloads");
91 91
         $maxitems = 0;
92 92
 
93
-        if ( ! is_wp_error( $rss ) ) {
94
-            $maxitems = $rss->get_item_quantity( 20 ); 
95
-            $rss_items = $rss->get_items( 0, $maxitems );
93
+        if (!is_wp_error($rss)) {
94
+            $maxitems = $rss->get_item_quantity(20); 
95
+            $rss_items = $rss->get_items(0, $maxitems);
96 96
         } ?>
97 97
         <ul>
98 98
             <?php
99
-            if ( $maxitems == 0 ) {
99
+            if ($maxitems == 0) {
100 100
                 echo $noFeedText;
101 101
             } else {
102
-                foreach ( $rss_items as $item ) : 
103
-                    $itemURL = esc_url( $item->get_permalink() ); ?>
102
+                foreach ($rss_items as $item) : 
103
+                    $itemURL = esc_url($item->get_permalink()); ?>
104 104
                     <li class="itemDetail">
105
-                        <h3 class="itemTitle"><a href="<?php echo $itemURL; ?>" target="_blank"><?php echo esc_html( $item->get_title() ); ?></a></h3>
105
+                        <h3 class="itemTitle"><a href="<?php echo $itemURL; ?>" target="_blank"><?php echo esc_html($item->get_title()); ?></a></h3>
106 106
                         <?php
107
-                        if (($enclosure = $item->get_enclosure()) && (strpos($enclosure->get_type(),"image")!==false) ) {
108
-                            $itemImgURL=esc_url($enclosure->get_link());
107
+                        if (($enclosure = $item->get_enclosure()) && (strpos($enclosure->get_type(), "image") !== false)) {
108
+                            $itemImgURL = esc_url($enclosure->get_link());
109 109
                             echo "<div class=\"itemImage\"><a href=\"".$itemURL."\" target=\"_blank\"><img src=\"".$itemImgURL."\"/></a></div>";
110 110
                         }
111 111
                         ?>
112
-                        <div class="itemDescription"><?php echo wp_kses_post($item -> get_description() ); ?></div>
113
-                        <div class="itemButtonRow"><div class="itemButton button-secondary"><a href="<?php echo $itemURL; ?>" target="_blank"><?php _e('More info','autoptimize'); ?></a></div></div>
112
+                        <div class="itemDescription"><?php echo wp_kses_post($item -> get_description()); ?></div>
113
+                        <div class="itemButtonRow"><div class="itemButton button-secondary"><a href="<?php echo $itemURL; ?>" target="_blank"><?php _e('More info', 'autoptimize'); ?></a></div></div>
114 114
                     </li>
115 115
                 <?php endforeach; ?>
116 116
             <?php } ?>
Please login to merge, or discard this patch.
classlesses/autoptimizeExtra.php 1 patch
Spacing   +123 added lines, -123 removed lines patch added patch discarded remove patch
@@ -1,18 +1,18 @@  discard block
 block discarded – undo
1 1
 <?php
2
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
2
+if (!defined('ABSPATH')) exit; // Exit if accessed directly
3 3
 
4 4
 // initialize
5
-if ( is_admin() ) {
6
-    add_action( 'admin_menu', 'autoptimize_extra_admin' );
7
-    add_filter( 'autoptimize_filter_settingsscreen_tabs','add_autoptimize_extra_tab' );
5
+if (is_admin()) {
6
+    add_action('admin_menu', 'autoptimize_extra_admin');
7
+    add_filter('autoptimize_filter_settingsscreen_tabs', 'add_autoptimize_extra_tab');
8 8
 } else {
9 9
     autoptimize_extra_init();
10 10
 }
11 11
 
12 12
 // get option
13 13
 function autoptimize_extra_get_options() {
14
-    $_default_val = array("autoptimize_extra_checkbox_field_1"=>"0","autoptimize_extra_checkbox_field_0"=>"0","autoptimize_extra_radio_field_4"=>"1","autoptimize_extra_text_field_2"=>"","autoptimize_extra_text_field_3"=>"");
15
-    $_option_val = get_option( 'autoptimize_extra_settings' );
14
+    $_default_val = array("autoptimize_extra_checkbox_field_1"=>"0", "autoptimize_extra_checkbox_field_0"=>"0", "autoptimize_extra_radio_field_4"=>"1", "autoptimize_extra_text_field_2"=>"", "autoptimize_extra_text_field_3"=>"");
15
+    $_option_val = get_option('autoptimize_extra_settings');
16 16
     if (empty($_option_val)) {
17 17
         $_option_val = $_default_val;
18 18
     }
@@ -24,14 +24,14 @@  discard block
 block discarded – undo
24 24
     $autoptimize_extra_options = autoptimize_extra_get_options();
25 25
 
26 26
     /* disable emojis */
27
-    if ( !empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_1']) ) {
27
+    if (!empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_1'])) {
28 28
         autoptimize_extra_disable_emojis();
29 29
     }
30 30
     
31 31
     /* remove version from query string */
32
-    if ( !empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_0']) ) {
33
-        add_filter( 'script_loader_src', 'autoptimize_extra_remove_qs', 15, 1 );
34
-        add_filter( 'style_loader_src', 'autoptimize_extra_remove_qs', 15, 1 );
32
+    if (!empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_0'])) {
33
+        add_filter('script_loader_src', 'autoptimize_extra_remove_qs', 15, 1);
34
+        add_filter('style_loader_src', 'autoptimize_extra_remove_qs', 15, 1);
35 35
     }
36 36
 
37 37
     /* 
@@ -41,68 +41,68 @@  discard block
 block discarded – undo
41 41
      * cfr. https://codex.wordpress.org/Function_Reference/is_plugin_active
42 42
      * so we need to source in wp-admin/includes/plugin.php
43 43
     */
44
-    include_once( ABSPATH . 'wp-admin/includes/plugin.php' );
44
+    include_once(ABSPATH.'wp-admin/includes/plugin.php');
45 45
     $_asyncJSactive = false;
46
-    if ( function_exists('is_plugin_active') && is_plugin_active('async-javascript/async-javascript.php') ) {
46
+    if (function_exists('is_plugin_active') && is_plugin_active('async-javascript/async-javascript.php')) {
47 47
         $_asyncJSactive = true;
48 48
     }
49
-    if ( !empty($autoptimize_extra_options['autoptimize_extra_text_field_3']) && $_asyncJSactive === false ) {
50
-        add_filter('autoptimize_filter_js_exclude','autoptimize_extra_async_js',10,1);
49
+    if (!empty($autoptimize_extra_options['autoptimize_extra_text_field_3']) && $_asyncJSactive === false) {
50
+        add_filter('autoptimize_filter_js_exclude', 'autoptimize_extra_async_js', 10, 1);
51 51
     }
52 52
 
53 53
     /* optimize google fonts */
54
-    if ( !empty( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] ) && ( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] != "1" ) ) {
55
-        add_filter( 'wp_resource_hints', 'autoptimize_extra_gfonts_remove_dnsprefetch', 10, 2 );        
56
-        if ( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "2" ) {
57
-            add_filter('autoptimize_filter_css_removables','autoptimize_extra_remove_gfonts',10,1);
54
+    if (!empty($autoptimize_extra_options['autoptimize_extra_radio_field_4']) && ($autoptimize_extra_options['autoptimize_extra_radio_field_4'] != "1")) {
55
+        add_filter('wp_resource_hints', 'autoptimize_extra_gfonts_remove_dnsprefetch', 10, 2);        
56
+        if ($autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "2") {
57
+            add_filter('autoptimize_filter_css_removables', 'autoptimize_extra_remove_gfonts', 10, 1);
58 58
         } else {
59
-            add_filter('autoptimize_html_after_minify','autoptimize_extra_gfonts',10,1);
60
-            add_filter('autoptimize_extra_filter_tobepreconn','autoptimize_extra_preconnectgooglefonts',10,1);
59
+            add_filter('autoptimize_html_after_minify', 'autoptimize_extra_gfonts', 10, 1);
60
+            add_filter('autoptimize_extra_filter_tobepreconn', 'autoptimize_extra_preconnectgooglefonts', 10, 1);
61 61
         }
62 62
     }
63 63
     
64 64
     /* preconnect */
65
-    if ( !empty($autoptimize_extra_options['autoptimize_extra_text_field_2']) || has_filter('autoptimize_extra_filter_tobepreconn') ) {
66
-        add_filter( 'wp_resource_hints', 'autoptimize_extra_preconnect', 10, 2 );
65
+    if (!empty($autoptimize_extra_options['autoptimize_extra_text_field_2']) || has_filter('autoptimize_extra_filter_tobepreconn')) {
66
+        add_filter('wp_resource_hints', 'autoptimize_extra_preconnect', 10, 2);
67 67
     }
68 68
 }
69 69
 
70 70
 // disable emoji's functions
71 71
 function autoptimize_extra_disable_emojis() {
72 72
     // all actions related to emojis
73
-    remove_action( 'admin_print_styles', 'print_emoji_styles' );
74
-    remove_action( 'wp_head', 'print_emoji_detection_script', 7 );
75
-    remove_action( 'admin_print_scripts', 'print_emoji_detection_script' );
76
-    remove_action( 'wp_print_styles', 'print_emoji_styles' );
77
-    remove_filter( 'wp_mail', 'wp_staticize_emoji_for_email' );
78
-    remove_filter( 'the_content_feed', 'wp_staticize_emoji' );
79
-    remove_filter( 'comment_text_rss', 'wp_staticize_emoji' );
73
+    remove_action('admin_print_styles', 'print_emoji_styles');
74
+    remove_action('wp_head', 'print_emoji_detection_script', 7);
75
+    remove_action('admin_print_scripts', 'print_emoji_detection_script');
76
+    remove_action('wp_print_styles', 'print_emoji_styles');
77
+    remove_filter('wp_mail', 'wp_staticize_emoji_for_email');
78
+    remove_filter('the_content_feed', 'wp_staticize_emoji');
79
+    remove_filter('comment_text_rss', 'wp_staticize_emoji');
80 80
 
81 81
     // filter to remove TinyMCE emojis
82
-    add_filter( 'tiny_mce_plugins', 'autoptimize_extra_disable_emojis_tinymce' );
82
+    add_filter('tiny_mce_plugins', 'autoptimize_extra_disable_emojis_tinymce');
83 83
 
84 84
     // and remove dns-prefetch for emoji
85
-    add_filter( 'wp_resource_hints', 'autoptimize_extra_emojis_remove_dns_prefetch', 10, 2 );
85
+    add_filter('wp_resource_hints', 'autoptimize_extra_emojis_remove_dns_prefetch', 10, 2);
86 86
 }
87 87
 
88
-function autoptimize_extra_disable_emojis_tinymce( $plugins ) {
89
-    if ( is_array( $plugins ) ) {
90
-        return array_diff( $plugins, array( 'wpemoji' ) );
88
+function autoptimize_extra_disable_emojis_tinymce($plugins) {
89
+    if (is_array($plugins)) {
90
+        return array_diff($plugins, array('wpemoji'));
91 91
     } else {
92 92
         return array();
93 93
     }
94 94
 }
95 95
 
96
-function autoptimize_extra_emojis_remove_dns_prefetch( $urls, $relation_type ) {
97
-    $_emoji_svg_url = apply_filters( 'emoji_svg_url', 'https://s.w.org/images/core/emoji/' );
96
+function autoptimize_extra_emojis_remove_dns_prefetch($urls, $relation_type) {
97
+    $_emoji_svg_url = apply_filters('emoji_svg_url', 'https://s.w.org/images/core/emoji/');
98 98
 
99
-    return autoptimize_extra_remove_dns_prefetch( $urls, $relation_type, $_emoji_svg_url );
99
+    return autoptimize_extra_remove_dns_prefetch($urls, $relation_type, $_emoji_svg_url);
100 100
 }
101 101
 
102 102
 // remove query string function
103
-function autoptimize_extra_remove_qs( $src ) {
104
-    if ( strpos($src, '?ver=') ) {
105
-            $src = remove_query_arg( 'ver', $src );
103
+function autoptimize_extra_remove_qs($src) {
104
+    if (strpos($src, '?ver=')) {
105
+            $src = remove_query_arg('ver', $src);
106 106
     }
107 107
     return $src;
108 108
 }
@@ -114,19 +114,19 @@  discard block
 block discarded – undo
114 114
     // get exclusions
115 115
     $AO_JSexclArrayIn = array();
116 116
     if (!empty($in)) {
117
-        $AO_JSexclArrayIn = array_fill_keys(array_filter(array_map('trim',explode(",",$in))),"");
117
+        $AO_JSexclArrayIn = array_fill_keys(array_filter(array_map('trim', explode(",", $in))), "");
118 118
     }
119 119
     
120 120
     // get asyncs
121 121
     $_fromSetting = $autoptimize_extra_options['autoptimize_extra_text_field_3'];
122
-    $AO_asynced_JS = array_fill_keys(array_filter(array_map('trim',explode(",",$_fromSetting))),"");
123
-    $AO_async_flag = apply_filters('autoptimize_filter_extra_async',"async");
122
+    $AO_asynced_JS = array_fill_keys(array_filter(array_map('trim', explode(",", $_fromSetting))), "");
123
+    $AO_async_flag = apply_filters('autoptimize_filter_extra_async', "async");
124 124
     foreach ($AO_asynced_JS as $JSkey => $JSvalue) {
125 125
         $AO_asynced_JS[$JSkey] = $AO_async_flag;
126 126
     }
127 127
     
128 128
     // merge exclusions & asyncs in one array and return to AO API
129
-    $AO_excl_w_async = array_merge( $AO_JSexclArrayIn, $AO_asynced_JS );
129
+    $AO_excl_w_async = array_merge($AO_JSexclArrayIn, $AO_asynced_JS);
130 130
     return $AO_excl_w_async;
131 131
 }
132 132
 
@@ -135,25 +135,25 @@  discard block
 block discarded – undo
135 135
     $autoptimize_extra_options = autoptimize_extra_get_options();
136 136
     
137 137
     // get setting and store in array
138
-    $_to_be_preconnected = array_filter(array_map('trim',explode(",",$autoptimize_extra_options['autoptimize_extra_text_field_2'])));
139
-    $_to_be_preconnected = apply_filters( 'autoptimize_extra_filter_tobepreconn', $_to_be_preconnected );
138
+    $_to_be_preconnected = array_filter(array_map('trim', explode(",", $autoptimize_extra_options['autoptimize_extra_text_field_2'])));
139
+    $_to_be_preconnected = apply_filters('autoptimize_extra_filter_tobepreconn', $_to_be_preconnected);
140 140
 
141 141
     // walk array, extract domain and add to new array with crossorigin attribute
142 142
     foreach ($_to_be_preconnected as $_preconn_single) {
143 143
         $_preconn_parsed = parse_url($_preconn_single);
144 144
         
145
-        if ( is_array($_preconn_parsed) && empty($_preconn_parsed['scheme']) ) {
145
+        if (is_array($_preconn_parsed) && empty($_preconn_parsed['scheme'])) {
146 146
             $_preconn_domain = "//".$_preconn_parsed['host'];
147
-        } else if ( is_array($_preconn_parsed) ) {
147
+        } else if (is_array($_preconn_parsed)) {
148 148
             $_preconn_domain = $_preconn_parsed['scheme']."://".$_preconn_parsed['host'];
149 149
         }
150 150
         
151
-        if ( !empty($_preconn_domain) ) {
151
+        if (!empty($_preconn_domain)) {
152 152
             $_preconn_hint = array('href' => $_preconn_domain);
153 153
             // fonts don't get preconnected unless crossorigin flag is set, non-fonts don't get preconnected if origin flag is set
154 154
             // so hardcode fonts.gstatic.com to come with crossorigin and have filter to add other domains if needed
155
-            $_preconn_crossorigin = apply_filters( 'autoptimize_extra_filter_preconn_crossorigin', array('https://fonts.gstatic.com') );
156
-            if ( in_array( $_preconn_domain, $_preconn_crossorigin ) ) {
155
+            $_preconn_crossorigin = apply_filters('autoptimize_extra_filter_preconn_crossorigin', array('https://fonts.gstatic.com'));
156
+            if (in_array($_preconn_domain, $_preconn_crossorigin)) {
157 157
                 $_preconn_hint['crossorigin'] = 'anonymous';
158 158
             }
159 159
             $_new_hints[] = $_preconn_hint;
@@ -161,7 +161,7 @@  discard block
 block discarded – undo
161 161
     }
162 162
 
163 163
     // merge in wordpress' preconnect hints
164
-    if ( 'preconnect' === $relation_type && !empty($_new_hints) ) {
164
+    if ('preconnect' === $relation_type && !empty($_new_hints)) {
165 165
         $hints = array_merge($hints, $_new_hints);      
166 166
     }
167 167
     
@@ -169,10 +169,10 @@  discard block
 block discarded – undo
169 169
 }
170 170
 
171 171
 // google font functions
172
-function autoptimize_extra_gfonts_remove_dnsprefetch ( $urls, $relation_type ) {
172
+function autoptimize_extra_gfonts_remove_dnsprefetch($urls, $relation_type) {
173 173
     $_gfonts_url = "fonts.googleapis.com";
174 174
     
175
-    return autoptimize_extra_remove_dns_prefetch( $urls, $relation_type, $_gfonts_url );
175
+    return autoptimize_extra_remove_dns_prefetch($urls, $relation_type, $_gfonts_url);
176 176
 }
177 177
 
178 178
 function autoptimize_extra_remove_gfonts($in) { 
@@ -184,48 +184,48 @@  discard block
 block discarded – undo
184 184
     $autoptimize_extra_options = autoptimize_extra_get_options();
185 185
     
186 186
     // extract fonts, partly based on wp rocket's extraction code
187
-    $_without_comments = preg_replace( '/<!--(.*)-->/Uis', '', $in );
188
-    preg_match_all( '#<link(?:\s+(?:(?!href\s*=\s*)[^>])+)?(?:\s+href\s*=\s*([\'"])((?:https?:)?\/\/fonts\.googleapis\.com\/css(?:(?!\1).)+)\1)(?:\s+[^>]*)?>#iU', $_without_comments, $matches );
187
+    $_without_comments = preg_replace('/<!--(.*)-->/Uis', '', $in);
188
+    preg_match_all('#<link(?:\s+(?:(?!href\s*=\s*)[^>])+)?(?:\s+href\s*=\s*([\'"])((?:https?:)?\/\/fonts\.googleapis\.com\/css(?:(?!\1).)+)\1)(?:\s+[^>]*)?>#iU', $_without_comments, $matches);
189 189
 
190 190
     $i = 0;
191 191
     $fontsCollection = array();
192
-    if ( ! $matches[2] ) {
192
+    if (!$matches[2]) {
193 193
         return $in;
194 194
     }
195 195
     
196 196
     // store them in $fonts array
197
-    foreach ( $matches[2] as $font ) {
198
-        if ( ! preg_match( '/rel=["\']dns-prefetch["\']/', $matches[0][ $i ] ) ) {
197
+    foreach ($matches[2] as $font) {
198
+        if (!preg_match('/rel=["\']dns-prefetch["\']/', $matches[0][$i])) {
199 199
             // Get fonts name.
200
-            $font = str_replace( array( '%7C', '%7c' ) , '|', $font );
201
-            $font = explode( 'family=', $font );
202
-            $font = ( isset( $font[1] ) ) ? explode( '&', $font[1] ) : array();
200
+            $font = str_replace(array('%7C', '%7c'), '|', $font);
201
+            $font = explode('family=', $font);
202
+            $font = (isset($font[1])) ? explode('&', $font[1]) : array();
203 203
             // Add font to $fonts[$i] but make sure not to pollute with an empty family
204
-            $_thisfont = array_values( array_filter( explode( '|', reset( $font ) ) ) );
205
-            if ( !empty($_thisfont) ) {
204
+            $_thisfont = array_values(array_filter(explode('|', reset($font))));
205
+            if (!empty($_thisfont)) {
206 206
                 $fontsCollection[$i]["fonts"] = $_thisfont;
207 207
                 // And add subset if any
208
-                $subset = ( is_array( $font ) ) ? end( $font ) : '';
209
-                if ( false !== strpos( $subset, 'subset=' ) ) {
210
-                    $subset = explode( 'subset=', $subset );
211
-                    $fontsCollection[$i]["subsets"] = explode( ',', $subset[1] );
208
+                $subset = (is_array($font)) ? end($font) : '';
209
+                if (false !== strpos($subset, 'subset=')) {
210
+                    $subset = explode('subset=', $subset);
211
+                    $fontsCollection[$i]["subsets"] = explode(',', $subset[1]);
212 212
                 }
213 213
             }
214 214
             // And remove Google Fonts.
215
-            $in = str_replace( $matches[0][ $i ], '', $in );
215
+            $in = str_replace($matches[0][$i], '', $in);
216 216
         }
217 217
         $i++;
218 218
     }
219 219
 
220
-    $_fontsOut="";
221
-    if ( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "3" ) {
220
+    $_fontsOut = "";
221
+    if ($autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "3") {
222 222
         // aggregate & link
223
-        $_fontsString="";
224
-        $_subsetString="";
223
+        $_fontsString = "";
224
+        $_subsetString = "";
225 225
         foreach ($fontsCollection as $font) {
226
-            $_fontsString .= '|'.trim( implode( '|' , $font["fonts"] ), '|' );
227
-            if ( !empty( $font["subsets"] ) ) {
228
-                $_subsetString .= implode( ',', $font["subsets"] ); 
226
+            $_fontsString .= '|'.trim(implode('|', $font["fonts"]), '|');
227
+            if (!empty($font["subsets"])) {
228
+                $_subsetString .= implode(',', $font["subsets"]); 
229 229
             }
230 230
         }
231 231
                     
@@ -233,17 +233,17 @@  discard block
 block discarded – undo
233 233
             $_fontsString = $_fontsString."#038;subset=".$_subsetString;
234 234
         }
235 235
 
236
-        $_fontsString = str_replace( '|', '%7C', ltrim($_fontsString,'|') );
236
+        $_fontsString = str_replace('|', '%7C', ltrim($_fontsString, '|'));
237 237
         
238
-        if ( ! empty( $_fontsString ) ) {
239
-            $_fontsOut = '<link rel="stylesheet" id="ao_optimized_gfonts" href="https://fonts.googleapis.com/css?family=' . $_fontsString . '" />';
238
+        if (!empty($_fontsString)) {
239
+            $_fontsOut = '<link rel="stylesheet" id="ao_optimized_gfonts" href="https://fonts.googleapis.com/css?family='.$_fontsString.'" />';
240 240
         }
241
-    } else if ( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "4" ) {
241
+    } else if ($autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "4") {
242 242
         // aggregate & load async (webfont.js impl.)
243 243
         $_fontsArray = array();
244 244
         foreach ($fontsCollection as $_fonts) {
245
-            if ( !empty( $_fonts["subsets"] ) ) {
246
-                $_subset = implode(",",$_fonts["subsets"]);
245
+            if (!empty($_fonts["subsets"])) {
246
+                $_subset = implode(",", $_fonts["subsets"]);
247 247
                 foreach ($_fonts["fonts"] as $key => $_one_font) {
248 248
                     $_one_font = $_one_font.":".$_subset;
249 249
                     $_fonts["fonts"][$key] = $_one_font;
@@ -256,7 +256,7 @@  discard block
 block discarded – undo
256 256
         foreach ($_fontsArray as $_font) {
257 257
             $_fontsOut .= $_font."','";
258 258
         }
259
-        $_fontsOut = trim(trim($_fontsOut,"'"),",");
259
+        $_fontsOut = trim(trim($_fontsOut, "'"), ",");
260 260
         $_fontsOut .= '] },classes:false, events:false, timeout:1500};(function() {var wf = document.createElement(\'script\');wf.src=\'https://ajax.googleapis.com/ajax/libs/webfont/1/webfont.js\';wf.type=\'text/javascript\';wf.defer=\'true\';var s=document.getElementsByTagName(\'script\')[0];s.parentNode.insertBefore(wf, s);})();</script>';
261 261
     }
262 262
  
@@ -270,7 +270,7 @@  discard block
 block discarded – undo
270 270
 
271 271
     // preconnect to fonts.gstatic.com speed up download of static font-files
272 272
     $in[] = "https://fonts.gstatic.com";
273
-    if ( $autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "4" ) {
273
+    if ($autoptimize_extra_options['autoptimize_extra_radio_field_4'] == "4") {
274 274
         // and more preconnects for webfont.js
275 275
         $in[] = "https://ajax.googleapis.com";
276 276
         $in[] = "https://fonts.googleapis.com";
@@ -278,11 +278,11 @@  discard block
 block discarded – undo
278 278
     return $in;
279 279
 }
280 280
 
281
-function autoptimize_extra_remove_dns_prefetch( $urls, $relation_type, $_remove_url ) {
282
-        if ( 'dns-prefetch' == $relation_type ) {
283
-        $_count=0;
281
+function autoptimize_extra_remove_dns_prefetch($urls, $relation_type, $_remove_url) {
282
+        if ('dns-prefetch' == $relation_type) {
283
+        $_count = 0;
284 284
         foreach ($urls as $_url) {
285
-            if ( strpos($_url, $_remove_url) !== false ) {
285
+            if (strpos($_url, $_remove_url) !== false) {
286 286
                 unset($urls[$_count]);
287 287
             }
288 288
             $_count++;
@@ -294,12 +294,12 @@  discard block
 block discarded – undo
294 294
 
295 295
 /* admin page functions */
296 296
 function autoptimize_extra_admin() { 
297
-    add_submenu_page( null, 'autoptimize_extra', 'autoptimize_extra', 'manage_options', 'autoptimize_extra', 'autoptimize_extra_options_page' );
298
-    register_setting( 'autoptimize_extra_settings', 'autoptimize_extra_settings' );
297
+    add_submenu_page(null, 'autoptimize_extra', 'autoptimize_extra', 'manage_options', 'autoptimize_extra', 'autoptimize_extra_options_page');
298
+    register_setting('autoptimize_extra_settings', 'autoptimize_extra_settings');
299 299
 }
300 300
 
301 301
 function add_autoptimize_extra_tab($in) {
302
-    $in=array_merge($in,array('autoptimize_extra' => __('Extra','autoptimize')));
302
+    $in = array_merge($in, array('autoptimize_extra' => __('Extra', 'autoptimize')));
303 303
     return $in;
304 304
 }
305 305
 
@@ -313,74 +313,74 @@  discard block
 block discarded – undo
313 313
         #autoptimize_extra_descr{font-size: 120%;}
314 314
     </style>
315 315
     <div class="wrap">
316
-    <h1><?php _e('Autoptimize Settings','autoptimize'); ?></h1>
316
+    <h1><?php _e('Autoptimize Settings', 'autoptimize'); ?></h1>
317 317
     <?php echo autoptimizeConfig::ao_admin_tabs(); ?>
318 318
     <form id='ao_settings_form' action='options.php' method='post'>
319 319
         <?php settings_fields('autoptimize_extra_settings'); ?>
320
-        <h2><?php _e('Extra Auto-Optimizations','autoptimize'); ?></h2>
321
-        <span id='autoptimize_extra_descr'><?php _e('The following settings can improve your site\'s performance even more.','autoptimize'); ?></span>
320
+        <h2><?php _e('Extra Auto-Optimizations', 'autoptimize'); ?></h2>
321
+        <span id='autoptimize_extra_descr'><?php _e('The following settings can improve your site\'s performance even more.', 'autoptimize'); ?></span>
322 322
         <table class="form-table">
323 323
             <tr>
324
-                <th scope="row"><?php _e('Remove emojis','autoptimize'); ?></th>
324
+                <th scope="row"><?php _e('Remove emojis', 'autoptimize'); ?></th>
325 325
                 <td>
326
-                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_1]' <?php if (!empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_1']) && 1 == $autoptimize_extra_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>
326
+                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_1]' <?php if (!empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_1']) && 1 == $autoptimize_extra_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>
327 327
                 </td>
328 328
             </tr>
329 329
             <tr>
330
-                <th scope="row"><?php _e('Remove query strings from static resources','autoptimize'); ?></th>
330
+                <th scope="row"><?php _e('Remove query strings from static resources', 'autoptimize'); ?></th>
331 331
                 <td>
332
-                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_0]' <?php if (!empty( $autoptimize_extra_options['autoptimize_extra_checkbox_field_0']) && 1 == $autoptimize_extra_options['autoptimize_extra_checkbox_field_0']) echo 'checked="checked"'; ?> value='1'><?php _e('Removing query strings (or more specificaly the <code>ver</code> parameter) will not improve load time, but might improve performance scores.','autoptimize'); ?></label>
332
+                    <label><input type='checkbox' name='autoptimize_extra_settings[autoptimize_extra_checkbox_field_0]' <?php if (!empty($autoptimize_extra_options['autoptimize_extra_checkbox_field_0']) && 1 == $autoptimize_extra_options['autoptimize_extra_checkbox_field_0']) echo 'checked="checked"'; ?> value='1'><?php _e('Removing query strings (or more specificaly the <code>ver</code> parameter) will not improve load time, but might improve performance scores.', 'autoptimize'); ?></label>
333 333
                 </td>
334 334
             </tr>
335 335
             <tr>
336
-                <th scope="row"><?php _e('Google Fonts','autoptimize'); ?></th>
336
+                <th scope="row"><?php _e('Google Fonts', 'autoptimize'); ?></th>
337 337
                 <td>
338
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="1" <?php if (!in_array($_googlef,array(2,3,4))) {echo "checked"; } ?> ><?php _e('Leave as is','autoptimize'); ?><br/>
339
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="2" <?php checked(2, $_googlef, true); ?> ><?php _e('Remove Google Fonts','autoptimize'); ?><br/>
340
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="3" <?php checked(3, $_googlef, true); ?> ><?php _e('Combine and link in head','autoptimize'); ?><br/>
341
-                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="4" <?php checked(4, $_googlef, true); ?> ><?php _e('Combine and load fonts asynchronously with <a href="https://github.com/typekit/webfontloader#readme" target="_blank">webfont.js</a>','autoptimize'); ?><br/>
338
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="1" <?php if (!in_array($_googlef, array(2, 3, 4))) {echo "checked"; } ?> ><?php _e('Leave as is', 'autoptimize'); ?><br/>
339
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="2" <?php checked(2, $_googlef, true); ?> ><?php _e('Remove Google Fonts', 'autoptimize'); ?><br/>
340
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="3" <?php checked(3, $_googlef, true); ?> ><?php _e('Combine and link in head', 'autoptimize'); ?><br/>
341
+                    <input type="radio" name="autoptimize_extra_settings[autoptimize_extra_radio_field_4]" value="4" <?php checked(4, $_googlef, true); ?> ><?php _e('Combine and load fonts asynchronously with <a href="https://github.com/typekit/webfontloader#readme" target="_blank">webfont.js</a>', 'autoptimize'); ?><br/>
342 342
                 </td>
343 343
             </tr>
344 344
             <tr>
345
-                <th scope="row"><?php _e('Preconnect to 3rd party domains <em>(advanced users)</em>','autoptimize'); ?></th>
345
+                <th scope="row"><?php _e('Preconnect to 3rd party domains <em>(advanced users)</em>', 'autoptimize'); ?></th>
346 346
                 <td>
347
-                    <label><input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_2]' value='<?php echo $autoptimize_extra_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>
347
+                    <label><input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_2]' value='<?php echo $autoptimize_extra_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>
348 348
                 </td>
349 349
             </tr>
350 350
             <tr>
351
-                <th scope="row"><?php _e('Async Javascript-files <em>(advanced users)</em>','autoptimize'); ?></th>
351
+                <th scope="row"><?php _e('Async Javascript-files <em>(advanced users)</em>', 'autoptimize'); ?></th>
352 352
                 <td>
353
-                    <?php if ( function_exists('is_plugin_active') && is_plugin_active('async-javascript/async-javascript.php') ) {
354
-                        _e('You have "Async JavaScript" installed,','autoptimize');
355
-                        $asj_config_url="options-general.php?page=async-javascript";
356
-                        echo sprintf(' <a href="'.$asj_config_url.'">%s</a>', __('configuration of async javascript is best done there.','autoptimize'));
353
+                    <?php if (function_exists('is_plugin_active') && is_plugin_active('async-javascript/async-javascript.php')) {
354
+                        _e('You have "Async JavaScript" installed,', 'autoptimize');
355
+                        $asj_config_url = "options-general.php?page=async-javascript";
356
+                        echo sprintf(' <a href="'.$asj_config_url.'">%s</a>', __('configuration of async javascript is best done there.', 'autoptimize'));
357 357
                     } else { ?>
358 358
                         <input type='text' style='width:80%' name='autoptimize_extra_settings[autoptimize_extra_text_field_3]' value='<?php echo $autoptimize_extra_options['autoptimize_extra_text_field_3']; ?>'>
359 359
                         <br />
360 360
                         <?php 
361
-                        _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');
362
-                        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>"');
363
-                        $asj_install_url= network_admin_url()."plugin-install.php?s=async+javascript&tab=search&type=term";
364
-                        echo sprintf(' <a href="'.$asj_install_url.'">%s</a>', __('Click here to install and activate it.','autoptimize'));
361
+                        _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');
362
+                        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>"');
363
+                        $asj_install_url = network_admin_url()."plugin-install.php?s=async+javascript&tab=search&type=term";
364
+                        echo sprintf(' <a href="'.$asj_install_url.'">%s</a>', __('Click here to install and activate it.', 'autoptimize'));
365 365
                     } ?>
366 366
                 </td>
367 367
             </tr>
368 368
             <tr>
369
-                <th scope="row"><?php _e('Optimize YouTube videos','autoptimize'); ?></th>
369
+                <th scope="row"><?php _e('Optimize YouTube videos', 'autoptimize'); ?></th>
370 370
                 <td>
371
-                    <?php if ( function_exists('is_plugin_active') && is_plugin_active('wp-youtube-lyte/wp-youtube-lyte.php') ) {
372
-                        _e('Great, you have WP YouTube Lyte installed.','autoptimize');
373
-                        $lyte_config_url="options-general.php?page=lyte_settings_page";
374
-                        echo sprintf(' <a href="'.$lyte_config_url.'">%s</a>', __('Click here to configure it.','autoptimize'));
371
+                    <?php if (function_exists('is_plugin_active') && is_plugin_active('wp-youtube-lyte/wp-youtube-lyte.php')) {
372
+                        _e('Great, you have WP YouTube Lyte installed.', 'autoptimize');
373
+                        $lyte_config_url = "options-general.php?page=lyte_settings_page";
374
+                        echo sprintf(' <a href="'.$lyte_config_url.'">%s</a>', __('Click here to configure it.', 'autoptimize'));
375 375
                     } else {
376
-                        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>');
377
-                        $lyte_install_url= network_admin_url()."plugin-install.php?s=lyte&tab=search&type=term";
378
-                        echo sprintf(' <a href="'.$lyte_install_url.'">%s</a>', __('Click here to install and activate it.','autoptimize'));
376
+                        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>');
377
+                        $lyte_install_url = network_admin_url()."plugin-install.php?s=lyte&tab=search&type=term";
378
+                        echo sprintf(' <a href="'.$lyte_install_url.'">%s</a>', __('Click here to install and activate it.', 'autoptimize'));
379 379
                     } ?>
380 380
                 </td>
381 381
             </tr>
382 382
         </table>
383
-        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e('Save Changes','autoptimize') ?>" /></p>
383
+        <p class="submit"><input type="submit" name="submit" id="submit" class="button button-primary" value="<?php _e('Save Changes', 'autoptimize') ?>" /></p>
384 384
     </form>
385 385
     <?php
386 386
 }
Please login to merge, or discard this patch.
classes/autoptimizeStyles.php 1 patch
Spacing   +191 added lines, -191 removed lines patch added patch discarded remove patch
@@ -1,5 +1,5 @@  discard block
 block discarded – undo
1 1
 <?php
2
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
2
+if (!defined('ABSPATH')) exit; // Exit if accessed directly
3 3
 
4 4
 class autoptimizeStyles extends autoptimizeBase {
5 5
 
@@ -23,62 +23,62 @@  discard block
 block discarded – undo
23 23
 
24 24
     //Reads the page and collects style tags
25 25
     public function read($options) {
26
-        $noptimizeCSS = apply_filters( 'autoptimize_filter_css_noptimize', false, $this->content );
26
+        $noptimizeCSS = apply_filters('autoptimize_filter_css_noptimize', false, $this->content);
27 27
         if ($noptimizeCSS) return false;
28 28
 
29
-        $whitelistCSS = apply_filters( 'autoptimize_filter_css_whitelist', '', $this->content );
29
+        $whitelistCSS = apply_filters('autoptimize_filter_css_whitelist', '', $this->content);
30 30
         if (!empty($whitelistCSS)) {
31
-            $this->whitelist = array_filter(array_map('trim',explode(",",$whitelistCSS)));
31
+            $this->whitelist = array_filter(array_map('trim', explode(",", $whitelistCSS)));
32 32
         }
33 33
         
34
-        $removableCSS = apply_filters( 'autoptimize_filter_css_removables','' );
34
+        $removableCSS = apply_filters('autoptimize_filter_css_removables', '');
35 35
         if (!empty($removableCSS)) {
36
-            $this->cssremovables = array_filter(array_map('trim',explode(",",$removableCSS)));
36
+            $this->cssremovables = array_filter(array_map('trim', explode(",", $removableCSS)));
37 37
         }
38 38
 
39
-        $this->cssinlinesize = apply_filters('autoptimize_filter_css_inlinesize',256);
39
+        $this->cssinlinesize = apply_filters('autoptimize_filter_css_inlinesize', 256);
40 40
 
41 41
         // filter to "late inject minified CSS", default to true for now (it is faster)
42
-        $this->inject_min_late = apply_filters('autoptimize_filter_css_inject_min_late',true);
42
+        $this->inject_min_late = apply_filters('autoptimize_filter_css_inject_min_late', true);
43 43
 
44 44
         // Remove everything that's not the header
45
-        if ( apply_filters('autoptimize_filter_css_justhead',$options['justhead']) == true ) {
46
-            $content = explode('</head>',$this->content,2);
45
+        if (apply_filters('autoptimize_filter_css_justhead', $options['justhead']) == true) {
46
+            $content = explode('</head>', $this->content, 2);
47 47
             $this->content = $content[0].'</head>';
48 48
             $this->restofcontent = $content[1];
49 49
         }
50 50
 
51 51
         // include inline?
52
-        if( apply_filters('autoptimize_css_include_inline',$options['include_inline']) == true ) {
52
+        if (apply_filters('autoptimize_css_include_inline', $options['include_inline']) == true) {
53 53
             $this->include_inline = true;
54 54
         }
55 55
         
56 56
         // what CSS shouldn't be autoptimized
57 57
         $excludeCSS = $options['css_exclude'];
58
-        $excludeCSS = apply_filters( 'autoptimize_filter_css_exclude', $excludeCSS, $this->content );
59
-        if ($excludeCSS!=="") {
60
-            $this->dontmove = array_filter(array_map('trim',explode(",",$excludeCSS)));
58
+        $excludeCSS = apply_filters('autoptimize_filter_css_exclude', $excludeCSS, $this->content);
59
+        if ($excludeCSS !== "") {
60
+            $this->dontmove = array_filter(array_map('trim', explode(",", $excludeCSS)));
61 61
         } else {
62 62
             $this->dontmove = array();
63 63
         }
64 64
         
65 65
         // forcefully exclude CSS with data-noptimize attrib
66
-        $this->dontmove[]="data-noptimize";
66
+        $this->dontmove[] = "data-noptimize";
67 67
 
68 68
         // should we defer css?
69 69
         // value: true/ false
70 70
         $this->defer = $options['defer'];
71
-        $this->defer = apply_filters( 'autoptimize_filter_css_defer', $this->defer, $this->content );
71
+        $this->defer = apply_filters('autoptimize_filter_css_defer', $this->defer, $this->content);
72 72
 
73 73
         // should we inline while deferring?
74 74
         // value: inlined CSS
75 75
         $this->defer_inline = $options['defer_inline'];
76
-        $this->defer_inline = apply_filters( 'autoptimize_filter_css_defer_inline', $this->defer_inline, $this->content );
76
+        $this->defer_inline = apply_filters('autoptimize_filter_css_defer_inline', $this->defer_inline, $this->content);
77 77
 
78 78
         // should we inline?
79 79
         // value: true/ false
80 80
         $this->inline = $options['inline'];
81
-        $this->inline = apply_filters( 'autoptimize_filter_css_inline', $this->inline, $this->content );
81
+        $this->inline = apply_filters('autoptimize_filter_css_inline', $this->inline, $this->content);
82 82
         
83 83
         // get cdn url
84 84
         $this->cdn_url = $options['cdn_url'];
@@ -90,10 +90,10 @@  discard block
 block discarded – undo
90 90
         $this->content = $this->hide_noptimize($this->content);
91 91
         
92 92
         // exclude (no)script, as those may contain CSS which should be left as is
93
-        if ( strpos( $this->content, '<script' ) !== false ) { 
93
+        if (strpos($this->content, '<script') !== false) { 
94 94
             $this->content = preg_replace_callback(
95 95
                 '#<(?:no)?script.*?<\/(?:no)?script>#is',
96
-                function ($matches) {return "%%SCRIPT" . AUTOPTIMIZE_HASH . "%%" . base64_encode($matches[0]) . "%%SCRIPT%%";},
96
+                function($matches) {return "%%SCRIPT".AUTOPTIMIZE_HASH."%%".base64_encode($matches[0])."%%SCRIPT%%"; },
97 97
                 $this->content
98 98
             );
99 99
         }
@@ -105,65 +105,65 @@  discard block
 block discarded – undo
105 105
         $this->content = $this->hide_comments($this->content);
106 106
         
107 107
         // Get <style> and <link>
108
-        if(preg_match_all('#(<style[^>]*>.*</style>)|(<link[^>]*stylesheet[^>]*>)#Usmi',$this->content,$matches)) {
109
-            foreach($matches[0] as $tag) {
110
-                if ($this->isremovable($tag,$this->cssremovables)) {
111
-                    $this->content = str_replace($tag,'',$this->content);
108
+        if (preg_match_all('#(<style[^>]*>.*</style>)|(<link[^>]*stylesheet[^>]*>)#Usmi', $this->content, $matches)) {
109
+            foreach ($matches[0] as $tag) {
110
+                if ($this->isremovable($tag, $this->cssremovables)) {
111
+                    $this->content = str_replace($tag, '', $this->content);
112 112
                 } else if ($this->ismovable($tag)) {
113 113
                     // Get the media
114
-                    if(strpos($tag,'media=')!==false) {
115
-                        preg_match('#media=(?:"|\')([^>]*)(?:"|\')#Ui',$tag,$medias);
116
-                        $medias = explode(',',$medias[1]);
114
+                    if (strpos($tag, 'media=') !== false) {
115
+                        preg_match('#media=(?:"|\')([^>]*)(?:"|\')#Ui', $tag, $medias);
116
+                        $medias = explode(',', $medias[1]);
117 117
                         $media = array();
118
-                        foreach($medias as $elem) {
119
-                            if (empty($elem)) { $elem="all"; }
118
+                        foreach ($medias as $elem) {
119
+                            if (empty($elem)) { $elem = "all"; }
120 120
                             $media[] = $elem;
121 121
                         }
122 122
                     } else {
123 123
                         // No media specified - applies to all
124 124
                         $media = array('all');
125 125
                     }
126
-                    $media = apply_filters( 'autoptimize_filter_css_tagmedia',$media,$tag );
126
+                    $media = apply_filters('autoptimize_filter_css_tagmedia', $media, $tag);
127 127
                 
128
-                    if(preg_match('#<link.*href=("|\')(.*)("|\')#Usmi',$tag,$source)) {
128
+                    if (preg_match('#<link.*href=("|\')(.*)("|\')#Usmi', $tag, $source)) {
129 129
                         // <link>
130
-                        $explUrl = explode('?',$source[2],2);
130
+                        $explUrl = explode('?', $source[2], 2);
131 131
                         $url = $explUrl[0];
132 132
                         $path = $this->getpath($url);
133 133
                         
134
-                        if($path!==false && preg_match('#\.css$#',$path)) {
134
+                        if ($path !== false && preg_match('#\.css$#', $path)) {
135 135
                             // Good link
136
-                            $this->css[] = array($media,$path);
137
-                        }else{
136
+                            $this->css[] = array($media, $path);
137
+                        } else {
138 138
                             // Link is dynamic (.php etc)
139 139
                             $tag = '';
140 140
                         }
141 141
                     } else {
142 142
                         // inline css in style tags can be wrapped in comment tags, so restore comments
143 143
                         $tag = $this->restore_comments($tag);
144
-                        preg_match('#<style.*>(.*)</style>#Usmi',$tag,$code);
144
+                        preg_match('#<style.*>(.*)</style>#Usmi', $tag, $code);
145 145
 
146 146
                         // and re-hide them to be able to to the removal based on tag
147 147
                         $tag = $this->hide_comments($tag);
148 148
 
149
-                        if ( $this->include_inline ) {
150
-                            $code = preg_replace('#^.*<!\[CDATA\[(?:\s*\*/)?(.*)(?://|/\*)\s*?\]\]>.*$#sm','$1',$code[1]);
151
-                            $this->css[] = array($media,'INLINE;'.$code);
149
+                        if ($this->include_inline) {
150
+                            $code = preg_replace('#^.*<!\[CDATA\[(?:\s*\*/)?(.*)(?://|/\*)\s*?\]\]>.*$#sm', '$1', $code[1]);
151
+                            $this->css[] = array($media, 'INLINE;'.$code);
152 152
                         } else {
153 153
                             $tag = '';
154 154
                         }
155 155
                     }
156 156
                     
157 157
                     // Remove the original style tag
158
-                    $this->content = str_replace($tag,'',$this->content);
158
+                    $this->content = str_replace($tag, '', $this->content);
159 159
                 } else {
160 160
 					// excluded CSS, minify if getpath 
161
-					if (preg_match('#<link.*href=("|\')(.*)("|\')#Usmi',$tag,$source)) {
162
-						$explUrl = explode('?',$source[2],2);
161
+					if (preg_match('#<link.*href=("|\')(.*)("|\')#Usmi', $tag, $source)) {
162
+						$explUrl = explode('?', $source[2], 2);
163 163
                         $url = $explUrl[0];
164 164
                         $path = $this->getpath($url);
165 165
  					
166
-						if ($path && apply_filters('autoptimize_filter_css_minify_excluded',false)) {
166
+						if ($path && apply_filters('autoptimize_filter_css_minify_excluded', false)) {
167 167
 							$_CachedMinifiedUrl = $this->minify_single($path);
168 168
 
169 169
 							if (!empty($_CachedMinifiedUrl)) {
@@ -174,12 +174,12 @@  discard block
 block discarded – undo
174 174
 							}
175 175
 							
176 176
 							// remove querystring from URL
177
-							if ( !empty($explUrl[1]) ) {
178
-								$newTag = str_replace("?".$explUrl[1],"",$newTag);
177
+							if (!empty($explUrl[1])) {
178
+								$newTag = str_replace("?".$explUrl[1], "", $newTag);
179 179
 							}
180 180
 
181 181
 							// and replace
182
-							$this->content = str_replace($tag,$newTag,$this->content);
182
+							$this->content = str_replace($tag, $newTag, $this->content);
183 183
 						}
184 184
 					}					
185 185
 				}
@@ -192,31 +192,31 @@  discard block
 block discarded – undo
192 192
     
193 193
     // Joins and optimizes CSS
194 194
     public function minify() {
195
-        foreach($this->css as $group) {
196
-            list($media,$css) = $group;
197
-            if(preg_match('#^INLINE;#',$css)) {
195
+        foreach ($this->css as $group) {
196
+            list($media, $css) = $group;
197
+            if (preg_match('#^INLINE;#', $css)) {
198 198
                 // <style>
199
-                $css = preg_replace('#^INLINE;#','',$css);
200
-                $css = $this->fixurls(ABSPATH.'/index.php',$css);
201
-                $tmpstyle = apply_filters( 'autoptimize_css_individual_style', $css, "" );
202
-                if ( has_filter('autoptimize_css_individual_style') && !empty($tmpstyle) ) {
203
-                    $css=$tmpstyle;
204
-                    $this->alreadyminified=true;
199
+                $css = preg_replace('#^INLINE;#', '', $css);
200
+                $css = $this->fixurls(ABSPATH.'/index.php', $css);
201
+                $tmpstyle = apply_filters('autoptimize_css_individual_style', $css, "");
202
+                if (has_filter('autoptimize_css_individual_style') && !empty($tmpstyle)) {
203
+                    $css = $tmpstyle;
204
+                    $this->alreadyminified = true;
205 205
                 }
206 206
             } else {
207 207
                 //<link>
208
-                if($css !== false && file_exists($css) && is_readable($css)) {
208
+                if ($css !== false && file_exists($css) && is_readable($css)) {
209 209
                     $cssPath = $css;
210 210
                     $cssContents = file_get_contents($cssPath);
211 211
                     $cssHash = md5($cssContents);
212
-                    $css = $this->fixurls($cssPath,$cssContents);
213
-                    $css = preg_replace('/\x{EF}\x{BB}\x{BF}/','',$css);
214
-                    $tmpstyle = apply_filters( 'autoptimize_css_individual_style', $css, $cssPath );
212
+                    $css = $this->fixurls($cssPath, $cssContents);
213
+                    $css = preg_replace('/\x{EF}\x{BB}\x{BF}/', '', $css);
214
+                    $tmpstyle = apply_filters('autoptimize_css_individual_style', $css, $cssPath);
215 215
                     if (has_filter('autoptimize_css_individual_style') && !empty($tmpstyle)) {
216
-                        $css=$tmpstyle;
217
-                        $this->alreadyminified=true;
218
-                    } else if ($this->can_inject_late($cssPath,$css)) {
219
-                        $css="/*!%%INJECTLATER%%".base64_encode($cssPath)."|".$cssHash."%%INJECTLATER%%*/";
216
+                        $css = $tmpstyle;
217
+                        $this->alreadyminified = true;
218
+                    } else if ($this->can_inject_late($cssPath, $css)) {
219
+                        $css = "/*!%%INJECTLATER%%".base64_encode($cssPath)."|".$cssHash."%%INJECTLATER%%*/";
220 220
                     }
221 221
                 } else {
222 222
                     // Couldn't read CSS. Maybe getpath isn't working?
@@ -224,8 +224,8 @@  discard block
 block discarded – undo
224 224
                 }
225 225
             }
226 226
             
227
-            foreach($media as $elem) {
228
-                if(!isset($this->csscode[$elem]))
227
+            foreach ($media as $elem) {
228
+                if (!isset($this->csscode[$elem]))
229 229
                     $this->csscode[$elem] = '';
230 230
                 $this->csscode[$elem] .= "\n/*FILESTART*/".$css;
231 231
             }
@@ -234,12 +234,12 @@  discard block
 block discarded – undo
234 234
         // Check for duplicate code
235 235
         $md5list = array();
236 236
         $tmpcss = $this->csscode;
237
-        foreach($tmpcss as $media => $code) {
237
+        foreach ($tmpcss as $media => $code) {
238 238
             $md5sum = md5($code);
239 239
             $medianame = $media;
240
-            foreach($md5list as $med => $sum) {
240
+            foreach ($md5list as $med => $sum) {
241 241
                 // If same code
242
-                if($sum === $md5sum) {
242
+                if ($sum === $md5sum) {
243 243
                     //Add the merged code
244 244
                     $medianame = $med.', '.$media;
245 245
                     $this->csscode[$medianame] = $code;
@@ -259,30 +259,30 @@  discard block
 block discarded – undo
259 259
             $external_imports = "";
260 260
 
261 261
             // remove comments to avoid importing commented-out imports
262
-            $thiscss_nocomments = preg_replace('#/\*.*\*/#Us','',$thiscss);
262
+            $thiscss_nocomments = preg_replace('#/\*.*\*/#Us', '', $thiscss);
263 263
 
264
-            while(preg_match_all('#@import +(?:url)?(?:(?:\\(([\"\']?)(?:[^\"\')]+)\\1\\)|([\"\'])(?:[^\"\']+)\\2)(?:[^,;\"\']+(?:,[^,;\"\']+)*)?)(?:;)#m',$thiscss_nocomments,$matches)) {
265
-                foreach($matches[0] as $import)    {
266
-                    if ($this->isremovable($import,$this->cssremovables)) {
267
-                        $thiscss = str_replace($import,'',$thiscss);
264
+            while (preg_match_all('#@import +(?:url)?(?:(?:\\(([\"\']?)(?:[^\"\')]+)\\1\\)|([\"\'])(?:[^\"\']+)\\2)(?:[^,;\"\']+(?:,[^,;\"\']+)*)?)(?:;)#m', $thiscss_nocomments, $matches)) {
265
+                foreach ($matches[0] as $import) {
266
+                    if ($this->isremovable($import, $this->cssremovables)) {
267
+                        $thiscss = str_replace($import, '', $thiscss);
268 268
                         $import_ok = true;
269 269
                     } else {
270
-                        $url = trim(preg_replace('#^.*((?:https?:|ftp:)?//.*\.css).*$#','$1',trim($import))," \t\n\r\0\x0B\"'");
270
+                        $url = trim(preg_replace('#^.*((?:https?:|ftp:)?//.*\.css).*$#', '$1', trim($import)), " \t\n\r\0\x0B\"'");
271 271
                         $path = $this->getpath($url);
272 272
                         $import_ok = false;
273 273
                         if (file_exists($path) && is_readable($path)) {
274
-                            $code = addcslashes($this->fixurls($path,file_get_contents($path)),"\\");
275
-                            $code = preg_replace('/\x{EF}\x{BB}\x{BF}/','',$code);
276
-                            $tmpstyle = apply_filters( 'autoptimize_css_individual_style', $code, "" );
277
-                            if ( has_filter('autoptimize_css_individual_style') && !empty($tmpstyle)) {
278
-                                $code=$tmpstyle;
279
-                                $this->alreadyminified=true;
280
-                            } else if ($this->can_inject_late($path,$code)) {
281
-                                $code="/*!%%INJECTLATER".AUTOPTIMIZE_HASH."%%".base64_encode($path)."|".md5($code)."%%INJECTLATER%%*/";
274
+                            $code = addcslashes($this->fixurls($path, file_get_contents($path)), "\\");
275
+                            $code = preg_replace('/\x{EF}\x{BB}\x{BF}/', '', $code);
276
+                            $tmpstyle = apply_filters('autoptimize_css_individual_style', $code, "");
277
+                            if (has_filter('autoptimize_css_individual_style') && !empty($tmpstyle)) {
278
+                                $code = $tmpstyle;
279
+                                $this->alreadyminified = true;
280
+                            } else if ($this->can_inject_late($path, $code)) {
281
+                                $code = "/*!%%INJECTLATER".AUTOPTIMIZE_HASH."%%".base64_encode($path)."|".md5($code)."%%INJECTLATER%%*/";
282 282
                             }
283 283
                             
284
-                            if(!empty($code)) {
285
-                                $tmp_thiscss = preg_replace('#(/\*FILESTART\*/.*)'.preg_quote($import,'#').'#Us','/*FILESTART2*/'.$code.'$1',$thiscss);
284
+                            if (!empty($code)) {
285
+                                $tmp_thiscss = preg_replace('#(/\*FILESTART\*/.*)'.preg_quote($import, '#').'#Us', '/*FILESTART2*/'.$code.'$1', $thiscss);
286 286
                                 if (!empty($tmp_thiscss)) {
287 287
                                     $thiscss = $tmp_thiscss;
288 288
                                     $import_ok = true;
@@ -296,31 +296,31 @@  discard block
 block discarded – undo
296 296
                     if (!$import_ok) {
297 297
                         // external imports and general fall-back
298 298
                         $external_imports .= $import;
299
-                        $thiscss = str_replace($import,'',$thiscss);
299
+                        $thiscss = str_replace($import, '', $thiscss);
300 300
                         $fiximports = true;
301 301
                     }
302 302
                 }
303
-                $thiscss = preg_replace('#/\*FILESTART\*/#','',$thiscss);
304
-                $thiscss = preg_replace('#/\*FILESTART2\*/#','/*FILESTART*/',$thiscss);
303
+                $thiscss = preg_replace('#/\*FILESTART\*/#', '', $thiscss);
304
+                $thiscss = preg_replace('#/\*FILESTART2\*/#', '/*FILESTART*/', $thiscss);
305 305
                 
306 306
                 // and update $thiscss_nocomments before going into next iteration in while loop
307
-                $thiscss_nocomments=preg_replace('#/\*.*\*/#Us','',$thiscss);
307
+                $thiscss_nocomments = preg_replace('#/\*.*\*/#Us', '', $thiscss);
308 308
             }
309 309
             unset($thiscss_nocomments);
310 310
 
311 311
             // add external imports to top of aggregated CSS
312
-            if($fiximports) {
313
-                $thiscss=$external_imports.$thiscss;
312
+            if ($fiximports) {
313
+                $thiscss = $external_imports.$thiscss;
314 314
             }
315 315
         }
316 316
         unset($thiscss);
317 317
         // $this->csscode has all the uncompressed code now. 
318
-        foreach($this->csscode as &$code) {
318
+        foreach ($this->csscode as &$code) {
319 319
             // Check for already-minified code
320 320
             $hash = md5($code);
321
-            do_action( 'autoptimize_action_css_hash', $hash );
322
-            $ccheck = new autoptimizeCache($hash,'css');
323
-            if($ccheck->check()) {
321
+            do_action('autoptimize_action_css_hash', $hash);
322
+            $ccheck = new autoptimizeCache($hash, 'css');
323
+            if ($ccheck->check()) {
324 324
                 $code = $ccheck->retrieve();
325 325
                 $this->hashmap[md5($code)] = $hash;
326 326
                 continue;
@@ -329,44 +329,44 @@  discard block
 block discarded – undo
329 329
 
330 330
             // Do the imaging!
331 331
             $imgreplace = array();
332
-            preg_match_all( self::ASSETS_REGEX, $code, $matches );
332
+            preg_match_all(self::ASSETS_REGEX, $code, $matches);
333 333
 
334
-            if ( ($this->datauris == true) && (function_exists('base64_encode')) && (is_array($matches)) ) {
335
-                foreach($matches[1] as $count => $quotedurl) {
336
-                    $iurl = trim($quotedurl," \t\n\r\0\x0B\"'");
334
+            if (($this->datauris == true) && (function_exists('base64_encode')) && (is_array($matches))) {
335
+                foreach ($matches[1] as $count => $quotedurl) {
336
+                    $iurl = trim($quotedurl, " \t\n\r\0\x0B\"'");
337 337
 
338 338
                     // if querystring, remove it from url
339
-                    if (strpos($iurl,'?') !== false) { $iurl = strtok($iurl,'?'); }
339
+                    if (strpos($iurl, '?') !== false) { $iurl = strtok($iurl, '?'); }
340 340
                     
341 341
                     $ipath = $this->getpath($iurl);
342 342
 
343 343
                     $datauri_max_size = 4096;
344
-                    $datauri_max_size = (int) apply_filters( 'autoptimize_filter_css_datauri_maxsize', $datauri_max_size );
345
-                    $datauri_exclude = apply_filters( 'autoptimize_filter_css_datauri_exclude', "");
344
+                    $datauri_max_size = (int) apply_filters('autoptimize_filter_css_datauri_maxsize', $datauri_max_size);
345
+                    $datauri_exclude = apply_filters('autoptimize_filter_css_datauri_exclude', "");
346 346
                     if (!empty($datauri_exclude)) {
347
-                        $no_datauris=array_filter(array_map('trim',explode(",",$datauri_exclude)));
347
+                        $no_datauris = array_filter(array_map('trim', explode(",", $datauri_exclude)));
348 348
                         foreach ($no_datauris as $no_datauri) {
349
-                            if (strpos($iurl,$no_datauri)!==false) {
350
-                                $ipath=false;
349
+                            if (strpos($iurl, $no_datauri) !== false) {
350
+                                $ipath = false;
351 351
                                 break;
352 352
                             }
353 353
                         }
354 354
                     }
355 355
 
356
-                    if($ipath != false && preg_match('#\.(jpe?g|png|gif|bmp)$#i',$ipath) && file_exists($ipath) && is_readable($ipath) && filesize($ipath) <= $datauri_max_size) {
357
-                        $ihash=md5($ipath);
358
-                        $icheck = new autoptimizeCache($ihash,'img');
359
-                        if($icheck->check()) {
356
+                    if ($ipath != false && preg_match('#\.(jpe?g|png|gif|bmp)$#i', $ipath) && file_exists($ipath) && is_readable($ipath) && filesize($ipath) <= $datauri_max_size) {
357
+                        $ihash = md5($ipath);
358
+                        $icheck = new autoptimizeCache($ihash, 'img');
359
+                        if ($icheck->check()) {
360 360
                             // we have the base64 image in cache
361
-                            $headAndData=$icheck->retrieve();
362
-                            $_base64data=explode(";base64,",$headAndData);
363
-                            $base64data=$_base64data[1];
361
+                            $headAndData = $icheck->retrieve();
362
+                            $_base64data = explode(";base64,", $headAndData);
363
+                            $base64data = $_base64data[1];
364 364
                         } else {
365 365
                             // It's an image and we don't have it in cache, get the type
366
-                            $explA=explode('.',$ipath);
367
-                            $type=end($explA);
366
+                            $explA = explode('.', $ipath);
367
+                            $type = end($explA);
368 368
 
369
-                            switch($type) {
369
+                            switch ($type) {
370 370
                                 case 'jpeg':
371 371
                                     $dataurihead = 'data:image/jpeg;base64,';
372 372
                                     break;
@@ -388,42 +388,42 @@  discard block
 block discarded – undo
388 388
 
389 389
                             // Encode the data
390 390
                             $base64data = base64_encode(file_get_contents($ipath));
391
-                            $headAndData=$dataurihead.$base64data;
391
+                            $headAndData = $dataurihead.$base64data;
392 392
 
393 393
                             // Save in cache
394
-                            $icheck->cache($headAndData,"text/plain");
394
+                            $icheck->cache($headAndData, "text/plain");
395 395
                         }
396 396
                         unset($icheck);
397 397
 
398 398
                         // Add it to the list for replacement
399
-                        $imgreplace[$matches[0][$count]] = str_replace($quotedurl,$headAndData,$matches[0][$count]);
399
+                        $imgreplace[$matches[0][$count]] = str_replace($quotedurl, $headAndData, $matches[0][$count]);
400 400
                     } else {
401 401
                         // just cdn the URL if applicable
402 402
                         if (!empty($this->cdn_url)) {
403
-                            $imgreplace[$matches[0][$count]] = str_replace($quotedurl,$this->maybe_cdn_urls($quotedurl),$matches[0][$count]);
403
+                            $imgreplace[$matches[0][$count]] = str_replace($quotedurl, $this->maybe_cdn_urls($quotedurl), $matches[0][$count]);
404 404
 						}
405 405
                     }
406 406
                 }
407 407
             } else if ((is_array($matches)) && (!empty($this->cdn_url))) {
408 408
                 // change urls to cdn-url
409
-                foreach($matches[1] as $count => $quotedurl) {
410
-                    $imgreplace[$matches[0][$count]] = str_replace($quotedurl,$this->maybe_cdn_urls($quotedurl),$matches[0][$count]);
409
+                foreach ($matches[1] as $count => $quotedurl) {
410
+                    $imgreplace[$matches[0][$count]] = str_replace($quotedurl, $this->maybe_cdn_urls($quotedurl), $matches[0][$count]);
411 411
                 }
412 412
             }
413 413
             
414
-            if(!empty($imgreplace)) {
415
-                $code = str_replace(array_keys($imgreplace),array_values($imgreplace),$code);
414
+            if (!empty($imgreplace)) {
415
+                $code = str_replace(array_keys($imgreplace), array_values($imgreplace), $code);
416 416
             }
417 417
             
418 418
             // Minify
419
-            if (($this->alreadyminified!==true) && (apply_filters( "autoptimize_css_do_minify", true))) {
419
+            if (($this->alreadyminified !== true) && (apply_filters("autoptimize_css_do_minify", true))) {
420 420
                 if (class_exists('Minify_CSS_Compressor')) {
421 421
                     $tmp_code = trim(Minify_CSS_Compressor::process($code));
422
-                } else if(class_exists('CSSmin')) {
422
+                } else if (class_exists('CSSmin')) {
423 423
                     $cssmin = new CSSmin();
424
-                    if (method_exists($cssmin,"run")) {
424
+                    if (method_exists($cssmin, "run")) {
425 425
                         $tmp_code = trim($cssmin->run($code));
426
-                    } elseif (@is_callable(array($cssmin,"minify"))) {
426
+                    } elseif (@is_callable(array($cssmin, "minify"))) {
427 427
                         $tmp_code = trim(CssMin::minify($code));
428 428
                     }
429 429
                 }
@@ -435,7 +435,7 @@  discard block
 block discarded – undo
435 435
             
436 436
             $code = $this->inject_minified($code);
437 437
             
438
-            $tmp_code = apply_filters( 'autoptimize_css_after_minify', $code );
438
+            $tmp_code = apply_filters('autoptimize_css_after_minify', $code);
439 439
             if (!empty($tmp_code)) {
440 440
                 $code = $tmp_code;
441 441
                 unset($tmp_code);
@@ -450,13 +450,13 @@  discard block
 block discarded – undo
450 450
     //Caches the CSS in uncompressed, deflated and gzipped form.
451 451
     public function cache() {
452 452
         // CSS cache
453
-        foreach($this->csscode as $media => $code) {
453
+        foreach ($this->csscode as $media => $code) {
454 454
             $md5 = $this->hashmap[md5($code)];
455 455
                 
456
-            $cache = new autoptimizeCache($md5,'css');
457
-            if(!$cache->check()) {
456
+            $cache = new autoptimizeCache($md5, 'css');
457
+            if (!$cache->check()) {
458 458
                 // Cache our code
459
-                $cache->cache($code,'text/css');
459
+                $cache->cache($code, 'text/css');
460 460
             }
461 461
             $this->url[$media] = AUTOPTIMIZE_CACHE_URL.$cache->getname();
462 462
         }
@@ -471,10 +471,10 @@  discard block
 block discarded – undo
471 471
         $this->content = $this->restore_comments($this->content);
472 472
         
473 473
         // restore (no)script
474
-        if ( strpos( $this->content, '%%SCRIPT%%' ) !== false ) { 
474
+        if (strpos($this->content, '%%SCRIPT%%') !== false) { 
475 475
             $this->content = preg_replace_callback(
476 476
                 '#%%SCRIPT'.AUTOPTIMIZE_HASH.'%%(.*?)%%SCRIPT%%#is',
477
-                function ($matches) {return base64_decode($matches[1]);},
477
+                function($matches) {return base64_decode($matches[1]); },
478 478
                 $this->content
479 479
             );
480 480
         }
@@ -483,55 +483,55 @@  discard block
 block discarded – undo
483 483
         $this->content = $this->restore_noptimize($this->content);
484 484
         
485 485
         //Restore the full content
486
-        if(!empty($this->restofcontent)) {
486
+        if (!empty($this->restofcontent)) {
487 487
             $this->content .= $this->restofcontent;
488 488
             $this->restofcontent = '';
489 489
         }
490 490
         
491 491
         // Inject the new stylesheets
492
-        $replaceTag = array("<title","before");
493
-        $replaceTag = apply_filters( 'autoptimize_filter_css_replacetag', $replaceTag, $this->content );
492
+        $replaceTag = array("<title", "before");
493
+        $replaceTag = apply_filters('autoptimize_filter_css_replacetag', $replaceTag, $this->content);
494 494
 
495 495
         if ($this->inline == true) {
496
-            foreach($this->csscode as $media => $code) {
497
-                $this->inject_in_html('<style type="text/css" media="'.$media.'">'.$code.'</style>',$replaceTag);
496
+            foreach ($this->csscode as $media => $code) {
497
+                $this->inject_in_html('<style type="text/css" media="'.$media.'">'.$code.'</style>', $replaceTag);
498 498
             }
499 499
         } else {
500 500
             if ($this->defer == true) {
501 501
                 $preloadCssBlock = "";
502 502
                 $noScriptCssBlock = "<noscript id=\"aonoscrcss\">";
503
-                $defer_inline_code=$this->defer_inline;
504
-                if(!empty($defer_inline_code)){
505
-                    if ( apply_filters( 'autoptimize_filter_css_critcss_minify', true ) ) {
503
+                $defer_inline_code = $this->defer_inline;
504
+                if (!empty($defer_inline_code)) {
505
+                    if (apply_filters('autoptimize_filter_css_critcss_minify', true)) {
506 506
                         $iCssHash = md5($defer_inline_code);
507
-                        $iCssCache = new autoptimizeCache($iCssHash,'css');
508
-                        if($iCssCache->check()) { 
507
+                        $iCssCache = new autoptimizeCache($iCssHash, 'css');
508
+                        if ($iCssCache->check()) { 
509 509
                             // we have the optimized inline CSS in cache
510
-                            $defer_inline_code=$iCssCache->retrieve();
510
+                            $defer_inline_code = $iCssCache->retrieve();
511 511
                         } else {
512 512
                             if (class_exists('Minify_CSS_Compressor')) {
513 513
                                 $tmp_code = trim(Minify_CSS_Compressor::process($defer_inline_code));
514
-                            } else if(class_exists('CSSmin')) {
514
+                            } else if (class_exists('CSSmin')) {
515 515
                                 $cssmin = new CSSmin();
516 516
                                 $tmp_code = trim($cssmin->run($defer_inline_code));
517 517
                             }
518 518
                             if (!empty($tmp_code)) {
519 519
                                 $defer_inline_code = $tmp_code;
520
-                                $iCssCache->cache($defer_inline_code,"text/css");
520
+                                $iCssCache->cache($defer_inline_code, "text/css");
521 521
                                 unset($tmp_code);
522 522
                             }
523 523
                         }
524 524
                     }
525
-                    $code_out='<style type="text/css" id="aoatfcss" media="all">'.$defer_inline_code.'</style>';
526
-                    $this->inject_in_html($code_out,$replaceTag);
525
+                    $code_out = '<style type="text/css" id="aoatfcss" media="all">'.$defer_inline_code.'</style>';
526
+                    $this->inject_in_html($code_out, $replaceTag);
527 527
                 }
528 528
             }
529 529
 
530
-            foreach($this->url as $media => $url) {
530
+            foreach ($this->url as $media => $url) {
531 531
                 $url = $this->url_replace_cdn($url);
532 532
                 
533 533
                 //Add the stylesheet either deferred (import at bottom) or normal links in head
534
-                if($this->defer == true) {
534
+                if ($this->defer == true) {
535 535
                     
536 536
                     // Filter to modify the onload attribute - passes value and the stylesheet url
537 537
                     $preloadOnLoad = apply_filters('autoptimize_filter_css_preload_onload', "this.onload=null;this.rel='stylesheet'", $url);
@@ -541,22 +541,22 @@  discard block
 block discarded – undo
541 541
                     
542 542
                 } else {
543 543
                     if (strlen($this->csscode[$media]) > $this->cssinlinesize) {
544
-                        $this->inject_in_html('<link type="text/css" media="'.$media.'" href="'.$url.'" rel="stylesheet" />',$replaceTag);
545
-                    } else if (strlen($this->csscode[$media])>0) {
546
-                        $this->inject_in_html('<style type="text/css" media="'.$media.'">'.$this->csscode[$media].'</style>',$replaceTag);
544
+                        $this->inject_in_html('<link type="text/css" media="'.$media.'" href="'.$url.'" rel="stylesheet" />', $replaceTag);
545
+                    } else if (strlen($this->csscode[$media]) > 0) {
546
+                        $this->inject_in_html('<style type="text/css" media="'.$media.'">'.$this->csscode[$media].'</style>', $replaceTag);
547 547
                     }
548 548
                 }
549 549
             }
550 550
             
551
-            if($this->defer == true) {
551
+            if ($this->defer == true) {
552 552
                 $preloadPolyfill = '<script data-cfasync=\'false\'>!function(t){"use strict";t.loadCSS||(t.loadCSS=function(){});var e=loadCSS.relpreload={};if(e.support=function(){var e;try{e=t.document.createElement("link").relList.supports("preload")}catch(t){e=!1}return function(){return e}}(),e.bindMediaToggle=function(t){function e(){t.media=a}var a=t.media||"all";t.addEventListener?t.addEventListener("load",e):t.attachEvent&&t.attachEvent("onload",e),setTimeout(function(){t.rel="stylesheet",t.media="only x"}),setTimeout(e,3e3)},e.poly=function(){if(!e.support())for(var a=t.document.getElementsByTagName("link"),n=0;n<a.length;n++){var o=a[n];"preload"!==o.rel||"style"!==o.getAttribute("as")||o.getAttribute("data-loadcss")||(o.setAttribute("data-loadcss",!0),e.bindMediaToggle(o))}},!e.support()){e.poly();var a=t.setInterval(e.poly,500);t.addEventListener?t.addEventListener("load",function(){e.poly(),t.clearInterval(a)}):t.attachEvent&&t.attachEvent("onload",function(){e.poly(),t.clearInterval(a)})}"undefined"!=typeof exports?exports.loadCSS=loadCSS:t.loadCSS=loadCSS}("undefined"!=typeof global?global:this);</script>';
553 553
                 $noScriptCssBlock .= "</noscript>";
554
-                $this->inject_in_html($preloadCssBlock.$noScriptCssBlock,$replaceTag);
554
+                $this->inject_in_html($preloadCssBlock.$noScriptCssBlock, $replaceTag);
555 555
                 
556 556
                 // Adds preload polyfill at end of body tag
557 557
                 $this->inject_in_html(
558 558
                     apply_filters('autoptimize_css_preload_polyfill', $preloadPolyfill),
559
-                    array('</body>','before')
559
+                    array('</body>', 'before')
560 560
                 );
561 561
             }
562 562
         }
@@ -567,62 +567,62 @@  discard block
 block discarded – undo
567 567
     
568 568
     static function fixurls($file, $code) {
569 569
         // Switch all imports to the url() syntax
570
-        $code = preg_replace( '#@import ("|\')(.+?)\.css.*?("|\')#', '@import url("${2}.css")', $code );
570
+        $code = preg_replace('#@import ("|\')(.+?)\.css.*?("|\')#', '@import url("${2}.css")', $code);
571 571
 
572
-        if ( preg_match_all( self::ASSETS_REGEX, $code, $matches ) ) {
573
-            $file = str_replace( WP_ROOT_DIR, '/', $file );
574
-            $dir = dirname( $file ); // Like /themes/expound/css
572
+        if (preg_match_all(self::ASSETS_REGEX, $code, $matches)) {
573
+            $file = str_replace(WP_ROOT_DIR, '/', $file);
574
+            $dir = dirname($file); // Like /themes/expound/css
575 575
 
576 576
             // $dir should not contain backslashes, since it's used to replace
577 577
             // urls, but it can contain them when running on Windows because
578 578
             // fixurls() is sometimes called with `ABSPATH . 'index.php'`
579
-            $dir = str_replace( '\\', '/', $dir );
580
-            unset( $file ); // not used below at all
579
+            $dir = str_replace('\\', '/', $dir);
580
+            unset($file); // not used below at all
581 581
 
582 582
             $replace = array();
583
-            foreach ( $matches[1] as $k => $url ) {
583
+            foreach ($matches[1] as $k => $url) {
584 584
                 // Remove quotes
585
-                $url    = trim( $url," \t\n\r\0\x0B\"'" );
586
-                $noQurl = trim( $url, "\"'" );
587
-                if ( $url !== $noQurl ) {
585
+                $url    = trim($url, " \t\n\r\0\x0B\"'");
586
+                $noQurl = trim($url, "\"'");
587
+                if ($url !== $noQurl) {
588 588
                     $removedQuotes = true;
589 589
                 } else {
590 590
                     $removedQuotes = false;
591 591
                 }
592 592
 
593
-                if ( '' === $noQurl ) {
593
+                if ('' === $noQurl) {
594 594
                     continue;
595 595
                 }
596 596
 
597 597
                 $url = $noQurl;
598
-                if ( '/' === $url{0} || preg_match( '#^(https?://|ftp://|data:)#i', $url ) ) {
598
+                if ('/' === $url{0} || preg_match('#^(https?://|ftp://|data:)#i', $url)) {
599 599
                     // URL is protocol-relative, host-relative or something we don't touch
600 600
                     continue;
601 601
                 } else {
602 602
                     // Relative URL
603
-                    $newurl = preg_replace( '/https?:/', '', str_replace( ' ', '%20', AUTOPTIMIZE_WP_ROOT_URL . str_replace( '//', '/', $dir . '/' . $url ) ) );
603
+                    $newurl = preg_replace('/https?:/', '', str_replace(' ', '%20', AUTOPTIMIZE_WP_ROOT_URL.str_replace('//', '/', $dir.'/'.$url)));
604 604
 
605 605
                     // Hash the url + whatever was behind potentially for replacement
606 606
                     // We must do this, or different css classes referencing the same bg image (but
607 607
                     // different parts of it, say, in sprites and such) loose their stuff...
608
-                    $hash = md5( $url . $matches[2][$k] );
609
-                    $code = str_replace( $matches[0][$k], $hash, $code );
608
+                    $hash = md5($url.$matches[2][$k]);
609
+                    $code = str_replace($matches[0][$k], $hash, $code);
610 610
 
611
-                    if ( $removedQuotes ) {
612
-                        $replace[$hash] = "url('" . $newurl . "')" . $matches[2][$k];
611
+                    if ($removedQuotes) {
612
+                        $replace[$hash] = "url('".$newurl."')".$matches[2][$k];
613 613
                     } else {
614
-                        $replace[$hash] = 'url(' . $newurl . ')' . $matches[2][$k];
614
+                        $replace[$hash] = 'url('.$newurl.')'.$matches[2][$k];
615 615
                     }
616 616
                 }
617 617
             }
618 618
 
619
-            if ( ! empty( $replace ) ) {
619
+            if (!empty($replace)) {
620 620
                 // Sort the replacements array by key length in desc order (so that the longest strings are replaced first)
621
-                $keys = array_map( 'strlen', array_keys( $replace ) );
622
-                array_multisort( $keys, SORT_DESC, $replace );
621
+                $keys = array_map('strlen', array_keys($replace));
622
+                array_multisort($keys, SORT_DESC, $replace);
623 623
 
624 624
                 // Replace URLs found within $code
625
-                $code = str_replace( array_keys( $replace ), array_values( $replace ), $code );
625
+                $code = str_replace(array_keys($replace), array_values($replace), $code);
626 626
             }
627 627
         }
628 628
 
@@ -630,11 +630,11 @@  discard block
 block discarded – undo
630 630
     }
631 631
     
632 632
     private function ismovable($tag) {
633
-		if ( apply_filters('autoptimize_filter_css_dontaggregate', false) ) {
633
+		if (apply_filters('autoptimize_filter_css_dontaggregate', false)) {
634 634
 			return false;
635 635
         } else if (!empty($this->whitelist)) {
636 636
             foreach ($this->whitelist as $match) {
637
-                if(strpos($tag,$match)!==false) {
637
+                if (strpos($tag, $match) !== false) {
638 638
                     return true;
639 639
                 }
640 640
             }
@@ -642,8 +642,8 @@  discard block
 block discarded – undo
642 642
             return false;
643 643
         } else {
644 644
             if (is_array($this->dontmove)) {
645
-                foreach($this->dontmove as $match) {
646
-                    if(strpos($tag,$match)!==false) {
645
+                foreach ($this->dontmove as $match) {
646
+                    if (strpos($tag, $match) !== false) {
647 647
                         //Matched something
648 648
                         return false;
649 649
                     }
@@ -655,21 +655,21 @@  discard block
 block discarded – undo
655 655
         }
656 656
     }
657 657
     
658
-    private function can_inject_late($cssPath,$css) {
658
+    private function can_inject_late($cssPath, $css) {
659 659
 		$consider_minified_array = apply_filters('autoptimize_filter_css_consider_minified', false, $cssPath);
660
-        if ( $this->inject_min_late !== true ) {
660
+        if ($this->inject_min_late !== true) {
661 661
             // late-inject turned off
662 662
             return false;
663
-        } else if ( (strpos($cssPath,"min.css") === false) && ( str_replace($consider_minified_array, '', $cssPath) === $cssPath ) ) {
663
+        } else if ((strpos($cssPath, "min.css") === false) && (str_replace($consider_minified_array, '', $cssPath) === $cssPath)) {
664 664
 			// file not minified based on filename & filter
665 665
 			return false;
666
-        } else if ( strpos($css,"@import") !== false ) {
666
+        } else if (strpos($css, "@import") !== false) {
667 667
             // can't late-inject files with imports as those need to be aggregated 
668 668
             return false;
669
-        } else if ( (strpos($css,"@font-face")!==false ) && ( apply_filters("autoptimize_filter_css_fonts_cdn",false)===true) && (!empty($this->cdn_url)) ) {
669
+        } else if ((strpos($css, "@font-face") !== false) && (apply_filters("autoptimize_filter_css_fonts_cdn", false) === true) && (!empty($this->cdn_url))) {
670 670
             // don't late-inject CSS with font-src's if fonts are set to be CDN'ed
671 671
             return false;
672
-        } else if ( (($this->datauris == true) || (!empty($this->cdn_url))) && preg_match("#background[^;}]*url\(#Ui",$css) ) {
672
+        } else if ((($this->datauris == true) || (!empty($this->cdn_url))) && preg_match("#background[^;}]*url\(#Ui", $css)) {
673 673
             // don't late-inject CSS with images if CDN is set OR is image inlining is on
674 674
             return false;
675 675
         } else {
@@ -679,11 +679,11 @@  discard block
 block discarded – undo
679 679
     }
680 680
     
681 681
     private function maybe_cdn_urls($inUrl) {
682
-        $url = trim($inUrl," \t\n\r\0\x0B\"'");
683
-        $urlPath = parse_url($url,PHP_URL_PATH);
682
+        $url = trim($inUrl, " \t\n\r\0\x0B\"'");
683
+        $urlPath = parse_url($url, PHP_URL_PATH);
684 684
 
685 685
         // exclude fonts from CDN except if filter returns true
686
-        if ( !preg_match('#\.(woff2?|eot|ttf|otf)$#i',$urlPath) || apply_filters('autoptimize_filter_css_fonts_cdn',false) ) {
686
+        if (!preg_match('#\.(woff2?|eot|ttf|otf)$#i', $urlPath) || apply_filters('autoptimize_filter_css_fonts_cdn', false)) {
687 687
             $cdn_url = $this->url_replace_cdn($url);
688 688
         } else {
689 689
             $cdn_url = $url;
Please login to merge, or discard this patch.
classes/autoptimizeBase.php 1 patch
Spacing   +90 added lines, -90 removed lines patch added patch discarded remove patch
@@ -1,5 +1,5 @@  discard block
 block discarded – undo
1 1
 <?php
2
-if ( ! defined( 'ABSPATH' ) ) exit; // Exit if accessed directly
2
+if (!defined('ABSPATH')) exit; // Exit if accessed directly
3 3
 
4 4
 abstract class autoptimizeBase {
5 5
     protected $content = '';
@@ -23,37 +23,37 @@  discard block
 block discarded – undo
23 23
     
24 24
     //Converts an URL to a full path
25 25
     protected function getpath($url) {
26
-        $url=apply_filters( 'autoptimize_filter_cssjs_alter_url', $url);
26
+        $url = apply_filters('autoptimize_filter_cssjs_alter_url', $url);
27 27
         
28
-        if (strpos($url,'%')!==false) {
29
-            $url=urldecode($url);
28
+        if (strpos($url, '%') !== false) {
29
+            $url = urldecode($url);
30 30
         }
31 31
 
32
-        $siteHost=parse_url(AUTOPTIMIZE_WP_SITE_URL,PHP_URL_HOST);
33
-        $contentHost=parse_url(AUTOPTIMIZE_WP_ROOT_URL,PHP_URL_HOST);
32
+        $siteHost = parse_url(AUTOPTIMIZE_WP_SITE_URL, PHP_URL_HOST);
33
+        $contentHost = parse_url(AUTOPTIMIZE_WP_ROOT_URL, PHP_URL_HOST);
34 34
         
35 35
         // normalize
36
-        if (strpos($url,'//')===0) {
36
+        if (strpos($url, '//') === 0) {
37 37
             if (is_ssl()) {
38 38
                 $url = "https:".$url;
39 39
             } else {
40 40
                 $url = "http:".$url;
41 41
             }
42
-        } else if ((strpos($url,'//')===false) && (strpos($url,$siteHost)===false)) {
42
+        } else if ((strpos($url, '//') === false) && (strpos($url, $siteHost) === false)) {
43 43
             if (AUTOPTIMIZE_WP_SITE_URL === $siteHost) {
44 44
                 $url = AUTOPTIMIZE_WP_SITE_URL.$url;
45 45
             } else {
46
-                $subdir_levels=substr_count(preg_replace("/https?:\/\//","",AUTOPTIMIZE_WP_SITE_URL),"/");
47
-                $url = AUTOPTIMIZE_WP_SITE_URL.str_repeat("/..",$subdir_levels).$url;
46
+                $subdir_levels = substr_count(preg_replace("/https?:\/\//", "", AUTOPTIMIZE_WP_SITE_URL), "/");
47
+                $url = AUTOPTIMIZE_WP_SITE_URL.str_repeat("/..", $subdir_levels).$url;
48 48
             }
49 49
         }
50 50
         
51 51
         if ($siteHost !== $contentHost) {
52
-            $url=str_replace(AUTOPTIMIZE_WP_CONTENT_URL,AUTOPTIMIZE_WP_SITE_URL.AUTOPTIMIZE_WP_CONTENT_NAME,$url);
52
+            $url = str_replace(AUTOPTIMIZE_WP_CONTENT_URL, AUTOPTIMIZE_WP_SITE_URL.AUTOPTIMIZE_WP_CONTENT_NAME, $url);
53 53
         }
54 54
 
55 55
         // first check; hostname wp site should be hostname of url
56
-        $thisHost=@parse_url($url,PHP_URL_HOST);
56
+        $thisHost = @parse_url($url, PHP_URL_HOST);
57 57
         if ($thisHost !== $siteHost) {
58 58
             /* 
59 59
             * first try to get all domains from WPML (if available)
@@ -65,18 +65,18 @@  discard block
 block discarded – undo
65 65
             
66 66
             $multidomainsWPML = apply_filters('wpml_setting', array(), 'language_domains');
67 67
             if (!empty($multidomainsWPML)) {
68
-                $multidomains = array_map(array($this,"ao_getDomain"),$multidomainsWPML);
68
+                $multidomains = array_map(array($this, "ao_getDomain"), $multidomainsWPML);
69 69
             }
70 70
             
71 71
             if (!empty($this->cdn_url)) {
72
-                $multidomains[]=parse_url($this->cdn_url,PHP_URL_HOST);
72
+                $multidomains[] = parse_url($this->cdn_url, PHP_URL_HOST);
73 73
             }
74 74
             
75 75
             $multidomains = apply_filters('autoptimize_filter_cssjs_multidomain', $multidomains);
76 76
             
77 77
             if (!empty($multidomains)) {
78
-                if (in_array($thisHost,$multidomains)) {
79
-                    $url=str_replace($thisHost, parse_url(AUTOPTIMIZE_WP_SITE_URL,PHP_URL_HOST), $url);
78
+                if (in_array($thisHost, $multidomains)) {
79
+                    $url = str_replace($thisHost, parse_url(AUTOPTIMIZE_WP_SITE_URL, PHP_URL_HOST), $url);
80 80
                 } else {
81 81
                     return false;
82 82
                 }
@@ -86,22 +86,22 @@  discard block
 block discarded – undo
86 86
         }
87 87
         
88 88
         // try to remove "wp root url" from url while not minding http<>https
89
-        $tmp_ao_root = preg_replace('/https?:/','',AUTOPTIMIZE_WP_ROOT_URL);
89
+        $tmp_ao_root = preg_replace('/https?:/', '', AUTOPTIMIZE_WP_ROOT_URL);
90 90
         if ($siteHost !== $contentHost) {
91 91
             // as we replaced the content-domain with the site-domain, we should match against that 
92
-            $tmp_ao_root = preg_replace('/https?:/','',AUTOPTIMIZE_WP_SITE_URL);
92
+            $tmp_ao_root = preg_replace('/https?:/', '', AUTOPTIMIZE_WP_SITE_URL);
93 93
         }
94
-        $tmp_url = preg_replace('/https?:/','',$url);
95
-        $path = str_replace($tmp_ao_root,'',$tmp_url);
94
+        $tmp_url = preg_replace('/https?:/', '', $url);
95
+        $path = str_replace($tmp_ao_root, '', $tmp_url);
96 96
         
97 97
         // if path starts with :// or //, this is not a URL in the WP context and we have to assume we can't aggregate
98
-        if (preg_match('#^:?//#',$path)) {
98
+        if (preg_match('#^:?//#', $path)) {
99 99
             /** External script/css (adsense, etc) */
100 100
             return false;
101 101
         }
102 102
 
103 103
         // prepend with WP_ROOT_DIR to have full path to file
104
-        $path = str_replace('//','/',WP_ROOT_DIR.$path);
104
+        $path = str_replace('//', '/', WP_ROOT_DIR.$path);
105 105
         
106 106
         // final check: does file exist and is it readable
107 107
         if (file_exists($path) && is_file($path) && is_readable($path)) {
@@ -114,25 +114,25 @@  discard block
 block discarded – undo
114 114
     // needed for WPML-filter
115 115
     protected function ao_getDomain($in) {
116 116
         // make sure the url starts with something vaguely resembling a protocol
117
-        if ((strpos($in,"http")!==0) && (strpos($in,"//")!==0)) {
118
-            $in="http://".$in;
117
+        if ((strpos($in, "http") !== 0) && (strpos($in, "//") !== 0)) {
118
+            $in = "http://".$in;
119 119
         }
120 120
         
121 121
         // do the actual parse_url
122
-        $out = parse_url($in,PHP_URL_HOST);
122
+        $out = parse_url($in, PHP_URL_HOST);
123 123
         
124 124
         // fallback if parse_url does not understand the url is in fact a url
125
-        if (empty($out)) $out=$in;
125
+        if (empty($out)) $out = $in;
126 126
         
127 127
         return $out;
128 128
     }
129 129
 
130 130
 
131 131
     // logger
132
-    protected function ao_logger($logmsg,$appendHTML=true) {
132
+    protected function ao_logger($logmsg, $appendHTML = true) {
133 133
         if ($appendHTML) {
134
-            $logmsg="<!--noptimize--><!-- ".$logmsg." --><!--/noptimize-->";
135
-            $this->content.=$logmsg;
134
+            $logmsg = "<!--noptimize--><!-- ".$logmsg." --><!--/noptimize-->";
135
+            $this->content .= $logmsg;
136 136
         } else {
137 137
             error_log("Autoptimize: ".$logmsg);
138 138
         }
@@ -140,10 +140,10 @@  discard block
 block discarded – undo
140 140
 
141 141
     // hide everything between noptimize-comment tags
142 142
     protected function hide_noptimize($noptimize_in) {
143
-        if ( preg_match( '/<!--\s?noptimize\s?-->/', $noptimize_in ) ) { 
143
+        if (preg_match('/<!--\s?noptimize\s?-->/', $noptimize_in)) { 
144 144
             $noptimize_out = preg_replace_callback(
145 145
                 '#<!--\s?noptimize\s?-->.*?<!--\s?/\s?noptimize\s?-->#is',
146
-                function ($matches) {return "%%NOPTIMIZE" . AUTOPTIMIZE_HASH . "%%" . base64_encode($matches[0]) . "%%NOPTIMIZE%%";},
146
+                function($matches) {return "%%NOPTIMIZE".AUTOPTIMIZE_HASH."%%".base64_encode($matches[0])."%%NOPTIMIZE%%"; },
147 147
                 $noptimize_in
148 148
             );
149 149
         } else {
@@ -154,10 +154,10 @@  discard block
 block discarded – undo
154 154
     
155 155
     // unhide noptimize-tags
156 156
     protected function restore_noptimize($noptimize_in) {
157
-        if ( strpos( $noptimize_in, '%%NOPTIMIZE%%' ) !== false ) { 
157
+        if (strpos($noptimize_in, '%%NOPTIMIZE%%') !== false) { 
158 158
             $noptimize_out = preg_replace_callback(
159 159
                 '#%%NOPTIMIZE'.AUTOPTIMIZE_HASH.'%%(.*?)%%NOPTIMIZE%%#is',
160
-                function ($matches) {return base64_decode($matches[1]);},
160
+                function($matches) {return base64_decode($matches[1]); },
161 161
                 $noptimize_in
162 162
             );
163 163
         } else {
@@ -167,10 +167,10 @@  discard block
 block discarded – undo
167 167
     }
168 168
 
169 169
     protected function hide_iehacks($iehacks_in) {
170
-        if ( strpos( $iehacks_in, '<!--[if' ) !== false ) { 
170
+        if (strpos($iehacks_in, '<!--[if') !== false) { 
171 171
             $iehacks_out = preg_replace_callback(
172 172
                 '#<!--\[if.*?\[endif\]-->#is',
173
-                function ($matches) {return "%%IEHACK" . AUTOPTIMIZE_HASH . "%%" . base64_encode($matches[0]) . "%%IEHACK%%";},
173
+                function($matches) {return "%%IEHACK".AUTOPTIMIZE_HASH."%%".base64_encode($matches[0])."%%IEHACK%%"; },
174 174
                 $iehacks_in
175 175
             );
176 176
         } else {
@@ -180,23 +180,23 @@  discard block
 block discarded – undo
180 180
     }
181 181
 
182 182
     protected function restore_iehacks($iehacks_in) {
183
-        if ( strpos( $iehacks_in, '%%IEHACK%%' ) !== false ) { 
183
+        if (strpos($iehacks_in, '%%IEHACK%%') !== false) { 
184 184
             $iehacks_out = preg_replace_callback(
185 185
                 '#%%IEHACK'.AUTOPTIMIZE_HASH.'%%(.*?)%%IEHACK%%#is',
186
-                function ($matches) {return base64_decode($matches[1]);},
186
+                function($matches) {return base64_decode($matches[1]); },
187 187
                 $iehacks_in
188 188
             );
189 189
         } else {
190
-            $iehacks_out=$iehacks_in;
190
+            $iehacks_out = $iehacks_in;
191 191
         }
192 192
         return $iehacks_out;
193 193
     }
194 194
 
195 195
     protected function hide_comments($comments_in) {
196
-        if ( strpos( $comments_in, '<!--' ) !== false ) {
196
+        if (strpos($comments_in, '<!--') !== false) {
197 197
             $comments_out = preg_replace_callback(
198 198
                 '#<!--.*?-->#is',
199
-                function ($matches) {return "%%COMMENTS" . AUTOPTIMIZE_HASH . "%%" . base64_encode($matches[0]) . "%%COMMENTS%%";},
199
+                function($matches) {return "%%COMMENTS".AUTOPTIMIZE_HASH."%%".base64_encode($matches[0])."%%COMMENTS%%"; },
200 200
                 $comments_in
201 201
             );
202 202
         } else {
@@ -206,38 +206,38 @@  discard block
 block discarded – undo
206 206
     }
207 207
 
208 208
     protected function restore_comments($comments_in) {
209
-        if ( strpos( $comments_in, '%%COMMENTS%%' ) !== false ) {
209
+        if (strpos($comments_in, '%%COMMENTS%%') !== false) {
210 210
             $comments_out = preg_replace_callback(
211 211
                 '#%%COMMENTS'.AUTOPTIMIZE_HASH.'%%(.*?)%%COMMENTS%%#is',
212
-                function ($matches) {return base64_decode($matches[1]);},
212
+                function($matches) {return base64_decode($matches[1]); },
213 213
                 $comments_in
214 214
             );
215 215
         } else {
216
-            $comments_out=$comments_in;
216
+            $comments_out = $comments_in;
217 217
         }
218 218
         return $comments_out;
219 219
     }
220 220
 
221
-    protected function url_replace_cdn( $url ) {
221
+    protected function url_replace_cdn($url) {
222 222
         // API filter to change base CDN URL
223
-        $cdn_url = apply_filters( 'autoptimize_filter_base_cdnurl', $this->cdn_url );
223
+        $cdn_url = apply_filters('autoptimize_filter_base_cdnurl', $this->cdn_url);
224 224
 
225
-        if ( !empty($cdn_url) )  {
225
+        if (!empty($cdn_url)) {
226 226
             // prepend domain-less absolute URL's
227
-            if ( ( substr( $url, 0, 1 ) === '/' ) && ( substr( $url, 1, 1 ) !== '/' ) ) {
228
-                $url = rtrim( $cdn_url, '/' ) . $url;
227
+            if ((substr($url, 0, 1) === '/') && (substr($url, 1, 1) !== '/')) {
228
+                $url = rtrim($cdn_url, '/').$url;
229 229
             } else {
230 230
                 // get wordpress base URL
231
-                $WPSiteBreakdown = parse_url( AUTOPTIMIZE_WP_SITE_URL );
232
-                $WPBaseUrl       = $WPSiteBreakdown['scheme'] . '://' . $WPSiteBreakdown['host'];
233
-                if ( ! empty( $WPSiteBreakdown['port'] ) ) {
234
-                    $WPBaseUrl .= ":" . $WPSiteBreakdown['port'];
231
+                $WPSiteBreakdown = parse_url(AUTOPTIMIZE_WP_SITE_URL);
232
+                $WPBaseUrl       = $WPSiteBreakdown['scheme'].'://'.$WPSiteBreakdown['host'];
233
+                if (!empty($WPSiteBreakdown['port'])) {
234
+                    $WPBaseUrl .= ":".$WPSiteBreakdown['port'];
235 235
                 }
236 236
                 // replace full url's with scheme
237
-                $tmp_url = str_replace( $WPBaseUrl, rtrim( $cdn_url, '/' ), $url );
238
-                if ( $tmp_url === $url ) {
237
+                $tmp_url = str_replace($WPBaseUrl, rtrim($cdn_url, '/'), $url);
238
+                if ($tmp_url === $url) {
239 239
                     // last attempt; replace scheme-less URL's
240
-                    $url = str_replace( preg_replace( '/https?:/', '', $WPBaseUrl ), rtrim( $cdn_url, '/' ), $url );
240
+                    $url = str_replace(preg_replace('/https?:/', '', $WPBaseUrl), rtrim($cdn_url, '/'), $url);
241 241
                 } else {
242 242
                     $url = $tmp_url;
243 243
                 }
@@ -245,32 +245,32 @@  discard block
 block discarded – undo
245 245
         }
246 246
 
247 247
         // allow API filter to alter URL after CDN replacement
248
-        $url = apply_filters( 'autoptimize_filter_base_replace_cdn', $url );
248
+        $url = apply_filters('autoptimize_filter_base_replace_cdn', $url);
249 249
         return $url;
250 250
     }
251 251
 
252
-    protected function inject_in_html($payload,$replaceTag) {
253
-        if (strpos($this->content,$replaceTag[0])!== false) {
254
-            if ($replaceTag[1]==="after") {
255
-                $replaceBlock=$replaceTag[0].$payload;
256
-            } else if ($replaceTag[1]==="replace"){
257
-                $replaceBlock=$payload;
252
+    protected function inject_in_html($payload, $replaceTag) {
253
+        if (strpos($this->content, $replaceTag[0]) !== false) {
254
+            if ($replaceTag[1] === "after") {
255
+                $replaceBlock = $replaceTag[0].$payload;
256
+            } else if ($replaceTag[1] === "replace") {
257
+                $replaceBlock = $payload;
258 258
             } else {
259
-                $replaceBlock=$payload.$replaceTag[0];
259
+                $replaceBlock = $payload.$replaceTag[0];
260 260
             }
261
-            $this->content = substr_replace($this->content,$replaceBlock,strpos($this->content,$replaceTag[0]),strlen($replaceTag[0]));
261
+            $this->content = substr_replace($this->content, $replaceBlock, strpos($this->content, $replaceTag[0]), strlen($replaceTag[0]));
262 262
         } else {
263 263
             $this->content .= $payload;
264 264
             if (!$this->tagWarning) {
265
-                $this->content .= "<!--noptimize--><!-- Autoptimize found a problem with the HTML in your Theme, tag \"".str_replace(array("<",">"),"",$replaceTag[0])."\" missing --><!--/noptimize-->";
266
-                $this->tagWarning=true;
265
+                $this->content .= "<!--noptimize--><!-- Autoptimize found a problem with the HTML in your Theme, tag \"".str_replace(array("<", ">"), "", $replaceTag[0])."\" missing --><!--/noptimize-->";
266
+                $this->tagWarning = true;
267 267
             }
268 268
         }
269 269
     }
270 270
     
271 271
     protected function isremovable($tag, $removables) {
272 272
         foreach ($removables as $match) {
273
-            if (strpos($tag,$match)!==false) {
273
+            if (strpos($tag, $match) !== false) {
274 274
                 return true;
275 275
             }
276 276
         }
@@ -279,10 +279,10 @@  discard block
 block discarded – undo
279 279
     
280 280
     // inject already minified code in optimized JS/CSS
281 281
     protected function inject_minified($in) {
282
-        if ( strpos( $in, '%%INJECTLATER%%' ) !== false ) {
282
+        if (strpos($in, '%%INJECTLATER%%') !== false) {
283 283
             $out = preg_replace_callback(
284 284
                 '#\/\*\!%%INJECTLATER'.AUTOPTIMIZE_HASH.'%%(.*?)%%INJECTLATER%%\*\/#is',
285
-                function ($matches) {$filepath = base64_decode(strtok($matches[1], "|"));
285
+                function($matches) {$filepath = base64_decode(strtok($matches[1], "|"));
286 286
                     $filecontent = file_get_contents($filepath);
287 287
 
288 288
                     // remove BOM
@@ -303,14 +303,14 @@  discard block
 block discarded – undo
303 303
                         }
304 304
 
305 305
                         if (get_option("autoptimize_js_trycatch") === "on") {
306
-                            $filecontent = "try{" . $filecontent . "}catch(e){}";
306
+                            $filecontent = "try{".$filecontent."}catch(e){}";
307 307
                         }
308 308
                     } else if ((substr($filepath, -4, 4) === ".css")) {
309 309
                         $filecontent = autoptimizeStyles::fixurls($filepath, $filecontent);
310 310
                     } else {
311 311
                         $filecontent = "";
312 312
                     }
313
-                    return "\n" . $filecontent;
313
+                    return "\n".$filecontent;
314 314
                 },
315 315
                 $in
316 316
             );
@@ -322,49 +322,49 @@  discard block
 block discarded – undo
322 322
     
323 323
     protected function minify_single($pathIn) {
324 324
 		// determine JS or CSS and set var (also mimetype), return false if neither
325
-		if ( $this->str_ends_in($pathIn,".js") === true ) {
326
-			$codeType="js";
327
-			$codeMime="text/javascript";
328
-		} else if ( $this->str_ends_in($pathIn,".css") === true ) {
329
-			$codeType="css";
330
-			$codeMime="text/css";			
325
+		if ($this->str_ends_in($pathIn, ".js") === true) {
326
+			$codeType = "js";
327
+			$codeMime = "text/javascript";
328
+		} else if ($this->str_ends_in($pathIn, ".css") === true) {
329
+			$codeType = "css";
330
+			$codeMime = "text/css";			
331 331
 		} else {
332 332
 			return false;
333 333
 		}
334 334
 		
335 335
 		// if min.js or min.css return false
336
-		if (( $this->str_ends_in($pathIn,"-min.".$codeType) === true ) || ( $this->str_ends_in($pathIn,".min.".$codeType) === true ) || ( $this->str_ends_in($pathIn,"js/jquery/jquery.js") === true ) ) {
336
+		if (($this->str_ends_in($pathIn, "-min.".$codeType) === true) || ($this->str_ends_in($pathIn, ".min.".$codeType) === true) || ($this->str_ends_in($pathIn, "js/jquery/jquery.js") === true)) {
337 337
 			return false;
338 338
 		}
339 339
 		
340 340
 		// read file, return false if empty
341 341
 		$_toMinify = file_get_contents($pathIn);
342
-		if ( empty($_toMinify) ) return false;
342
+		if (empty($_toMinify)) return false;
343 343
 		
344 344
 		// check cache
345 345
 		$_md5hash = "single_".md5($_toMinify);
346
-		$_cache = new autoptimizeCache($_md5hash,$codeType);
347
-		if ($_cache->check() ) {
346
+		$_cache = new autoptimizeCache($_md5hash, $codeType);
347
+		if ($_cache->check()) {
348 348
 			$_CachedMinifiedUrl = AUTOPTIMIZE_CACHE_URL.$_cache->getname();
349 349
 		} else {
350 350
 			// if not in cache first minify
351 351
 			$_Minified = $_toMinify;
352 352
 			if ($codeType === "js") {
353
-				if (class_exists('JSMin') && apply_filters( 'autoptimize_js_do_minify' , true)) {
354
-					if (@is_callable(array("JSMin","minify"))) {
353
+				if (class_exists('JSMin') && apply_filters('autoptimize_js_do_minify', true)) {
354
+					if (@is_callable(array("JSMin", "minify"))) {
355 355
 						$tmp_code = trim(JSMin::minify($_toMinify));
356 356
 					}
357 357
 				}
358 358
 			} else if ($codeType === "css") {
359 359
                 // make sure paths to background images/ imported css/ fonts .. are OK
360
-                $_toMinify = autoptimizeStyles::fixurls($pathIn,$_toMinify);
360
+                $_toMinify = autoptimizeStyles::fixurls($pathIn, $_toMinify);
361 361
                 if (class_exists('Minify_CSS_Compressor')) {
362 362
 					$tmp_code = trim(Minify_CSS_Compressor::process($_toMinify));
363
-                } else if(class_exists('CSSmin')) {
363
+                } else if (class_exists('CSSmin')) {
364 364
                     $cssmin = new CSSmin();
365
-                    if (method_exists($cssmin,"run")) {
365
+                    if (method_exists($cssmin, "run")) {
366 366
                         $tmp_code = trim($cssmin->run($_toMinify));
367
-                    } elseif (@is_callable(array($cssmin,"minify"))) {
367
+                    } elseif (@is_callable(array($cssmin, "minify"))) {
368 368
                         $tmp_code = trim(CssMin::minify($_toMinify));
369 369
                     }
370 370
                 }
@@ -374,7 +374,7 @@  discard block
 block discarded – undo
374 374
 				unset($tmp_code);
375 375
 			}
376 376
 			// and then cache
377
-			$_cache->cache($_Minified,$codeMime);
377
+			$_cache->cache($_Minified, $codeMime);
378 378
 			$_CachedMinifiedUrl = AUTOPTIMIZE_CACHE_URL.$_cache->getname();
379 379
 		}
380 380
 		unset($_cache);
@@ -385,10 +385,10 @@  discard block
 block discarded – undo
385 385
 		return $_CachedMinifiedUrl;
386 386
 	}
387 387
 	
388
-	protected function str_ends_in($haystack,$needle) {
388
+	protected function str_ends_in($haystack, $needle) {
389 389
 		$needleLength = strlen($needle);
390 390
 		$haystackLength = strlen($haystack);
391
-		$lastPos=strrpos($haystack,$needle);
391
+		$lastPos = strrpos($haystack, $needle);
392 392
 		if ($lastPos === $haystackLength - $needleLength) {
393 393
 			return true;
394 394
 		} else {
Please login to merge, or discard this patch.