PluginProbe ʕ •ᴥ•ʔ
NitroPack – Performance, Page Speed & Cache Plugin for Core Web Vitals, CDN & Image Optimization / trunk
NitroPack – Performance, Page Speed & Cache Plugin for Core Web Vitals, CDN & Image Optimization vtrunk
1.19.8 1.19.7 1.19.6 1.19.5 trunk 1.10.0 1.10.1 1.10.2 1.10.3 1.10.4 1.11.0 1.12.0 1.13.0 1.14.0 1.15.0 1.15.1 1.15.2 1.15.3 1.16.0 1.16.1 1.16.2 1.16.3 1.16.4 1.16.5 1.16.6 1.16.7 1.16.8 1.17.0 1.17.6 1.17.7 1.17.8 1.17.9 1.18.0 1.18.1 1.18.2 1.18.3 1.18.4 1.18.5 1.18.6 1.18.7 1.18.8 1.18.9 1.19.0 1.19.1 1.19.2 1.19.3 1.19.4 1.3.19 1.3.20 1.4.0 1.4.1 1.5.0 1.5.1 1.5.10 1.5.11 1.5.12 1.5.13 1.5.14 1.5.15 1.5.16 1.5.17 1.5.18 1.5.19 1.5.2 1.5.3 1.5.4 1.5.5 1.5.6 1.5.7 1.5.8 1.5.9 1.6.0 1.6.1 1.7.0 1.7.1 1.8.0 1.8.1 1.8.3 1.9.0 1.9.1 1.9.2
nitropack / view / modals / modal-modes.php
nitropack / view / modals Last commit date
modal-cache-warmup.php 1 month ago modal-disconnect.php 1 month ago modal-go-live.php 1 month ago modal-modes.php 3 days ago modal-not-optimized-CPT.php 1 year ago modal-optimization-mode.php 1 month ago modal-plugin-deactivate.php 1 month ago modal-posttypes.php 3 months ago modal-processing-html-error.php 3 months ago modal-processing-html-success.php 1 month ago modal-processing-html.php 1 month ago modal-purge-cache.php 1 month ago modal-safemode.php 1 month ago modal-test-mode.php 1 month ago modal-unsaved-changes.php 1 month ago
modal-modes.php
177 lines
1 <?php
2 $modes_api = $modes['optimization_options'];
3
4 $table_columns = array();
5 foreach ( $modes_api as $mode_id => $mode ) {
6 if ( $mode_id === 'custom' ) {
7 continue;
8 }
9 $table_columns[ $mode_id ] = __( $mode['human_readable_name'], 'nitropack' );
10 }
11 $table_columns_count = count( $table_columns );
12
13 $table_cells = array(
14 array(
15 'name' => __( 'Add HTML preconnects', 'nitropack' ), 'features' => array( 'standard', 'medium', 'strong', 'ludicrous', 'ludicrousPlus' ),
16 ),
17 array(
18 'name' => __( 'Minify resources', 'nitropack' ), 'features' => array( 'medium', 'strong', 'ludicrous', 'ludicrousPlus' ),
19 ),
20 array(
21 'name' => __( 'Combine JavaScript', 'nitropack' ), 'features' => array( '', '', '', '' ), 'always_render' => true,
22 ),
23 array(
24 'name' => __( 'Combine CSS', 'nitropack' ), 'features' => array( 'medium', 'strong', 'ludicrous', 'ludicrousPlus' )
25 ),
26 array(
27 'name' => __( 'Merge screen and all media styles', 'nitropack' ), 'features' => array( 'medium', 'strong', 'ludicrous', 'ludicrousPlus' ),
28 ),
29 array(
30 'name' => __( 'Generate critical CSS', 'nitropack' ), 'features' => array( 'medium', 'strong', 'ludicrous', 'ludicrousPlus' ),
31 ),
32 array(
33 'name' => __( 'Remove render-blocking resources', 'nitropack' ), 'features' => array( 'medium', 'strong', 'ludicrous', 'ludicrousPlus' ),
34 ),
35 array(
36 'name' => __( 'Use resource loader script', 'nitropack' ), 'features' => array( 'strong', 'ludicrous', 'ludicrousPlus' ), 'sub' => true
37 ),
38 array(
39 'name' => __( 'Delay loading of non-critical resources', 'nitropack' ), 'features' => array( 'ludicrous', 'ludicrousPlus' ), 'sub' => true
40 ),
41 array(
42 'name' => __( 'Resource loading strategy', 'nitropack' ), 'features' => array( 'standard' => 'Styles first', 'medium' => 'Styles first', 'strong' => 'Styles first', 'ludicrous' => 'Styles first', 'ludicrousPlus' => 'Styles first' ), 'sub' => true
43 ),
44 array(
45 'name' => __( 'Images lazy-loading', 'nitropack' ), 'features' => array( 'medium', 'strong', 'ludicrous', 'ludicrousPlus' ),
46 ),
47 array(
48 'name' => __( 'Size images preemtively', 'nitropack' ), 'features' => array( 'medium', 'strong', 'ludicrous', 'ludicrousPlus' ), 'sub' => true
49 ),
50 array(
51 'name' => __( 'iFrames lazy load', 'nitropack' ), 'features' => array( 'medium', 'strong', 'ludicrous', 'ludicrousPlus' ),
52 ),
53 array(
54 'name' => __( 'Image optimization', 'nitropack' ), 'features' => array( 'standard', 'medium', 'strong', 'ludicrous', 'ludicrousPlus' ),
55 ),
56 array(
57 'name' => __( 'Image quality', 'nitropack' ), 'features' => array( 'standard' => '100%', 'medium' => '80%', 'strong' => '80%', 'ludicrous' => '80%', 'ludicrousPlus' => '80%' ), 'sub' => true
58 ),
59 array(
60 'name' => __( 'Animated image optimization', 'nitropack' ), 'features' => array( 'ludicrousPlus' ),
61 ),
62 array(
63 'name' => __( 'Adaptive image sizing', 'nitropack' ), 'features' => array( 'ludicrousPlus' ),
64 ),
65 array(
66 'name' => __( 'Override font rendering behavior', 'nitropack' ), 'features' => array( 'strong', 'ludicrous', 'ludicrousPlus' ),
67 ),
68 array(
69 'name' => __( 'Font-display value', 'nitropack' ), 'features' => array( 'standard' => '', 'medium' => '', 'strong' => 'swap', 'ludicrous' => 'swap', 'ludicrousPlus' => 'swap' ), 'sub' => true,
70 ),
71 array(
72 'name' => __( 'Font loading', 'nitropack' ), 'features' => array( 'standard' => 'native', 'medium' => 'native', 'strong' => 'native', 'ludicrous' => 'native', 'ludicrousPlus' => 'onload' ),
73 ),
74 array(
75 'name' => __( 'Font compression', 'nitropack' ), 'features' => array( 'ludicrousPlus' ),
76 ),
77 array(
78 'name' => __( 'Instant cache reoptimize', 'nitropack' ), 'features' => array( 'ludicrousPlus' ),
79 ),
80 array(
81 'name' => __( 'Dynamic queue', 'nitropack' ), 'features' => array( 'ludicrousPlus' ),
82 ),
83 ); ?>
84
85 <div id="modal-modes" data-modal-backdrop="" tabindex="-1" aria-hidden="true" class="hidden modal-wrapper">
86 <div class="modal-container" style="max-width: 840px;">
87 <div class="modal-inner">
88 <!-- Modal header -->
89 <div class="modal-header">
90 <h3><?php esc_html_e( 'Modes comparison', 'nitropack' ); ?></h3>
91 <button type="button" class="close-modal" data-modal-hide="modal-modes">
92 <svg width="13" height="13" viewBox="0 0 13 13" fill="none" xmlns="http://www.w3.org/2000/svg">
93 <path fill-rule="evenodd" clip-rule="evenodd"
94 d="M0.293031 1.29308C0.480558 1.10561 0.734866 1.00029 1.00003 1.00029C1.26519 1.00029 1.5195 1.10561 1.70703 1.29308L6.00003 5.58608L10.293 1.29308C10.3853 1.19757 10.4956 1.12139 10.6176 1.06898C10.7396 1.01657 10.8709 0.988985 11.0036 0.987831C11.1364 0.986677 11.2681 1.01198 11.391 1.06226C11.5139 1.11254 11.6255 1.18679 11.7194 1.28069C11.8133 1.37458 11.8876 1.48623 11.9379 1.60913C11.9881 1.73202 12.0134 1.8637 12.0123 1.99648C12.0111 2.12926 11.9835 2.26048 11.9311 2.38249C11.8787 2.50449 11.8025 2.61483 11.707 2.70708L7.41403 7.00008L11.707 11.2931C11.8892 11.4817 11.99 11.7343 11.9877 11.9965C11.9854 12.2587 11.8803 12.5095 11.6948 12.6949C11.5094 12.8803 11.2586 12.9855 10.9964 12.9878C10.7342 12.99 10.4816 12.8892 10.293 12.7071L6.00003 8.41408L1.70703 12.7071C1.51843 12.8892 1.26583 12.99 1.00363 12.9878C0.741432 12.9855 0.49062 12.8803 0.305212 12.6949C0.119804 12.5095 0.0146347 12.2587 0.0123563 11.9965C0.0100779 11.7343 0.110873 11.4817 0.293031 11.2931L4.58603 7.00008L0.293031 2.70708C0.10556 2.51955 0.000244141 2.26525 0.000244141 2.00008C0.000244141 1.73492 0.10556 1.48061 0.293031 1.29308Z"
95 fill="#1B004E" />
96 </svg>
97 <span class="sr-only"><?php esc_html_e( 'Close modal', 'nitropack' ); ?></span>
98 </button>
99 </div>
100 <!-- Modal body -->
101 <div class="modal-body">
102 <div class="modern-table">
103 <div class="grid grid-cols-first-240 col-span-2 thead">
104 <div></div>
105 <div class="grid grid-cols-<?php echo esc_attr( $table_columns_count ); ?>">
106 <?php foreach ( $table_columns as $table_column ) : ?>
107 <div class="th">
108 <?php echo $table_column; ?>
109 </div>
110 <?php endforeach; ?>
111 </div>
112 </div>
113 <div class="scrollbar-default overflow-auto" style="max-height: calc(100% - 50px);">
114 <?php
115 foreach ( $table_cells as $feature ) :
116 $has_any_mode_feature = false;
117 foreach ( $table_columns as $key => $column ) {
118 if ( in_array( $key, $feature['features'], true ) || array_key_exists( $key, $feature['features'] ) ) {
119 $has_any_mode_feature = true;
120 break;
121 }
122 }
123
124 if ( ! $has_any_mode_feature && empty( $feature['always_render'] ) ) {
125 continue;
126 }
127 ?>
128 <div class="col-span-2 grid grid-cols-first-240 tr">
129 <div class="flex gap-2 td feature-name">
130 <?php if ( isset( $feature['sub'] ) ) : ?>
131 <svg width="10" height="16" viewBox="0 0 10 16" fill="none"
132 xmlns="http://www.w3.org/2000/svg" class="text-gray-500">
133 <path
134 d="M1 12H0.5V12.5H1V12ZM9.35355 12.3536C9.54882 12.1583 9.54882 11.8417 9.35355 11.6464L6.17157 8.46447C5.97631 8.2692 5.65973 8.2692 5.46447 8.46447C5.2692 8.65973 5.2692 8.97631 5.46447 9.17157L8.29289 12L5.46447 14.8284C5.2692 15.0237 5.2692 15.3403 5.46447 15.5355C5.65973 15.7308 5.97631 15.7308 6.17157 15.5355L9.35355 12.3536ZM0.5 0V12H1.5V0H0.5ZM1 12.5H9V11.5H1V12.5Z"
135 fill="currentColor"></path>
136 </svg>
137 <?php endif; ?>
138 <?php echo $feature['name']; ?>
139 </div>
140
141 <div class="grid grid-cols-<?php echo esc_attr( $table_columns_count ); ?> td modes">
142 <?php if ( $feature['features'] ) :
143 foreach ( $table_columns as $key => $column ) {
144 echo '<div class="flex justify-center items-center mode">';
145 // Check if the feature is available in the current column
146 $has_feature = in_array( $key, $feature['features'] );
147 // Display checkbox if the feature is available
148 if ( $has_feature ) {
149 echo '<svg width="16" height="11" viewBox="0 0 16 11" fill="none" xmlns="http://www.w3.org/2000/svg">
150 <path d="M14.6666 1L5.49992 10.1667L1.33325 6" stroke="#4600CC" stroke-width="1.33333" stroke-linecap="round" stroke-linejoin="round"/>
151 </svg>
152 ';
153 }
154 if ( array_key_exists( $key, $feature['features'] ) ) {
155 // Display the text specified in the features
156 echo '' . $feature['features'][ $key ] . '';
157 }
158 echo '</div>';
159 }
160 ?>
161
162 <?php
163 endif; ?>
164 </div>
165 </div>
166 <?php endforeach; ?>
167 </div>
168 </div>
169 <!-- Modal footer -->
170 <div class="modal-footer" style="margin-bottom: 0">
171 <button data-modal-hide="modal-modes" type="button"
172 class="btn btn-secondary ml-auto"><?php esc_html_e( 'Close', 'nitropack' ); ?></button>
173 </div>
174 </div>
175 </div>
176 </div>
177 </div>