@@ -13,30 +13,30 @@ discard block |
||
13 | 13 | class GetPaid_Bank_Transfer_Gateway extends GetPaid_Payment_Gateway { |
14 | 14 | |
15 | 15 | /** |
16 | - * Payment method id. |
|
17 | - * |
|
18 | - * @var string |
|
19 | - */ |
|
16 | + * Payment method id. |
|
17 | + * |
|
18 | + * @var string |
|
19 | + */ |
|
20 | 20 | public $id = 'bank_transfer'; |
21 | 21 | |
22 | - /** |
|
23 | - * An array of features that this gateway supports. |
|
24 | - * |
|
25 | - * @var array |
|
26 | - */ |
|
27 | - protected $supports = array( 'addons' ); |
|
22 | + /** |
|
23 | + * An array of features that this gateway supports. |
|
24 | + * |
|
25 | + * @var array |
|
26 | + */ |
|
27 | + protected $supports = array( 'addons' ); |
|
28 | 28 | |
29 | 29 | /** |
30 | - * Payment method order. |
|
31 | - * |
|
32 | - * @var int |
|
33 | - */ |
|
34 | - public $order = 8; |
|
30 | + * Payment method order. |
|
31 | + * |
|
32 | + * @var int |
|
33 | + */ |
|
34 | + public $order = 8; |
|
35 | 35 | |
36 | 36 | /** |
37 | - * Class constructor. |
|
38 | - */ |
|
39 | - public function __construct() { |
|
37 | + * Class constructor. |
|
38 | + */ |
|
39 | + public function __construct() { |
|
40 | 40 | parent::__construct(); |
41 | 41 | |
42 | 42 | $this->title = __( 'Direct bank transfer', 'invoicing' ); |
@@ -44,23 +44,23 @@ discard block |
||
44 | 44 | $this->checkout_button_text = __( 'Proceed', 'invoicing' ); |
45 | 45 | $this->instructions = apply_filters( 'wpinv_bank_instructions', $this->get_option( 'info' ) ); |
46 | 46 | |
47 | - add_action( 'wpinv_receipt_end', array( $this, 'thankyou_page' ) ); |
|
48 | - add_action( 'getpaid_invoice_line_items', array( $this, 'thankyou_page' ), 40 ); |
|
49 | - add_action( 'wpinv_pdf_content_billing', array( $this, 'thankyou_page' ), 11 ); |
|
50 | - add_action( 'wpinv_email_invoice_details', array( $this, 'email_instructions' ), 10, 3 ); |
|
47 | + add_action( 'wpinv_receipt_end', array( $this, 'thankyou_page' ) ); |
|
48 | + add_action( 'getpaid_invoice_line_items', array( $this, 'thankyou_page' ), 40 ); |
|
49 | + add_action( 'wpinv_pdf_content_billing', array( $this, 'thankyou_page' ), 11 ); |
|
50 | + add_action( 'wpinv_email_invoice_details', array( $this, 'email_instructions' ), 10, 3 ); |
|
51 | 51 | |
52 | 52 | } |
53 | 53 | |
54 | 54 | /** |
55 | - * Process Payment. |
|
56 | - * |
|
57 | - * |
|
58 | - * @param WPInv_Invoice $invoice Invoice. |
|
59 | - * @param array $submission_data Posted checkout fields. |
|
60 | - * @param GetPaid_Payment_Form_Submission $submission Checkout submission. |
|
61 | - * @return array |
|
62 | - */ |
|
63 | - public function process_payment( $invoice, $submission_data, $submission ) { |
|
55 | + * Process Payment. |
|
56 | + * |
|
57 | + * |
|
58 | + * @param WPInv_Invoice $invoice Invoice. |
|
59 | + * @param array $submission_data Posted checkout fields. |
|
60 | + * @param GetPaid_Payment_Form_Submission $submission Checkout submission. |
|
61 | + * @return array |
|
62 | + */ |
|
63 | + public function process_payment( $invoice, $submission_data, $submission ) { |
|
64 | 64 | |
65 | 65 | // Add a transaction id. |
66 | 66 | $invoice->set_transaction_id( $invoice->generate_key('trans_') ); |
@@ -81,66 +81,66 @@ discard block |
||
81 | 81 | } |
82 | 82 | |
83 | 83 | /** |
84 | - * Output for the order received page. |
|
85 | - * |
|
86 | - * @param WPInv_Invoice $invoice Invoice. |
|
87 | - */ |
|
88 | - public function thankyou_page( $invoice ) { |
|
84 | + * Output for the order received page. |
|
85 | + * |
|
86 | + * @param WPInv_Invoice $invoice Invoice. |
|
87 | + */ |
|
88 | + public function thankyou_page( $invoice ) { |
|
89 | 89 | |
90 | 90 | if ( 'bank_transfer' === $invoice->get_gateway() && $invoice->needs_payment() ) { |
91 | 91 | |
92 | - echo '<div class="mt-4 mb-2 getpaid-bank-transfer-details">' . PHP_EOL; |
|
92 | + echo '<div class="mt-4 mb-2 getpaid-bank-transfer-details">' . PHP_EOL; |
|
93 | 93 | |
94 | 94 | if ( ! empty( $this->instructions ) ) { |
95 | 95 | echo wp_kses_post( wpautop( wptexturize( $this->instructions ) ) ); |
96 | - } |
|
96 | + } |
|
97 | 97 | |
98 | - $this->bank_details( $invoice ); |
|
98 | + $this->bank_details( $invoice ); |
|
99 | 99 | |
100 | - echo '</div>'; |
|
100 | + echo '</div>'; |
|
101 | 101 | |
102 | 102 | } |
103 | 103 | |
104 | - } |
|
104 | + } |
|
105 | 105 | |
106 | 106 | /** |
107 | - * Add content to the WPI emails. |
|
108 | - * |
|
109 | - * @param WPInv_Invoice $invoice Invoice. |
|
110 | - * @param string $email_type Email format: plain text or HTML. |
|
111 | - * @param bool $sent_to_admin Sent to admin. |
|
112 | - */ |
|
113 | - public function email_instructions( $invoice, $email_type, $sent_to_admin ) { |
|
107 | + * Add content to the WPI emails. |
|
108 | + * |
|
109 | + * @param WPInv_Invoice $invoice Invoice. |
|
110 | + * @param string $email_type Email format: plain text or HTML. |
|
111 | + * @param bool $sent_to_admin Sent to admin. |
|
112 | + */ |
|
113 | + public function email_instructions( $invoice, $email_type, $sent_to_admin ) { |
|
114 | 114 | |
115 | - if ( ! $sent_to_admin && 'bank_transfer' === $invoice->get_gateway() && $invoice->needs_payment() ) { |
|
115 | + if ( ! $sent_to_admin && 'bank_transfer' === $invoice->get_gateway() && $invoice->needs_payment() ) { |
|
116 | 116 | |
117 | - echo '<div class="wpi-email-row getpaid-bank-transfer-details">'; |
|
117 | + echo '<div class="wpi-email-row getpaid-bank-transfer-details">'; |
|
118 | 118 | |
119 | - if ( $this->instructions ) { |
|
120 | - echo wp_kses_post( wpautop( wptexturize( $this->instructions ) ) . PHP_EOL ); |
|
119 | + if ( $this->instructions ) { |
|
120 | + echo wp_kses_post( wpautop( wptexturize( $this->instructions ) ) . PHP_EOL ); |
|
121 | 121 | } |
122 | 122 | |
123 | - $this->bank_details( $invoice ); |
|
123 | + $this->bank_details( $invoice ); |
|
124 | 124 | |
125 | - echo '</div>'; |
|
125 | + echo '</div>'; |
|
126 | 126 | |
127 | - } |
|
127 | + } |
|
128 | 128 | |
129 | 129 | } |
130 | 130 | |
131 | 131 | /** |
132 | - * Get bank details and place into a list format. |
|
133 | - * |
|
134 | - * @param WPInv_Invoice $invoice Invoice. |
|
135 | - */ |
|
136 | - protected function bank_details( $invoice ) { |
|
132 | + * Get bank details and place into a list format. |
|
133 | + * |
|
134 | + * @param WPInv_Invoice $invoice Invoice. |
|
135 | + */ |
|
136 | + protected function bank_details( $invoice ) { |
|
137 | 137 | |
138 | - // Get the invoice country and country $locale. |
|
139 | - $country = $invoice->get_country(); |
|
140 | - $locale = $this->get_country_locale(); |
|
138 | + // Get the invoice country and country $locale. |
|
139 | + $country = $invoice->get_country(); |
|
140 | + $locale = $this->get_country_locale(); |
|
141 | 141 | |
142 | - // Get sortcode label in the $locale array and use appropriate one. |
|
143 | - $sortcode = isset( $locale[ $country ]['sortcode']['label'] ) ? $locale[ $country ]['sortcode']['label'] : __( 'Sort code', 'invoicing' ); |
|
142 | + // Get sortcode label in the $locale array and use appropriate one. |
|
143 | + $sortcode = isset( $locale[ $country ]['sortcode']['label'] ) ? $locale[ $country ]['sortcode']['label'] : __( 'Sort code', 'invoicing' ); |
|
144 | 144 | |
145 | 145 | $bank_fields = array( |
146 | 146 | 'ac_name' => __( 'Account Name', 'invoicing' ), |
@@ -169,144 +169,144 @@ discard block |
||
169 | 169 | return; |
170 | 170 | } |
171 | 171 | |
172 | - echo '<h3 class="getpaid-bank-transfer-title"> ' . apply_filters( 'wpinv_receipt_bank_details_title', __( 'Bank Details', 'invoicing' ) ) . '</h3>' . PHP_EOL; |
|
172 | + echo '<h3 class="getpaid-bank-transfer-title"> ' . apply_filters( 'wpinv_receipt_bank_details_title', __( 'Bank Details', 'invoicing' ) ) . '</h3>' . PHP_EOL; |
|
173 | 173 | |
174 | - echo '<table class="table table-bordered getpaid-bank-transfer-details">' . PHP_EOL; |
|
174 | + echo '<table class="table table-bordered getpaid-bank-transfer-details">' . PHP_EOL; |
|
175 | 175 | |
176 | - foreach ( $bank_info as $key => $data ) { |
|
176 | + foreach ( $bank_info as $key => $data ) { |
|
177 | 177 | |
178 | - $key = sanitize_html_class( $key ); |
|
179 | - $label = wp_kses_post( $data['label'] ); |
|
180 | - $value = wp_kses_post( wptexturize( $data['value'] ) ); |
|
178 | + $key = sanitize_html_class( $key ); |
|
179 | + $label = wp_kses_post( $data['label'] ); |
|
180 | + $value = wp_kses_post( wptexturize( $data['value'] ) ); |
|
181 | 181 | |
182 | - echo "<tr class='getpaid-bank-transfer-$key'><th>$label</th><td>$value</td></tr>" . PHP_EOL; |
|
183 | - } |
|
182 | + echo "<tr class='getpaid-bank-transfer-$key'><th>$label</th><td>$value</td></tr>" . PHP_EOL; |
|
183 | + } |
|
184 | 184 | |
185 | - echo '</table>'; |
|
185 | + echo '</table>'; |
|
186 | 186 | |
187 | 187 | } |
188 | 188 | |
189 | 189 | /** |
190 | - * Get country locale if localized. |
|
191 | - * |
|
192 | - * @return array |
|
193 | - */ |
|
194 | - public function get_country_locale() { |
|
195 | - |
|
196 | - if ( empty( $this->locale ) ) { |
|
197 | - |
|
198 | - // Locale information to be used - only those that are not 'Sort Code'. |
|
199 | - $this->locale = apply_filters( |
|
200 | - 'getpaid_get_bank_transfer_locale', |
|
201 | - array( |
|
202 | - 'AU' => array( |
|
203 | - 'sortcode' => array( |
|
204 | - 'label' => __( 'BSB', 'invoicing' ), |
|
205 | - ), |
|
206 | - ), |
|
207 | - 'CA' => array( |
|
208 | - 'sortcode' => array( |
|
209 | - 'label' => __( 'Bank transit number', 'invoicing' ), |
|
210 | - ), |
|
211 | - ), |
|
212 | - 'IN' => array( |
|
213 | - 'sortcode' => array( |
|
214 | - 'label' => __( 'IFSC', 'invoicing' ), |
|
215 | - ), |
|
216 | - ), |
|
217 | - 'IT' => array( |
|
218 | - 'sortcode' => array( |
|
219 | - 'label' => __( 'Branch sort', 'invoicing' ), |
|
220 | - ), |
|
221 | - ), |
|
222 | - 'NZ' => array( |
|
223 | - 'sortcode' => array( |
|
224 | - 'label' => __( 'Bank code', 'invoicing' ), |
|
225 | - ), |
|
226 | - ), |
|
227 | - 'SE' => array( |
|
228 | - 'sortcode' => array( |
|
229 | - 'label' => __( 'Bank code', 'invoicing' ), |
|
230 | - ), |
|
231 | - ), |
|
232 | - 'US' => array( |
|
233 | - 'sortcode' => array( |
|
234 | - 'label' => __( 'Routing number', 'invoicing' ), |
|
235 | - ), |
|
236 | - ), |
|
237 | - 'ZA' => array( |
|
238 | - 'sortcode' => array( |
|
239 | - 'label' => __( 'Branch code', 'invoicing' ), |
|
240 | - ), |
|
241 | - ), |
|
242 | - ) |
|
243 | - ); |
|
244 | - |
|
245 | - } |
|
246 | - |
|
247 | - return $this->locale; |
|
248 | - |
|
249 | - } |
|
250 | - |
|
251 | - /** |
|
252 | - * Filters the gateway settings. |
|
253 | - * |
|
254 | - * @param array $admin_settings |
|
255 | - */ |
|
256 | - public function admin_settings( $admin_settings ) { |
|
190 | + * Get country locale if localized. |
|
191 | + * |
|
192 | + * @return array |
|
193 | + */ |
|
194 | + public function get_country_locale() { |
|
195 | + |
|
196 | + if ( empty( $this->locale ) ) { |
|
197 | + |
|
198 | + // Locale information to be used - only those that are not 'Sort Code'. |
|
199 | + $this->locale = apply_filters( |
|
200 | + 'getpaid_get_bank_transfer_locale', |
|
201 | + array( |
|
202 | + 'AU' => array( |
|
203 | + 'sortcode' => array( |
|
204 | + 'label' => __( 'BSB', 'invoicing' ), |
|
205 | + ), |
|
206 | + ), |
|
207 | + 'CA' => array( |
|
208 | + 'sortcode' => array( |
|
209 | + 'label' => __( 'Bank transit number', 'invoicing' ), |
|
210 | + ), |
|
211 | + ), |
|
212 | + 'IN' => array( |
|
213 | + 'sortcode' => array( |
|
214 | + 'label' => __( 'IFSC', 'invoicing' ), |
|
215 | + ), |
|
216 | + ), |
|
217 | + 'IT' => array( |
|
218 | + 'sortcode' => array( |
|
219 | + 'label' => __( 'Branch sort', 'invoicing' ), |
|
220 | + ), |
|
221 | + ), |
|
222 | + 'NZ' => array( |
|
223 | + 'sortcode' => array( |
|
224 | + 'label' => __( 'Bank code', 'invoicing' ), |
|
225 | + ), |
|
226 | + ), |
|
227 | + 'SE' => array( |
|
228 | + 'sortcode' => array( |
|
229 | + 'label' => __( 'Bank code', 'invoicing' ), |
|
230 | + ), |
|
231 | + ), |
|
232 | + 'US' => array( |
|
233 | + 'sortcode' => array( |
|
234 | + 'label' => __( 'Routing number', 'invoicing' ), |
|
235 | + ), |
|
236 | + ), |
|
237 | + 'ZA' => array( |
|
238 | + 'sortcode' => array( |
|
239 | + 'label' => __( 'Branch code', 'invoicing' ), |
|
240 | + ), |
|
241 | + ), |
|
242 | + ) |
|
243 | + ); |
|
244 | + |
|
245 | + } |
|
246 | + |
|
247 | + return $this->locale; |
|
248 | + |
|
249 | + } |
|
250 | + |
|
251 | + /** |
|
252 | + * Filters the gateway settings. |
|
253 | + * |
|
254 | + * @param array $admin_settings |
|
255 | + */ |
|
256 | + public function admin_settings( $admin_settings ) { |
|
257 | 257 | |
258 | 258 | $admin_settings['bank_transfer_desc']['std'] = __( "Make your payment directly into our bank account. Please use your Invoice Number as the payment reference. Your invoice won't be processed until the funds have cleared in our account.", 'invoicing' ); |
259 | - $admin_settings['bank_transfer_active']['desc'] = __( 'Enable bank transfer', 'invoicing' ); |
|
259 | + $admin_settings['bank_transfer_active']['desc'] = __( 'Enable bank transfer', 'invoicing' ); |
|
260 | 260 | |
261 | - $locale = $this->get_country_locale(); |
|
261 | + $locale = $this->get_country_locale(); |
|
262 | 262 | |
263 | - // Get sortcode label in the $locale array and use appropriate one. |
|
264 | - $country = wpinv_default_billing_country(); |
|
265 | - $sortcode = isset( $locale[ $country ]['sortcode']['label'] ) ? $locale[ $country ]['sortcode']['label'] : __( 'Sort code', 'invoicing' ); |
|
263 | + // Get sortcode label in the $locale array and use appropriate one. |
|
264 | + $country = wpinv_default_billing_country(); |
|
265 | + $sortcode = isset( $locale[ $country ]['sortcode']['label'] ) ? $locale[ $country ]['sortcode']['label'] : __( 'Sort code', 'invoicing' ); |
|
266 | 266 | |
267 | - $admin_settings['bank_transfer_ac_name'] = array( |
|
267 | + $admin_settings['bank_transfer_ac_name'] = array( |
|
268 | 268 | 'type' => 'text', |
269 | 269 | 'id' => 'bank_transfer_ac_name', |
270 | 270 | 'name' => __( 'Account Name', 'invoicing' ), |
271 | - ); |
|
271 | + ); |
|
272 | 272 | |
273 | - $admin_settings['bank_transfer_ac_no'] = array( |
|
273 | + $admin_settings['bank_transfer_ac_no'] = array( |
|
274 | 274 | 'type' => 'text', |
275 | 275 | 'id' => 'bank_transfer_ac_no', |
276 | 276 | 'name' => __( 'Account Number', 'invoicing' ), |
277 | - ); |
|
277 | + ); |
|
278 | 278 | |
279 | - $admin_settings['bank_transfer_bank_name'] = array( |
|
279 | + $admin_settings['bank_transfer_bank_name'] = array( |
|
280 | 280 | 'type' => 'text', |
281 | 281 | 'id' => 'bank_transfer_bank_name', |
282 | 282 | 'name' => __( 'Bank Name', 'invoicing' ), |
283 | - ); |
|
283 | + ); |
|
284 | 284 | |
285 | - $admin_settings['bank_transfer_ifsc'] = array( |
|
285 | + $admin_settings['bank_transfer_ifsc'] = array( |
|
286 | 286 | 'type' => 'text', |
287 | 287 | 'id' => 'bank_transfer_ifsc', |
288 | 288 | 'name' => __( 'IFSC Code', 'invoicing' ), |
289 | - ); |
|
289 | + ); |
|
290 | 290 | |
291 | - $admin_settings['bank_transfer_iban'] = array( |
|
291 | + $admin_settings['bank_transfer_iban'] = array( |
|
292 | 292 | 'type' => 'text', |
293 | 293 | 'id' => 'bank_transfer_iban', |
294 | 294 | 'name' => __( 'IBAN', 'invoicing' ), |
295 | - ); |
|
295 | + ); |
|
296 | 296 | |
297 | - $admin_settings['bank_transfer_bic'] = array( |
|
297 | + $admin_settings['bank_transfer_bic'] = array( |
|
298 | 298 | 'type' => 'text', |
299 | 299 | 'id' => 'bank_transfer_bic', |
300 | 300 | 'name' => __( 'BIC/Swift Code', 'invoicing' ), |
301 | - ); |
|
301 | + ); |
|
302 | 302 | |
303 | - $admin_settings['bank_transfer_sort_code'] = array( |
|
304 | - 'type' => 'text', |
|
305 | - 'id' => 'bank_transfer_sort_code', |
|
306 | - 'name' => $sortcode, |
|
307 | - ); |
|
303 | + $admin_settings['bank_transfer_sort_code'] = array( |
|
304 | + 'type' => 'text', |
|
305 | + 'id' => 'bank_transfer_sort_code', |
|
306 | + 'name' => $sortcode, |
|
307 | + ); |
|
308 | 308 | |
309 | - $admin_settings['bank_transfer_info'] = array( |
|
309 | + $admin_settings['bank_transfer_info'] = array( |
|
310 | 310 | 'id' => 'bank_transfer_info', |
311 | 311 | 'name' => __( 'Instructions', 'invoicing' ), |
312 | 312 | 'desc' => __( 'Instructions that will be added to the thank you page and emails.', 'invoicing' ), |
@@ -316,17 +316,17 @@ discard block |
||
316 | 316 | 'rows' => 5 |
317 | 317 | ); |
318 | 318 | |
319 | - return $admin_settings; |
|
320 | - } |
|
319 | + return $admin_settings; |
|
320 | + } |
|
321 | 321 | |
322 | - /** |
|
323 | - * Processes invoice addons. |
|
324 | - * |
|
325 | - * @param WPInv_Invoice $invoice |
|
326 | - * @param GetPaid_Form_Item[] $items |
|
327 | - * @return WPInv_Invoice |
|
328 | - */ |
|
329 | - public function process_addons( $invoice, $items ) { |
|
322 | + /** |
|
323 | + * Processes invoice addons. |
|
324 | + * |
|
325 | + * @param WPInv_Invoice $invoice |
|
326 | + * @param GetPaid_Form_Item[] $items |
|
327 | + * @return WPInv_Invoice |
|
328 | + */ |
|
329 | + public function process_addons( $invoice, $items ) { |
|
330 | 330 | |
331 | 331 | foreach ( $items as $item ) { |
332 | 332 | $invoice->add_item( $item ); |
@@ -334,6 +334,6 @@ discard block |
||
334 | 334 | |
335 | 335 | $invoice->recalculate_total(); |
336 | 336 | $invoice->save(); |
337 | - } |
|
337 | + } |
|
338 | 338 | |
339 | 339 | } |
@@ -18,758 +18,758 @@ |
||
18 | 18 | */ |
19 | 19 | class GetPaid_REST_Settings_Controller extends GetPaid_REST_Controller { |
20 | 20 | |
21 | - /** |
|
22 | - * An array of available settings. |
|
23 | - * |
|
24 | - * @var string |
|
25 | - */ |
|
26 | - protected $settings; |
|
27 | - |
|
28 | - /** |
|
29 | - * Route base. |
|
30 | - * |
|
31 | - * @var string |
|
32 | - */ |
|
33 | - protected $rest_base = 'settings'; |
|
34 | - |
|
35 | - /** |
|
36 | - * Registers the routes for the objects of the controller. |
|
37 | - * |
|
38 | - * @since 2.0.0 |
|
39 | - * |
|
40 | - * @see register_rest_route() |
|
41 | - */ |
|
42 | - public function register_namespace_routes( $namespace ) { |
|
43 | - |
|
44 | - // List all registered tabs. |
|
45 | - register_rest_route( |
|
46 | - $namespace, |
|
47 | - $this->rest_base, |
|
48 | - array( |
|
49 | - array( |
|
50 | - 'methods' => WP_REST_Server::READABLE, |
|
51 | - 'callback' => array( $this, 'get_tabs' ), |
|
52 | - 'permission_callback' => array( $this, 'get_items_permissions_check' ), |
|
53 | - ), |
|
54 | - 'schema' => '__return_empty_array', |
|
55 | - ) |
|
56 | - ); |
|
57 | - |
|
58 | - // View/Update a single setting. |
|
59 | - register_rest_route( |
|
60 | - $namespace, |
|
61 | - $this->rest_base . '/setting/(?P<id>[\w-]+)', |
|
62 | - array( |
|
63 | - 'args' => array( |
|
64 | - 'id' => array( |
|
65 | - 'description' => __( 'Unique identifier for the setting.', 'invoicing' ), |
|
66 | - 'type' => 'string', |
|
67 | - 'required' => true, |
|
68 | - ), |
|
69 | - ), |
|
70 | - array( |
|
71 | - 'methods' => WP_REST_Server::READABLE, |
|
72 | - 'callback' => array( $this, 'get_item' ), |
|
73 | - 'permission_callback' => array( $this, 'get_items_permissions_check' ), |
|
74 | - ), |
|
75 | - array( |
|
76 | - 'methods' => WP_REST_Server::EDITABLE, |
|
77 | - 'callback' => array( $this, 'update_item' ), |
|
78 | - 'permission_callback' => array( $this, 'update_items_permissions_check' ), |
|
79 | - 'args' => $this->get_endpoint_args_for_item_schema( WP_REST_Server::EDITABLE ), |
|
80 | - ), |
|
81 | - 'schema' => array( $this, 'get_public_item_schema' ), |
|
82 | - ) |
|
83 | - ); |
|
84 | - |
|
85 | - // List registered sections for a given tab. |
|
86 | - register_rest_route( |
|
87 | - $namespace, |
|
88 | - $this->rest_base . '/(?P<tab>[\w-]+)', |
|
89 | - array( |
|
90 | - 'args' => array( |
|
91 | - 'tab' => array( |
|
92 | - 'description' => __( 'Unique identifier for the tab whose sections should be retrieved.', 'invoicing' ), |
|
93 | - 'type' => 'string', |
|
94 | - 'required' => true, |
|
95 | - 'enum' => array_keys( wpinv_get_settings_tabs() ), |
|
96 | - ), |
|
97 | - ), |
|
98 | - array( |
|
99 | - 'methods' => WP_REST_Server::READABLE, |
|
100 | - 'callback' => array( $this, 'get_sections' ), |
|
101 | - 'permission_callback' => array( $this, 'get_items_permissions_check' ), |
|
102 | - ), |
|
103 | - 'schema' => '__return_empty_array', |
|
104 | - ) |
|
105 | - ); |
|
106 | - |
|
107 | - // List all registered settings for a given tab. |
|
108 | - register_rest_route( |
|
109 | - $namespace, |
|
110 | - $this->rest_base . '/(?P<tab>[\w-]+)/(?P<section>[\w-]+)', |
|
111 | - array( |
|
112 | - 'args' => array( |
|
113 | - 'tab' => array( |
|
114 | - 'description' => __( 'Unique identifier for the tab whose settings should be retrieved.', 'invoicing' ), |
|
115 | - 'type' => 'string', |
|
116 | - 'required' => true, |
|
117 | - 'enum' => array_keys( wpinv_get_settings_tabs() ), |
|
118 | - ), |
|
119 | - 'section' => array( |
|
120 | - 'description' => __( 'The section in the tab whose settings should be retrieved.', 'invoicing' ), |
|
121 | - 'type' => 'string', |
|
122 | - 'required' => true, |
|
123 | - ), |
|
124 | - ), |
|
125 | - array( |
|
126 | - 'methods' => WP_REST_Server::READABLE, |
|
127 | - 'callback' => array( $this, 'get_items' ), |
|
128 | - 'permission_callback' => array( $this, 'get_items_permissions_check' ), |
|
129 | - ), |
|
130 | - 'schema' => array( $this, 'get_public_item_schema' ), |
|
131 | - ) |
|
132 | - ); |
|
133 | - |
|
134 | - register_rest_route( |
|
135 | - $namespace, |
|
136 | - '/' . $this->rest_base . '/batch', |
|
137 | - array( |
|
138 | - 'args' => array( |
|
139 | - 'id' => array( |
|
140 | - 'description' => __( 'Setting ID.', 'invoicing' ), |
|
141 | - 'type' => 'string', |
|
142 | - ), |
|
143 | - ), |
|
144 | - array( |
|
145 | - 'methods' => WP_REST_Server::EDITABLE, |
|
146 | - 'callback' => array( $this, 'batch_items' ), |
|
147 | - 'permission_callback' => array( $this, 'batch_items_permissions_check' ), |
|
148 | - 'args' => $this->get_endpoint_args_for_item_schema( WP_REST_Server::EDITABLE ), |
|
149 | - ), |
|
150 | - 'schema' => array( $this, 'get_public_batch_schema' ), |
|
151 | - ) |
|
152 | - ); |
|
153 | - |
|
154 | - } |
|
21 | + /** |
|
22 | + * An array of available settings. |
|
23 | + * |
|
24 | + * @var string |
|
25 | + */ |
|
26 | + protected $settings; |
|
27 | + |
|
28 | + /** |
|
29 | + * Route base. |
|
30 | + * |
|
31 | + * @var string |
|
32 | + */ |
|
33 | + protected $rest_base = 'settings'; |
|
34 | + |
|
35 | + /** |
|
36 | + * Registers the routes for the objects of the controller. |
|
37 | + * |
|
38 | + * @since 2.0.0 |
|
39 | + * |
|
40 | + * @see register_rest_route() |
|
41 | + */ |
|
42 | + public function register_namespace_routes( $namespace ) { |
|
43 | + |
|
44 | + // List all registered tabs. |
|
45 | + register_rest_route( |
|
46 | + $namespace, |
|
47 | + $this->rest_base, |
|
48 | + array( |
|
49 | + array( |
|
50 | + 'methods' => WP_REST_Server::READABLE, |
|
51 | + 'callback' => array( $this, 'get_tabs' ), |
|
52 | + 'permission_callback' => array( $this, 'get_items_permissions_check' ), |
|
53 | + ), |
|
54 | + 'schema' => '__return_empty_array', |
|
55 | + ) |
|
56 | + ); |
|
57 | + |
|
58 | + // View/Update a single setting. |
|
59 | + register_rest_route( |
|
60 | + $namespace, |
|
61 | + $this->rest_base . '/setting/(?P<id>[\w-]+)', |
|
62 | + array( |
|
63 | + 'args' => array( |
|
64 | + 'id' => array( |
|
65 | + 'description' => __( 'Unique identifier for the setting.', 'invoicing' ), |
|
66 | + 'type' => 'string', |
|
67 | + 'required' => true, |
|
68 | + ), |
|
69 | + ), |
|
70 | + array( |
|
71 | + 'methods' => WP_REST_Server::READABLE, |
|
72 | + 'callback' => array( $this, 'get_item' ), |
|
73 | + 'permission_callback' => array( $this, 'get_items_permissions_check' ), |
|
74 | + ), |
|
75 | + array( |
|
76 | + 'methods' => WP_REST_Server::EDITABLE, |
|
77 | + 'callback' => array( $this, 'update_item' ), |
|
78 | + 'permission_callback' => array( $this, 'update_items_permissions_check' ), |
|
79 | + 'args' => $this->get_endpoint_args_for_item_schema( WP_REST_Server::EDITABLE ), |
|
80 | + ), |
|
81 | + 'schema' => array( $this, 'get_public_item_schema' ), |
|
82 | + ) |
|
83 | + ); |
|
84 | + |
|
85 | + // List registered sections for a given tab. |
|
86 | + register_rest_route( |
|
87 | + $namespace, |
|
88 | + $this->rest_base . '/(?P<tab>[\w-]+)', |
|
89 | + array( |
|
90 | + 'args' => array( |
|
91 | + 'tab' => array( |
|
92 | + 'description' => __( 'Unique identifier for the tab whose sections should be retrieved.', 'invoicing' ), |
|
93 | + 'type' => 'string', |
|
94 | + 'required' => true, |
|
95 | + 'enum' => array_keys( wpinv_get_settings_tabs() ), |
|
96 | + ), |
|
97 | + ), |
|
98 | + array( |
|
99 | + 'methods' => WP_REST_Server::READABLE, |
|
100 | + 'callback' => array( $this, 'get_sections' ), |
|
101 | + 'permission_callback' => array( $this, 'get_items_permissions_check' ), |
|
102 | + ), |
|
103 | + 'schema' => '__return_empty_array', |
|
104 | + ) |
|
105 | + ); |
|
106 | + |
|
107 | + // List all registered settings for a given tab. |
|
108 | + register_rest_route( |
|
109 | + $namespace, |
|
110 | + $this->rest_base . '/(?P<tab>[\w-]+)/(?P<section>[\w-]+)', |
|
111 | + array( |
|
112 | + 'args' => array( |
|
113 | + 'tab' => array( |
|
114 | + 'description' => __( 'Unique identifier for the tab whose settings should be retrieved.', 'invoicing' ), |
|
115 | + 'type' => 'string', |
|
116 | + 'required' => true, |
|
117 | + 'enum' => array_keys( wpinv_get_settings_tabs() ), |
|
118 | + ), |
|
119 | + 'section' => array( |
|
120 | + 'description' => __( 'The section in the tab whose settings should be retrieved.', 'invoicing' ), |
|
121 | + 'type' => 'string', |
|
122 | + 'required' => true, |
|
123 | + ), |
|
124 | + ), |
|
125 | + array( |
|
126 | + 'methods' => WP_REST_Server::READABLE, |
|
127 | + 'callback' => array( $this, 'get_items' ), |
|
128 | + 'permission_callback' => array( $this, 'get_items_permissions_check' ), |
|
129 | + ), |
|
130 | + 'schema' => array( $this, 'get_public_item_schema' ), |
|
131 | + ) |
|
132 | + ); |
|
133 | + |
|
134 | + register_rest_route( |
|
135 | + $namespace, |
|
136 | + '/' . $this->rest_base . '/batch', |
|
137 | + array( |
|
138 | + 'args' => array( |
|
139 | + 'id' => array( |
|
140 | + 'description' => __( 'Setting ID.', 'invoicing' ), |
|
141 | + 'type' => 'string', |
|
142 | + ), |
|
143 | + ), |
|
144 | + array( |
|
145 | + 'methods' => WP_REST_Server::EDITABLE, |
|
146 | + 'callback' => array( $this, 'batch_items' ), |
|
147 | + 'permission_callback' => array( $this, 'batch_items_permissions_check' ), |
|
148 | + 'args' => $this->get_endpoint_args_for_item_schema( WP_REST_Server::EDITABLE ), |
|
149 | + ), |
|
150 | + 'schema' => array( $this, 'get_public_batch_schema' ), |
|
151 | + ) |
|
152 | + ); |
|
153 | + |
|
154 | + } |
|
155 | 155 | |
156 | - /** |
|
157 | - * Return all settings. |
|
158 | - * |
|
159 | - * @since 2.0.0 |
|
160 | - * @param WP_REST_Request $request Request data. |
|
161 | - * @return WP_Error|WP_REST_Response |
|
162 | - */ |
|
163 | - public function get_items( $request ) { |
|
164 | - |
|
165 | - $settings = $this->get_settings(); |
|
166 | - |
|
167 | - if ( ! isset( $settings[ $request['tab'] ] ) ) { |
|
168 | - return new WP_Error( 'rest_invalid_tab', __( 'Invalid tab.', 'invoicing' ), array( 'status' => 400 ) ); |
|
169 | - } |
|
170 | - |
|
171 | - if ( ! isset( $settings[ $request['tab'] ][ $request['section'] ] ) ) { |
|
172 | - return new WP_Error( 'rest_invalid_section', __( 'Invalid section.', 'invoicing' ), array( 'status' => 400 ) ); |
|
173 | - } |
|
174 | - |
|
175 | - $settings = $settings[ $request['tab'] ][ $request['section'] ]; |
|
176 | - $prepared = array(); |
|
177 | - |
|
178 | - foreach ( $settings as $setting ) { |
|
179 | - |
|
180 | - $setting = $this->sanitize_setting( $setting ); |
|
181 | - $setting_data = $this->prepare_item_for_response( $setting, $request ); |
|
182 | - $setting_data = $this->prepare_response_for_collection( $setting_data ); |
|
183 | - |
|
184 | - if ( $this->is_setting_type_valid( $setting['type'] ) ) { |
|
185 | - $prepared[] = $setting_data; |
|
186 | - } |
|
187 | - |
|
188 | - } |
|
189 | - |
|
190 | - return rest_ensure_response( $prepared ); |
|
191 | - } |
|
192 | - |
|
193 | - /** |
|
194 | - * Return a single setting. |
|
195 | - * |
|
196 | - * @since 2.0.0 |
|
197 | - * @param WP_REST_Request $request Request data. |
|
198 | - * @return WP_Error|WP_REST_Response |
|
199 | - */ |
|
200 | - public function get_item( $request ) { |
|
201 | - $setting = $this->get_setting( $request['id'] ); |
|
202 | - |
|
203 | - if ( is_wp_error( $setting ) ) { |
|
204 | - return $setting; |
|
205 | - } |
|
206 | - |
|
207 | - $setting = $this->sanitize_setting( $setting ); |
|
208 | - $response = $this->prepare_item_for_response( $setting, $request ); |
|
209 | - return rest_ensure_response( $response ); |
|
210 | - } |
|
211 | - |
|
212 | - /** |
|
213 | - * Update a single setting. |
|
214 | - * |
|
215 | - * @since 2.0.0 |
|
216 | - * @param WP_REST_Request $request Request data. |
|
217 | - * @return WP_Error|WP_REST_Response |
|
218 | - */ |
|
219 | - public function update_item( $request ) { |
|
220 | - $setting = $this->get_setting( $request['id'] ); |
|
221 | - |
|
222 | - if ( is_wp_error( $setting ) ) { |
|
223 | - return $setting; |
|
224 | - } |
|
225 | - |
|
226 | - if ( is_callable( array( $this, 'validate_setting_' . $setting['type'] . '_field' ) ) ) { |
|
227 | - $value = $this->{'validate_setting_' . $setting['type'] . '_field'}( $request['value'], $setting ); |
|
228 | - } else { |
|
229 | - $value = $this->validate_setting_text_field( $request['value'], $setting ); |
|
230 | - } |
|
231 | - |
|
232 | - if ( is_wp_error( $value ) ) { |
|
233 | - return $value; |
|
234 | - } |
|
235 | - |
|
236 | - wpinv_update_option( $request['id'], $value ); |
|
237 | - $setting['value'] = $value; |
|
238 | - $setting = $this->sanitize_setting( $setting ); |
|
239 | - $response = $this->prepare_item_for_response( $setting, $request ); |
|
240 | - |
|
241 | - return rest_ensure_response( $response ); |
|
242 | - } |
|
243 | - |
|
244 | - /** |
|
245 | - * Makes sure the current user has access to READ the settings APIs. |
|
246 | - * |
|
247 | - * @since 2.0.0 |
|
248 | - * @param WP_REST_Request $request Full data about the request. |
|
249 | - * @return WP_Error|boolean |
|
250 | - */ |
|
251 | - public function get_items_permissions_check( $request ) { |
|
252 | - if ( ! wpinv_current_user_can_manage_invoicing() ) { |
|
253 | - return new WP_Error( 'rest_cannot_view', __( 'Sorry, you cannot list resources.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) ); |
|
254 | - } |
|
255 | - |
|
256 | - return true; |
|
257 | - } |
|
258 | - |
|
259 | - /** |
|
260 | - * Makes sure the current user has access to WRITE the settings APIs. |
|
261 | - * |
|
262 | - * @since 2.0.0 |
|
263 | - * @param WP_REST_Request $request Full data about the request. |
|
264 | - * @return WP_Error|boolean |
|
265 | - */ |
|
266 | - public function update_items_permissions_check( $request ) { |
|
267 | - if ( ! wpinv_current_user_can_manage_invoicing() ) { |
|
268 | - return new WP_Error( 'rest_cannot_edit', __( 'Sorry, you cannot edit this resource.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) ); |
|
269 | - } |
|
270 | - |
|
271 | - return true; |
|
272 | - } |
|
273 | - |
|
274 | - /** |
|
275 | - * Check if a given request has access batch create, update and delete items. |
|
276 | - * |
|
277 | - * @param WP_REST_Request $request Full details about the request. |
|
278 | - * |
|
279 | - * @return boolean|WP_Error |
|
280 | - */ |
|
281 | - public function batch_items_permissions_check( $request ) { |
|
282 | - return wpinv_current_user_can_manage_invoicing() ? true : new WP_Error( 'rest_cannot_batch', __( 'Sorry, you are not allowed to batch manipulate this resource.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) ); |
|
283 | - } |
|
284 | - |
|
285 | - /** |
|
286 | - * Prepare links for the request. |
|
287 | - * |
|
288 | - * @param string $setting_id Setting ID. |
|
289 | - * @return array Links for the given setting. |
|
290 | - */ |
|
291 | - protected function prepare_links( $setting_id ) { |
|
292 | - |
|
293 | - $links = array( |
|
294 | - 'self' => array( |
|
295 | - 'href' => rest_url( sprintf( '/%s/%s/setting/%s', $this->namespace, $this->rest_base, $setting_id ) ), |
|
296 | - ), |
|
297 | - 'collection' => array( |
|
298 | - 'href' => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ), |
|
299 | - ), |
|
300 | - ); |
|
301 | - |
|
302 | - return $links; |
|
303 | - } |
|
304 | - |
|
305 | - /** |
|
306 | - * Prepare a settings object for serialization. |
|
307 | - * |
|
308 | - * @since 2.0.0 |
|
309 | - * @param array $item Setting object. |
|
310 | - * @param WP_REST_Request $request Request object. |
|
311 | - * @return WP_REST_Response $response Response data. |
|
312 | - */ |
|
313 | - public function prepare_item_for_response( $item, $request ) { |
|
314 | - $context = empty( $request['context'] ) ? 'view' : $request['context']; |
|
315 | - $data = $this->add_additional_fields_to_object( $item, $request ); |
|
316 | - $data = $this->filter_response_by_context( $data, $context ); |
|
317 | - |
|
318 | - $response = rest_ensure_response( $data ); |
|
319 | - |
|
320 | - $response->add_links( $this->prepare_links( $item['id'] ) ); |
|
321 | - |
|
322 | - return $response; |
|
323 | - } |
|
324 | - |
|
325 | - /** |
|
326 | - * Filters out bad values from the settings array/filter so we |
|
327 | - * only return known values via the API. |
|
328 | - * |
|
329 | - * @since 2.0.0 |
|
330 | - * @param array $setting Setting. |
|
331 | - * @return array |
|
332 | - */ |
|
333 | - public function filter_setting( $setting ) { |
|
334 | - return array_intersect_key( |
|
335 | - $setting, |
|
336 | - array_flip( array_filter( array_keys( $setting ), array( $this, 'allowed_setting_keys' ) ) ) |
|
337 | - ); |
|
338 | - } |
|
339 | - |
|
340 | - /** |
|
341 | - * Callback for allowed keys for each setting response. |
|
342 | - * |
|
343 | - * @param string $key Key to check. |
|
344 | - * @return boolean |
|
345 | - */ |
|
346 | - public function allowed_setting_keys( $key ) { |
|
347 | - return in_array( $key, array_keys( $this->setting_defaults() ), true ); |
|
348 | - } |
|
349 | - |
|
350 | - /** |
|
351 | - * Returns default options for a setting. null means the field is required. |
|
352 | - * |
|
353 | - * @since 2.0.0 |
|
354 | - * @return array |
|
355 | - */ |
|
356 | - protected function setting_defaults() { |
|
357 | - return array( |
|
358 | - 'id' => null, |
|
359 | - 'name' => null, |
|
360 | - 'desc' => '', |
|
361 | - 'options' => array(), |
|
362 | - 'std' => false, |
|
363 | - 'value' => false, |
|
364 | - 'placeholder' => '', |
|
365 | - 'readonly' => false, |
|
366 | - 'faux' => false, |
|
367 | - 'section' => 'main', |
|
368 | - 'tab' => 'general', |
|
369 | - 'type' => 'text', |
|
370 | - ); |
|
371 | - } |
|
372 | - |
|
373 | - /** |
|
374 | - * Sanitizes a setting's field. |
|
375 | - * |
|
376 | - * @param array $setting The setting to sanitize. |
|
377 | - * @return array |
|
378 | - */ |
|
379 | - public function sanitize_setting( $setting ) { |
|
156 | + /** |
|
157 | + * Return all settings. |
|
158 | + * |
|
159 | + * @since 2.0.0 |
|
160 | + * @param WP_REST_Request $request Request data. |
|
161 | + * @return WP_Error|WP_REST_Response |
|
162 | + */ |
|
163 | + public function get_items( $request ) { |
|
164 | + |
|
165 | + $settings = $this->get_settings(); |
|
166 | + |
|
167 | + if ( ! isset( $settings[ $request['tab'] ] ) ) { |
|
168 | + return new WP_Error( 'rest_invalid_tab', __( 'Invalid tab.', 'invoicing' ), array( 'status' => 400 ) ); |
|
169 | + } |
|
170 | + |
|
171 | + if ( ! isset( $settings[ $request['tab'] ][ $request['section'] ] ) ) { |
|
172 | + return new WP_Error( 'rest_invalid_section', __( 'Invalid section.', 'invoicing' ), array( 'status' => 400 ) ); |
|
173 | + } |
|
174 | + |
|
175 | + $settings = $settings[ $request['tab'] ][ $request['section'] ]; |
|
176 | + $prepared = array(); |
|
177 | + |
|
178 | + foreach ( $settings as $setting ) { |
|
179 | + |
|
180 | + $setting = $this->sanitize_setting( $setting ); |
|
181 | + $setting_data = $this->prepare_item_for_response( $setting, $request ); |
|
182 | + $setting_data = $this->prepare_response_for_collection( $setting_data ); |
|
183 | + |
|
184 | + if ( $this->is_setting_type_valid( $setting['type'] ) ) { |
|
185 | + $prepared[] = $setting_data; |
|
186 | + } |
|
187 | + |
|
188 | + } |
|
189 | + |
|
190 | + return rest_ensure_response( $prepared ); |
|
191 | + } |
|
192 | + |
|
193 | + /** |
|
194 | + * Return a single setting. |
|
195 | + * |
|
196 | + * @since 2.0.0 |
|
197 | + * @param WP_REST_Request $request Request data. |
|
198 | + * @return WP_Error|WP_REST_Response |
|
199 | + */ |
|
200 | + public function get_item( $request ) { |
|
201 | + $setting = $this->get_setting( $request['id'] ); |
|
202 | + |
|
203 | + if ( is_wp_error( $setting ) ) { |
|
204 | + return $setting; |
|
205 | + } |
|
206 | + |
|
207 | + $setting = $this->sanitize_setting( $setting ); |
|
208 | + $response = $this->prepare_item_for_response( $setting, $request ); |
|
209 | + return rest_ensure_response( $response ); |
|
210 | + } |
|
211 | + |
|
212 | + /** |
|
213 | + * Update a single setting. |
|
214 | + * |
|
215 | + * @since 2.0.0 |
|
216 | + * @param WP_REST_Request $request Request data. |
|
217 | + * @return WP_Error|WP_REST_Response |
|
218 | + */ |
|
219 | + public function update_item( $request ) { |
|
220 | + $setting = $this->get_setting( $request['id'] ); |
|
221 | + |
|
222 | + if ( is_wp_error( $setting ) ) { |
|
223 | + return $setting; |
|
224 | + } |
|
225 | + |
|
226 | + if ( is_callable( array( $this, 'validate_setting_' . $setting['type'] . '_field' ) ) ) { |
|
227 | + $value = $this->{'validate_setting_' . $setting['type'] . '_field'}( $request['value'], $setting ); |
|
228 | + } else { |
|
229 | + $value = $this->validate_setting_text_field( $request['value'], $setting ); |
|
230 | + } |
|
231 | + |
|
232 | + if ( is_wp_error( $value ) ) { |
|
233 | + return $value; |
|
234 | + } |
|
235 | + |
|
236 | + wpinv_update_option( $request['id'], $value ); |
|
237 | + $setting['value'] = $value; |
|
238 | + $setting = $this->sanitize_setting( $setting ); |
|
239 | + $response = $this->prepare_item_for_response( $setting, $request ); |
|
240 | + |
|
241 | + return rest_ensure_response( $response ); |
|
242 | + } |
|
243 | + |
|
244 | + /** |
|
245 | + * Makes sure the current user has access to READ the settings APIs. |
|
246 | + * |
|
247 | + * @since 2.0.0 |
|
248 | + * @param WP_REST_Request $request Full data about the request. |
|
249 | + * @return WP_Error|boolean |
|
250 | + */ |
|
251 | + public function get_items_permissions_check( $request ) { |
|
252 | + if ( ! wpinv_current_user_can_manage_invoicing() ) { |
|
253 | + return new WP_Error( 'rest_cannot_view', __( 'Sorry, you cannot list resources.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) ); |
|
254 | + } |
|
255 | + |
|
256 | + return true; |
|
257 | + } |
|
258 | + |
|
259 | + /** |
|
260 | + * Makes sure the current user has access to WRITE the settings APIs. |
|
261 | + * |
|
262 | + * @since 2.0.0 |
|
263 | + * @param WP_REST_Request $request Full data about the request. |
|
264 | + * @return WP_Error|boolean |
|
265 | + */ |
|
266 | + public function update_items_permissions_check( $request ) { |
|
267 | + if ( ! wpinv_current_user_can_manage_invoicing() ) { |
|
268 | + return new WP_Error( 'rest_cannot_edit', __( 'Sorry, you cannot edit this resource.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) ); |
|
269 | + } |
|
270 | + |
|
271 | + return true; |
|
272 | + } |
|
273 | + |
|
274 | + /** |
|
275 | + * Check if a given request has access batch create, update and delete items. |
|
276 | + * |
|
277 | + * @param WP_REST_Request $request Full details about the request. |
|
278 | + * |
|
279 | + * @return boolean|WP_Error |
|
280 | + */ |
|
281 | + public function batch_items_permissions_check( $request ) { |
|
282 | + return wpinv_current_user_can_manage_invoicing() ? true : new WP_Error( 'rest_cannot_batch', __( 'Sorry, you are not allowed to batch manipulate this resource.', 'invoicing' ), array( 'status' => rest_authorization_required_code() ) ); |
|
283 | + } |
|
284 | + |
|
285 | + /** |
|
286 | + * Prepare links for the request. |
|
287 | + * |
|
288 | + * @param string $setting_id Setting ID. |
|
289 | + * @return array Links for the given setting. |
|
290 | + */ |
|
291 | + protected function prepare_links( $setting_id ) { |
|
292 | + |
|
293 | + $links = array( |
|
294 | + 'self' => array( |
|
295 | + 'href' => rest_url( sprintf( '/%s/%s/setting/%s', $this->namespace, $this->rest_base, $setting_id ) ), |
|
296 | + ), |
|
297 | + 'collection' => array( |
|
298 | + 'href' => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ), |
|
299 | + ), |
|
300 | + ); |
|
301 | + |
|
302 | + return $links; |
|
303 | + } |
|
304 | + |
|
305 | + /** |
|
306 | + * Prepare a settings object for serialization. |
|
307 | + * |
|
308 | + * @since 2.0.0 |
|
309 | + * @param array $item Setting object. |
|
310 | + * @param WP_REST_Request $request Request object. |
|
311 | + * @return WP_REST_Response $response Response data. |
|
312 | + */ |
|
313 | + public function prepare_item_for_response( $item, $request ) { |
|
314 | + $context = empty( $request['context'] ) ? 'view' : $request['context']; |
|
315 | + $data = $this->add_additional_fields_to_object( $item, $request ); |
|
316 | + $data = $this->filter_response_by_context( $data, $context ); |
|
317 | + |
|
318 | + $response = rest_ensure_response( $data ); |
|
319 | + |
|
320 | + $response->add_links( $this->prepare_links( $item['id'] ) ); |
|
321 | + |
|
322 | + return $response; |
|
323 | + } |
|
324 | + |
|
325 | + /** |
|
326 | + * Filters out bad values from the settings array/filter so we |
|
327 | + * only return known values via the API. |
|
328 | + * |
|
329 | + * @since 2.0.0 |
|
330 | + * @param array $setting Setting. |
|
331 | + * @return array |
|
332 | + */ |
|
333 | + public function filter_setting( $setting ) { |
|
334 | + return array_intersect_key( |
|
335 | + $setting, |
|
336 | + array_flip( array_filter( array_keys( $setting ), array( $this, 'allowed_setting_keys' ) ) ) |
|
337 | + ); |
|
338 | + } |
|
339 | + |
|
340 | + /** |
|
341 | + * Callback for allowed keys for each setting response. |
|
342 | + * |
|
343 | + * @param string $key Key to check. |
|
344 | + * @return boolean |
|
345 | + */ |
|
346 | + public function allowed_setting_keys( $key ) { |
|
347 | + return in_array( $key, array_keys( $this->setting_defaults() ), true ); |
|
348 | + } |
|
349 | + |
|
350 | + /** |
|
351 | + * Returns default options for a setting. null means the field is required. |
|
352 | + * |
|
353 | + * @since 2.0.0 |
|
354 | + * @return array |
|
355 | + */ |
|
356 | + protected function setting_defaults() { |
|
357 | + return array( |
|
358 | + 'id' => null, |
|
359 | + 'name' => null, |
|
360 | + 'desc' => '', |
|
361 | + 'options' => array(), |
|
362 | + 'std' => false, |
|
363 | + 'value' => false, |
|
364 | + 'placeholder' => '', |
|
365 | + 'readonly' => false, |
|
366 | + 'faux' => false, |
|
367 | + 'section' => 'main', |
|
368 | + 'tab' => 'general', |
|
369 | + 'type' => 'text', |
|
370 | + ); |
|
371 | + } |
|
372 | + |
|
373 | + /** |
|
374 | + * Sanitizes a setting's field. |
|
375 | + * |
|
376 | + * @param array $setting The setting to sanitize. |
|
377 | + * @return array |
|
378 | + */ |
|
379 | + public function sanitize_setting( $setting ) { |
|
380 | 380 | |
381 | - $setting = wp_parse_args( $setting, $this->setting_defaults() ); |
|
382 | - $setting['value'] = wpinv_get_option( $setting['id'], $setting['std'] ); |
|
383 | - return $this->filter_setting( $setting ); |
|
384 | - |
|
385 | - } |
|
386 | - |
|
387 | - /** |
|
388 | - * Get setting data. |
|
389 | - * |
|
390 | - * @since 2.0.0 |
|
391 | - * @param string $setting_id Setting ID. |
|
392 | - * @return array|WP_Error |
|
393 | - */ |
|
394 | - public function get_setting( $setting_id ) { |
|
395 | - |
|
396 | - if ( empty( $setting_id ) ) { |
|
397 | - return new WP_Error( 'rest_setting_setting_invalid', __( 'Invalid setting.', 'invoicing' ), array( 'status' => 404 ) ); |
|
398 | - } |
|
399 | - |
|
400 | - $settings = $this->get_settings(); |
|
401 | - |
|
402 | - foreach ( $settings as $tabs ) { |
|
403 | - |
|
404 | - foreach ( $tabs as $sections ) { |
|
405 | - |
|
406 | - if ( isset( $sections[ $setting_id ] ) ) { |
|
407 | - if ( ! $this->is_setting_type_valid( $sections[ $setting_id ]['type'] ) ) { |
|
408 | - return new WP_Error( 'rest_setting_setting_type_invalid', __( 'Invalid setting type.', 'invoicing' ), array( 'status' => 404 ) ); |
|
409 | - } |
|
410 | - |
|
411 | - return $sections[ $setting_id ]; |
|
412 | - } |
|
413 | - |
|
414 | - } |
|
415 | - |
|
416 | - } |
|
417 | - |
|
418 | - return new WP_Error( 'rest_setting_setting_invalid', __( 'Invalid setting.', 'invoicing' ), array( 'status' => 404 ) ); |
|
419 | - } |
|
420 | - |
|
421 | - /** |
|
422 | - * Get all tabs. |
|
423 | - * |
|
424 | - * @param WP_REST_Request $request Request data. |
|
425 | - * @return array |
|
426 | - */ |
|
427 | - public function get_tabs( $request ) { |
|
428 | - $tabs = wpinv_get_settings_tabs(); |
|
429 | - $prepared = array(); |
|
430 | - |
|
431 | - foreach ( $tabs as $id => $tab ) { |
|
432 | - |
|
433 | - $_request = $request; |
|
434 | - $_request['tab'] = sanitize_title( $id ); |
|
435 | - $data = array( |
|
436 | - 'id' => sanitize_title( $id ), |
|
437 | - 'label' => sanitize_text_field( $tab ), |
|
438 | - 'sections' => $this->get_sections( $_request ), |
|
439 | - ); |
|
440 | - |
|
441 | - $data = $this->add_additional_fields_to_object( $data, $request ); |
|
442 | - $response = rest_ensure_response( $data ); |
|
443 | - |
|
444 | - if ( ! is_wp_error( $response ) ) { |
|
445 | - $links = array( |
|
446 | - 'sections' => array( |
|
447 | - 'href' => rest_url( sprintf( '/%s/%s/%s', $this->namespace, $this->rest_base, $id ) ), |
|
448 | - ), |
|
449 | - 'collection' => array( |
|
450 | - 'href' => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ), |
|
451 | - ), |
|
452 | - ); |
|
453 | - $response->add_links( $links ); |
|
454 | - $response = $this->prepare_response_for_collection( $response ); |
|
455 | - } |
|
456 | - |
|
457 | - $prepared[] = $response; |
|
458 | - |
|
459 | - } |
|
460 | - |
|
461 | - return rest_ensure_response( $prepared ); |
|
462 | - } |
|
463 | - |
|
464 | - /** |
|
465 | - * Get all sections. |
|
466 | - * |
|
467 | - * @param WP_REST_Request $request Request data. |
|
468 | - * @return array |
|
469 | - */ |
|
470 | - public function get_sections( $request ) { |
|
471 | - |
|
472 | - $tab = sanitize_title( $request['tab'] ); |
|
473 | - $sections = wpinv_get_settings_tab_sections( $tab ); |
|
474 | - $prepared = array(); |
|
475 | - |
|
476 | - foreach ( $sections as $id => $section ) { |
|
477 | - |
|
478 | - $data = array( |
|
479 | - 'id' => sanitize_title( $id ), |
|
480 | - 'label' => sanitize_text_field( $section ), |
|
481 | - ); |
|
482 | - |
|
483 | - $data = $this->add_additional_fields_to_object( $data, $request ); |
|
484 | - $response = rest_ensure_response( $data ); |
|
485 | - |
|
486 | - if ( ! is_wp_error( $response ) ) { |
|
487 | - $links = array( |
|
488 | - 'settings' => array( |
|
489 | - 'href' => rest_url( sprintf( '/%s/%s/%s/%s', $this->namespace, $this->rest_base, $tab, $id ) ), |
|
490 | - ), |
|
491 | - 'collection' => array( |
|
492 | - 'href' => rest_url( sprintf( '/%s/%s/%s', $this->namespace, $this->rest_base, $tab ) ), |
|
493 | - ), |
|
494 | - 'tabs' => array( |
|
495 | - 'href' => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ), |
|
496 | - ), |
|
497 | - ); |
|
498 | - $response->add_links( $links ); |
|
499 | - $response = $this->prepare_response_for_collection( $response ); |
|
500 | - } |
|
501 | - |
|
502 | - $prepared[] = $response; |
|
503 | - |
|
504 | - } |
|
505 | - |
|
506 | - return rest_ensure_response( $prepared ); |
|
507 | - } |
|
508 | - |
|
509 | - /** |
|
510 | - * Get all settings. |
|
511 | - * |
|
512 | - * @return array |
|
513 | - */ |
|
514 | - public function get_settings() { |
|
515 | - |
|
516 | - if ( empty( $this->settings ) ) { |
|
517 | - $this->settings = wpinv_get_registered_settings(); |
|
518 | - } |
|
519 | - |
|
520 | - return $this->settings; |
|
521 | - |
|
522 | - } |
|
523 | - |
|
524 | - /** |
|
525 | - * Boolean for if a setting type is a valid supported setting type. |
|
526 | - * |
|
527 | - * @since 2.0.0 |
|
528 | - * @param string $type Type. |
|
529 | - * @return bool |
|
530 | - */ |
|
531 | - public function is_setting_type_valid( $type ) { |
|
532 | - |
|
533 | - return in_array( |
|
534 | - $type, array( |
|
535 | - 'text', // Validates with validate_setting_text_field. |
|
536 | - 'email', // Validates with validate_setting_text_field. |
|
537 | - 'number', // Validates with validate_setting_text_field. |
|
538 | - 'color', // Validates with validate_setting_text_field. |
|
539 | - 'password', // Validates with validate_setting_text_field. |
|
540 | - 'textarea', // Validates with validate_setting_textarea_field. |
|
541 | - 'select', // Validates with validate_setting_select_field. |
|
542 | - 'multiselect', // Validates with validate_setting_multiselect_field. |
|
543 | - 'radio', // Validates with validate_setting_radio_field (-> validate_setting_select_field). |
|
544 | - 'checkbox', // Validates with validate_setting_checkbox_field. |
|
545 | - 'header', // Validates with validate_setting_text_field. |
|
546 | - ) |
|
547 | - ); |
|
548 | - |
|
549 | - } |
|
550 | - |
|
551 | - /** |
|
552 | - * Get the settings schema, conforming to JSON Schema. |
|
553 | - * |
|
554 | - * @return array |
|
555 | - */ |
|
556 | - public function get_item_schema() { |
|
557 | - |
|
558 | - // Maybe retrieve the schema from cache. |
|
559 | - if ( ! empty( $this->schema ) ) { |
|
560 | - return $this->add_additional_fields_schema( $this->schema ); |
|
561 | - } |
|
562 | - |
|
563 | - $schema = array( |
|
564 | - '$schema' => 'http://json-schema.org/draft-04/schema#', |
|
565 | - 'title' => 'setting', |
|
566 | - 'type' => 'object', |
|
567 | - 'properties' => array( |
|
568 | - 'id' => array( |
|
569 | - 'description' => __( 'A unique identifier for the setting.', 'invoicing' ), |
|
570 | - 'type' => 'string', |
|
571 | - 'arg_options' => array( |
|
572 | - 'sanitize_callback' => 'sanitize_title', |
|
573 | - ), |
|
574 | - 'context' => array( 'view', 'edit' ), |
|
575 | - 'readonly' => true, |
|
576 | - ), |
|
577 | - 'tab' => array( |
|
578 | - 'description' => __( 'An identifier for the tab this setting belongs to.', 'invoicing' ), |
|
579 | - 'type' => 'string', |
|
580 | - 'arg_options' => array( |
|
581 | - 'sanitize_callback' => 'sanitize_title', |
|
582 | - ), |
|
583 | - 'context' => array( 'view', 'edit' ), |
|
584 | - 'readonly' => true, |
|
585 | - ), |
|
586 | - 'section' => array( |
|
587 | - 'description' => __( 'An identifier for the section this setting belongs to.', 'invoicing' ), |
|
588 | - 'type' => 'string', |
|
589 | - 'arg_options' => array( |
|
590 | - 'sanitize_callback' => 'sanitize_title', |
|
591 | - ), |
|
592 | - 'context' => array( 'view', 'edit' ), |
|
593 | - 'readonly' => true, |
|
594 | - ), |
|
595 | - 'name' => array( |
|
596 | - 'description' => __( 'A human readable label for the setting used in interfaces.', 'invoicing' ), |
|
597 | - 'type' => 'string', |
|
598 | - 'arg_options' => array( |
|
599 | - 'sanitize_callback' => 'sanitize_text_field', |
|
600 | - ), |
|
601 | - 'context' => array( 'view', 'edit' ), |
|
602 | - 'readonly' => true, |
|
603 | - ), |
|
604 | - 'desc' => array( |
|
605 | - 'description' => __( 'A human readable description for the setting used in interfaces.', 'invoicing' ), |
|
606 | - 'type' => 'string', |
|
607 | - 'context' => array( 'view', 'edit' ), |
|
608 | - 'readonly' => true, |
|
609 | - ), |
|
610 | - 'value' => array( |
|
611 | - 'description' => __( 'The current value of this setting.', 'invoicing' ), |
|
612 | - 'type' => 'mixed', |
|
613 | - 'context' => array( 'view', 'edit' ), |
|
614 | - ), |
|
615 | - 'default' => array( |
|
616 | - 'description' => __( 'Default value for the setting.', 'invoicing' ), |
|
617 | - 'type' => 'mixed', |
|
618 | - 'context' => array( 'view', 'edit' ), |
|
619 | - 'readonly' => true, |
|
620 | - ), |
|
621 | - 'placeholder' => array( |
|
622 | - 'description' => __( 'Placeholder text to be displayed in text inputs.', 'invoicing' ), |
|
623 | - 'type' => 'string', |
|
624 | - 'arg_options' => array( |
|
625 | - 'sanitize_callback' => 'sanitize_text_field', |
|
626 | - ), |
|
627 | - 'context' => array( 'view', 'edit' ), |
|
628 | - 'readonly' => true, |
|
629 | - ), |
|
630 | - 'type' => array( |
|
631 | - 'description' => __( 'Type of setting.', 'invoicing' ), |
|
632 | - 'type' => 'string', |
|
633 | - 'arg_options' => array( |
|
634 | - 'sanitize_callback' => 'sanitize_text_field', |
|
635 | - ), |
|
636 | - 'context' => array( 'view', 'edit' ), |
|
637 | - 'enum' => array( 'text', 'email', 'number', 'color', 'password', 'textarea', 'select', 'multiselect', 'radio', 'image_width', 'checkbox', 'raw_html' ), |
|
638 | - 'readonly' => true, |
|
639 | - ), |
|
640 | - 'options' => array( |
|
641 | - 'description' => __( 'Array of options (key value pairs) for inputs such as select, multiselect, and radio buttons.', 'invoicing' ), |
|
642 | - 'type' => 'object', |
|
643 | - 'context' => array( 'view', 'edit' ), |
|
644 | - 'readonly' => true, |
|
645 | - ), |
|
646 | - 'readonly' => array( |
|
647 | - 'description' => __( 'Whether or not this setting is readonly', 'invoicing' ), |
|
648 | - 'type' => 'string', |
|
649 | - 'context' => array( 'view' ), |
|
650 | - 'readonly' => true, |
|
651 | - ), |
|
652 | - 'faux' => array( |
|
653 | - 'description' => __( 'Whether or not this setting is readonly/faux', 'invoicing' ), |
|
654 | - 'type' => 'string', |
|
655 | - 'context' => array( 'view' ), |
|
656 | - 'readonly' => true, |
|
657 | - ), |
|
658 | - ), |
|
659 | - ); |
|
660 | - |
|
661 | - // Filters the settings schema for the REST API. |
|
381 | + $setting = wp_parse_args( $setting, $this->setting_defaults() ); |
|
382 | + $setting['value'] = wpinv_get_option( $setting['id'], $setting['std'] ); |
|
383 | + return $this->filter_setting( $setting ); |
|
384 | + |
|
385 | + } |
|
386 | + |
|
387 | + /** |
|
388 | + * Get setting data. |
|
389 | + * |
|
390 | + * @since 2.0.0 |
|
391 | + * @param string $setting_id Setting ID. |
|
392 | + * @return array|WP_Error |
|
393 | + */ |
|
394 | + public function get_setting( $setting_id ) { |
|
395 | + |
|
396 | + if ( empty( $setting_id ) ) { |
|
397 | + return new WP_Error( 'rest_setting_setting_invalid', __( 'Invalid setting.', 'invoicing' ), array( 'status' => 404 ) ); |
|
398 | + } |
|
399 | + |
|
400 | + $settings = $this->get_settings(); |
|
401 | + |
|
402 | + foreach ( $settings as $tabs ) { |
|
403 | + |
|
404 | + foreach ( $tabs as $sections ) { |
|
405 | + |
|
406 | + if ( isset( $sections[ $setting_id ] ) ) { |
|
407 | + if ( ! $this->is_setting_type_valid( $sections[ $setting_id ]['type'] ) ) { |
|
408 | + return new WP_Error( 'rest_setting_setting_type_invalid', __( 'Invalid setting type.', 'invoicing' ), array( 'status' => 404 ) ); |
|
409 | + } |
|
410 | + |
|
411 | + return $sections[ $setting_id ]; |
|
412 | + } |
|
413 | + |
|
414 | + } |
|
415 | + |
|
416 | + } |
|
417 | + |
|
418 | + return new WP_Error( 'rest_setting_setting_invalid', __( 'Invalid setting.', 'invoicing' ), array( 'status' => 404 ) ); |
|
419 | + } |
|
420 | + |
|
421 | + /** |
|
422 | + * Get all tabs. |
|
423 | + * |
|
424 | + * @param WP_REST_Request $request Request data. |
|
425 | + * @return array |
|
426 | + */ |
|
427 | + public function get_tabs( $request ) { |
|
428 | + $tabs = wpinv_get_settings_tabs(); |
|
429 | + $prepared = array(); |
|
430 | + |
|
431 | + foreach ( $tabs as $id => $tab ) { |
|
432 | + |
|
433 | + $_request = $request; |
|
434 | + $_request['tab'] = sanitize_title( $id ); |
|
435 | + $data = array( |
|
436 | + 'id' => sanitize_title( $id ), |
|
437 | + 'label' => sanitize_text_field( $tab ), |
|
438 | + 'sections' => $this->get_sections( $_request ), |
|
439 | + ); |
|
440 | + |
|
441 | + $data = $this->add_additional_fields_to_object( $data, $request ); |
|
442 | + $response = rest_ensure_response( $data ); |
|
443 | + |
|
444 | + if ( ! is_wp_error( $response ) ) { |
|
445 | + $links = array( |
|
446 | + 'sections' => array( |
|
447 | + 'href' => rest_url( sprintf( '/%s/%s/%s', $this->namespace, $this->rest_base, $id ) ), |
|
448 | + ), |
|
449 | + 'collection' => array( |
|
450 | + 'href' => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ), |
|
451 | + ), |
|
452 | + ); |
|
453 | + $response->add_links( $links ); |
|
454 | + $response = $this->prepare_response_for_collection( $response ); |
|
455 | + } |
|
456 | + |
|
457 | + $prepared[] = $response; |
|
458 | + |
|
459 | + } |
|
460 | + |
|
461 | + return rest_ensure_response( $prepared ); |
|
462 | + } |
|
463 | + |
|
464 | + /** |
|
465 | + * Get all sections. |
|
466 | + * |
|
467 | + * @param WP_REST_Request $request Request data. |
|
468 | + * @return array |
|
469 | + */ |
|
470 | + public function get_sections( $request ) { |
|
471 | + |
|
472 | + $tab = sanitize_title( $request['tab'] ); |
|
473 | + $sections = wpinv_get_settings_tab_sections( $tab ); |
|
474 | + $prepared = array(); |
|
475 | + |
|
476 | + foreach ( $sections as $id => $section ) { |
|
477 | + |
|
478 | + $data = array( |
|
479 | + 'id' => sanitize_title( $id ), |
|
480 | + 'label' => sanitize_text_field( $section ), |
|
481 | + ); |
|
482 | + |
|
483 | + $data = $this->add_additional_fields_to_object( $data, $request ); |
|
484 | + $response = rest_ensure_response( $data ); |
|
485 | + |
|
486 | + if ( ! is_wp_error( $response ) ) { |
|
487 | + $links = array( |
|
488 | + 'settings' => array( |
|
489 | + 'href' => rest_url( sprintf( '/%s/%s/%s/%s', $this->namespace, $this->rest_base, $tab, $id ) ), |
|
490 | + ), |
|
491 | + 'collection' => array( |
|
492 | + 'href' => rest_url( sprintf( '/%s/%s/%s', $this->namespace, $this->rest_base, $tab ) ), |
|
493 | + ), |
|
494 | + 'tabs' => array( |
|
495 | + 'href' => rest_url( sprintf( '/%s/%s', $this->namespace, $this->rest_base ) ), |
|
496 | + ), |
|
497 | + ); |
|
498 | + $response->add_links( $links ); |
|
499 | + $response = $this->prepare_response_for_collection( $response ); |
|
500 | + } |
|
501 | + |
|
502 | + $prepared[] = $response; |
|
503 | + |
|
504 | + } |
|
505 | + |
|
506 | + return rest_ensure_response( $prepared ); |
|
507 | + } |
|
508 | + |
|
509 | + /** |
|
510 | + * Get all settings. |
|
511 | + * |
|
512 | + * @return array |
|
513 | + */ |
|
514 | + public function get_settings() { |
|
515 | + |
|
516 | + if ( empty( $this->settings ) ) { |
|
517 | + $this->settings = wpinv_get_registered_settings(); |
|
518 | + } |
|
519 | + |
|
520 | + return $this->settings; |
|
521 | + |
|
522 | + } |
|
523 | + |
|
524 | + /** |
|
525 | + * Boolean for if a setting type is a valid supported setting type. |
|
526 | + * |
|
527 | + * @since 2.0.0 |
|
528 | + * @param string $type Type. |
|
529 | + * @return bool |
|
530 | + */ |
|
531 | + public function is_setting_type_valid( $type ) { |
|
532 | + |
|
533 | + return in_array( |
|
534 | + $type, array( |
|
535 | + 'text', // Validates with validate_setting_text_field. |
|
536 | + 'email', // Validates with validate_setting_text_field. |
|
537 | + 'number', // Validates with validate_setting_text_field. |
|
538 | + 'color', // Validates with validate_setting_text_field. |
|
539 | + 'password', // Validates with validate_setting_text_field. |
|
540 | + 'textarea', // Validates with validate_setting_textarea_field. |
|
541 | + 'select', // Validates with validate_setting_select_field. |
|
542 | + 'multiselect', // Validates with validate_setting_multiselect_field. |
|
543 | + 'radio', // Validates with validate_setting_radio_field (-> validate_setting_select_field). |
|
544 | + 'checkbox', // Validates with validate_setting_checkbox_field. |
|
545 | + 'header', // Validates with validate_setting_text_field. |
|
546 | + ) |
|
547 | + ); |
|
548 | + |
|
549 | + } |
|
550 | + |
|
551 | + /** |
|
552 | + * Get the settings schema, conforming to JSON Schema. |
|
553 | + * |
|
554 | + * @return array |
|
555 | + */ |
|
556 | + public function get_item_schema() { |
|
557 | + |
|
558 | + // Maybe retrieve the schema from cache. |
|
559 | + if ( ! empty( $this->schema ) ) { |
|
560 | + return $this->add_additional_fields_schema( $this->schema ); |
|
561 | + } |
|
562 | + |
|
563 | + $schema = array( |
|
564 | + '$schema' => 'http://json-schema.org/draft-04/schema#', |
|
565 | + 'title' => 'setting', |
|
566 | + 'type' => 'object', |
|
567 | + 'properties' => array( |
|
568 | + 'id' => array( |
|
569 | + 'description' => __( 'A unique identifier for the setting.', 'invoicing' ), |
|
570 | + 'type' => 'string', |
|
571 | + 'arg_options' => array( |
|
572 | + 'sanitize_callback' => 'sanitize_title', |
|
573 | + ), |
|
574 | + 'context' => array( 'view', 'edit' ), |
|
575 | + 'readonly' => true, |
|
576 | + ), |
|
577 | + 'tab' => array( |
|
578 | + 'description' => __( 'An identifier for the tab this setting belongs to.', 'invoicing' ), |
|
579 | + 'type' => 'string', |
|
580 | + 'arg_options' => array( |
|
581 | + 'sanitize_callback' => 'sanitize_title', |
|
582 | + ), |
|
583 | + 'context' => array( 'view', 'edit' ), |
|
584 | + 'readonly' => true, |
|
585 | + ), |
|
586 | + 'section' => array( |
|
587 | + 'description' => __( 'An identifier for the section this setting belongs to.', 'invoicing' ), |
|
588 | + 'type' => 'string', |
|
589 | + 'arg_options' => array( |
|
590 | + 'sanitize_callback' => 'sanitize_title', |
|
591 | + ), |
|
592 | + 'context' => array( 'view', 'edit' ), |
|
593 | + 'readonly' => true, |
|
594 | + ), |
|
595 | + 'name' => array( |
|
596 | + 'description' => __( 'A human readable label for the setting used in interfaces.', 'invoicing' ), |
|
597 | + 'type' => 'string', |
|
598 | + 'arg_options' => array( |
|
599 | + 'sanitize_callback' => 'sanitize_text_field', |
|
600 | + ), |
|
601 | + 'context' => array( 'view', 'edit' ), |
|
602 | + 'readonly' => true, |
|
603 | + ), |
|
604 | + 'desc' => array( |
|
605 | + 'description' => __( 'A human readable description for the setting used in interfaces.', 'invoicing' ), |
|
606 | + 'type' => 'string', |
|
607 | + 'context' => array( 'view', 'edit' ), |
|
608 | + 'readonly' => true, |
|
609 | + ), |
|
610 | + 'value' => array( |
|
611 | + 'description' => __( 'The current value of this setting.', 'invoicing' ), |
|
612 | + 'type' => 'mixed', |
|
613 | + 'context' => array( 'view', 'edit' ), |
|
614 | + ), |
|
615 | + 'default' => array( |
|
616 | + 'description' => __( 'Default value for the setting.', 'invoicing' ), |
|
617 | + 'type' => 'mixed', |
|
618 | + 'context' => array( 'view', 'edit' ), |
|
619 | + 'readonly' => true, |
|
620 | + ), |
|
621 | + 'placeholder' => array( |
|
622 | + 'description' => __( 'Placeholder text to be displayed in text inputs.', 'invoicing' ), |
|
623 | + 'type' => 'string', |
|
624 | + 'arg_options' => array( |
|
625 | + 'sanitize_callback' => 'sanitize_text_field', |
|
626 | + ), |
|
627 | + 'context' => array( 'view', 'edit' ), |
|
628 | + 'readonly' => true, |
|
629 | + ), |
|
630 | + 'type' => array( |
|
631 | + 'description' => __( 'Type of setting.', 'invoicing' ), |
|
632 | + 'type' => 'string', |
|
633 | + 'arg_options' => array( |
|
634 | + 'sanitize_callback' => 'sanitize_text_field', |
|
635 | + ), |
|
636 | + 'context' => array( 'view', 'edit' ), |
|
637 | + 'enum' => array( 'text', 'email', 'number', 'color', 'password', 'textarea', 'select', 'multiselect', 'radio', 'image_width', 'checkbox', 'raw_html' ), |
|
638 | + 'readonly' => true, |
|
639 | + ), |
|
640 | + 'options' => array( |
|
641 | + 'description' => __( 'Array of options (key value pairs) for inputs such as select, multiselect, and radio buttons.', 'invoicing' ), |
|
642 | + 'type' => 'object', |
|
643 | + 'context' => array( 'view', 'edit' ), |
|
644 | + 'readonly' => true, |
|
645 | + ), |
|
646 | + 'readonly' => array( |
|
647 | + 'description' => __( 'Whether or not this setting is readonly', 'invoicing' ), |
|
648 | + 'type' => 'string', |
|
649 | + 'context' => array( 'view' ), |
|
650 | + 'readonly' => true, |
|
651 | + ), |
|
652 | + 'faux' => array( |
|
653 | + 'description' => __( 'Whether or not this setting is readonly/faux', 'invoicing' ), |
|
654 | + 'type' => 'string', |
|
655 | + 'context' => array( 'view' ), |
|
656 | + 'readonly' => true, |
|
657 | + ), |
|
658 | + ), |
|
659 | + ); |
|
660 | + |
|
661 | + // Filters the settings schema for the REST API. |
|
662 | 662 | $schema = apply_filters( 'getpaid_rest_settings_schema', $schema ); |
663 | 663 | |
664 | - // Cache the settings schema. |
|
665 | - $this->schema = $schema; |
|
666 | - |
|
667 | - return $this->add_additional_fields_schema( $this->schema ); |
|
668 | - |
|
669 | - } |
|
670 | - |
|
671 | - /** |
|
672 | - * Validate a text value for a text based setting. |
|
673 | - * |
|
674 | - * @since 2.0.0 |
|
675 | - * @param string $value Value. |
|
676 | - * @param array $setting Setting. |
|
677 | - * @return string |
|
678 | - */ |
|
679 | - public function validate_setting_text_field( $value ) { |
|
680 | - $value = is_null( $value ) ? '' : $value; |
|
681 | - return wp_kses_post( trim( stripslashes( $value ) ) ); |
|
682 | - } |
|
683 | - |
|
684 | - /** |
|
685 | - * Validate select based settings. |
|
686 | - * |
|
687 | - * @since 2.0.0 |
|
688 | - * @param string $value Value. |
|
689 | - * @param array $setting Setting. |
|
690 | - * @return string|WP_Error |
|
691 | - */ |
|
692 | - public function validate_setting_select_field( $value, $setting ) { |
|
693 | - if ( array_key_exists( $value, $setting['options'] ) ) { |
|
694 | - return $value; |
|
695 | - } else { |
|
696 | - return new WP_Error( 'rest_setting_value_invalid', __( 'An invalid setting value was passed.', 'invoicing' ), array( 'status' => 400 ) ); |
|
697 | - } |
|
698 | - } |
|
699 | - |
|
700 | - /** |
|
701 | - * Validate multiselect based settings. |
|
702 | - * |
|
703 | - * @since 2.0.0 |
|
704 | - * @param array $values Values. |
|
705 | - * @param array $setting Setting. |
|
706 | - * @return array|WP_Error |
|
707 | - */ |
|
708 | - public function validate_setting_multiselect_field( $values, $setting ) { |
|
709 | - if ( empty( $values ) ) { |
|
710 | - return array(); |
|
711 | - } |
|
712 | - |
|
713 | - if ( ! is_array( $values ) ) { |
|
714 | - return new WP_Error( 'rest_setting_value_invalid', __( 'An invalid setting value was passed.', 'invoicing' ), array( 'status' => 400 ) ); |
|
715 | - } |
|
716 | - |
|
717 | - $final_values = array(); |
|
718 | - foreach ( $values as $value ) { |
|
719 | - if ( array_key_exists( $value, $setting['options'] ) ) { |
|
720 | - $final_values[] = $value; |
|
721 | - } |
|
722 | - } |
|
723 | - |
|
724 | - return $final_values; |
|
725 | - } |
|
726 | - |
|
727 | - /** |
|
728 | - * Validate radio based settings. |
|
729 | - * |
|
730 | - * @since 2.0.0 |
|
731 | - * @param string $value Value. |
|
732 | - * @param array $setting Setting. |
|
733 | - * @return string|WP_Error |
|
734 | - */ |
|
735 | - public function validate_setting_radio_field( $value, $setting ) { |
|
736 | - return $this->validate_setting_select_field( $value, $setting ); |
|
737 | - } |
|
738 | - |
|
739 | - /** |
|
740 | - * Validate checkbox based settings. |
|
741 | - * |
|
742 | - * @since 2.0.0 |
|
743 | - * @param string $value Value. |
|
744 | - * @return int |
|
745 | - */ |
|
746 | - public function validate_setting_checkbox_field( $value ) { |
|
747 | - return (int) ! empty( $value ); |
|
748 | - } |
|
749 | - |
|
750 | - /** |
|
751 | - * Validate textarea based settings. |
|
752 | - * |
|
753 | - * @since 2.0.0 |
|
754 | - * @param string $value Value. |
|
755 | - * @return string |
|
756 | - */ |
|
757 | - public function validate_setting_textarea_field( $value ) { |
|
758 | - $value = is_null( $value ) ? '' : $value; |
|
759 | - return wp_kses( |
|
760 | - trim( stripslashes( $value ) ), |
|
761 | - array_merge( |
|
762 | - array( |
|
763 | - 'iframe' => array( |
|
764 | - 'src' => true, |
|
765 | - 'style' => true, |
|
766 | - 'id' => true, |
|
767 | - 'class' => true, |
|
768 | - ), |
|
769 | - ), |
|
770 | - wp_kses_allowed_html( 'post' ) |
|
771 | - ) |
|
772 | - ); |
|
773 | - } |
|
664 | + // Cache the settings schema. |
|
665 | + $this->schema = $schema; |
|
666 | + |
|
667 | + return $this->add_additional_fields_schema( $this->schema ); |
|
668 | + |
|
669 | + } |
|
670 | + |
|
671 | + /** |
|
672 | + * Validate a text value for a text based setting. |
|
673 | + * |
|
674 | + * @since 2.0.0 |
|
675 | + * @param string $value Value. |
|
676 | + * @param array $setting Setting. |
|
677 | + * @return string |
|
678 | + */ |
|
679 | + public function validate_setting_text_field( $value ) { |
|
680 | + $value = is_null( $value ) ? '' : $value; |
|
681 | + return wp_kses_post( trim( stripslashes( $value ) ) ); |
|
682 | + } |
|
683 | + |
|
684 | + /** |
|
685 | + * Validate select based settings. |
|
686 | + * |
|
687 | + * @since 2.0.0 |
|
688 | + * @param string $value Value. |
|
689 | + * @param array $setting Setting. |
|
690 | + * @return string|WP_Error |
|
691 | + */ |
|
692 | + public function validate_setting_select_field( $value, $setting ) { |
|
693 | + if ( array_key_exists( $value, $setting['options'] ) ) { |
|
694 | + return $value; |
|
695 | + } else { |
|
696 | + return new WP_Error( 'rest_setting_value_invalid', __( 'An invalid setting value was passed.', 'invoicing' ), array( 'status' => 400 ) ); |
|
697 | + } |
|
698 | + } |
|
699 | + |
|
700 | + /** |
|
701 | + * Validate multiselect based settings. |
|
702 | + * |
|
703 | + * @since 2.0.0 |
|
704 | + * @param array $values Values. |
|
705 | + * @param array $setting Setting. |
|
706 | + * @return array|WP_Error |
|
707 | + */ |
|
708 | + public function validate_setting_multiselect_field( $values, $setting ) { |
|
709 | + if ( empty( $values ) ) { |
|
710 | + return array(); |
|
711 | + } |
|
712 | + |
|
713 | + if ( ! is_array( $values ) ) { |
|
714 | + return new WP_Error( 'rest_setting_value_invalid', __( 'An invalid setting value was passed.', 'invoicing' ), array( 'status' => 400 ) ); |
|
715 | + } |
|
716 | + |
|
717 | + $final_values = array(); |
|
718 | + foreach ( $values as $value ) { |
|
719 | + if ( array_key_exists( $value, $setting['options'] ) ) { |
|
720 | + $final_values[] = $value; |
|
721 | + } |
|
722 | + } |
|
723 | + |
|
724 | + return $final_values; |
|
725 | + } |
|
726 | + |
|
727 | + /** |
|
728 | + * Validate radio based settings. |
|
729 | + * |
|
730 | + * @since 2.0.0 |
|
731 | + * @param string $value Value. |
|
732 | + * @param array $setting Setting. |
|
733 | + * @return string|WP_Error |
|
734 | + */ |
|
735 | + public function validate_setting_radio_field( $value, $setting ) { |
|
736 | + return $this->validate_setting_select_field( $value, $setting ); |
|
737 | + } |
|
738 | + |
|
739 | + /** |
|
740 | + * Validate checkbox based settings. |
|
741 | + * |
|
742 | + * @since 2.0.0 |
|
743 | + * @param string $value Value. |
|
744 | + * @return int |
|
745 | + */ |
|
746 | + public function validate_setting_checkbox_field( $value ) { |
|
747 | + return (int) ! empty( $value ); |
|
748 | + } |
|
749 | + |
|
750 | + /** |
|
751 | + * Validate textarea based settings. |
|
752 | + * |
|
753 | + * @since 2.0.0 |
|
754 | + * @param string $value Value. |
|
755 | + * @return string |
|
756 | + */ |
|
757 | + public function validate_setting_textarea_field( $value ) { |
|
758 | + $value = is_null( $value ) ? '' : $value; |
|
759 | + return wp_kses( |
|
760 | + trim( stripslashes( $value ) ), |
|
761 | + array_merge( |
|
762 | + array( |
|
763 | + 'iframe' => array( |
|
764 | + 'src' => true, |
|
765 | + 'style' => true, |
|
766 | + 'id' => true, |
|
767 | + 'class' => true, |
|
768 | + ), |
|
769 | + ), |
|
770 | + wp_kses_allowed_html( 'post' ) |
|
771 | + ) |
|
772 | + ); |
|
773 | + } |
|
774 | 774 | |
775 | 775 | } |
@@ -12,294 +12,294 @@ |
||
12 | 12 | */ |
13 | 13 | class GetPaid_Reports_Helper { |
14 | 14 | |
15 | - /** |
|
16 | - * Get report totals such as invoice totals and discount amounts. |
|
17 | - * |
|
18 | - * Data example: |
|
19 | - * |
|
20 | - * 'subtotal' => array( |
|
21 | - * 'type' => 'invoice_data', |
|
22 | - * 'function' => 'SUM', |
|
23 | - * 'name' => 'subtotal' |
|
24 | - * ) |
|
25 | - * |
|
26 | - * @param array $args |
|
27 | - * @return mixed depending on query_type |
|
28 | - */ |
|
29 | - public static function get_invoice_report_data( $args = array() ) { |
|
30 | - global $wpdb; |
|
31 | - |
|
32 | - $default_args = array( |
|
33 | - 'data' => array(), // The data to retrieve. |
|
34 | - 'where' => array(), // An array of where queries. |
|
35 | - 'query_type' => 'get_row', // wpdb query to run. |
|
36 | - 'group_by' => '', // What to group results by. |
|
37 | - 'order_by' => '', // What to order by. |
|
38 | - 'limit' => '', // Results limit. |
|
39 | - 'filter_range' => array(), // An array of before and after dates to limit results by. |
|
40 | - 'invoice_types' => array( 'wpi_invoice' ), // An array of post types to retrieve. |
|
41 | - 'invoice_status' => array( 'publish', 'wpi-processing', 'wpi-onhold' ), |
|
42 | - 'parent_invoice_status' => false, // Optionally filter by parent invoice status. |
|
43 | - ); |
|
44 | - |
|
45 | - $args = apply_filters( 'getpaid_reports_get_invoice_report_data_args', $args ); |
|
46 | - $args = wp_parse_args( $args, $default_args ); |
|
47 | - |
|
48 | - extract( $args ); |
|
49 | - |
|
50 | - if ( empty( $data ) ) { |
|
51 | - return ''; |
|
52 | - } |
|
53 | - |
|
54 | - $query = array(); |
|
55 | - $query['select'] = 'SELECT ' . implode( ',', self::prepare_invoice_data( $data ) ); |
|
56 | - $query['from'] = "FROM {$wpdb->posts} AS posts"; |
|
57 | - $query['join'] = implode( ' ', self::prepare_invoice_joins( $data + $where, ! empty( $parent_invoice_status ) ) ); |
|
58 | - |
|
59 | - $query['where'] = " |
|
15 | + /** |
|
16 | + * Get report totals such as invoice totals and discount amounts. |
|
17 | + * |
|
18 | + * Data example: |
|
19 | + * |
|
20 | + * 'subtotal' => array( |
|
21 | + * 'type' => 'invoice_data', |
|
22 | + * 'function' => 'SUM', |
|
23 | + * 'name' => 'subtotal' |
|
24 | + * ) |
|
25 | + * |
|
26 | + * @param array $args |
|
27 | + * @return mixed depending on query_type |
|
28 | + */ |
|
29 | + public static function get_invoice_report_data( $args = array() ) { |
|
30 | + global $wpdb; |
|
31 | + |
|
32 | + $default_args = array( |
|
33 | + 'data' => array(), // The data to retrieve. |
|
34 | + 'where' => array(), // An array of where queries. |
|
35 | + 'query_type' => 'get_row', // wpdb query to run. |
|
36 | + 'group_by' => '', // What to group results by. |
|
37 | + 'order_by' => '', // What to order by. |
|
38 | + 'limit' => '', // Results limit. |
|
39 | + 'filter_range' => array(), // An array of before and after dates to limit results by. |
|
40 | + 'invoice_types' => array( 'wpi_invoice' ), // An array of post types to retrieve. |
|
41 | + 'invoice_status' => array( 'publish', 'wpi-processing', 'wpi-onhold' ), |
|
42 | + 'parent_invoice_status' => false, // Optionally filter by parent invoice status. |
|
43 | + ); |
|
44 | + |
|
45 | + $args = apply_filters( 'getpaid_reports_get_invoice_report_data_args', $args ); |
|
46 | + $args = wp_parse_args( $args, $default_args ); |
|
47 | + |
|
48 | + extract( $args ); |
|
49 | + |
|
50 | + if ( empty( $data ) ) { |
|
51 | + return ''; |
|
52 | + } |
|
53 | + |
|
54 | + $query = array(); |
|
55 | + $query['select'] = 'SELECT ' . implode( ',', self::prepare_invoice_data( $data ) ); |
|
56 | + $query['from'] = "FROM {$wpdb->posts} AS posts"; |
|
57 | + $query['join'] = implode( ' ', self::prepare_invoice_joins( $data + $where, ! empty( $parent_invoice_status ) ) ); |
|
58 | + |
|
59 | + $query['where'] = " |
|
60 | 60 | WHERE posts.post_type IN ( '" . implode( "','", $invoice_types ) . "' ) |
61 | 61 | "; |
62 | 62 | |
63 | - if ( ! empty( $invoice_status ) ) { |
|
64 | - $query['where'] .= " |
|
63 | + if ( ! empty( $invoice_status ) ) { |
|
64 | + $query['where'] .= " |
|
65 | 65 | AND posts.post_status IN ( '" . implode( "','", $invoice_status ) . "' ) |
66 | 66 | "; |
67 | - } |
|
68 | - |
|
69 | - if ( ! empty( $parent_invoice_status ) ) { |
|
70 | - if ( ! empty( $invoice_status ) ) { |
|
71 | - $query['where'] .= " AND ( parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) OR parent.ID IS NULL ) "; |
|
72 | - } else { |
|
73 | - $query['where'] .= " AND parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) "; |
|
74 | - } |
|
75 | - } |
|
76 | - |
|
77 | - if ( ! empty( $filter_range['before'] ) ) { |
|
78 | - $query['where'] .= " |
|
67 | + } |
|
68 | + |
|
69 | + if ( ! empty( $parent_invoice_status ) ) { |
|
70 | + if ( ! empty( $invoice_status ) ) { |
|
71 | + $query['where'] .= " AND ( parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) OR parent.ID IS NULL ) "; |
|
72 | + } else { |
|
73 | + $query['where'] .= " AND parent.post_status IN ( '" . implode( "','", $parent_invoice_status ) . "' ) "; |
|
74 | + } |
|
75 | + } |
|
76 | + |
|
77 | + if ( ! empty( $filter_range['before'] ) ) { |
|
78 | + $query['where'] .= " |
|
79 | 79 | AND posts.post_date < '" . date( 'Y-m-d H:i:s', strtotime( $filter_range['before'] ) ) . "' |
80 | 80 | "; |
81 | - } |
|
81 | + } |
|
82 | 82 | |
83 | - if ( ! empty( $filter_range['after'] ) ) { |
|
84 | - $query['where'] .= " |
|
83 | + if ( ! empty( $filter_range['after'] ) ) { |
|
84 | + $query['where'] .= " |
|
85 | 85 | AND posts.post_date > '" . date( 'Y-m-d H:i:s', strtotime( $filter_range['after'] ) ) . "' |
86 | 86 | "; |
87 | - } |
|
87 | + } |
|
88 | 88 | |
89 | - if ( ! empty( $where ) ) { |
|
89 | + if ( ! empty( $where ) ) { |
|
90 | 90 | |
91 | - foreach ( $where as $value ) { |
|
91 | + foreach ( $where as $value ) { |
|
92 | 92 | |
93 | - if ( strtolower( $value['operator'] ) == 'in' || strtolower( $value['operator'] ) == 'not in' ) { |
|
94 | - |
|
95 | - if ( is_array( $value['value'] ) ) { |
|
96 | - $value['value'] = implode( "','", $value['value'] ); |
|
97 | - } |
|
98 | - |
|
99 | - if ( ! empty( $value['value'] ) ) { |
|
100 | - $where_value = "{$value['operator']} ('{$value['value']}')"; |
|
101 | - } |
|
102 | - } else { |
|
103 | - $where_value = "{$value['operator']} '{$value['value']}'"; |
|
104 | - } |
|
105 | - |
|
106 | - if ( ! empty( $where_value ) ) { |
|
107 | - $query['where'] .= " AND {$value['key']} {$where_value}"; |
|
108 | - } |
|
109 | - } |
|
110 | - } |
|
111 | - |
|
112 | - if ( $group_by ) { |
|
113 | - $query['group_by'] = "GROUP BY {$group_by}"; |
|
114 | - } |
|
115 | - |
|
116 | - if ( $order_by ) { |
|
117 | - $query['order_by'] = "ORDER BY {$order_by}"; |
|
118 | - } |
|
119 | - |
|
120 | - if ( $limit ) { |
|
121 | - $query['limit'] = "LIMIT {$limit}"; |
|
122 | - } |
|
123 | - |
|
124 | - $query = apply_filters( 'getpaid_reports_get_invoice_report_query', $query, $data ); |
|
125 | - $query = implode( ' ', $query ); |
|
126 | - |
|
127 | - return self::execute( $query_type, $query ); |
|
128 | - |
|
129 | - } |
|
130 | - |
|
131 | - /** |
|
132 | - * Prepares the data to select. |
|
133 | - * |
|
134 | - * |
|
135 | - * @param array $data |
|
136 | - * @return array |
|
137 | - */ |
|
138 | - public static function prepare_invoice_data( $data ) { |
|
139 | - |
|
140 | - $prepared = array(); |
|
141 | - |
|
142 | - foreach ( $data as $raw_key => $value ) { |
|
143 | - $key = sanitize_key( $raw_key ); |
|
144 | - $distinct = ''; |
|
145 | - |
|
146 | - if ( isset( $value['distinct'] ) ) { |
|
147 | - $distinct = 'DISTINCT'; |
|
148 | - } |
|
149 | - |
|
150 | - $get_key = self::get_invoice_table_key( $key, $value['type'] ); |
|
151 | - |
|
152 | - if ( false === $get_key ) { |
|
153 | - // Skip to the next foreach iteration else the query will be invalid. |
|
154 | - continue; |
|
155 | - } |
|
156 | - |
|
157 | - if ( ! empty( $value['function'] ) ) { |
|
158 | - $get = "{$value['function']}({$distinct} {$get_key})"; |
|
159 | - } else { |
|
160 | - $get = "{$distinct} {$get_key}"; |
|
161 | - } |
|
162 | - |
|
163 | - $prepared[] = "{$get} as {$value['name']}"; |
|
164 | - } |
|
165 | - |
|
166 | - return $prepared; |
|
167 | - |
|
168 | - } |
|
169 | - |
|
170 | - /** |
|
171 | - * Prepares the joins to use. |
|
172 | - * |
|
173 | - * |
|
174 | - * @param array $data |
|
175 | - * @param bool $with_parent |
|
176 | - * @return array |
|
177 | - */ |
|
178 | - public static function prepare_invoice_joins( $data, $with_parent ) { |
|
179 | - global $wpdb; |
|
180 | - |
|
181 | - $prepared = array(); |
|
182 | - |
|
183 | - foreach ( $data as $raw_key => $value ) { |
|
184 | - $join_type = isset( $value['join_type'] ) ? $value['join_type'] : 'INNER'; |
|
185 | - $type = isset( $value['type'] ) ? $value['type'] : false; |
|
186 | - $key = sanitize_key( $raw_key ); |
|
187 | - |
|
188 | - switch ( $type ) { |
|
189 | - case 'meta': |
|
190 | - $prepared[ "meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS meta_{$key} ON ( posts.ID = meta_{$key}.post_id AND meta_{$key}.meta_key = '{$raw_key}' )"; |
|
191 | - break; |
|
192 | - case 'parent_meta': |
|
193 | - $prepared[ "parent_meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS parent_meta_{$key} ON (posts.post_parent = parent_meta_{$key}.post_id) AND (parent_meta_{$key}.meta_key = '{$raw_key}')"; |
|
194 | - break; |
|
195 | - case 'invoice_data': |
|
196 | - $prepared['invoices'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoices AS invoices ON posts.ID = invoices.post_id"; |
|
197 | - break; |
|
198 | - case 'invoice_item': |
|
199 | - $prepared['invoice_items'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoice_items AS invoice_items ON posts.ID = invoice_items.post_id"; |
|
200 | - break; |
|
201 | - } |
|
202 | - } |
|
203 | - |
|
204 | - if ( $with_parent ) { |
|
205 | - $prepared['parent'] = "LEFT JOIN {$wpdb->posts} AS parent ON posts.post_parent = parent.ID"; |
|
206 | - } |
|
207 | - |
|
208 | - return $prepared; |
|
209 | - |
|
210 | - } |
|
211 | - |
|
212 | - /** |
|
213 | - * Retrieves the appropriate table key to use. |
|
214 | - * |
|
215 | - * |
|
216 | - * @param string $key |
|
217 | - * @param string $table |
|
218 | - * @return string|false |
|
219 | - */ |
|
220 | - public static function get_invoice_table_key( $key, $table ) { |
|
221 | - |
|
222 | - $keys = array( |
|
223 | - 'meta' => "meta_{$key}.meta_value", |
|
224 | - 'parent_meta' => "parent_meta_{$key}.meta_value", |
|
225 | - 'post_data' => "posts.{$key}", |
|
226 | - 'invoice_data' => "invoices.{$key}", |
|
227 | - 'invoice_item' => "invoice_items.{$key}", |
|
228 | - ); |
|
229 | - |
|
230 | - return isset( $keys[ $table ] ) ? $keys[ $table ] : false; |
|
231 | - |
|
232 | - } |
|
233 | - |
|
234 | - /** |
|
235 | - * Executes a query and caches the result for a minute. |
|
236 | - * |
|
237 | - * |
|
238 | - * @param string $query_type |
|
239 | - * @param string $query |
|
240 | - * @return mixed depending on query_type |
|
241 | - */ |
|
242 | - public static function execute( $query_type, $query ) { |
|
243 | - global $wpdb; |
|
244 | - |
|
245 | - $query_hash = md5( $query_type . $query ); |
|
246 | - $result = self::get_cached_query( $query_hash ); |
|
247 | - if ( $result === false ) { |
|
248 | - self::enable_big_selects(); |
|
249 | - |
|
250 | - $result = $wpdb->$query_type( $query ); |
|
251 | - self::set_cached_query( $query_hash, $result ); |
|
252 | - } |
|
253 | - |
|
254 | - return $result; |
|
255 | - |
|
256 | - } |
|
257 | - |
|
258 | - /** |
|
259 | - * Enables big mysql selects for reports, just once for this session. |
|
260 | - */ |
|
261 | - protected static function enable_big_selects() { |
|
262 | - static $big_selects = false; |
|
263 | - |
|
264 | - global $wpdb; |
|
265 | - |
|
266 | - if ( ! $big_selects ) { |
|
267 | - $wpdb->query( 'SET SESSION SQL_BIG_SELECTS=1' ); |
|
268 | - $big_selects = true; |
|
269 | - } |
|
270 | - } |
|
271 | - |
|
272 | - /** |
|
273 | - * Get the cached query result or null if it's not in the cache. |
|
274 | - * |
|
275 | - * @param string $query_hash The query hash. |
|
276 | - * |
|
277 | - * @return mixed|false The cache contents on success, false on failure to retrieve contents. |
|
278 | - */ |
|
279 | - protected static function get_cached_query( $query_hash ) { |
|
280 | - |
|
281 | - return wp_cache_get( |
|
282 | - $query_hash, |
|
283 | - strtolower( __CLASS__ ) |
|
284 | - ); |
|
285 | - |
|
286 | - } |
|
287 | - |
|
288 | - /** |
|
289 | - * Set the cached query result. |
|
290 | - * |
|
291 | - * @param string $query_hash The query hash. |
|
292 | - * @param mixed $data The data to cache. |
|
293 | - */ |
|
294 | - protected static function set_cached_query( $query_hash, $data ) { |
|
295 | - |
|
296 | - wp_cache_set( |
|
297 | - $query_hash, |
|
298 | - $data, |
|
299 | - strtolower( __CLASS__ ), |
|
300 | - 5 * MINUTE_IN_SECONDS |
|
301 | - ); |
|
302 | - |
|
303 | - } |
|
93 | + if ( strtolower( $value['operator'] ) == 'in' || strtolower( $value['operator'] ) == 'not in' ) { |
|
94 | + |
|
95 | + if ( is_array( $value['value'] ) ) { |
|
96 | + $value['value'] = implode( "','", $value['value'] ); |
|
97 | + } |
|
98 | + |
|
99 | + if ( ! empty( $value['value'] ) ) { |
|
100 | + $where_value = "{$value['operator']} ('{$value['value']}')"; |
|
101 | + } |
|
102 | + } else { |
|
103 | + $where_value = "{$value['operator']} '{$value['value']}'"; |
|
104 | + } |
|
105 | + |
|
106 | + if ( ! empty( $where_value ) ) { |
|
107 | + $query['where'] .= " AND {$value['key']} {$where_value}"; |
|
108 | + } |
|
109 | + } |
|
110 | + } |
|
111 | + |
|
112 | + if ( $group_by ) { |
|
113 | + $query['group_by'] = "GROUP BY {$group_by}"; |
|
114 | + } |
|
115 | + |
|
116 | + if ( $order_by ) { |
|
117 | + $query['order_by'] = "ORDER BY {$order_by}"; |
|
118 | + } |
|
119 | + |
|
120 | + if ( $limit ) { |
|
121 | + $query['limit'] = "LIMIT {$limit}"; |
|
122 | + } |
|
123 | + |
|
124 | + $query = apply_filters( 'getpaid_reports_get_invoice_report_query', $query, $data ); |
|
125 | + $query = implode( ' ', $query ); |
|
126 | + |
|
127 | + return self::execute( $query_type, $query ); |
|
128 | + |
|
129 | + } |
|
130 | + |
|
131 | + /** |
|
132 | + * Prepares the data to select. |
|
133 | + * |
|
134 | + * |
|
135 | + * @param array $data |
|
136 | + * @return array |
|
137 | + */ |
|
138 | + public static function prepare_invoice_data( $data ) { |
|
139 | + |
|
140 | + $prepared = array(); |
|
141 | + |
|
142 | + foreach ( $data as $raw_key => $value ) { |
|
143 | + $key = sanitize_key( $raw_key ); |
|
144 | + $distinct = ''; |
|
145 | + |
|
146 | + if ( isset( $value['distinct'] ) ) { |
|
147 | + $distinct = 'DISTINCT'; |
|
148 | + } |
|
149 | + |
|
150 | + $get_key = self::get_invoice_table_key( $key, $value['type'] ); |
|
151 | + |
|
152 | + if ( false === $get_key ) { |
|
153 | + // Skip to the next foreach iteration else the query will be invalid. |
|
154 | + continue; |
|
155 | + } |
|
156 | + |
|
157 | + if ( ! empty( $value['function'] ) ) { |
|
158 | + $get = "{$value['function']}({$distinct} {$get_key})"; |
|
159 | + } else { |
|
160 | + $get = "{$distinct} {$get_key}"; |
|
161 | + } |
|
162 | + |
|
163 | + $prepared[] = "{$get} as {$value['name']}"; |
|
164 | + } |
|
165 | + |
|
166 | + return $prepared; |
|
167 | + |
|
168 | + } |
|
169 | + |
|
170 | + /** |
|
171 | + * Prepares the joins to use. |
|
172 | + * |
|
173 | + * |
|
174 | + * @param array $data |
|
175 | + * @param bool $with_parent |
|
176 | + * @return array |
|
177 | + */ |
|
178 | + public static function prepare_invoice_joins( $data, $with_parent ) { |
|
179 | + global $wpdb; |
|
180 | + |
|
181 | + $prepared = array(); |
|
182 | + |
|
183 | + foreach ( $data as $raw_key => $value ) { |
|
184 | + $join_type = isset( $value['join_type'] ) ? $value['join_type'] : 'INNER'; |
|
185 | + $type = isset( $value['type'] ) ? $value['type'] : false; |
|
186 | + $key = sanitize_key( $raw_key ); |
|
187 | + |
|
188 | + switch ( $type ) { |
|
189 | + case 'meta': |
|
190 | + $prepared[ "meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS meta_{$key} ON ( posts.ID = meta_{$key}.post_id AND meta_{$key}.meta_key = '{$raw_key}' )"; |
|
191 | + break; |
|
192 | + case 'parent_meta': |
|
193 | + $prepared[ "parent_meta_{$key}" ] = "{$join_type} JOIN {$wpdb->postmeta} AS parent_meta_{$key} ON (posts.post_parent = parent_meta_{$key}.post_id) AND (parent_meta_{$key}.meta_key = '{$raw_key}')"; |
|
194 | + break; |
|
195 | + case 'invoice_data': |
|
196 | + $prepared['invoices'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoices AS invoices ON posts.ID = invoices.post_id"; |
|
197 | + break; |
|
198 | + case 'invoice_item': |
|
199 | + $prepared['invoice_items'] = "{$join_type} JOIN {$wpdb->prefix}getpaid_invoice_items AS invoice_items ON posts.ID = invoice_items.post_id"; |
|
200 | + break; |
|
201 | + } |
|
202 | + } |
|
203 | + |
|
204 | + if ( $with_parent ) { |
|
205 | + $prepared['parent'] = "LEFT JOIN {$wpdb->posts} AS parent ON posts.post_parent = parent.ID"; |
|
206 | + } |
|
207 | + |
|
208 | + return $prepared; |
|
209 | + |
|
210 | + } |
|
211 | + |
|
212 | + /** |
|
213 | + * Retrieves the appropriate table key to use. |
|
214 | + * |
|
215 | + * |
|
216 | + * @param string $key |
|
217 | + * @param string $table |
|
218 | + * @return string|false |
|
219 | + */ |
|
220 | + public static function get_invoice_table_key( $key, $table ) { |
|
221 | + |
|
222 | + $keys = array( |
|
223 | + 'meta' => "meta_{$key}.meta_value", |
|
224 | + 'parent_meta' => "parent_meta_{$key}.meta_value", |
|
225 | + 'post_data' => "posts.{$key}", |
|
226 | + 'invoice_data' => "invoices.{$key}", |
|
227 | + 'invoice_item' => "invoice_items.{$key}", |
|
228 | + ); |
|
229 | + |
|
230 | + return isset( $keys[ $table ] ) ? $keys[ $table ] : false; |
|
231 | + |
|
232 | + } |
|
233 | + |
|
234 | + /** |
|
235 | + * Executes a query and caches the result for a minute. |
|
236 | + * |
|
237 | + * |
|
238 | + * @param string $query_type |
|
239 | + * @param string $query |
|
240 | + * @return mixed depending on query_type |
|
241 | + */ |
|
242 | + public static function execute( $query_type, $query ) { |
|
243 | + global $wpdb; |
|
244 | + |
|
245 | + $query_hash = md5( $query_type . $query ); |
|
246 | + $result = self::get_cached_query( $query_hash ); |
|
247 | + if ( $result === false ) { |
|
248 | + self::enable_big_selects(); |
|
249 | + |
|
250 | + $result = $wpdb->$query_type( $query ); |
|
251 | + self::set_cached_query( $query_hash, $result ); |
|
252 | + } |
|
253 | + |
|
254 | + return $result; |
|
255 | + |
|
256 | + } |
|
257 | + |
|
258 | + /** |
|
259 | + * Enables big mysql selects for reports, just once for this session. |
|
260 | + */ |
|
261 | + protected static function enable_big_selects() { |
|
262 | + static $big_selects = false; |
|
263 | + |
|
264 | + global $wpdb; |
|
265 | + |
|
266 | + if ( ! $big_selects ) { |
|
267 | + $wpdb->query( 'SET SESSION SQL_BIG_SELECTS=1' ); |
|
268 | + $big_selects = true; |
|
269 | + } |
|
270 | + } |
|
271 | + |
|
272 | + /** |
|
273 | + * Get the cached query result or null if it's not in the cache. |
|
274 | + * |
|
275 | + * @param string $query_hash The query hash. |
|
276 | + * |
|
277 | + * @return mixed|false The cache contents on success, false on failure to retrieve contents. |
|
278 | + */ |
|
279 | + protected static function get_cached_query( $query_hash ) { |
|
280 | + |
|
281 | + return wp_cache_get( |
|
282 | + $query_hash, |
|
283 | + strtolower( __CLASS__ ) |
|
284 | + ); |
|
285 | + |
|
286 | + } |
|
287 | + |
|
288 | + /** |
|
289 | + * Set the cached query result. |
|
290 | + * |
|
291 | + * @param string $query_hash The query hash. |
|
292 | + * @param mixed $data The data to cache. |
|
293 | + */ |
|
294 | + protected static function set_cached_query( $query_hash, $data ) { |
|
295 | + |
|
296 | + wp_cache_set( |
|
297 | + $query_hash, |
|
298 | + $data, |
|
299 | + strtolower( __CLASS__ ), |
|
300 | + 5 * MINUTE_IN_SECONDS |
|
301 | + ); |
|
302 | + |
|
303 | + } |
|
304 | 304 | |
305 | 305 | } |
@@ -18,50 +18,50 @@ |
||
18 | 18 | */ |
19 | 19 | class GetPaid_REST_Report_Top_Earners_Controller extends GetPaid_REST_Report_Top_Sellers_Controller { |
20 | 20 | |
21 | - /** |
|
22 | - * Route base. |
|
23 | - * |
|
24 | - * @var string |
|
25 | - */ |
|
26 | - protected $rest_base = 'reports/top_earners'; |
|
21 | + /** |
|
22 | + * Route base. |
|
23 | + * |
|
24 | + * @var string |
|
25 | + */ |
|
26 | + protected $rest_base = 'reports/top_earners'; |
|
27 | 27 | |
28 | - /** |
|
29 | - * Get all data needed for this report and store in the class. |
|
30 | - */ |
|
31 | - protected function query_report_data() { |
|
28 | + /** |
|
29 | + * Get all data needed for this report and store in the class. |
|
30 | + */ |
|
31 | + protected function query_report_data() { |
|
32 | 32 | |
33 | - $this->report_data = GetPaid_Reports_Helper::get_invoice_report_data( |
|
34 | - array( |
|
35 | - 'data' => array( |
|
36 | - 'quantity' => array( |
|
37 | - 'type' => 'invoice_item', |
|
38 | - 'function' => 'SUM', |
|
39 | - 'name' => 'invoice_item_qty', |
|
40 | - ), |
|
41 | - 'item_id' => array( |
|
42 | - 'type' => 'invoice_item', |
|
43 | - 'function' => '', |
|
44 | - 'name' => 'invoice_item_id', |
|
45 | - ), |
|
46 | - 'item_name' => array( |
|
47 | - 'type' => 'invoice_item', |
|
48 | - 'function' => '', |
|
49 | - 'name' => 'invoice_item_name', |
|
50 | - ), |
|
51 | - 'price' => array( |
|
52 | - 'type' => 'invoice_item', |
|
53 | - 'function' => 'SUM', |
|
54 | - 'name' => 'invoice_item_price', |
|
55 | - ), |
|
56 | - ), |
|
57 | - 'group_by' => 'invoice_item_id', |
|
58 | - 'order_by' => 'invoice_item_price DESC', |
|
59 | - 'query_type' => 'get_results', |
|
60 | - 'limit' => 10, |
|
61 | - 'filter_range' => $this->report_range, |
|
62 | - ) |
|
63 | - ); |
|
33 | + $this->report_data = GetPaid_Reports_Helper::get_invoice_report_data( |
|
34 | + array( |
|
35 | + 'data' => array( |
|
36 | + 'quantity' => array( |
|
37 | + 'type' => 'invoice_item', |
|
38 | + 'function' => 'SUM', |
|
39 | + 'name' => 'invoice_item_qty', |
|
40 | + ), |
|
41 | + 'item_id' => array( |
|
42 | + 'type' => 'invoice_item', |
|
43 | + 'function' => '', |
|
44 | + 'name' => 'invoice_item_id', |
|
45 | + ), |
|
46 | + 'item_name' => array( |
|
47 | + 'type' => 'invoice_item', |
|
48 | + 'function' => '', |
|
49 | + 'name' => 'invoice_item_name', |
|
50 | + ), |
|
51 | + 'price' => array( |
|
52 | + 'type' => 'invoice_item', |
|
53 | + 'function' => 'SUM', |
|
54 | + 'name' => 'invoice_item_price', |
|
55 | + ), |
|
56 | + ), |
|
57 | + 'group_by' => 'invoice_item_id', |
|
58 | + 'order_by' => 'invoice_item_price DESC', |
|
59 | + 'query_type' => 'get_results', |
|
60 | + 'limit' => 10, |
|
61 | + 'filter_range' => $this->report_range, |
|
62 | + ) |
|
63 | + ); |
|
64 | 64 | |
65 | - } |
|
65 | + } |
|
66 | 66 | |
67 | 67 | } |
@@ -18,179 +18,179 @@ |
||
18 | 18 | */ |
19 | 19 | class GetPaid_REST_Report_Top_Sellers_Controller extends GetPaid_REST_Report_Sales_Controller { |
20 | 20 | |
21 | - /** |
|
22 | - * Route base. |
|
23 | - * |
|
24 | - * @var string |
|
25 | - */ |
|
26 | - protected $rest_base = 'reports/top_sellers'; |
|
27 | - |
|
28 | - /** |
|
29 | - * Get top sellers report. |
|
30 | - * |
|
31 | - * @param WP_REST_Request $request |
|
32 | - * @return array|WP_Error |
|
33 | - */ |
|
34 | - public function get_items( $request ) { |
|
35 | - |
|
36 | - // Prepare items. |
|
37 | - $this->report_range = $this->get_date_range( $request ); |
|
38 | - $report_data = $this->get_report_data(); |
|
39 | - |
|
40 | - $top_sellers = array(); |
|
41 | - |
|
42 | - foreach ( $report_data as $item ) { |
|
43 | - |
|
44 | - $item_obj = new WPInv_Item( $item ); |
|
45 | - $item_name = $item->invoice_item_name; |
|
46 | - $item_qty = absint( $item->invoice_item_qty ); |
|
47 | - $item_id = absint( $item->invoice_item_id ); |
|
48 | - $price = sanitize_text_field( wpinv_price( $item->invoice_item_price ) ); |
|
49 | - |
|
50 | - $item_obj = new WPInv_Item( $item_id ); |
|
51 | - |
|
52 | - if ( $item_obj->exists() ) { |
|
53 | - $item_name = $item_obj->get_name(); |
|
54 | - } else { |
|
55 | - $item_id = 0; |
|
56 | - } |
|
57 | - |
|
58 | - $top_sellers[] = array( |
|
59 | - 'name' =>sanitize_text_field( $item_name ), |
|
60 | - 'item_id' => $item_id, |
|
61 | - 'quantity' => $item_qty, |
|
62 | - 'earnings' => wpinv_round_amount( $item->invoice_item_price ), |
|
63 | - 'earnings_formatted' => sanitize_text_field( wpinv_price( $price ) ), |
|
64 | - ); |
|
65 | - |
|
66 | - } |
|
67 | - |
|
68 | - $data = array(); |
|
69 | - foreach ( $top_sellers as $top_seller ) { |
|
70 | - $item = $this->prepare_item_for_response( (object) $top_seller, $request ); |
|
71 | - $data[] = $this->prepare_response_for_collection( $item ); |
|
72 | - } |
|
73 | - |
|
74 | - return rest_ensure_response( $data ); |
|
75 | - |
|
76 | - } |
|
77 | - |
|
78 | - /** |
|
79 | - * Prepare a report sales object for serialization. |
|
80 | - * |
|
81 | - * @param stdClass $top_seller |
|
82 | - * @param WP_REST_Request $request Request object. |
|
83 | - * @return WP_REST_Response $response Response data. |
|
84 | - */ |
|
85 | - public function prepare_item_for_response( $top_seller, $request ) { |
|
86 | - $data = (array) $top_seller; |
|
87 | - |
|
88 | - $context = ! empty( $request['context'] ) ? $request['context'] : 'view'; |
|
89 | - $data = $this->add_additional_fields_to_object( $data, $request ); |
|
90 | - $data = $this->filter_response_by_context( $data, $context ); |
|
91 | - |
|
92 | - // Wrap the data in a response object. |
|
93 | - $response = rest_ensure_response( $data ); |
|
94 | - $links = array( |
|
95 | - 'about' => array( |
|
96 | - 'href' => rest_url( sprintf( '%s/reports', $this->namespace ) ), |
|
97 | - ), |
|
98 | - ); |
|
99 | - |
|
100 | - if ( ! empty( $top_seller->item_id ) ) { |
|
101 | - $links['item'] = array( |
|
102 | - 'href' => rest_url( sprintf( '/%s/items/%s', $this->namespace, $top_seller->item_id ) ), |
|
103 | - 'embeddable' => true, |
|
104 | - ); |
|
105 | - } |
|
106 | - |
|
107 | - $response->add_links( $links ); |
|
108 | - return apply_filters( 'getpaid_rest_prepare_report_' . $this->rest_base, $response, $top_seller, $request ); |
|
109 | - } |
|
110 | - |
|
111 | - /** |
|
112 | - * Get all data needed for this report and store in the class. |
|
113 | - */ |
|
114 | - protected function query_report_data() { |
|
115 | - |
|
116 | - $this->report_data = GetPaid_Reports_Helper::get_invoice_report_data( |
|
117 | - array( |
|
118 | - 'data' => array( |
|
119 | - 'quantity' => array( |
|
120 | - 'type' => 'invoice_item', |
|
121 | - 'function' => 'SUM', |
|
122 | - 'name' => 'invoice_item_qty', |
|
123 | - ), |
|
124 | - 'item_id' => array( |
|
125 | - 'type' => 'invoice_item', |
|
126 | - 'function' => '', |
|
127 | - 'name' => 'invoice_item_id', |
|
128 | - ), |
|
129 | - 'item_name' => array( |
|
130 | - 'type' => 'invoice_item', |
|
131 | - 'function' => '', |
|
132 | - 'name' => 'invoice_item_name', |
|
133 | - ), |
|
134 | - 'price' => array( |
|
135 | - 'type' => 'invoice_item', |
|
136 | - 'function' => 'SUM', |
|
137 | - 'name' => 'invoice_item_price', |
|
138 | - ), |
|
139 | - ), |
|
140 | - 'group_by' => 'invoice_item_id', |
|
141 | - 'order_by' => 'invoice_item_qty DESC', |
|
142 | - 'query_type' => 'get_results', |
|
143 | - 'limit' => 10, |
|
144 | - 'filter_range' => $this->report_range, |
|
145 | - ) |
|
146 | - ); |
|
147 | - |
|
148 | - } |
|
149 | - |
|
150 | - /** |
|
151 | - * Get the Report's schema, conforming to JSON Schema. |
|
152 | - * |
|
153 | - * @return array |
|
154 | - */ |
|
155 | - public function get_item_schema() { |
|
156 | - $schema = array( |
|
157 | - '$schema' => 'http://json-schema.org/draft-04/schema#', |
|
158 | - 'title' => $this->rest_base, |
|
159 | - 'type' => 'object', |
|
160 | - 'properties' => array( |
|
161 | - 'name' => array( |
|
162 | - 'description' => __( 'Item name.', 'invoicing' ), |
|
163 | - 'type' => 'string', |
|
164 | - 'context' => array( 'view' ), |
|
165 | - 'readonly' => true, |
|
166 | - ), |
|
167 | - 'item_id' => array( |
|
168 | - 'description' => __( 'Item ID.', 'invoicing' ), |
|
169 | - 'type' => 'integer', |
|
170 | - 'context' => array( 'view' ), |
|
171 | - 'readonly' => true, |
|
172 | - ), |
|
173 | - 'quantity' => array( |
|
174 | - 'description' => __( 'Total number of purchases.', 'invoicing' ), |
|
175 | - 'type' => 'integer', |
|
176 | - 'context' => array( 'view' ), |
|
177 | - 'readonly' => true, |
|
178 | - ), |
|
179 | - 'earnings' => array( |
|
180 | - 'description' => __( 'Total earnings for the item.', 'invoicing' ), |
|
181 | - 'type' => 'double', |
|
182 | - 'context' => array( 'view' ), |
|
183 | - 'readonly' => true, |
|
184 | - ), |
|
185 | - 'earnings_formatted"' => array( |
|
186 | - 'description' => __( 'Total earnings (formatted) for the item.', 'invoicing' ), |
|
187 | - 'type' => 'string', |
|
188 | - 'context' => array( 'view' ), |
|
189 | - 'readonly' => true, |
|
190 | - ), |
|
191 | - ), |
|
192 | - ); |
|
193 | - |
|
194 | - return $this->add_additional_fields_schema( $schema ); |
|
195 | - } |
|
21 | + /** |
|
22 | + * Route base. |
|
23 | + * |
|
24 | + * @var string |
|
25 | + */ |
|
26 | + protected $rest_base = 'reports/top_sellers'; |
|
27 | + |
|
28 | + /** |
|
29 | + * Get top sellers report. |
|
30 | + * |
|
31 | + * @param WP_REST_Request $request |
|
32 | + * @return array|WP_Error |
|
33 | + */ |
|
34 | + public function get_items( $request ) { |
|
35 | + |
|
36 | + // Prepare items. |
|
37 | + $this->report_range = $this->get_date_range( $request ); |
|
38 | + $report_data = $this->get_report_data(); |
|
39 | + |
|
40 | + $top_sellers = array(); |
|
41 | + |
|
42 | + foreach ( $report_data as $item ) { |
|
43 | + |
|
44 | + $item_obj = new WPInv_Item( $item ); |
|
45 | + $item_name = $item->invoice_item_name; |
|
46 | + $item_qty = absint( $item->invoice_item_qty ); |
|
47 | + $item_id = absint( $item->invoice_item_id ); |
|
48 | + $price = sanitize_text_field( wpinv_price( $item->invoice_item_price ) ); |
|
49 | + |
|
50 | + $item_obj = new WPInv_Item( $item_id ); |
|
51 | + |
|
52 | + if ( $item_obj->exists() ) { |
|
53 | + $item_name = $item_obj->get_name(); |
|
54 | + } else { |
|
55 | + $item_id = 0; |
|
56 | + } |
|
57 | + |
|
58 | + $top_sellers[] = array( |
|
59 | + 'name' =>sanitize_text_field( $item_name ), |
|
60 | + 'item_id' => $item_id, |
|
61 | + 'quantity' => $item_qty, |
|
62 | + 'earnings' => wpinv_round_amount( $item->invoice_item_price ), |
|
63 | + 'earnings_formatted' => sanitize_text_field( wpinv_price( $price ) ), |
|
64 | + ); |
|
65 | + |
|
66 | + } |
|
67 | + |
|
68 | + $data = array(); |
|
69 | + foreach ( $top_sellers as $top_seller ) { |
|
70 | + $item = $this->prepare_item_for_response( (object) $top_seller, $request ); |
|
71 | + $data[] = $this->prepare_response_for_collection( $item ); |
|
72 | + } |
|
73 | + |
|
74 | + return rest_ensure_response( $data ); |
|
75 | + |
|
76 | + } |
|
77 | + |
|
78 | + /** |
|
79 | + * Prepare a report sales object for serialization. |
|
80 | + * |
|
81 | + * @param stdClass $top_seller |
|
82 | + * @param WP_REST_Request $request Request object. |
|
83 | + * @return WP_REST_Response $response Response data. |
|
84 | + */ |
|
85 | + public function prepare_item_for_response( $top_seller, $request ) { |
|
86 | + $data = (array) $top_seller; |
|
87 | + |
|
88 | + $context = ! empty( $request['context'] ) ? $request['context'] : 'view'; |
|
89 | + $data = $this->add_additional_fields_to_object( $data, $request ); |
|
90 | + $data = $this->filter_response_by_context( $data, $context ); |
|
91 | + |
|
92 | + // Wrap the data in a response object. |
|
93 | + $response = rest_ensure_response( $data ); |
|
94 | + $links = array( |
|
95 | + 'about' => array( |
|
96 | + 'href' => rest_url( sprintf( '%s/reports', $this->namespace ) ), |
|
97 | + ), |
|
98 | + ); |
|
99 | + |
|
100 | + if ( ! empty( $top_seller->item_id ) ) { |
|
101 | + $links['item'] = array( |
|
102 | + 'href' => rest_url( sprintf( '/%s/items/%s', $this->namespace, $top_seller->item_id ) ), |
|
103 | + 'embeddable' => true, |
|
104 | + ); |
|
105 | + } |
|
106 | + |
|
107 | + $response->add_links( $links ); |
|
108 | + return apply_filters( 'getpaid_rest_prepare_report_' . $this->rest_base, $response, $top_seller, $request ); |
|
109 | + } |
|
110 | + |
|
111 | + /** |
|
112 | + * Get all data needed for this report and store in the class. |
|
113 | + */ |
|
114 | + protected function query_report_data() { |
|
115 | + |
|
116 | + $this->report_data = GetPaid_Reports_Helper::get_invoice_report_data( |
|
117 | + array( |
|
118 | + 'data' => array( |
|
119 | + 'quantity' => array( |
|
120 | + 'type' => 'invoice_item', |
|
121 | + 'function' => 'SUM', |
|
122 | + 'name' => 'invoice_item_qty', |
|
123 | + ), |
|
124 | + 'item_id' => array( |
|
125 | + 'type' => 'invoice_item', |
|
126 | + 'function' => '', |
|
127 | + 'name' => 'invoice_item_id', |
|
128 | + ), |
|
129 | + 'item_name' => array( |
|
130 | + 'type' => 'invoice_item', |
|
131 | + 'function' => '', |
|
132 | + 'name' => 'invoice_item_name', |
|
133 | + ), |
|
134 | + 'price' => array( |
|
135 | + 'type' => 'invoice_item', |
|
136 | + 'function' => 'SUM', |
|
137 | + 'name' => 'invoice_item_price', |
|
138 | + ), |
|
139 | + ), |
|
140 | + 'group_by' => 'invoice_item_id', |
|
141 | + 'order_by' => 'invoice_item_qty DESC', |
|
142 | + 'query_type' => 'get_results', |
|
143 | + 'limit' => 10, |
|
144 | + 'filter_range' => $this->report_range, |
|
145 | + ) |
|
146 | + ); |
|
147 | + |
|
148 | + } |
|
149 | + |
|
150 | + /** |
|
151 | + * Get the Report's schema, conforming to JSON Schema. |
|
152 | + * |
|
153 | + * @return array |
|
154 | + */ |
|
155 | + public function get_item_schema() { |
|
156 | + $schema = array( |
|
157 | + '$schema' => 'http://json-schema.org/draft-04/schema#', |
|
158 | + 'title' => $this->rest_base, |
|
159 | + 'type' => 'object', |
|
160 | + 'properties' => array( |
|
161 | + 'name' => array( |
|
162 | + 'description' => __( 'Item name.', 'invoicing' ), |
|
163 | + 'type' => 'string', |
|
164 | + 'context' => array( 'view' ), |
|
165 | + 'readonly' => true, |
|
166 | + ), |
|
167 | + 'item_id' => array( |
|
168 | + 'description' => __( 'Item ID.', 'invoicing' ), |
|
169 | + 'type' => 'integer', |
|
170 | + 'context' => array( 'view' ), |
|
171 | + 'readonly' => true, |
|
172 | + ), |
|
173 | + 'quantity' => array( |
|
174 | + 'description' => __( 'Total number of purchases.', 'invoicing' ), |
|
175 | + 'type' => 'integer', |
|
176 | + 'context' => array( 'view' ), |
|
177 | + 'readonly' => true, |
|
178 | + ), |
|
179 | + 'earnings' => array( |
|
180 | + 'description' => __( 'Total earnings for the item.', 'invoicing' ), |
|
181 | + 'type' => 'double', |
|
182 | + 'context' => array( 'view' ), |
|
183 | + 'readonly' => true, |
|
184 | + ), |
|
185 | + 'earnings_formatted"' => array( |
|
186 | + 'description' => __( 'Total earnings (formatted) for the item.', 'invoicing' ), |
|
187 | + 'type' => 'string', |
|
188 | + 'context' => array( 'view' ), |
|
189 | + 'readonly' => true, |
|
190 | + ), |
|
191 | + ), |
|
192 | + ); |
|
193 | + |
|
194 | + return $this->add_additional_fields_schema( $schema ); |
|
195 | + } |
|
196 | 196 | } |
@@ -18,102 +18,102 @@ |
||
18 | 18 | */ |
19 | 19 | class GetPaid_REST_Report_Invoice_Counts_Controller extends GetPaid_REST_Reports_Controller { |
20 | 20 | |
21 | - /** |
|
22 | - * Route base. |
|
23 | - * |
|
24 | - * @var string |
|
25 | - */ |
|
26 | - protected $rest_base = 'reports/invoices/counts'; |
|
27 | - |
|
28 | - /** |
|
29 | - * Prepare a report object for serialization. |
|
30 | - * |
|
31 | - * @param stdClass $report Report data. |
|
32 | - * @param WP_REST_Request $request Request object. |
|
33 | - * @return WP_REST_Response $response Response data. |
|
34 | - */ |
|
35 | - public function prepare_item_for_response( $report, $request ) { |
|
36 | - |
|
37 | - $data = (array) $report; |
|
38 | - $context = ! empty( $request['context'] ) ? $request['context'] : 'view'; |
|
39 | - $data = $this->add_additional_fields_to_object( $data, $request ); |
|
40 | - $data = $this->filter_response_by_context( $data, $context ); |
|
41 | - |
|
42 | - // Wrap the data in a response object. |
|
43 | - $response = rest_ensure_response( $data ); |
|
44 | - |
|
45 | - $response->add_links( |
|
46 | - array( |
|
47 | - 'about' => array( |
|
48 | - 'href' => rest_url( sprintf( '%s/reports', $this->namespace ) ), |
|
49 | - ), |
|
50 | - ) |
|
51 | - ); |
|
52 | - |
|
53 | - return apply_filters( 'getpaid_rest_prepare_report_invoices_count', $response, $report, $request ); |
|
54 | - } |
|
55 | - |
|
56 | - /** |
|
57 | - * Get reports list. |
|
58 | - * |
|
59 | - * @since 2.0.0 |
|
60 | - * @return array |
|
61 | - */ |
|
62 | - protected function get_reports() { |
|
63 | - |
|
64 | - $counts = wp_count_posts( 'wpi_invoice' ); |
|
65 | - $data = array(); |
|
66 | - |
|
67 | - foreach ( wpinv_get_invoice_statuses() as $slug => $name ) { |
|
68 | - |
|
69 | - if ( ! isset( $counts->$slug ) ) { |
|
70 | - continue; |
|
71 | - } |
|
72 | - |
|
73 | - $data[] = array( |
|
74 | - 'slug' => $slug, |
|
75 | - 'name' => $name, |
|
76 | - 'count' => (int) $counts->$slug, |
|
77 | - ); |
|
78 | - |
|
79 | - } |
|
80 | - |
|
81 | - return $data; |
|
82 | - |
|
83 | - } |
|
84 | - |
|
85 | - /** |
|
86 | - * Get the Report's schema, conforming to JSON Schema. |
|
87 | - * |
|
88 | - * @return array |
|
89 | - */ |
|
90 | - public function get_item_schema() { |
|
91 | - $schema = array( |
|
92 | - '$schema' => 'http://json-schema.org/draft-04/schema#', |
|
93 | - 'title' => 'report_invoice_counts', |
|
94 | - 'type' => 'object', |
|
95 | - 'properties' => array( |
|
96 | - 'slug' => array( |
|
97 | - 'description' => __( 'An alphanumeric identifier for the resource.', 'invoicing' ), |
|
98 | - 'type' => 'string', |
|
99 | - 'context' => array( 'view' ), |
|
100 | - 'readonly' => true, |
|
101 | - ), |
|
102 | - 'name' => array( |
|
103 | - 'description' => __( 'Invoice status name.', 'invoicing' ), |
|
104 | - 'type' => 'string', |
|
105 | - 'context' => array( 'view' ), |
|
106 | - 'readonly' => true, |
|
107 | - ), |
|
108 | - 'count' => array( |
|
109 | - 'description' => __( 'Number of invoices.', 'invoicing' ), |
|
110 | - 'type' => 'string', |
|
111 | - 'context' => array( 'view' ), |
|
112 | - 'readonly' => true, |
|
113 | - ), |
|
114 | - ), |
|
115 | - ); |
|
116 | - |
|
117 | - return $this->add_additional_fields_schema( $schema ); |
|
118 | - } |
|
21 | + /** |
|
22 | + * Route base. |
|
23 | + * |
|
24 | + * @var string |
|
25 | + */ |
|
26 | + protected $rest_base = 'reports/invoices/counts'; |
|
27 | + |
|
28 | + /** |
|
29 | + * Prepare a report object for serialization. |
|
30 | + * |
|
31 | + * @param stdClass $report Report data. |
|
32 | + * @param WP_REST_Request $request Request object. |
|
33 | + * @return WP_REST_Response $response Response data. |
|
34 | + */ |
|
35 | + public function prepare_item_for_response( $report, $request ) { |
|
36 | + |
|
37 | + $data = (array) $report; |
|
38 | + $context = ! empty( $request['context'] ) ? $request['context'] : 'view'; |
|
39 | + $data = $this->add_additional_fields_to_object( $data, $request ); |
|
40 | + $data = $this->filter_response_by_context( $data, $context ); |
|
41 | + |
|
42 | + // Wrap the data in a response object. |
|
43 | + $response = rest_ensure_response( $data ); |
|
44 | + |
|
45 | + $response->add_links( |
|
46 | + array( |
|
47 | + 'about' => array( |
|
48 | + 'href' => rest_url( sprintf( '%s/reports', $this->namespace ) ), |
|
49 | + ), |
|
50 | + ) |
|
51 | + ); |
|
52 | + |
|
53 | + return apply_filters( 'getpaid_rest_prepare_report_invoices_count', $response, $report, $request ); |
|
54 | + } |
|
55 | + |
|
56 | + /** |
|
57 | + * Get reports list. |
|
58 | + * |
|
59 | + * @since 2.0.0 |
|
60 | + * @return array |
|
61 | + */ |
|
62 | + protected function get_reports() { |
|
63 | + |
|
64 | + $counts = wp_count_posts( 'wpi_invoice' ); |
|
65 | + $data = array(); |
|
66 | + |
|
67 | + foreach ( wpinv_get_invoice_statuses() as $slug => $name ) { |
|
68 | + |
|
69 | + if ( ! isset( $counts->$slug ) ) { |
|
70 | + continue; |
|
71 | + } |
|
72 | + |
|
73 | + $data[] = array( |
|
74 | + 'slug' => $slug, |
|
75 | + 'name' => $name, |
|
76 | + 'count' => (int) $counts->$slug, |
|
77 | + ); |
|
78 | + |
|
79 | + } |
|
80 | + |
|
81 | + return $data; |
|
82 | + |
|
83 | + } |
|
84 | + |
|
85 | + /** |
|
86 | + * Get the Report's schema, conforming to JSON Schema. |
|
87 | + * |
|
88 | + * @return array |
|
89 | + */ |
|
90 | + public function get_item_schema() { |
|
91 | + $schema = array( |
|
92 | + '$schema' => 'http://json-schema.org/draft-04/schema#', |
|
93 | + 'title' => 'report_invoice_counts', |
|
94 | + 'type' => 'object', |
|
95 | + 'properties' => array( |
|
96 | + 'slug' => array( |
|
97 | + 'description' => __( 'An alphanumeric identifier for the resource.', 'invoicing' ), |
|
98 | + 'type' => 'string', |
|
99 | + 'context' => array( 'view' ), |
|
100 | + 'readonly' => true, |
|
101 | + ), |
|
102 | + 'name' => array( |
|
103 | + 'description' => __( 'Invoice status name.', 'invoicing' ), |
|
104 | + 'type' => 'string', |
|
105 | + 'context' => array( 'view' ), |
|
106 | + 'readonly' => true, |
|
107 | + ), |
|
108 | + 'count' => array( |
|
109 | + 'description' => __( 'Number of invoices.', 'invoicing' ), |
|
110 | + 'type' => 'string', |
|
111 | + 'context' => array( 'view' ), |
|
112 | + 'readonly' => true, |
|
113 | + ), |
|
114 | + ), |
|
115 | + ); |
|
116 | + |
|
117 | + return $this->add_additional_fields_schema( $schema ); |
|
118 | + } |
|
119 | 119 | } |
@@ -7,40 +7,40 @@ |
||
7 | 7 | * Bail if we are not in WP. |
8 | 8 | */ |
9 | 9 | if ( ! defined( 'ABSPATH' ) ) { |
10 | - exit; |
|
10 | + exit; |
|
11 | 11 | } |
12 | 12 | |
13 | 13 | /** |
14 | 14 | * Set the version only if its the current newest while loading. |
15 | 15 | */ |
16 | 16 | add_action('after_setup_theme', function () { |
17 | - global $ayecode_ui_version,$ayecode_ui_file_key; |
|
18 | - $this_version = "0.1.38"; |
|
19 | - if(version_compare($this_version , $ayecode_ui_version, '>')){ |
|
20 | - $ayecode_ui_version = $this_version ; |
|
21 | - $ayecode_ui_file_key = wp_hash( __FILE__ ); |
|
22 | - } |
|
17 | + global $ayecode_ui_version,$ayecode_ui_file_key; |
|
18 | + $this_version = "0.1.38"; |
|
19 | + if(version_compare($this_version , $ayecode_ui_version, '>')){ |
|
20 | + $ayecode_ui_version = $this_version ; |
|
21 | + $ayecode_ui_file_key = wp_hash( __FILE__ ); |
|
22 | + } |
|
23 | 23 | },0); |
24 | 24 | |
25 | 25 | /** |
26 | 26 | * Load this version of WP Bootstrap Settings only if the file hash is the current one. |
27 | 27 | */ |
28 | 28 | add_action('after_setup_theme', function () { |
29 | - global $ayecode_ui_file_key; |
|
30 | - if($ayecode_ui_file_key && $ayecode_ui_file_key == wp_hash( __FILE__ )){ |
|
31 | - include_once( dirname( __FILE__ ) . '/includes/class-aui.php' ); |
|
32 | - include_once( dirname( __FILE__ ) . '/includes/ayecode-ui-settings.php' ); |
|
33 | - } |
|
29 | + global $ayecode_ui_file_key; |
|
30 | + if($ayecode_ui_file_key && $ayecode_ui_file_key == wp_hash( __FILE__ )){ |
|
31 | + include_once( dirname( __FILE__ ) . '/includes/class-aui.php' ); |
|
32 | + include_once( dirname( __FILE__ ) . '/includes/ayecode-ui-settings.php' ); |
|
33 | + } |
|
34 | 34 | },1); |
35 | 35 | |
36 | 36 | /** |
37 | 37 | * Add the function that calls the class. |
38 | 38 | */ |
39 | 39 | if(!function_exists('aui')){ |
40 | - function aui(){ |
|
41 | - if(!class_exists("AUI",false)){ |
|
42 | - return false; |
|
43 | - } |
|
44 | - return AUI::instance(); |
|
45 | - } |
|
40 | + function aui(){ |
|
41 | + if(!class_exists("AUI",false)){ |
|
42 | + return false; |
|
43 | + } |
|
44 | + return AUI::instance(); |
|
45 | + } |
|
46 | 46 | } |
47 | 47 | \ No newline at end of file |
@@ -1,7 +1,7 @@ discard block |
||
1 | 1 | <?php |
2 | 2 | |
3 | 3 | if ( ! defined( 'ABSPATH' ) ) { |
4 | - exit; // Exit if accessed directly |
|
4 | + exit; // Exit if accessed directly |
|
5 | 5 | } |
6 | 6 | |
7 | 7 | /** |
@@ -11,231 +11,231 @@ discard block |
||
11 | 11 | */ |
12 | 12 | class AUI { |
13 | 13 | |
14 | - /** |
|
15 | - * Holds the class instance. |
|
16 | - * |
|
17 | - * @since 1.0.0 |
|
18 | - * @var null |
|
19 | - */ |
|
20 | - private static $instance = null; |
|
21 | - |
|
22 | - /** |
|
23 | - * Holds the current AUI version number. |
|
24 | - * |
|
25 | - * @var string $ver The current version number. |
|
26 | - */ |
|
27 | - public static $ver = '0.1.38'; |
|
28 | - |
|
29 | - public static $options = null; |
|
30 | - |
|
31 | - /** |
|
32 | - * There can be only one. |
|
33 | - * |
|
34 | - * @since 1.0.0 |
|
35 | - * @return AUI|null |
|
36 | - */ |
|
37 | - public static function instance() { |
|
38 | - if ( self::$instance == null ) { |
|
39 | - self::$instance = new AUI(); |
|
40 | - } |
|
41 | - |
|
42 | - return self::$instance; |
|
43 | - } |
|
44 | - |
|
45 | - /** |
|
46 | - * AUI constructor. |
|
47 | - * |
|
48 | - * @since 1.0.0 |
|
49 | - */ |
|
50 | - private function __construct() { |
|
51 | - if ( function_exists( "__autoload" ) ) { |
|
52 | - spl_autoload_register( "__autoload" ); |
|
53 | - } |
|
54 | - spl_autoload_register( array( $this, 'autoload' ) ); |
|
55 | - |
|
56 | - // load options |
|
57 | - self::$options = get_option('aui_options'); |
|
58 | - } |
|
59 | - |
|
60 | - /** |
|
61 | - * Autoload any components on the fly. |
|
62 | - * |
|
63 | - * @since 1.0.0 |
|
64 | - * |
|
65 | - * @param $classname |
|
66 | - */ |
|
67 | - private function autoload( $classname ) { |
|
68 | - $class = str_replace( '_', '-', strtolower( $classname ) ); |
|
69 | - $file_path = trailingslashit( dirname( __FILE__ ) ) . "components/class-" . $class . '.php'; |
|
70 | - if ( $file_path && is_readable( $file_path ) ) { |
|
71 | - include_once( $file_path ); |
|
72 | - } |
|
73 | - } |
|
74 | - |
|
75 | - /** |
|
76 | - * Get the AUI options. |
|
77 | - * |
|
78 | - * @param $option |
|
79 | - * |
|
80 | - * @return string|void |
|
81 | - */ |
|
82 | - public function get_option( $option ){ |
|
83 | - $result = isset(self::$options[$option]) ? esc_attr(self::$options[$option]) : ''; |
|
84 | - |
|
85 | - if ( ! $result && $option) { |
|
86 | - if( $option == 'color_primary' ){ |
|
87 | - $result = AUI_PRIMARY_COLOR; |
|
88 | - }elseif( $option == 'color_secondary' ){ |
|
89 | - $result = AUI_SECONDARY_COLOR; |
|
90 | - } |
|
91 | - } |
|
92 | - return $result; |
|
93 | - } |
|
94 | - |
|
95 | - public function render( $items = array() ) { |
|
96 | - $output = ''; |
|
97 | - |
|
98 | - if ( ! empty( $items ) ) { |
|
99 | - foreach ( $items as $args ) { |
|
100 | - $render = isset( $args['render'] ) ? $args['render'] : ''; |
|
101 | - if ( $render && method_exists( __CLASS__, $render ) ) { |
|
102 | - $output .= $this->$render( $args ); |
|
103 | - } |
|
104 | - } |
|
105 | - } |
|
106 | - |
|
107 | - return $output; |
|
108 | - } |
|
109 | - |
|
110 | - /** |
|
111 | - * Render and return a bootstrap alert component. |
|
112 | - * |
|
113 | - * @since 1.0.0 |
|
114 | - * |
|
115 | - * @param array $args |
|
116 | - * |
|
117 | - * @return string The rendered component. |
|
118 | - */ |
|
119 | - public function alert( $args = array() ) { |
|
120 | - return AUI_Component_Alert::get( $args ); |
|
121 | - } |
|
122 | - |
|
123 | - /** |
|
124 | - * Render and return a bootstrap input component. |
|
125 | - * |
|
126 | - * @since 1.0.0 |
|
127 | - * |
|
128 | - * @param array $args |
|
129 | - * |
|
130 | - * @return string The rendered component. |
|
131 | - */ |
|
132 | - public function input( $args = array() ) { |
|
133 | - return AUI_Component_Input::input( $args ); |
|
134 | - } |
|
135 | - |
|
136 | - /** |
|
137 | - * Render and return a bootstrap textarea component. |
|
138 | - * |
|
139 | - * @since 1.0.0 |
|
140 | - * |
|
141 | - * @param array $args |
|
142 | - * |
|
143 | - * @return string The rendered component. |
|
144 | - */ |
|
145 | - public function textarea( $args = array() ) { |
|
146 | - return AUI_Component_Input::textarea( $args ); |
|
147 | - } |
|
148 | - |
|
149 | - /** |
|
150 | - * Render and return a bootstrap button component. |
|
151 | - * |
|
152 | - * @since 1.0.0 |
|
153 | - * |
|
154 | - * @param array $args |
|
155 | - * |
|
156 | - * @return string The rendered component. |
|
157 | - */ |
|
158 | - public function button( $args = array() ) { |
|
159 | - return AUI_Component_Button::get( $args ); |
|
160 | - } |
|
161 | - |
|
162 | - /** |
|
163 | - * Render and return a bootstrap button component. |
|
164 | - * |
|
165 | - * @since 1.0.0 |
|
166 | - * |
|
167 | - * @param array $args |
|
168 | - * |
|
169 | - * @return string The rendered component. |
|
170 | - */ |
|
171 | - public function badge( $args = array() ) { |
|
172 | - $defaults = array( |
|
173 | - 'class' => 'badge badge-primary align-middle', |
|
174 | - ); |
|
175 | - |
|
176 | - // maybe set type |
|
177 | - if ( empty( $args['href'] ) ) { |
|
178 | - $defaults['type'] = 'badge'; |
|
179 | - } |
|
180 | - |
|
181 | - /** |
|
182 | - * Parse incoming $args into an array and merge it with $defaults |
|
183 | - */ |
|
184 | - $args = wp_parse_args( $args, $defaults ); |
|
185 | - |
|
186 | - return AUI_Component_Button::get( $args ); |
|
187 | - } |
|
188 | - |
|
189 | - /** |
|
190 | - * Render and return a bootstrap dropdown component. |
|
191 | - * |
|
192 | - * @since 1.0.0 |
|
193 | - * |
|
194 | - * @param array $args |
|
195 | - * |
|
196 | - * @return string The rendered component. |
|
197 | - */ |
|
198 | - public function dropdown( $args = array() ) { |
|
199 | - return AUI_Component_Dropdown::get( $args ); |
|
200 | - } |
|
201 | - |
|
202 | - /** |
|
203 | - * Render and return a bootstrap select component. |
|
204 | - * |
|
205 | - * @since 1.0.0 |
|
206 | - * |
|
207 | - * @param array $args |
|
208 | - * |
|
209 | - * @return string The rendered component. |
|
210 | - */ |
|
211 | - public function select( $args = array() ) { |
|
212 | - return AUI_Component_Input::select( $args ); |
|
213 | - } |
|
214 | - |
|
215 | - /** |
|
216 | - * Render and return a bootstrap radio component. |
|
217 | - * |
|
218 | - * @since 1.0.0 |
|
219 | - * |
|
220 | - * @param array $args |
|
221 | - * |
|
222 | - * @return string The rendered component. |
|
223 | - */ |
|
224 | - public function radio( $args = array() ) { |
|
225 | - return AUI_Component_Input::radio( $args ); |
|
226 | - } |
|
227 | - |
|
228 | - /** |
|
229 | - * Render and return a bootstrap pagination component. |
|
230 | - * |
|
231 | - * @since 1.0.0 |
|
232 | - * |
|
233 | - * @param array $args |
|
234 | - * |
|
235 | - * @return string The rendered component. |
|
236 | - */ |
|
237 | - public function pagination( $args = array() ) { |
|
238 | - return AUI_Component_Pagination::get( $args ); |
|
239 | - } |
|
14 | + /** |
|
15 | + * Holds the class instance. |
|
16 | + * |
|
17 | + * @since 1.0.0 |
|
18 | + * @var null |
|
19 | + */ |
|
20 | + private static $instance = null; |
|
21 | + |
|
22 | + /** |
|
23 | + * Holds the current AUI version number. |
|
24 | + * |
|
25 | + * @var string $ver The current version number. |
|
26 | + */ |
|
27 | + public static $ver = '0.1.38'; |
|
28 | + |
|
29 | + public static $options = null; |
|
30 | + |
|
31 | + /** |
|
32 | + * There can be only one. |
|
33 | + * |
|
34 | + * @since 1.0.0 |
|
35 | + * @return AUI|null |
|
36 | + */ |
|
37 | + public static function instance() { |
|
38 | + if ( self::$instance == null ) { |
|
39 | + self::$instance = new AUI(); |
|
40 | + } |
|
41 | + |
|
42 | + return self::$instance; |
|
43 | + } |
|
44 | + |
|
45 | + /** |
|
46 | + * AUI constructor. |
|
47 | + * |
|
48 | + * @since 1.0.0 |
|
49 | + */ |
|
50 | + private function __construct() { |
|
51 | + if ( function_exists( "__autoload" ) ) { |
|
52 | + spl_autoload_register( "__autoload" ); |
|
53 | + } |
|
54 | + spl_autoload_register( array( $this, 'autoload' ) ); |
|
55 | + |
|
56 | + // load options |
|
57 | + self::$options = get_option('aui_options'); |
|
58 | + } |
|
59 | + |
|
60 | + /** |
|
61 | + * Autoload any components on the fly. |
|
62 | + * |
|
63 | + * @since 1.0.0 |
|
64 | + * |
|
65 | + * @param $classname |
|
66 | + */ |
|
67 | + private function autoload( $classname ) { |
|
68 | + $class = str_replace( '_', '-', strtolower( $classname ) ); |
|
69 | + $file_path = trailingslashit( dirname( __FILE__ ) ) . "components/class-" . $class . '.php'; |
|
70 | + if ( $file_path && is_readable( $file_path ) ) { |
|
71 | + include_once( $file_path ); |
|
72 | + } |
|
73 | + } |
|
74 | + |
|
75 | + /** |
|
76 | + * Get the AUI options. |
|
77 | + * |
|
78 | + * @param $option |
|
79 | + * |
|
80 | + * @return string|void |
|
81 | + */ |
|
82 | + public function get_option( $option ){ |
|
83 | + $result = isset(self::$options[$option]) ? esc_attr(self::$options[$option]) : ''; |
|
84 | + |
|
85 | + if ( ! $result && $option) { |
|
86 | + if( $option == 'color_primary' ){ |
|
87 | + $result = AUI_PRIMARY_COLOR; |
|
88 | + }elseif( $option == 'color_secondary' ){ |
|
89 | + $result = AUI_SECONDARY_COLOR; |
|
90 | + } |
|
91 | + } |
|
92 | + return $result; |
|
93 | + } |
|
94 | + |
|
95 | + public function render( $items = array() ) { |
|
96 | + $output = ''; |
|
97 | + |
|
98 | + if ( ! empty( $items ) ) { |
|
99 | + foreach ( $items as $args ) { |
|
100 | + $render = isset( $args['render'] ) ? $args['render'] : ''; |
|
101 | + if ( $render && method_exists( __CLASS__, $render ) ) { |
|
102 | + $output .= $this->$render( $args ); |
|
103 | + } |
|
104 | + } |
|
105 | + } |
|
106 | + |
|
107 | + return $output; |
|
108 | + } |
|
109 | + |
|
110 | + /** |
|
111 | + * Render and return a bootstrap alert component. |
|
112 | + * |
|
113 | + * @since 1.0.0 |
|
114 | + * |
|
115 | + * @param array $args |
|
116 | + * |
|
117 | + * @return string The rendered component. |
|
118 | + */ |
|
119 | + public function alert( $args = array() ) { |
|
120 | + return AUI_Component_Alert::get( $args ); |
|
121 | + } |
|
122 | + |
|
123 | + /** |
|
124 | + * Render and return a bootstrap input component. |
|
125 | + * |
|
126 | + * @since 1.0.0 |
|
127 | + * |
|
128 | + * @param array $args |
|
129 | + * |
|
130 | + * @return string The rendered component. |
|
131 | + */ |
|
132 | + public function input( $args = array() ) { |
|
133 | + return AUI_Component_Input::input( $args ); |
|
134 | + } |
|
135 | + |
|
136 | + /** |
|
137 | + * Render and return a bootstrap textarea component. |
|
138 | + * |
|
139 | + * @since 1.0.0 |
|
140 | + * |
|
141 | + * @param array $args |
|
142 | + * |
|
143 | + * @return string The rendered component. |
|
144 | + */ |
|
145 | + public function textarea( $args = array() ) { |
|
146 | + return AUI_Component_Input::textarea( $args ); |
|
147 | + } |
|
148 | + |
|
149 | + /** |
|
150 | + * Render and return a bootstrap button component. |
|
151 | + * |
|
152 | + * @since 1.0.0 |
|
153 | + * |
|
154 | + * @param array $args |
|
155 | + * |
|
156 | + * @return string The rendered component. |
|
157 | + */ |
|
158 | + public function button( $args = array() ) { |
|
159 | + return AUI_Component_Button::get( $args ); |
|
160 | + } |
|
161 | + |
|
162 | + /** |
|
163 | + * Render and return a bootstrap button component. |
|
164 | + * |
|
165 | + * @since 1.0.0 |
|
166 | + * |
|
167 | + * @param array $args |
|
168 | + * |
|
169 | + * @return string The rendered component. |
|
170 | + */ |
|
171 | + public function badge( $args = array() ) { |
|
172 | + $defaults = array( |
|
173 | + 'class' => 'badge badge-primary align-middle', |
|
174 | + ); |
|
175 | + |
|
176 | + // maybe set type |
|
177 | + if ( empty( $args['href'] ) ) { |
|
178 | + $defaults['type'] = 'badge'; |
|
179 | + } |
|
180 | + |
|
181 | + /** |
|
182 | + * Parse incoming $args into an array and merge it with $defaults |
|
183 | + */ |
|
184 | + $args = wp_parse_args( $args, $defaults ); |
|
185 | + |
|
186 | + return AUI_Component_Button::get( $args ); |
|
187 | + } |
|
188 | + |
|
189 | + /** |
|
190 | + * Render and return a bootstrap dropdown component. |
|
191 | + * |
|
192 | + * @since 1.0.0 |
|
193 | + * |
|
194 | + * @param array $args |
|
195 | + * |
|
196 | + * @return string The rendered component. |
|
197 | + */ |
|
198 | + public function dropdown( $args = array() ) { |
|
199 | + return AUI_Component_Dropdown::get( $args ); |
|
200 | + } |
|
201 | + |
|
202 | + /** |
|
203 | + * Render and return a bootstrap select component. |
|
204 | + * |
|
205 | + * @since 1.0.0 |
|
206 | + * |
|
207 | + * @param array $args |
|
208 | + * |
|
209 | + * @return string The rendered component. |
|
210 | + */ |
|
211 | + public function select( $args = array() ) { |
|
212 | + return AUI_Component_Input::select( $args ); |
|
213 | + } |
|
214 | + |
|
215 | + /** |
|
216 | + * Render and return a bootstrap radio component. |
|
217 | + * |
|
218 | + * @since 1.0.0 |
|
219 | + * |
|
220 | + * @param array $args |
|
221 | + * |
|
222 | + * @return string The rendered component. |
|
223 | + */ |
|
224 | + public function radio( $args = array() ) { |
|
225 | + return AUI_Component_Input::radio( $args ); |
|
226 | + } |
|
227 | + |
|
228 | + /** |
|
229 | + * Render and return a bootstrap pagination component. |
|
230 | + * |
|
231 | + * @since 1.0.0 |
|
232 | + * |
|
233 | + * @param array $args |
|
234 | + * |
|
235 | + * @return string The rendered component. |
|
236 | + */ |
|
237 | + public function pagination( $args = array() ) { |
|
238 | + return AUI_Component_Pagination::get( $args ); |
|
239 | + } |
|
240 | 240 | |
241 | 241 | } |
242 | 242 | \ No newline at end of file |
@@ -1,262 +1,262 @@ discard block |
||
1 | 1 | <?php |
2 | 2 | if ( ! defined( 'ABSPATH' ) ) { |
3 | - exit; |
|
3 | + exit; |
|
4 | 4 | } |
5 | 5 | |
6 | 6 | if ( ! class_exists( 'WP_Super_Duper' ) ) { |
7 | 7 | |
8 | 8 | |
9 | - /** |
|
10 | - * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress. |
|
11 | - * |
|
12 | - * Should not be called direct but extended instead. |
|
13 | - * |
|
14 | - * Class WP_Super_Duper |
|
15 | - * @since 1.0.16 change log moved to file change-log.txt - CHANGED |
|
16 | - * @ver 1.0.19 |
|
17 | - */ |
|
18 | - class WP_Super_Duper extends WP_Widget { |
|
19 | - |
|
20 | - public $version = "1.0.23"; |
|
21 | - public $font_awesome_icon_version = "5.11.2"; |
|
22 | - public $block_code; |
|
23 | - public $options; |
|
24 | - public $base_id; |
|
25 | - public $settings_hash; |
|
26 | - public $arguments = array(); |
|
27 | - public $instance = array(); |
|
28 | - private $class_name; |
|
29 | - |
|
30 | - /** |
|
31 | - * The relative url to the current folder. |
|
32 | - * |
|
33 | - * @var string |
|
34 | - */ |
|
35 | - public $url = ''; |
|
36 | - |
|
37 | - /** |
|
38 | - * Take the array options and use them to build. |
|
39 | - */ |
|
40 | - public function __construct( $options ) { |
|
41 | - global $sd_widgets; |
|
42 | - |
|
43 | - $sd_widgets[ $options['base_id'] ] = array( |
|
44 | - 'name' => $options['name'], |
|
45 | - 'class_name' => $options['class_name'] |
|
46 | - ); |
|
47 | - $this->base_id = $options['base_id']; |
|
48 | - // lets filter the options before we do anything |
|
49 | - $options = apply_filters( "wp_super_duper_options", $options ); |
|
50 | - $options = apply_filters( "wp_super_duper_options_{$this->base_id}", $options ); |
|
51 | - $options = $this->add_name_from_key( $options ); |
|
52 | - $this->options = $options; |
|
53 | - |
|
54 | - $this->base_id = $options['base_id']; |
|
55 | - $this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array(); |
|
56 | - |
|
57 | - // init parent |
|
58 | - parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] ); |
|
59 | - |
|
60 | - if ( isset( $options['class_name'] ) ) { |
|
61 | - // register widget |
|
62 | - $this->class_name = $options['class_name']; |
|
63 | - |
|
64 | - // register shortcode |
|
65 | - $this->register_shortcode(); |
|
66 | - |
|
67 | - // Fusion Builder (avada) support |
|
68 | - if ( function_exists( 'fusion_builder_map' ) ) { |
|
69 | - add_action( 'init', array( $this, 'register_fusion_element' ) ); |
|
70 | - } |
|
71 | - |
|
72 | - // register block |
|
73 | - add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) ); |
|
74 | - } |
|
75 | - |
|
76 | - // add the CSS and JS we need ONCE |
|
77 | - global $sd_widget_scripts; |
|
78 | - |
|
79 | - if ( ! $sd_widget_scripts ) { |
|
80 | - wp_add_inline_script( 'admin-widgets', $this->widget_js() ); |
|
81 | - wp_add_inline_script( 'customize-controls', $this->widget_js() ); |
|
82 | - wp_add_inline_style( 'widgets', $this->widget_css() ); |
|
83 | - |
|
84 | - // maybe add elementor editor styles |
|
85 | - add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) ); |
|
86 | - |
|
87 | - $sd_widget_scripts = true; |
|
88 | - |
|
89 | - // add shortcode insert button once |
|
90 | - add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) ); |
|
91 | - // generatepress theme sections compatibility |
|
92 | - if ( function_exists( 'generate_sections_sections_metabox' ) ) { |
|
93 | - add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) ); |
|
94 | - } |
|
95 | - if ( $this->is_preview() ) { |
|
96 | - add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) ); |
|
97 | - // this makes the insert button work for elementor |
|
98 | - add_action( 'elementor/editor/after_enqueue_scripts', array( |
|
99 | - $this, |
|
100 | - 'shortcode_insert_button_script' |
|
101 | - ) ); // for elementor |
|
102 | - } |
|
103 | - // this makes the insert button work for cornerstone |
|
104 | - add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) ); |
|
105 | - |
|
106 | - add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) ); |
|
107 | - add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) ); |
|
108 | - |
|
109 | - // add generator text to admin head |
|
110 | - add_action( 'admin_head', array( $this, 'generator' ) ); |
|
111 | - } |
|
112 | - |
|
113 | - do_action( 'wp_super_duper_widget_init', $options, $this ); |
|
114 | - } |
|
115 | - |
|
116 | - /** |
|
117 | - * Add our widget CSS to elementor editor. |
|
118 | - */ |
|
119 | - public function elementor_editor_styles() { |
|
120 | - wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) ); |
|
121 | - } |
|
122 | - |
|
123 | - public function register_fusion_element() { |
|
124 | - |
|
125 | - $options = $this->options; |
|
126 | - |
|
127 | - if ( $this->base_id ) { |
|
128 | - |
|
129 | - $params = $this->get_fusion_params(); |
|
130 | - |
|
131 | - $args = array( |
|
132 | - 'name' => $options['name'], |
|
133 | - 'shortcode' => $this->base_id, |
|
134 | - 'icon' => $options['block-icon'] ? $options['block-icon'] : 'far fa-square', |
|
135 | - 'allow_generator' => true, |
|
136 | - ); |
|
137 | - |
|
138 | - if ( ! empty( $params ) ) { |
|
139 | - $args['params'] = $params; |
|
140 | - } |
|
141 | - |
|
142 | - fusion_builder_map( $args ); |
|
143 | - } |
|
144 | - |
|
145 | - } |
|
146 | - |
|
147 | - public function get_fusion_params() { |
|
148 | - $params = array(); |
|
149 | - $arguments = $this->get_arguments(); |
|
150 | - |
|
151 | - if ( ! empty( $arguments ) ) { |
|
152 | - foreach ( $arguments as $key => $val ) { |
|
153 | - $param = array(); |
|
154 | - // type |
|
155 | - $param['type'] = str_replace( |
|
156 | - array( |
|
157 | - "text", |
|
158 | - "number", |
|
159 | - "email", |
|
160 | - "color", |
|
161 | - "checkbox" |
|
162 | - ), |
|
163 | - array( |
|
164 | - "textfield", |
|
165 | - "textfield", |
|
166 | - "textfield", |
|
167 | - "colorpicker", |
|
168 | - "select", |
|
169 | - |
|
170 | - ), |
|
171 | - $val['type'] ); |
|
172 | - |
|
173 | - // multiselect |
|
174 | - if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) { |
|
175 | - $param['type'] = 'multiple_select'; |
|
176 | - $param['multiple'] = true; |
|
177 | - } |
|
178 | - |
|
179 | - // heading |
|
180 | - $param['heading'] = $val['title']; |
|
181 | - |
|
182 | - // description |
|
183 | - $param['description'] = isset( $val['desc'] ) ? $val['desc'] : ''; |
|
184 | - |
|
185 | - // param_name |
|
186 | - $param['param_name'] = $key; |
|
187 | - |
|
188 | - // Default |
|
189 | - $param['default'] = isset( $val['default'] ) ? $val['default'] : ''; |
|
190 | - |
|
191 | - // Group |
|
192 | - if ( isset( $val['group'] ) ) { |
|
193 | - $param['group'] = $val['group']; |
|
194 | - } |
|
195 | - |
|
196 | - // value |
|
197 | - if ( $val['type'] == 'checkbox' ) { |
|
198 | - if ( isset( $val['default'] ) && $val['default'] == '0' ) { |
|
199 | - unset( $param['default'] ); |
|
200 | - } |
|
201 | - $param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) ); |
|
202 | - } elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) { |
|
203 | - $param['value'] = isset( $val['options'] ) ? $val['options'] : array(); |
|
204 | - } else { |
|
205 | - $param['value'] = isset( $val['default'] ) ? $val['default'] : ''; |
|
206 | - } |
|
207 | - |
|
208 | - // setup the param |
|
209 | - $params[] = $param; |
|
210 | - |
|
211 | - } |
|
212 | - } |
|
213 | - |
|
214 | - |
|
215 | - return $params; |
|
216 | - } |
|
217 | - |
|
218 | - /** |
|
219 | - * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder |
|
220 | - */ |
|
221 | - public static function maybe_cornerstone_builder() { |
|
222 | - if ( did_action( 'cornerstone_before_boot_app' ) ) { |
|
223 | - self::shortcode_insert_button_script(); |
|
224 | - } |
|
225 | - } |
|
226 | - |
|
227 | - /** |
|
228 | - * A function to ge the shortcode builder picker html. |
|
229 | - * |
|
230 | - * @param string $editor_id |
|
231 | - * |
|
232 | - * @return string |
|
233 | - */ |
|
234 | - public static function get_picker( $editor_id = '' ) { |
|
235 | - |
|
236 | - ob_start(); |
|
237 | - if ( isset( $_POST['editor_id'] ) ) { |
|
238 | - $editor_id = esc_attr( $_POST['editor_id'] ); |
|
239 | - } elseif ( isset( $_REQUEST['et_fb'] ) ) { |
|
240 | - $editor_id = 'main_content_content_vb_tiny_mce'; |
|
241 | - } |
|
242 | - |
|
243 | - global $sd_widgets; |
|
244 | - ?> |
|
9 | + /** |
|
10 | + * A Class to be able to create a Widget, Shortcode or Block to be able to output content for WordPress. |
|
11 | + * |
|
12 | + * Should not be called direct but extended instead. |
|
13 | + * |
|
14 | + * Class WP_Super_Duper |
|
15 | + * @since 1.0.16 change log moved to file change-log.txt - CHANGED |
|
16 | + * @ver 1.0.19 |
|
17 | + */ |
|
18 | + class WP_Super_Duper extends WP_Widget { |
|
19 | + |
|
20 | + public $version = "1.0.23"; |
|
21 | + public $font_awesome_icon_version = "5.11.2"; |
|
22 | + public $block_code; |
|
23 | + public $options; |
|
24 | + public $base_id; |
|
25 | + public $settings_hash; |
|
26 | + public $arguments = array(); |
|
27 | + public $instance = array(); |
|
28 | + private $class_name; |
|
29 | + |
|
30 | + /** |
|
31 | + * The relative url to the current folder. |
|
32 | + * |
|
33 | + * @var string |
|
34 | + */ |
|
35 | + public $url = ''; |
|
36 | + |
|
37 | + /** |
|
38 | + * Take the array options and use them to build. |
|
39 | + */ |
|
40 | + public function __construct( $options ) { |
|
41 | + global $sd_widgets; |
|
42 | + |
|
43 | + $sd_widgets[ $options['base_id'] ] = array( |
|
44 | + 'name' => $options['name'], |
|
45 | + 'class_name' => $options['class_name'] |
|
46 | + ); |
|
47 | + $this->base_id = $options['base_id']; |
|
48 | + // lets filter the options before we do anything |
|
49 | + $options = apply_filters( "wp_super_duper_options", $options ); |
|
50 | + $options = apply_filters( "wp_super_duper_options_{$this->base_id}", $options ); |
|
51 | + $options = $this->add_name_from_key( $options ); |
|
52 | + $this->options = $options; |
|
53 | + |
|
54 | + $this->base_id = $options['base_id']; |
|
55 | + $this->arguments = isset( $options['arguments'] ) ? $options['arguments'] : array(); |
|
56 | + |
|
57 | + // init parent |
|
58 | + parent::__construct( $options['base_id'], $options['name'], $options['widget_ops'] ); |
|
59 | + |
|
60 | + if ( isset( $options['class_name'] ) ) { |
|
61 | + // register widget |
|
62 | + $this->class_name = $options['class_name']; |
|
63 | + |
|
64 | + // register shortcode |
|
65 | + $this->register_shortcode(); |
|
66 | + |
|
67 | + // Fusion Builder (avada) support |
|
68 | + if ( function_exists( 'fusion_builder_map' ) ) { |
|
69 | + add_action( 'init', array( $this, 'register_fusion_element' ) ); |
|
70 | + } |
|
71 | + |
|
72 | + // register block |
|
73 | + add_action( 'admin_enqueue_scripts', array( $this, 'register_block' ) ); |
|
74 | + } |
|
75 | + |
|
76 | + // add the CSS and JS we need ONCE |
|
77 | + global $sd_widget_scripts; |
|
78 | + |
|
79 | + if ( ! $sd_widget_scripts ) { |
|
80 | + wp_add_inline_script( 'admin-widgets', $this->widget_js() ); |
|
81 | + wp_add_inline_script( 'customize-controls', $this->widget_js() ); |
|
82 | + wp_add_inline_style( 'widgets', $this->widget_css() ); |
|
83 | + |
|
84 | + // maybe add elementor editor styles |
|
85 | + add_action( 'elementor/editor/after_enqueue_styles', array( $this, 'elementor_editor_styles' ) ); |
|
86 | + |
|
87 | + $sd_widget_scripts = true; |
|
88 | + |
|
89 | + // add shortcode insert button once |
|
90 | + add_action( 'media_buttons', array( $this, 'shortcode_insert_button' ) ); |
|
91 | + // generatepress theme sections compatibility |
|
92 | + if ( function_exists( 'generate_sections_sections_metabox' ) ) { |
|
93 | + add_action( 'generate_sections_metabox', array( $this, 'shortcode_insert_button_script' ) ); |
|
94 | + } |
|
95 | + if ( $this->is_preview() ) { |
|
96 | + add_action( 'wp_footer', array( $this, 'shortcode_insert_button_script' ) ); |
|
97 | + // this makes the insert button work for elementor |
|
98 | + add_action( 'elementor/editor/after_enqueue_scripts', array( |
|
99 | + $this, |
|
100 | + 'shortcode_insert_button_script' |
|
101 | + ) ); // for elementor |
|
102 | + } |
|
103 | + // this makes the insert button work for cornerstone |
|
104 | + add_action( 'wp_print_footer_scripts', array( __CLASS__, 'maybe_cornerstone_builder' ) ); |
|
105 | + |
|
106 | + add_action( 'wp_ajax_super_duper_get_widget_settings', array( __CLASS__, 'get_widget_settings' ) ); |
|
107 | + add_action( 'wp_ajax_super_duper_get_picker', array( __CLASS__, 'get_picker' ) ); |
|
108 | + |
|
109 | + // add generator text to admin head |
|
110 | + add_action( 'admin_head', array( $this, 'generator' ) ); |
|
111 | + } |
|
112 | + |
|
113 | + do_action( 'wp_super_duper_widget_init', $options, $this ); |
|
114 | + } |
|
115 | + |
|
116 | + /** |
|
117 | + * Add our widget CSS to elementor editor. |
|
118 | + */ |
|
119 | + public function elementor_editor_styles() { |
|
120 | + wp_add_inline_style( 'elementor-editor', $this->widget_css( false ) ); |
|
121 | + } |
|
122 | + |
|
123 | + public function register_fusion_element() { |
|
124 | + |
|
125 | + $options = $this->options; |
|
126 | + |
|
127 | + if ( $this->base_id ) { |
|
128 | + |
|
129 | + $params = $this->get_fusion_params(); |
|
130 | + |
|
131 | + $args = array( |
|
132 | + 'name' => $options['name'], |
|
133 | + 'shortcode' => $this->base_id, |
|
134 | + 'icon' => $options['block-icon'] ? $options['block-icon'] : 'far fa-square', |
|
135 | + 'allow_generator' => true, |
|
136 | + ); |
|
137 | + |
|
138 | + if ( ! empty( $params ) ) { |
|
139 | + $args['params'] = $params; |
|
140 | + } |
|
141 | + |
|
142 | + fusion_builder_map( $args ); |
|
143 | + } |
|
144 | + |
|
145 | + } |
|
146 | + |
|
147 | + public function get_fusion_params() { |
|
148 | + $params = array(); |
|
149 | + $arguments = $this->get_arguments(); |
|
150 | + |
|
151 | + if ( ! empty( $arguments ) ) { |
|
152 | + foreach ( $arguments as $key => $val ) { |
|
153 | + $param = array(); |
|
154 | + // type |
|
155 | + $param['type'] = str_replace( |
|
156 | + array( |
|
157 | + "text", |
|
158 | + "number", |
|
159 | + "email", |
|
160 | + "color", |
|
161 | + "checkbox" |
|
162 | + ), |
|
163 | + array( |
|
164 | + "textfield", |
|
165 | + "textfield", |
|
166 | + "textfield", |
|
167 | + "colorpicker", |
|
168 | + "select", |
|
169 | + |
|
170 | + ), |
|
171 | + $val['type'] ); |
|
172 | + |
|
173 | + // multiselect |
|
174 | + if ( $val['type'] == 'multiselect' || ( ( $param['type'] == 'select' || $val['type'] == 'select' ) && ! empty( $val['multiple'] ) ) ) { |
|
175 | + $param['type'] = 'multiple_select'; |
|
176 | + $param['multiple'] = true; |
|
177 | + } |
|
178 | + |
|
179 | + // heading |
|
180 | + $param['heading'] = $val['title']; |
|
181 | + |
|
182 | + // description |
|
183 | + $param['description'] = isset( $val['desc'] ) ? $val['desc'] : ''; |
|
184 | + |
|
185 | + // param_name |
|
186 | + $param['param_name'] = $key; |
|
187 | + |
|
188 | + // Default |
|
189 | + $param['default'] = isset( $val['default'] ) ? $val['default'] : ''; |
|
190 | + |
|
191 | + // Group |
|
192 | + if ( isset( $val['group'] ) ) { |
|
193 | + $param['group'] = $val['group']; |
|
194 | + } |
|
195 | + |
|
196 | + // value |
|
197 | + if ( $val['type'] == 'checkbox' ) { |
|
198 | + if ( isset( $val['default'] ) && $val['default'] == '0' ) { |
|
199 | + unset( $param['default'] ); |
|
200 | + } |
|
201 | + $param['value'] = array( '' => __( "No" ), '1' => __( "Yes" ) ); |
|
202 | + } elseif ( $param['type'] == 'select' || $param['type'] == 'multiple_select' ) { |
|
203 | + $param['value'] = isset( $val['options'] ) ? $val['options'] : array(); |
|
204 | + } else { |
|
205 | + $param['value'] = isset( $val['default'] ) ? $val['default'] : ''; |
|
206 | + } |
|
207 | + |
|
208 | + // setup the param |
|
209 | + $params[] = $param; |
|
210 | + |
|
211 | + } |
|
212 | + } |
|
213 | + |
|
214 | + |
|
215 | + return $params; |
|
216 | + } |
|
217 | + |
|
218 | + /** |
|
219 | + * Maybe insert the shortcode inserter button in the footer if we are in the cornerstone builder |
|
220 | + */ |
|
221 | + public static function maybe_cornerstone_builder() { |
|
222 | + if ( did_action( 'cornerstone_before_boot_app' ) ) { |
|
223 | + self::shortcode_insert_button_script(); |
|
224 | + } |
|
225 | + } |
|
226 | + |
|
227 | + /** |
|
228 | + * A function to ge the shortcode builder picker html. |
|
229 | + * |
|
230 | + * @param string $editor_id |
|
231 | + * |
|
232 | + * @return string |
|
233 | + */ |
|
234 | + public static function get_picker( $editor_id = '' ) { |
|
235 | + |
|
236 | + ob_start(); |
|
237 | + if ( isset( $_POST['editor_id'] ) ) { |
|
238 | + $editor_id = esc_attr( $_POST['editor_id'] ); |
|
239 | + } elseif ( isset( $_REQUEST['et_fb'] ) ) { |
|
240 | + $editor_id = 'main_content_content_vb_tiny_mce'; |
|
241 | + } |
|
242 | + |
|
243 | + global $sd_widgets; |
|
244 | + ?> |
|
245 | 245 | |
246 | 246 | <div class="sd-shortcode-left-wrap"> |
247 | 247 | <?php |
248 | - ksort( $sd_widgets ); |
|
249 | - // print_r($sd_widgets);exit; |
|
250 | - if ( ! empty( $sd_widgets ) ) { |
|
251 | - echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">'; |
|
252 | - echo "<option>" . __( 'Select shortcode' ) . "</option>"; |
|
253 | - foreach ( $sd_widgets as $shortcode => $class ) { |
|
254 | - echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>"; |
|
255 | - } |
|
256 | - echo "</select>"; |
|
257 | - |
|
258 | - } |
|
259 | - ?> |
|
248 | + ksort( $sd_widgets ); |
|
249 | + // print_r($sd_widgets);exit; |
|
250 | + if ( ! empty( $sd_widgets ) ) { |
|
251 | + echo '<select class="widefat" onchange="sd_get_shortcode_options(this);">'; |
|
252 | + echo "<option>" . __( 'Select shortcode' ) . "</option>"; |
|
253 | + foreach ( $sd_widgets as $shortcode => $class ) { |
|
254 | + echo "<option value='" . esc_attr( $shortcode ) . "'>" . esc_attr( $shortcode ) . " (" . esc_attr( $class['name'] ) . ")</option>"; |
|
255 | + } |
|
256 | + echo "</select>"; |
|
257 | + |
|
258 | + } |
|
259 | + ?> |
|
260 | 260 | <div class="sd-shortcode-settings"></div> |
261 | 261 | |
262 | 262 | </div> |
@@ -267,8 +267,8 @@ discard block |
||
267 | 267 | <?php if ( $editor_id != '' ) { ?> |
268 | 268 | <button class="button sd-insert-shortcode-button" |
269 | 269 | onclick="sd_insert_shortcode(<?php if ( ! empty( $editor_id ) ) { |
270 | - echo "'" . $editor_id . "'"; |
|
271 | - } ?>)"><?php _e( 'Insert shortcode' ); ?></button> |
|
270 | + echo "'" . $editor_id . "'"; |
|
271 | + } ?>)"><?php _e( 'Insert shortcode' ); ?></button> |
|
272 | 272 | <?php } ?> |
273 | 273 | <button class="button" |
274 | 274 | onclick="sd_copy_to_clipboard()"><?php _e( 'Copy shortcode' ); ?></button> |
@@ -276,134 +276,134 @@ discard block |
||
276 | 276 | </div> |
277 | 277 | <?php |
278 | 278 | |
279 | - $html = ob_get_clean(); |
|
280 | - |
|
281 | - if ( wp_doing_ajax() ) { |
|
282 | - echo $html; |
|
283 | - $should_die = true; |
|
284 | - |
|
285 | - // some builder get the editor via ajax so we should not die on those ocasions |
|
286 | - $dont_die = array( |
|
287 | - 'parent_tag',// WP Bakery |
|
288 | - 'avia_request' // enfold |
|
289 | - ); |
|
290 | - |
|
291 | - foreach ( $dont_die as $request ) { |
|
292 | - if ( isset( $_REQUEST[ $request ] ) ) { |
|
293 | - $should_die = false; |
|
294 | - } |
|
295 | - } |
|
296 | - |
|
297 | - if ( $should_die ) { |
|
298 | - wp_die(); |
|
299 | - } |
|
300 | - |
|
301 | - } else { |
|
302 | - return $html; |
|
303 | - } |
|
304 | - |
|
305 | - return ''; |
|
306 | - |
|
307 | - } |
|
308 | - |
|
309 | - /** |
|
310 | - * Output the version in the admin header. |
|
311 | - */ |
|
312 | - public function generator() { |
|
313 | - echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />'; |
|
314 | - } |
|
315 | - |
|
316 | - /** |
|
317 | - * Get widget settings. |
|
318 | - * |
|
319 | - * @since 1.0.0 |
|
320 | - */ |
|
321 | - public static function get_widget_settings() { |
|
322 | - global $sd_widgets; |
|
323 | - |
|
324 | - $shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : ''; |
|
325 | - if ( ! $shortcode ) { |
|
326 | - wp_die(); |
|
327 | - } |
|
328 | - $widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : ''; |
|
329 | - if ( ! $widget_args ) { |
|
330 | - wp_die(); |
|
331 | - } |
|
332 | - $class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : ''; |
|
333 | - if ( ! $class_name ) { |
|
334 | - wp_die(); |
|
335 | - } |
|
336 | - |
|
337 | - // invoke an instance method |
|
338 | - $widget = new $class_name; |
|
339 | - |
|
340 | - ob_start(); |
|
341 | - $widget->form( array() ); |
|
342 | - $form = ob_get_clean(); |
|
343 | - echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>"; |
|
344 | - echo "<style>" . $widget->widget_css() . "</style>"; |
|
345 | - echo "<script>" . $widget->widget_js() . "</script>"; |
|
346 | - ?> |
|
279 | + $html = ob_get_clean(); |
|
280 | + |
|
281 | + if ( wp_doing_ajax() ) { |
|
282 | + echo $html; |
|
283 | + $should_die = true; |
|
284 | + |
|
285 | + // some builder get the editor via ajax so we should not die on those ocasions |
|
286 | + $dont_die = array( |
|
287 | + 'parent_tag',// WP Bakery |
|
288 | + 'avia_request' // enfold |
|
289 | + ); |
|
290 | + |
|
291 | + foreach ( $dont_die as $request ) { |
|
292 | + if ( isset( $_REQUEST[ $request ] ) ) { |
|
293 | + $should_die = false; |
|
294 | + } |
|
295 | + } |
|
296 | + |
|
297 | + if ( $should_die ) { |
|
298 | + wp_die(); |
|
299 | + } |
|
300 | + |
|
301 | + } else { |
|
302 | + return $html; |
|
303 | + } |
|
304 | + |
|
305 | + return ''; |
|
306 | + |
|
307 | + } |
|
308 | + |
|
309 | + /** |
|
310 | + * Output the version in the admin header. |
|
311 | + */ |
|
312 | + public function generator() { |
|
313 | + echo '<meta name="generator" content="WP Super Duper v' . $this->version . '" />'; |
|
314 | + } |
|
315 | + |
|
316 | + /** |
|
317 | + * Get widget settings. |
|
318 | + * |
|
319 | + * @since 1.0.0 |
|
320 | + */ |
|
321 | + public static function get_widget_settings() { |
|
322 | + global $sd_widgets; |
|
323 | + |
|
324 | + $shortcode = isset( $_REQUEST['shortcode'] ) && $_REQUEST['shortcode'] ? sanitize_title_with_dashes( $_REQUEST['shortcode'] ) : ''; |
|
325 | + if ( ! $shortcode ) { |
|
326 | + wp_die(); |
|
327 | + } |
|
328 | + $widget_args = isset( $sd_widgets[ $shortcode ] ) ? $sd_widgets[ $shortcode ] : ''; |
|
329 | + if ( ! $widget_args ) { |
|
330 | + wp_die(); |
|
331 | + } |
|
332 | + $class_name = isset( $widget_args['class_name'] ) && $widget_args['class_name'] ? $widget_args['class_name'] : ''; |
|
333 | + if ( ! $class_name ) { |
|
334 | + wp_die(); |
|
335 | + } |
|
336 | + |
|
337 | + // invoke an instance method |
|
338 | + $widget = new $class_name; |
|
339 | + |
|
340 | + ob_start(); |
|
341 | + $widget->form( array() ); |
|
342 | + $form = ob_get_clean(); |
|
343 | + echo "<form id='$shortcode'>" . $form . "<div class=\"widget-control-save\"></div></form>"; |
|
344 | + echo "<style>" . $widget->widget_css() . "</style>"; |
|
345 | + echo "<script>" . $widget->widget_js() . "</script>"; |
|
346 | + ?> |
|
347 | 347 | <?php |
348 | - wp_die(); |
|
349 | - } |
|
350 | - |
|
351 | - /** |
|
352 | - * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed). |
|
353 | - * |
|
354 | - * @since 1.0.0 |
|
355 | - * |
|
356 | - * @param string $editor_id Optional. Shortcode editor id. Default null. |
|
357 | - * @param string $insert_shortcode_function Optional. Insert shotcode function. Default null. |
|
358 | - */ |
|
359 | - public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) { |
|
360 | - global $sd_widgets, $shortcode_insert_button_once; |
|
361 | - if ( $shortcode_insert_button_once ) { |
|
362 | - return; |
|
363 | - } |
|
364 | - add_thickbox(); |
|
365 | - |
|
366 | - |
|
367 | - /** |
|
368 | - * Cornerstone makes us play dirty tricks :/ |
|
369 | - * All media_buttons are removed via JS unless they are two specific id's so we wrap our content in this ID so it is not removed. |
|
370 | - */ |
|
371 | - if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) { |
|
372 | - echo '<span id="insert-media-button">'; |
|
373 | - } |
|
374 | - |
|
375 | - echo self::shortcode_button( 'this', 'true' ); |
|
376 | - |
|
377 | - // see opening note |
|
378 | - if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) { |
|
379 | - echo '</span>'; // end #insert-media-button |
|
380 | - } |
|
381 | - |
|
382 | - // Add separate script for generatepress theme sections |
|
383 | - if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) { |
|
384 | - } else { |
|
385 | - self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function ); |
|
386 | - } |
|
387 | - |
|
388 | - $shortcode_insert_button_once = true; |
|
389 | - } |
|
390 | - |
|
391 | - /** |
|
392 | - * Gets the shortcode insert button html. |
|
393 | - * |
|
394 | - * @param string $id |
|
395 | - * @param string $search_for_id |
|
396 | - * |
|
397 | - * @return mixed |
|
398 | - */ |
|
399 | - public static function shortcode_button( $id = '', $search_for_id = '' ) { |
|
400 | - ob_start(); |
|
401 | - ?> |
|
348 | + wp_die(); |
|
349 | + } |
|
350 | + |
|
351 | + /** |
|
352 | + * Insert shortcode builder button to classic editor (not inside Gutenberg, not needed). |
|
353 | + * |
|
354 | + * @since 1.0.0 |
|
355 | + * |
|
356 | + * @param string $editor_id Optional. Shortcode editor id. Default null. |
|
357 | + * @param string $insert_shortcode_function Optional. Insert shotcode function. Default null. |
|
358 | + */ |
|
359 | + public static function shortcode_insert_button( $editor_id = '', $insert_shortcode_function = '' ) { |
|
360 | + global $sd_widgets, $shortcode_insert_button_once; |
|
361 | + if ( $shortcode_insert_button_once ) { |
|
362 | + return; |
|
363 | + } |
|
364 | + add_thickbox(); |
|
365 | + |
|
366 | + |
|
367 | + /** |
|
368 | + * Cornerstone makes us play dirty tricks :/ |
|
369 | + * All media_buttons are removed via JS unless they are two specific id's so we wrap our content in this ID so it is not removed. |
|
370 | + */ |
|
371 | + if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) { |
|
372 | + echo '<span id="insert-media-button">'; |
|
373 | + } |
|
374 | + |
|
375 | + echo self::shortcode_button( 'this', 'true' ); |
|
376 | + |
|
377 | + // see opening note |
|
378 | + if ( function_exists( 'cornerstone_plugin_init' ) && ! is_admin() ) { |
|
379 | + echo '</span>'; // end #insert-media-button |
|
380 | + } |
|
381 | + |
|
382 | + // Add separate script for generatepress theme sections |
|
383 | + if ( function_exists( 'generate_sections_sections_metabox' ) && did_action( 'generate_sections_metabox' ) ) { |
|
384 | + } else { |
|
385 | + self::shortcode_insert_button_script( $editor_id, $insert_shortcode_function ); |
|
386 | + } |
|
387 | + |
|
388 | + $shortcode_insert_button_once = true; |
|
389 | + } |
|
390 | + |
|
391 | + /** |
|
392 | + * Gets the shortcode insert button html. |
|
393 | + * |
|
394 | + * @param string $id |
|
395 | + * @param string $search_for_id |
|
396 | + * |
|
397 | + * @return mixed |
|
398 | + */ |
|
399 | + public static function shortcode_button( $id = '', $search_for_id = '' ) { |
|
400 | + ob_start(); |
|
401 | + ?> |
|
402 | 402 | <span class="sd-lable-shortcode-inserter"> |
403 | 403 | <a onclick="sd_ajax_get_picker(<?php echo $id; |
404 | - if ( $search_for_id ) { |
|
405 | - echo "," . $search_for_id; |
|
406 | - } ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed" |
|
404 | + if ( $search_for_id ) { |
|
405 | + echo "," . $search_for_id; |
|
406 | + } ?>);" href="#TB_inline?width=100%&height=550&inlineId=super-duper-content-ajaxed" |
|
407 | 407 | class="thickbox button super-duper-content-open" title="Add Shortcode"> |
408 | 408 | <span style="vertical-align: middle;line-height: 18px;font-size: 20px;" |
409 | 409 | class="dashicons dashicons-screenoptions"></span> |
@@ -414,21 +414,21 @@ discard block |
||
414 | 414 | </span> |
415 | 415 | |
416 | 416 | <?php |
417 | - $html = ob_get_clean(); |
|
418 | - |
|
419 | - // remove line breaks so we can use it in js |
|
420 | - return preg_replace( "/\r|\n/", "", trim( $html ) ); |
|
421 | - } |
|
422 | - |
|
423 | - /** |
|
424 | - * Makes SD work with the siteOrigin page builder. |
|
425 | - * |
|
426 | - * @since 1.0.6 |
|
427 | - * @return mixed |
|
428 | - */ |
|
429 | - public static function siteorigin_js() { |
|
430 | - ob_start(); |
|
431 | - ?> |
|
417 | + $html = ob_get_clean(); |
|
418 | + |
|
419 | + // remove line breaks so we can use it in js |
|
420 | + return preg_replace( "/\r|\n/", "", trim( $html ) ); |
|
421 | + } |
|
422 | + |
|
423 | + /** |
|
424 | + * Makes SD work with the siteOrigin page builder. |
|
425 | + * |
|
426 | + * @since 1.0.6 |
|
427 | + * @return mixed |
|
428 | + */ |
|
429 | + public static function siteorigin_js() { |
|
430 | + ob_start(); |
|
431 | + ?> |
|
432 | 432 | <script> |
433 | 433 | /** |
434 | 434 | * Check a form to see what items shoudl be shown or hidden. |
@@ -506,28 +506,28 @@ discard block |
||
506 | 506 | }); |
507 | 507 | </script> |
508 | 508 | <?php |
509 | - $output = ob_get_clean(); |
|
509 | + $output = ob_get_clean(); |
|
510 | 510 | |
511 | - /* |
|
511 | + /* |
|
512 | 512 | * We only add the <script> tags for code highlighting, so we strip them from the output. |
513 | 513 | */ |
514 | 514 | |
515 | - return str_replace( array( |
|
516 | - '<script>', |
|
517 | - '</script>' |
|
518 | - ), '', $output ); |
|
519 | - } |
|
520 | - |
|
521 | - /** |
|
522 | - * Output the JS and CSS for the shortcode insert button. |
|
523 | - * |
|
524 | - * @since 1.0.6 |
|
525 | - * |
|
526 | - * @param string $editor_id |
|
527 | - * @param string $insert_shortcode_function |
|
528 | - */ |
|
529 | - public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) { |
|
530 | - ?> |
|
515 | + return str_replace( array( |
|
516 | + '<script>', |
|
517 | + '</script>' |
|
518 | + ), '', $output ); |
|
519 | + } |
|
520 | + |
|
521 | + /** |
|
522 | + * Output the JS and CSS for the shortcode insert button. |
|
523 | + * |
|
524 | + * @since 1.0.6 |
|
525 | + * |
|
526 | + * @param string $editor_id |
|
527 | + * @param string $insert_shortcode_function |
|
528 | + */ |
|
529 | + public static function shortcode_insert_button_script( $editor_id = '', $insert_shortcode_function = '' ) { |
|
530 | + ?> |
|
531 | 531 | <style> |
532 | 532 | .sd-shortcode-left-wrap { |
533 | 533 | float: left; |
@@ -653,35 +653,35 @@ discard block |
||
653 | 653 | <?php } ?> |
654 | 654 | </style> |
655 | 655 | <?php |
656 | - if ( class_exists( 'SiteOrigin_Panels' ) ) { |
|
657 | - echo "<script>" . self::siteorigin_js() . "</script>"; |
|
658 | - } |
|
659 | - ?> |
|
656 | + if ( class_exists( 'SiteOrigin_Panels' ) ) { |
|
657 | + echo "<script>" . self::siteorigin_js() . "</script>"; |
|
658 | + } |
|
659 | + ?> |
|
660 | 660 | <script> |
661 | 661 | <?php |
662 | - if(! empty( $insert_shortcode_function )){ |
|
663 | - echo $insert_shortcode_function; |
|
664 | - }else{ |
|
665 | - |
|
666 | - /** |
|
667 | - * Function for super duper insert shortcode. |
|
668 | - * |
|
669 | - * @since 1.0.0 |
|
670 | - */ |
|
671 | - ?> |
|
662 | + if(! empty( $insert_shortcode_function )){ |
|
663 | + echo $insert_shortcode_function; |
|
664 | + }else{ |
|
665 | + |
|
666 | + /** |
|
667 | + * Function for super duper insert shortcode. |
|
668 | + * |
|
669 | + * @since 1.0.0 |
|
670 | + */ |
|
671 | + ?> |
|
672 | 672 | function sd_insert_shortcode($editor_id) { |
673 | 673 | $shortcode = jQuery('#TB_ajaxContent #sd-shortcode-output').val(); |
674 | 674 | if ($shortcode) { |
675 | 675 | if (!$editor_id) { |
676 | 676 | <?php |
677 | - if ( isset( $_REQUEST['et_fb'] ) ) { |
|
678 | - echo '$editor_id = "#main_content_content_vb_tiny_mce";'; |
|
679 | - } elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) { |
|
680 | - echo '$editor_id = "#elementor-controls .wp-editor-container textarea";'; |
|
681 | - } else { |
|
682 | - echo '$editor_id = "#wp-content-editor-container textarea";'; |
|
683 | - } |
|
684 | - ?> |
|
677 | + if ( isset( $_REQUEST['et_fb'] ) ) { |
|
678 | + echo '$editor_id = "#main_content_content_vb_tiny_mce";'; |
|
679 | + } elseif ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) { |
|
680 | + echo '$editor_id = "#elementor-controls .wp-editor-container textarea";'; |
|
681 | + } else { |
|
682 | + echo '$editor_id = "#wp-content-editor-container textarea";'; |
|
683 | + } |
|
684 | + ?> |
|
685 | 685 | } else { |
686 | 686 | $editor_id = '#' + $editor_id; |
687 | 687 | } |
@@ -1007,18 +1007,18 @@ discard block |
||
1007 | 1007 | |
1008 | 1008 | </script> |
1009 | 1009 | <?php |
1010 | - } |
|
1011 | - |
|
1012 | - /** |
|
1013 | - * Gets some CSS for the widgets screen. |
|
1014 | - * |
|
1015 | - * @param bool $advanced If we should include advanced CSS. |
|
1016 | - * |
|
1017 | - * @return mixed |
|
1018 | - */ |
|
1019 | - public function widget_css( $advanced = true ) { |
|
1020 | - ob_start(); |
|
1021 | - ?> |
|
1010 | + } |
|
1011 | + |
|
1012 | + /** |
|
1013 | + * Gets some CSS for the widgets screen. |
|
1014 | + * |
|
1015 | + * @param bool $advanced If we should include advanced CSS. |
|
1016 | + * |
|
1017 | + * @return mixed |
|
1018 | + */ |
|
1019 | + public function widget_css( $advanced = true ) { |
|
1020 | + ob_start(); |
|
1021 | + ?> |
|
1022 | 1022 | <style> |
1023 | 1023 | <?php if( $advanced ){ ?> |
1024 | 1024 | .sd-advanced-setting { |
@@ -1056,26 +1056,26 @@ discard block |
||
1056 | 1056 | } |
1057 | 1057 | </style> |
1058 | 1058 | <?php |
1059 | - $output = ob_get_clean(); |
|
1059 | + $output = ob_get_clean(); |
|
1060 | 1060 | |
1061 | - /* |
|
1061 | + /* |
|
1062 | 1062 | * We only add the <script> tags for code highlighting, so we strip them from the output. |
1063 | 1063 | */ |
1064 | 1064 | |
1065 | - return str_replace( array( |
|
1066 | - '<style>', |
|
1067 | - '</style>' |
|
1068 | - ), '', $output ); |
|
1069 | - } |
|
1070 | - |
|
1071 | - /** |
|
1072 | - * Gets some JS for the widgets screen. |
|
1073 | - * |
|
1074 | - * @return mixed |
|
1075 | - */ |
|
1076 | - public function widget_js() { |
|
1077 | - ob_start(); |
|
1078 | - ?> |
|
1065 | + return str_replace( array( |
|
1066 | + '<style>', |
|
1067 | + '</style>' |
|
1068 | + ), '', $output ); |
|
1069 | + } |
|
1070 | + |
|
1071 | + /** |
|
1072 | + * Gets some JS for the widgets screen. |
|
1073 | + * |
|
1074 | + * @return mixed |
|
1075 | + */ |
|
1076 | + public function widget_js() { |
|
1077 | + ob_start(); |
|
1078 | + ?> |
|
1079 | 1079 | <script> |
1080 | 1080 | |
1081 | 1081 | /** |
@@ -1230,402 +1230,402 @@ discard block |
||
1230 | 1230 | <?php do_action( 'wp_super_duper_widget_js', $this ); ?> |
1231 | 1231 | </script> |
1232 | 1232 | <?php |
1233 | - $output = ob_get_clean(); |
|
1233 | + $output = ob_get_clean(); |
|
1234 | 1234 | |
1235 | - /* |
|
1235 | + /* |
|
1236 | 1236 | * We only add the <script> tags for code highlighting, so we strip them from the output. |
1237 | 1237 | */ |
1238 | 1238 | |
1239 | - return str_replace( array( |
|
1240 | - '<script>', |
|
1241 | - '</script>' |
|
1242 | - ), '', $output ); |
|
1243 | - } |
|
1244 | - |
|
1245 | - |
|
1246 | - /** |
|
1247 | - * Set the name from the argument key. |
|
1248 | - * |
|
1249 | - * @param $options |
|
1250 | - * |
|
1251 | - * @return mixed |
|
1252 | - */ |
|
1253 | - private function add_name_from_key( $options, $arguments = false ) { |
|
1254 | - if ( ! empty( $options['arguments'] ) ) { |
|
1255 | - foreach ( $options['arguments'] as $key => $val ) { |
|
1256 | - $options['arguments'][ $key ]['name'] = $key; |
|
1257 | - } |
|
1258 | - } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) { |
|
1259 | - foreach ( $options as $key => $val ) { |
|
1260 | - $options[ $key ]['name'] = $key; |
|
1261 | - } |
|
1262 | - } |
|
1263 | - |
|
1264 | - return $options; |
|
1265 | - } |
|
1266 | - |
|
1267 | - /** |
|
1268 | - * Register the parent shortcode. |
|
1269 | - * |
|
1270 | - * @since 1.0.0 |
|
1271 | - */ |
|
1272 | - public function register_shortcode() { |
|
1273 | - add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) ); |
|
1274 | - add_action( 'wp_ajax_super_duper_output_shortcode', array( __CLASS__, 'render_shortcode' ) ); |
|
1275 | - } |
|
1276 | - |
|
1277 | - /** |
|
1278 | - * Render the shortcode via ajax so we can return it to Gutenberg. |
|
1279 | - * |
|
1280 | - * @since 1.0.0 |
|
1281 | - */ |
|
1282 | - public static function render_shortcode() { |
|
1283 | - |
|
1284 | - check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true ); |
|
1285 | - if ( ! current_user_can( 'manage_options' ) ) { |
|
1286 | - wp_die(); |
|
1287 | - } |
|
1288 | - |
|
1289 | - // we might need the $post value here so lets set it. |
|
1290 | - if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) { |
|
1291 | - $post_obj = get_post( absint( $_POST['post_id'] ) ); |
|
1292 | - if ( ! empty( $post_obj ) && empty( $post ) ) { |
|
1293 | - global $post; |
|
1294 | - $post = $post_obj; |
|
1295 | - } |
|
1296 | - } |
|
1297 | - |
|
1298 | - if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) { |
|
1299 | - $shortcode_name = sanitize_title_with_dashes( $_POST['shortcode'] ); |
|
1300 | - $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array(); |
|
1301 | - $attributes = ''; |
|
1302 | - if ( ! empty( $attributes_array ) ) { |
|
1303 | - foreach ( $attributes_array as $key => $value ) { |
|
1304 | - $attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . wp_slash( $value ) . "' "; |
|
1305 | - } |
|
1306 | - } |
|
1307 | - |
|
1308 | - $shortcode = "[" . $shortcode_name . " " . $attributes . "]"; |
|
1309 | - |
|
1310 | - echo do_shortcode( $shortcode ); |
|
1311 | - |
|
1312 | - } |
|
1313 | - wp_die(); |
|
1314 | - } |
|
1315 | - |
|
1316 | - /** |
|
1317 | - * Output the shortcode. |
|
1318 | - * |
|
1319 | - * @param array $args |
|
1320 | - * @param string $content |
|
1321 | - * |
|
1322 | - * @return string |
|
1323 | - */ |
|
1324 | - public function shortcode_output( $args = array(), $content = '' ) { |
|
1325 | - $args = $this->argument_values( $args ); |
|
1326 | - |
|
1327 | - // add extra argument so we know its a output to gutenberg |
|
1328 | - //$args |
|
1329 | - $args = $this->string_to_bool( $args ); |
|
1330 | - |
|
1331 | - // if we have a enclosed shortcode we add it to the special `html` argument |
|
1332 | - if ( ! empty( $content ) ) { |
|
1333 | - $args['html'] = $content; |
|
1334 | - } |
|
1335 | - |
|
1336 | - $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : ''; |
|
1337 | - $class .= " sdel-".$this->get_instance_hash(); |
|
1338 | - |
|
1339 | - $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this ); |
|
1340 | - $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this ); |
|
1341 | - |
|
1342 | - $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this ); |
|
1343 | - $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this ); //@todo this does not seem right @kiran? |
|
1344 | - |
|
1345 | - $shortcode_args = array(); |
|
1346 | - $output = ''; |
|
1347 | - $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false; |
|
1348 | - if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) { |
|
1349 | - $no_wrap = true; |
|
1350 | - } |
|
1351 | - $main_content = $this->output( $args, $shortcode_args, $content ); |
|
1352 | - if ( $main_content && ! $no_wrap ) { |
|
1353 | - // wrap the shortcode in a div with the same class as the widget |
|
1354 | - $output .= '<div class="' . $class . '" ' . $attrs . '>'; |
|
1355 | - if ( ! empty( $args['title'] ) ) { |
|
1356 | - // if its a shortcode and there is a title try to grab the title wrappers |
|
1357 | - $shortcode_args = array( 'before_title' => '', 'after_title' => '' ); |
|
1358 | - if ( empty( $instance ) ) { |
|
1359 | - global $wp_registered_sidebars; |
|
1360 | - if ( ! empty( $wp_registered_sidebars ) ) { |
|
1361 | - foreach ( $wp_registered_sidebars as $sidebar ) { |
|
1362 | - if ( ! empty( $sidebar['before_title'] ) ) { |
|
1363 | - $shortcode_args['before_title'] = $sidebar['before_title']; |
|
1364 | - $shortcode_args['after_title'] = $sidebar['after_title']; |
|
1365 | - break; |
|
1366 | - } |
|
1367 | - } |
|
1368 | - } |
|
1369 | - } |
|
1370 | - $output .= $this->output_title( $shortcode_args, $args ); |
|
1371 | - } |
|
1372 | - $output .= $main_content; |
|
1373 | - $output .= '</div>'; |
|
1374 | - } elseif ( $main_content && $no_wrap ) { |
|
1375 | - $output .= $main_content; |
|
1376 | - } |
|
1377 | - |
|
1378 | - // if preview show a placeholder if empty |
|
1379 | - if ( $this->is_preview() && $output == '' ) { |
|
1380 | - $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" ); |
|
1381 | - } |
|
1382 | - |
|
1383 | - return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this ); |
|
1384 | - } |
|
1385 | - |
|
1386 | - /** |
|
1387 | - * Placeholder text to show if output is empty and we are on a preview/builder page. |
|
1388 | - * |
|
1389 | - * @param string $name |
|
1390 | - * |
|
1391 | - * @return string |
|
1392 | - */ |
|
1393 | - public function preview_placeholder_text( $name = '' ) { |
|
1394 | - return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>"; |
|
1395 | - } |
|
1396 | - |
|
1397 | - /** |
|
1398 | - * Sometimes booleans values can be turned to strings, so we fix that. |
|
1399 | - * |
|
1400 | - * @param $options |
|
1401 | - * |
|
1402 | - * @return mixed |
|
1403 | - */ |
|
1404 | - public function string_to_bool( $options ) { |
|
1405 | - // convert bool strings to booleans |
|
1406 | - foreach ( $options as $key => $val ) { |
|
1407 | - if ( $val == 'false' ) { |
|
1408 | - $options[ $key ] = false; |
|
1409 | - } elseif ( $val == 'true' ) { |
|
1410 | - $options[ $key ] = true; |
|
1411 | - } |
|
1412 | - } |
|
1413 | - |
|
1414 | - return $options; |
|
1415 | - } |
|
1416 | - |
|
1417 | - /** |
|
1418 | - * Get the argument values that are also filterable. |
|
1419 | - * |
|
1420 | - * @param $instance |
|
1421 | - * |
|
1422 | - * @since 1.0.12 Don't set checkbox default value if the value is empty. |
|
1423 | - * |
|
1424 | - * @return array |
|
1425 | - */ |
|
1426 | - public function argument_values( $instance ) { |
|
1427 | - $argument_values = array(); |
|
1428 | - |
|
1429 | - // set widget instance |
|
1430 | - $this->instance = $instance; |
|
1431 | - |
|
1432 | - if ( empty( $this->arguments ) ) { |
|
1433 | - $this->arguments = $this->get_arguments(); |
|
1434 | - } |
|
1435 | - |
|
1436 | - if ( ! empty( $this->arguments ) ) { |
|
1437 | - foreach ( $this->arguments as $key => $args ) { |
|
1438 | - // set the input name from the key |
|
1439 | - $args['name'] = $key; |
|
1440 | - // |
|
1441 | - $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : ''; |
|
1442 | - if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) { |
|
1443 | - // don't set default for an empty checkbox |
|
1444 | - } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) { |
|
1445 | - $argument_values[ $key ] = $args['default']; |
|
1446 | - } |
|
1447 | - } |
|
1448 | - } |
|
1449 | - |
|
1450 | - return $argument_values; |
|
1451 | - } |
|
1452 | - |
|
1453 | - /** |
|
1454 | - * Set arguments in super duper. |
|
1455 | - * |
|
1456 | - * @since 1.0.0 |
|
1457 | - * |
|
1458 | - * @return array Set arguments. |
|
1459 | - */ |
|
1460 | - public function set_arguments() { |
|
1461 | - return $this->arguments; |
|
1462 | - } |
|
1463 | - |
|
1464 | - /** |
|
1465 | - * Get arguments in super duper. |
|
1466 | - * |
|
1467 | - * @since 1.0.0 |
|
1468 | - * |
|
1469 | - * @return array Get arguments. |
|
1470 | - */ |
|
1471 | - public function get_arguments() { |
|
1472 | - if ( empty( $this->arguments ) ) { |
|
1473 | - $this->arguments = $this->set_arguments(); |
|
1474 | - } |
|
1475 | - |
|
1476 | - $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance ); |
|
1477 | - $this->arguments = $this->add_name_from_key( $this->arguments, true ); |
|
1478 | - |
|
1479 | - return $this->arguments; |
|
1480 | - } |
|
1481 | - |
|
1482 | - /** |
|
1483 | - * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class. |
|
1484 | - * |
|
1485 | - * @param array $args |
|
1486 | - * @param array $widget_args |
|
1487 | - * @param string $content |
|
1488 | - */ |
|
1489 | - public function output( $args = array(), $widget_args = array(), $content = '' ) { |
|
1490 | - |
|
1491 | - } |
|
1492 | - |
|
1493 | - /** |
|
1494 | - * Add the dynamic block code inline when the wp-block in enqueued. |
|
1495 | - */ |
|
1496 | - public function register_block() { |
|
1497 | - wp_add_inline_script( 'wp-blocks', $this->block() ); |
|
1498 | - if ( class_exists( 'SiteOrigin_Panels' ) ) { |
|
1499 | - wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() ); |
|
1500 | - } |
|
1501 | - } |
|
1502 | - |
|
1503 | - /** |
|
1504 | - * Check if we need to show advanced options. |
|
1505 | - * |
|
1506 | - * @return bool |
|
1507 | - */ |
|
1508 | - public function block_show_advanced() { |
|
1509 | - |
|
1510 | - $show = false; |
|
1511 | - $arguments = $this->arguments; |
|
1512 | - |
|
1513 | - if ( empty( $arguments ) ) { |
|
1514 | - $arguments = $this->get_arguments(); |
|
1515 | - } |
|
1516 | - |
|
1517 | - if ( ! empty( $arguments ) ) { |
|
1518 | - foreach ( $arguments as $argument ) { |
|
1519 | - if ( isset( $argument['advanced'] ) && $argument['advanced'] ) { |
|
1520 | - $show = true; |
|
1521 | - break; // no need to continue if we know we have it |
|
1522 | - } |
|
1523 | - } |
|
1524 | - } |
|
1525 | - |
|
1526 | - return $show; |
|
1527 | - } |
|
1528 | - |
|
1529 | - /** |
|
1530 | - * Get the url path to the current folder. |
|
1531 | - * |
|
1532 | - * @return string |
|
1533 | - */ |
|
1534 | - public function get_url() { |
|
1535 | - |
|
1536 | - $url = $this->url; |
|
1537 | - |
|
1538 | - if ( ! $url ) { |
|
1539 | - // check if we are inside a plugin |
|
1540 | - $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) ); |
|
1541 | - |
|
1542 | - $dir_parts = explode( "/wp-content/", $file_dir ); |
|
1543 | - $url_parts = explode( "/wp-content/", plugins_url() ); |
|
1544 | - |
|
1545 | - if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) { |
|
1546 | - $url = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] ); |
|
1547 | - $this->url = $url; |
|
1548 | - } |
|
1549 | - } |
|
1550 | - |
|
1551 | - |
|
1552 | - return $url; |
|
1553 | - } |
|
1554 | - |
|
1555 | - /** |
|
1556 | - * Generate the block icon. |
|
1557 | - * |
|
1558 | - * Enables the use of Font Awesome icons. |
|
1559 | - * |
|
1560 | - * @note xlink:href is actually deprecated but href is not supported by all so we use both. |
|
1561 | - * |
|
1562 | - * @param $icon |
|
1563 | - * |
|
1564 | - * @since 1.1.0 |
|
1565 | - * @return string |
|
1566 | - */ |
|
1567 | - public function get_block_icon( $icon ) { |
|
1568 | - |
|
1569 | - // check if we have a Font Awesome icon |
|
1570 | - $fa_type = ''; |
|
1571 | - if ( substr( $icon, 0, 7 ) === "fas fa-" ) { |
|
1572 | - $fa_type = 'solid'; |
|
1573 | - } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) { |
|
1574 | - $fa_type = 'regular'; |
|
1575 | - } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) { |
|
1576 | - $fa_type = 'brands'; |
|
1577 | - } else { |
|
1578 | - $icon = "'" . $icon . "'"; |
|
1579 | - } |
|
1580 | - |
|
1581 | - // set the icon if we found one |
|
1582 | - if ( $fa_type ) { |
|
1583 | - $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon ); |
|
1584 | - $icon = "el('svg',{width: 20, height: 20, viewBox: '0 0 20 20'},el('use', {'xlink:href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "','href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "'}))"; |
|
1585 | - } |
|
1586 | - |
|
1587 | - return $icon; |
|
1588 | - } |
|
1589 | - |
|
1590 | - public function group_arguments( $arguments ) { |
|
1239 | + return str_replace( array( |
|
1240 | + '<script>', |
|
1241 | + '</script>' |
|
1242 | + ), '', $output ); |
|
1243 | + } |
|
1244 | + |
|
1245 | + |
|
1246 | + /** |
|
1247 | + * Set the name from the argument key. |
|
1248 | + * |
|
1249 | + * @param $options |
|
1250 | + * |
|
1251 | + * @return mixed |
|
1252 | + */ |
|
1253 | + private function add_name_from_key( $options, $arguments = false ) { |
|
1254 | + if ( ! empty( $options['arguments'] ) ) { |
|
1255 | + foreach ( $options['arguments'] as $key => $val ) { |
|
1256 | + $options['arguments'][ $key ]['name'] = $key; |
|
1257 | + } |
|
1258 | + } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) { |
|
1259 | + foreach ( $options as $key => $val ) { |
|
1260 | + $options[ $key ]['name'] = $key; |
|
1261 | + } |
|
1262 | + } |
|
1263 | + |
|
1264 | + return $options; |
|
1265 | + } |
|
1266 | + |
|
1267 | + /** |
|
1268 | + * Register the parent shortcode. |
|
1269 | + * |
|
1270 | + * @since 1.0.0 |
|
1271 | + */ |
|
1272 | + public function register_shortcode() { |
|
1273 | + add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) ); |
|
1274 | + add_action( 'wp_ajax_super_duper_output_shortcode', array( __CLASS__, 'render_shortcode' ) ); |
|
1275 | + } |
|
1276 | + |
|
1277 | + /** |
|
1278 | + * Render the shortcode via ajax so we can return it to Gutenberg. |
|
1279 | + * |
|
1280 | + * @since 1.0.0 |
|
1281 | + */ |
|
1282 | + public static function render_shortcode() { |
|
1283 | + |
|
1284 | + check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true ); |
|
1285 | + if ( ! current_user_can( 'manage_options' ) ) { |
|
1286 | + wp_die(); |
|
1287 | + } |
|
1288 | + |
|
1289 | + // we might need the $post value here so lets set it. |
|
1290 | + if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) { |
|
1291 | + $post_obj = get_post( absint( $_POST['post_id'] ) ); |
|
1292 | + if ( ! empty( $post_obj ) && empty( $post ) ) { |
|
1293 | + global $post; |
|
1294 | + $post = $post_obj; |
|
1295 | + } |
|
1296 | + } |
|
1297 | + |
|
1298 | + if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) { |
|
1299 | + $shortcode_name = sanitize_title_with_dashes( $_POST['shortcode'] ); |
|
1300 | + $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array(); |
|
1301 | + $attributes = ''; |
|
1302 | + if ( ! empty( $attributes_array ) ) { |
|
1303 | + foreach ( $attributes_array as $key => $value ) { |
|
1304 | + $attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . wp_slash( $value ) . "' "; |
|
1305 | + } |
|
1306 | + } |
|
1307 | + |
|
1308 | + $shortcode = "[" . $shortcode_name . " " . $attributes . "]"; |
|
1309 | + |
|
1310 | + echo do_shortcode( $shortcode ); |
|
1311 | + |
|
1312 | + } |
|
1313 | + wp_die(); |
|
1314 | + } |
|
1315 | + |
|
1316 | + /** |
|
1317 | + * Output the shortcode. |
|
1318 | + * |
|
1319 | + * @param array $args |
|
1320 | + * @param string $content |
|
1321 | + * |
|
1322 | + * @return string |
|
1323 | + */ |
|
1324 | + public function shortcode_output( $args = array(), $content = '' ) { |
|
1325 | + $args = $this->argument_values( $args ); |
|
1326 | + |
|
1327 | + // add extra argument so we know its a output to gutenberg |
|
1328 | + //$args |
|
1329 | + $args = $this->string_to_bool( $args ); |
|
1330 | + |
|
1331 | + // if we have a enclosed shortcode we add it to the special `html` argument |
|
1332 | + if ( ! empty( $content ) ) { |
|
1333 | + $args['html'] = $content; |
|
1334 | + } |
|
1335 | + |
|
1336 | + $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : ''; |
|
1337 | + $class .= " sdel-".$this->get_instance_hash(); |
|
1338 | + |
|
1339 | + $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this ); |
|
1340 | + $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this ); |
|
1341 | + |
|
1342 | + $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this ); |
|
1343 | + $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this ); //@todo this does not seem right @kiran? |
|
1344 | + |
|
1345 | + $shortcode_args = array(); |
|
1346 | + $output = ''; |
|
1347 | + $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false; |
|
1348 | + if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) { |
|
1349 | + $no_wrap = true; |
|
1350 | + } |
|
1351 | + $main_content = $this->output( $args, $shortcode_args, $content ); |
|
1352 | + if ( $main_content && ! $no_wrap ) { |
|
1353 | + // wrap the shortcode in a div with the same class as the widget |
|
1354 | + $output .= '<div class="' . $class . '" ' . $attrs . '>'; |
|
1355 | + if ( ! empty( $args['title'] ) ) { |
|
1356 | + // if its a shortcode and there is a title try to grab the title wrappers |
|
1357 | + $shortcode_args = array( 'before_title' => '', 'after_title' => '' ); |
|
1358 | + if ( empty( $instance ) ) { |
|
1359 | + global $wp_registered_sidebars; |
|
1360 | + if ( ! empty( $wp_registered_sidebars ) ) { |
|
1361 | + foreach ( $wp_registered_sidebars as $sidebar ) { |
|
1362 | + if ( ! empty( $sidebar['before_title'] ) ) { |
|
1363 | + $shortcode_args['before_title'] = $sidebar['before_title']; |
|
1364 | + $shortcode_args['after_title'] = $sidebar['after_title']; |
|
1365 | + break; |
|
1366 | + } |
|
1367 | + } |
|
1368 | + } |
|
1369 | + } |
|
1370 | + $output .= $this->output_title( $shortcode_args, $args ); |
|
1371 | + } |
|
1372 | + $output .= $main_content; |
|
1373 | + $output .= '</div>'; |
|
1374 | + } elseif ( $main_content && $no_wrap ) { |
|
1375 | + $output .= $main_content; |
|
1376 | + } |
|
1377 | + |
|
1378 | + // if preview show a placeholder if empty |
|
1379 | + if ( $this->is_preview() && $output == '' ) { |
|
1380 | + $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" ); |
|
1381 | + } |
|
1382 | + |
|
1383 | + return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this ); |
|
1384 | + } |
|
1385 | + |
|
1386 | + /** |
|
1387 | + * Placeholder text to show if output is empty and we are on a preview/builder page. |
|
1388 | + * |
|
1389 | + * @param string $name |
|
1390 | + * |
|
1391 | + * @return string |
|
1392 | + */ |
|
1393 | + public function preview_placeholder_text( $name = '' ) { |
|
1394 | + return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>"; |
|
1395 | + } |
|
1396 | + |
|
1397 | + /** |
|
1398 | + * Sometimes booleans values can be turned to strings, so we fix that. |
|
1399 | + * |
|
1400 | + * @param $options |
|
1401 | + * |
|
1402 | + * @return mixed |
|
1403 | + */ |
|
1404 | + public function string_to_bool( $options ) { |
|
1405 | + // convert bool strings to booleans |
|
1406 | + foreach ( $options as $key => $val ) { |
|
1407 | + if ( $val == 'false' ) { |
|
1408 | + $options[ $key ] = false; |
|
1409 | + } elseif ( $val == 'true' ) { |
|
1410 | + $options[ $key ] = true; |
|
1411 | + } |
|
1412 | + } |
|
1413 | + |
|
1414 | + return $options; |
|
1415 | + } |
|
1416 | + |
|
1417 | + /** |
|
1418 | + * Get the argument values that are also filterable. |
|
1419 | + * |
|
1420 | + * @param $instance |
|
1421 | + * |
|
1422 | + * @since 1.0.12 Don't set checkbox default value if the value is empty. |
|
1423 | + * |
|
1424 | + * @return array |
|
1425 | + */ |
|
1426 | + public function argument_values( $instance ) { |
|
1427 | + $argument_values = array(); |
|
1428 | + |
|
1429 | + // set widget instance |
|
1430 | + $this->instance = $instance; |
|
1431 | + |
|
1432 | + if ( empty( $this->arguments ) ) { |
|
1433 | + $this->arguments = $this->get_arguments(); |
|
1434 | + } |
|
1435 | + |
|
1436 | + if ( ! empty( $this->arguments ) ) { |
|
1437 | + foreach ( $this->arguments as $key => $args ) { |
|
1438 | + // set the input name from the key |
|
1439 | + $args['name'] = $key; |
|
1440 | + // |
|
1441 | + $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : ''; |
|
1442 | + if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) { |
|
1443 | + // don't set default for an empty checkbox |
|
1444 | + } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) { |
|
1445 | + $argument_values[ $key ] = $args['default']; |
|
1446 | + } |
|
1447 | + } |
|
1448 | + } |
|
1449 | + |
|
1450 | + return $argument_values; |
|
1451 | + } |
|
1452 | + |
|
1453 | + /** |
|
1454 | + * Set arguments in super duper. |
|
1455 | + * |
|
1456 | + * @since 1.0.0 |
|
1457 | + * |
|
1458 | + * @return array Set arguments. |
|
1459 | + */ |
|
1460 | + public function set_arguments() { |
|
1461 | + return $this->arguments; |
|
1462 | + } |
|
1463 | + |
|
1464 | + /** |
|
1465 | + * Get arguments in super duper. |
|
1466 | + * |
|
1467 | + * @since 1.0.0 |
|
1468 | + * |
|
1469 | + * @return array Get arguments. |
|
1470 | + */ |
|
1471 | + public function get_arguments() { |
|
1472 | + if ( empty( $this->arguments ) ) { |
|
1473 | + $this->arguments = $this->set_arguments(); |
|
1474 | + } |
|
1475 | + |
|
1476 | + $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance ); |
|
1477 | + $this->arguments = $this->add_name_from_key( $this->arguments, true ); |
|
1478 | + |
|
1479 | + return $this->arguments; |
|
1480 | + } |
|
1481 | + |
|
1482 | + /** |
|
1483 | + * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class. |
|
1484 | + * |
|
1485 | + * @param array $args |
|
1486 | + * @param array $widget_args |
|
1487 | + * @param string $content |
|
1488 | + */ |
|
1489 | + public function output( $args = array(), $widget_args = array(), $content = '' ) { |
|
1490 | + |
|
1491 | + } |
|
1492 | + |
|
1493 | + /** |
|
1494 | + * Add the dynamic block code inline when the wp-block in enqueued. |
|
1495 | + */ |
|
1496 | + public function register_block() { |
|
1497 | + wp_add_inline_script( 'wp-blocks', $this->block() ); |
|
1498 | + if ( class_exists( 'SiteOrigin_Panels' ) ) { |
|
1499 | + wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() ); |
|
1500 | + } |
|
1501 | + } |
|
1502 | + |
|
1503 | + /** |
|
1504 | + * Check if we need to show advanced options. |
|
1505 | + * |
|
1506 | + * @return bool |
|
1507 | + */ |
|
1508 | + public function block_show_advanced() { |
|
1509 | + |
|
1510 | + $show = false; |
|
1511 | + $arguments = $this->arguments; |
|
1512 | + |
|
1513 | + if ( empty( $arguments ) ) { |
|
1514 | + $arguments = $this->get_arguments(); |
|
1515 | + } |
|
1516 | + |
|
1517 | + if ( ! empty( $arguments ) ) { |
|
1518 | + foreach ( $arguments as $argument ) { |
|
1519 | + if ( isset( $argument['advanced'] ) && $argument['advanced'] ) { |
|
1520 | + $show = true; |
|
1521 | + break; // no need to continue if we know we have it |
|
1522 | + } |
|
1523 | + } |
|
1524 | + } |
|
1525 | + |
|
1526 | + return $show; |
|
1527 | + } |
|
1528 | + |
|
1529 | + /** |
|
1530 | + * Get the url path to the current folder. |
|
1531 | + * |
|
1532 | + * @return string |
|
1533 | + */ |
|
1534 | + public function get_url() { |
|
1535 | + |
|
1536 | + $url = $this->url; |
|
1537 | + |
|
1538 | + if ( ! $url ) { |
|
1539 | + // check if we are inside a plugin |
|
1540 | + $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) ); |
|
1541 | + |
|
1542 | + $dir_parts = explode( "/wp-content/", $file_dir ); |
|
1543 | + $url_parts = explode( "/wp-content/", plugins_url() ); |
|
1544 | + |
|
1545 | + if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) { |
|
1546 | + $url = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] ); |
|
1547 | + $this->url = $url; |
|
1548 | + } |
|
1549 | + } |
|
1550 | + |
|
1551 | + |
|
1552 | + return $url; |
|
1553 | + } |
|
1554 | + |
|
1555 | + /** |
|
1556 | + * Generate the block icon. |
|
1557 | + * |
|
1558 | + * Enables the use of Font Awesome icons. |
|
1559 | + * |
|
1560 | + * @note xlink:href is actually deprecated but href is not supported by all so we use both. |
|
1561 | + * |
|
1562 | + * @param $icon |
|
1563 | + * |
|
1564 | + * @since 1.1.0 |
|
1565 | + * @return string |
|
1566 | + */ |
|
1567 | + public function get_block_icon( $icon ) { |
|
1568 | + |
|
1569 | + // check if we have a Font Awesome icon |
|
1570 | + $fa_type = ''; |
|
1571 | + if ( substr( $icon, 0, 7 ) === "fas fa-" ) { |
|
1572 | + $fa_type = 'solid'; |
|
1573 | + } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) { |
|
1574 | + $fa_type = 'regular'; |
|
1575 | + } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) { |
|
1576 | + $fa_type = 'brands'; |
|
1577 | + } else { |
|
1578 | + $icon = "'" . $icon . "'"; |
|
1579 | + } |
|
1580 | + |
|
1581 | + // set the icon if we found one |
|
1582 | + if ( $fa_type ) { |
|
1583 | + $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon ); |
|
1584 | + $icon = "el('svg',{width: 20, height: 20, viewBox: '0 0 20 20'},el('use', {'xlink:href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "','href': '" . $this->get_url() . "icons/" . $fa_type . ".svg#" . $fa_icon . "'}))"; |
|
1585 | + } |
|
1586 | + |
|
1587 | + return $icon; |
|
1588 | + } |
|
1589 | + |
|
1590 | + public function group_arguments( $arguments ) { |
|
1591 | 1591 | // echo '###';print_r($arguments); |
1592 | - if ( ! empty( $arguments ) ) { |
|
1593 | - $temp_arguments = array(); |
|
1594 | - $general = __( "General" ); |
|
1595 | - $add_sections = false; |
|
1596 | - foreach ( $arguments as $key => $args ) { |
|
1597 | - if ( isset( $args['group'] ) ) { |
|
1598 | - $temp_arguments[ $args['group'] ][ $key ] = $args; |
|
1599 | - $add_sections = true; |
|
1600 | - } else { |
|
1601 | - $temp_arguments[ $general ][ $key ] = $args; |
|
1602 | - } |
|
1603 | - } |
|
1604 | - |
|
1605 | - // only add sections if more than one |
|
1606 | - if ( $add_sections ) { |
|
1607 | - $arguments = $temp_arguments; |
|
1608 | - } |
|
1609 | - } |
|
1592 | + if ( ! empty( $arguments ) ) { |
|
1593 | + $temp_arguments = array(); |
|
1594 | + $general = __( "General" ); |
|
1595 | + $add_sections = false; |
|
1596 | + foreach ( $arguments as $key => $args ) { |
|
1597 | + if ( isset( $args['group'] ) ) { |
|
1598 | + $temp_arguments[ $args['group'] ][ $key ] = $args; |
|
1599 | + $add_sections = true; |
|
1600 | + } else { |
|
1601 | + $temp_arguments[ $general ][ $key ] = $args; |
|
1602 | + } |
|
1603 | + } |
|
1604 | + |
|
1605 | + // only add sections if more than one |
|
1606 | + if ( $add_sections ) { |
|
1607 | + $arguments = $temp_arguments; |
|
1608 | + } |
|
1609 | + } |
|
1610 | 1610 | |
1611 | 1611 | // echo '###';print_r($arguments); |
1612 | - return $arguments; |
|
1613 | - } |
|
1614 | - |
|
1615 | - |
|
1616 | - /** |
|
1617 | - * Output the JS for building the dynamic Guntenberg block. |
|
1618 | - * |
|
1619 | - * @since 1.0.4 Added block_wrap property which will set the block wrapping output element ie: div, span, p or empty for no wrap. |
|
1620 | - * @since 1.0.9 Save numbers as numbers and not strings. |
|
1621 | - * @since 1.1.0 Font Awesome classes can be used for icons. |
|
1622 | - * @return mixed |
|
1623 | - */ |
|
1624 | - public function block() { |
|
1625 | - ob_start(); |
|
1626 | - |
|
1627 | - $show_advanced = $this->block_show_advanced(); |
|
1628 | - ?> |
|
1612 | + return $arguments; |
|
1613 | + } |
|
1614 | + |
|
1615 | + |
|
1616 | + /** |
|
1617 | + * Output the JS for building the dynamic Guntenberg block. |
|
1618 | + * |
|
1619 | + * @since 1.0.4 Added block_wrap property which will set the block wrapping output element ie: div, span, p or empty for no wrap. |
|
1620 | + * @since 1.0.9 Save numbers as numbers and not strings. |
|
1621 | + * @since 1.1.0 Font Awesome classes can be used for icons. |
|
1622 | + * @return mixed |
|
1623 | + */ |
|
1624 | + public function block() { |
|
1625 | + ob_start(); |
|
1626 | + |
|
1627 | + $show_advanced = $this->block_show_advanced(); |
|
1628 | + ?> |
|
1629 | 1629 | <script> |
1630 | 1630 | /** |
1631 | 1631 | * BLOCK: Basic |
@@ -1669,97 +1669,97 @@ discard block |
||
1669 | 1669 | icon: <?php echo $this->get_block_icon( $this->options['block-icon'] );?>,//'<?php echo isset( $this->options['block-icon'] ) ? esc_attr( $this->options['block-icon'] ) : 'shield-alt';?>', // Block icon from Dashicons → https://developer.wordpress.org/resource/dashicons/. |
1670 | 1670 | supports: { |
1671 | 1671 | <?php |
1672 | - if ( isset( $this->options['block-supports'] ) ) { |
|
1673 | - echo $this->array_to_attributes( $this->options['block-supports'] ); |
|
1674 | - } |
|
1675 | - ?> |
|
1672 | + if ( isset( $this->options['block-supports'] ) ) { |
|
1673 | + echo $this->array_to_attributes( $this->options['block-supports'] ); |
|
1674 | + } |
|
1675 | + ?> |
|
1676 | 1676 | }, |
1677 | 1677 | category: '<?php echo isset( $this->options['block-category'] ) ? esc_attr( $this->options['block-category'] ) : 'common';?>', // Block category — Group blocks together based on common traits E.g. common, formatting, layout widgets, embed. |
1678 | 1678 | <?php if ( isset( $this->options['block-keywords'] ) ) { |
1679 | - echo "keywords : " . $this->options['block-keywords'] . ","; |
|
1680 | - }?> |
|
1679 | + echo "keywords : " . $this->options['block-keywords'] . ","; |
|
1680 | + }?> |
|
1681 | 1681 | |
1682 | 1682 | <?php |
1683 | 1683 | |
1684 | - // maybe set no_wrap |
|
1685 | - $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false; |
|
1686 | - if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) { |
|
1687 | - $no_wrap = true; |
|
1688 | - } |
|
1689 | - if ( $no_wrap ) { |
|
1690 | - $this->options['block-wrap'] = ''; |
|
1691 | - } |
|
1684 | + // maybe set no_wrap |
|
1685 | + $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false; |
|
1686 | + if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) { |
|
1687 | + $no_wrap = true; |
|
1688 | + } |
|
1689 | + if ( $no_wrap ) { |
|
1690 | + $this->options['block-wrap'] = ''; |
|
1691 | + } |
|
1692 | 1692 | |
1693 | 1693 | |
1694 | 1694 | |
1695 | - $show_alignment = false; |
|
1696 | - // align feature |
|
1697 | - /*echo "supports: {"; |
|
1695 | + $show_alignment = false; |
|
1696 | + // align feature |
|
1697 | + /*echo "supports: {"; |
|
1698 | 1698 | echo " align: true,"; |
1699 | 1699 | echo " html: false"; |
1700 | 1700 | echo "},";*/ |
1701 | 1701 | |
1702 | - if ( ! empty( $this->arguments ) ) { |
|
1703 | - echo "attributes : {"; |
|
1704 | - |
|
1705 | - if ( $show_advanced ) { |
|
1706 | - echo "show_advanced: {"; |
|
1707 | - echo " type: 'boolean',"; |
|
1708 | - echo " default: false,"; |
|
1709 | - echo "},"; |
|
1710 | - } |
|
1711 | - |
|
1712 | - // block wrap element |
|
1713 | - if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this? |
|
1714 | - echo "block_wrap: {"; |
|
1715 | - echo " type: 'string',"; |
|
1716 | - echo " default: '" . esc_attr( $this->options['block-wrap'] ) . "',"; |
|
1717 | - echo "},"; |
|
1718 | - } |
|
1719 | - |
|
1720 | - foreach ( $this->arguments as $key => $args ) { |
|
1721 | - |
|
1722 | - // set if we should show alignment |
|
1723 | - if ( $key == 'alignment' ) { |
|
1724 | - $show_alignment = true; |
|
1725 | - } |
|
1726 | - |
|
1727 | - $extra = ''; |
|
1728 | - |
|
1729 | - if ( $args['type'] == 'checkbox' ) { |
|
1730 | - $type = 'boolean'; |
|
1731 | - $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false'; |
|
1732 | - } elseif ( $args['type'] == 'number' ) { |
|
1733 | - $type = 'number'; |
|
1734 | - $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1735 | - } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) { |
|
1736 | - $type = 'array'; |
|
1737 | - if ( is_array( $args['default'] ) ) { |
|
1738 | - $default = isset( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]"; |
|
1739 | - } else { |
|
1740 | - $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1741 | - } |
|
1742 | - } elseif ( $args['type'] == 'multiselect' ) { |
|
1743 | - $type = 'array'; |
|
1744 | - $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1745 | - } else { |
|
1746 | - $type = 'string'; |
|
1747 | - $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1748 | - } |
|
1749 | - echo $key . " : {"; |
|
1750 | - echo "type : '$type',"; |
|
1751 | - echo "default : $default,"; |
|
1752 | - echo "},"; |
|
1753 | - } |
|
1754 | - |
|
1755 | - echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},"; |
|
1756 | - echo "className: { type: 'string', default: '' },"; |
|
1757 | - |
|
1758 | - echo "},"; |
|
1759 | - |
|
1760 | - } |
|
1761 | - |
|
1762 | - ?> |
|
1702 | + if ( ! empty( $this->arguments ) ) { |
|
1703 | + echo "attributes : {"; |
|
1704 | + |
|
1705 | + if ( $show_advanced ) { |
|
1706 | + echo "show_advanced: {"; |
|
1707 | + echo " type: 'boolean',"; |
|
1708 | + echo " default: false,"; |
|
1709 | + echo "},"; |
|
1710 | + } |
|
1711 | + |
|
1712 | + // block wrap element |
|
1713 | + if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this? |
|
1714 | + echo "block_wrap: {"; |
|
1715 | + echo " type: 'string',"; |
|
1716 | + echo " default: '" . esc_attr( $this->options['block-wrap'] ) . "',"; |
|
1717 | + echo "},"; |
|
1718 | + } |
|
1719 | + |
|
1720 | + foreach ( $this->arguments as $key => $args ) { |
|
1721 | + |
|
1722 | + // set if we should show alignment |
|
1723 | + if ( $key == 'alignment' ) { |
|
1724 | + $show_alignment = true; |
|
1725 | + } |
|
1726 | + |
|
1727 | + $extra = ''; |
|
1728 | + |
|
1729 | + if ( $args['type'] == 'checkbox' ) { |
|
1730 | + $type = 'boolean'; |
|
1731 | + $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false'; |
|
1732 | + } elseif ( $args['type'] == 'number' ) { |
|
1733 | + $type = 'number'; |
|
1734 | + $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1735 | + } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) { |
|
1736 | + $type = 'array'; |
|
1737 | + if ( is_array( $args['default'] ) ) { |
|
1738 | + $default = isset( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]"; |
|
1739 | + } else { |
|
1740 | + $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1741 | + } |
|
1742 | + } elseif ( $args['type'] == 'multiselect' ) { |
|
1743 | + $type = 'array'; |
|
1744 | + $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1745 | + } else { |
|
1746 | + $type = 'string'; |
|
1747 | + $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1748 | + } |
|
1749 | + echo $key . " : {"; |
|
1750 | + echo "type : '$type',"; |
|
1751 | + echo "default : $default,"; |
|
1752 | + echo "},"; |
|
1753 | + } |
|
1754 | + |
|
1755 | + echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},"; |
|
1756 | + echo "className: { type: 'string', default: '' },"; |
|
1757 | + |
|
1758 | + echo "},"; |
|
1759 | + |
|
1760 | + } |
|
1761 | + |
|
1762 | + ?> |
|
1763 | 1763 | |
1764 | 1764 | // The "edit" property must be a valid function. |
1765 | 1765 | edit: function (props) { |
@@ -1767,9 +1767,9 @@ discard block |
||
1767 | 1767 | |
1768 | 1768 | var $value = ''; |
1769 | 1769 | <?php |
1770 | - // if we have a post_type and a category then link them |
|
1771 | - if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){ |
|
1772 | - ?> |
|
1770 | + // if we have a post_type and a category then link them |
|
1771 | + if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){ |
|
1772 | + ?> |
|
1773 | 1773 | if(typeof(prev_attributes[props.id]) != 'undefined' ){ |
1774 | 1774 | $pt = props.attributes.post_type; |
1775 | 1775 | if(post_type_rest_slugs.length){ |
@@ -1853,8 +1853,8 @@ discard block |
||
1853 | 1853 | 'shortcode': '<?php echo $this->options['base_id'];?>', |
1854 | 1854 | 'attributes': props.attributes, |
1855 | 1855 | 'post_id': <?php global $post; if ( isset( $post->ID ) ) { |
1856 | - echo $post->ID; |
|
1857 | - }?>, |
|
1856 | + echo $post->ID; |
|
1857 | + }?>, |
|
1858 | 1858 | '_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>' |
1859 | 1859 | }; |
1860 | 1860 | |
@@ -1906,10 +1906,10 @@ discard block |
||
1906 | 1906 | |
1907 | 1907 | <?php |
1908 | 1908 | |
1909 | - if(! empty( $this->arguments )){ |
|
1909 | + if(! empty( $this->arguments )){ |
|
1910 | 1910 | |
1911 | - if ( $show_advanced ) { |
|
1912 | - ?> |
|
1911 | + if ( $show_advanced ) { |
|
1912 | + ?> |
|
1913 | 1913 | el('div', { |
1914 | 1914 | style: {'padding-left': '16px','padding-right': '16px'} |
1915 | 1915 | }, |
@@ -1927,79 +1927,79 @@ discard block |
||
1927 | 1927 | , |
1928 | 1928 | <?php |
1929 | 1929 | |
1930 | - } |
|
1930 | + } |
|
1931 | 1931 | |
1932 | - $arguments = $this->group_arguments( $this->arguments ); |
|
1932 | + $arguments = $this->group_arguments( $this->arguments ); |
|
1933 | 1933 | |
1934 | - // Do we have sections? |
|
1935 | - $has_sections = $arguments == $this->arguments ? false : true; |
|
1934 | + // Do we have sections? |
|
1935 | + $has_sections = $arguments == $this->arguments ? false : true; |
|
1936 | 1936 | |
1937 | 1937 | |
1938 | - if($has_sections){ |
|
1939 | - $panel_count = 0; |
|
1940 | - foreach($arguments as $key => $args){ |
|
1941 | - ?> |
|
1938 | + if($has_sections){ |
|
1939 | + $panel_count = 0; |
|
1940 | + foreach($arguments as $key => $args){ |
|
1941 | + ?> |
|
1942 | 1942 | el(wp.components.PanelBody, { |
1943 | 1943 | title: '<?php esc_attr_e( $key ); ?>', |
1944 | 1944 | initialOpen: <?php if ( $panel_count ) { |
1945 | - echo "false"; |
|
1946 | - } else { |
|
1947 | - echo "true"; |
|
1948 | - }?> |
|
1945 | + echo "false"; |
|
1946 | + } else { |
|
1947 | + echo "true"; |
|
1948 | + }?> |
|
1949 | 1949 | }, |
1950 | 1950 | <?php |
1951 | 1951 | |
1952 | 1952 | |
1953 | 1953 | |
1954 | - foreach ( $args as $k => $a ) { |
|
1954 | + foreach ( $args as $k => $a ) { |
|
1955 | 1955 | |
1956 | - $this->block_row_start( $k, $a ); |
|
1957 | - $this->build_block_arguments( $k, $a ); |
|
1958 | - $this->block_row_end( $k, $a ); |
|
1959 | - } |
|
1960 | - ?> |
|
1956 | + $this->block_row_start( $k, $a ); |
|
1957 | + $this->build_block_arguments( $k, $a ); |
|
1958 | + $this->block_row_end( $k, $a ); |
|
1959 | + } |
|
1960 | + ?> |
|
1961 | 1961 | ), |
1962 | 1962 | <?php |
1963 | - $panel_count ++; |
|
1963 | + $panel_count ++; |
|
1964 | 1964 | |
1965 | - } |
|
1966 | - }else { |
|
1967 | - ?> |
|
1965 | + } |
|
1966 | + }else { |
|
1967 | + ?> |
|
1968 | 1968 | el(wp.components.PanelBody, { |
1969 | 1969 | title: '<?php esc_attr_e( "Settings" ); ?>', |
1970 | 1970 | initialOpen: true |
1971 | 1971 | }, |
1972 | 1972 | <?php |
1973 | - foreach ( $this->arguments as $key => $args ) { |
|
1974 | - $this->block_row_start( $key, $args ); |
|
1975 | - $this->build_block_arguments( $key, $args ); |
|
1976 | - $this->block_row_end( $key, $args ); |
|
1977 | - } |
|
1978 | - ?> |
|
1973 | + foreach ( $this->arguments as $key => $args ) { |
|
1974 | + $this->block_row_start( $key, $args ); |
|
1975 | + $this->build_block_arguments( $key, $args ); |
|
1976 | + $this->block_row_end( $key, $args ); |
|
1977 | + } |
|
1978 | + ?> |
|
1979 | 1979 | ), |
1980 | 1980 | <?php |
1981 | - } |
|
1981 | + } |
|
1982 | 1982 | |
1983 | - } |
|
1984 | - ?> |
|
1983 | + } |
|
1984 | + ?> |
|
1985 | 1985 | |
1986 | 1986 | ), |
1987 | 1987 | |
1988 | 1988 | <?php |
1989 | - // If the user sets block-output array then build it |
|
1990 | - if ( ! empty( $this->options['block-output'] ) ) { |
|
1991 | - $this->block_element( $this->options['block-output'] ); |
|
1992 | - }else{ |
|
1993 | - // if no block-output is set then we try and get the shortcode html output via ajax. |
|
1994 | - ?> |
|
1989 | + // If the user sets block-output array then build it |
|
1990 | + if ( ! empty( $this->options['block-output'] ) ) { |
|
1991 | + $this->block_element( $this->options['block-output'] ); |
|
1992 | + }else{ |
|
1993 | + // if no block-output is set then we try and get the shortcode html output via ajax. |
|
1994 | + ?> |
|
1995 | 1995 | el('div', { |
1996 | 1996 | dangerouslySetInnerHTML: {__html: onChangeContent()}, |
1997 | 1997 | className: props.className, |
1998 | 1998 | style: {'minHeight': '30px'} |
1999 | 1999 | }) |
2000 | 2000 | <?php |
2001 | - } |
|
2002 | - ?> |
|
2001 | + } |
|
2002 | + ?> |
|
2003 | 2003 | ]; // end return |
2004 | 2004 | }, |
2005 | 2005 | |
@@ -2017,10 +2017,10 @@ discard block |
||
2017 | 2017 | $html = ''; |
2018 | 2018 | <?php |
2019 | 2019 | |
2020 | - if(! empty( $this->arguments )){ |
|
2020 | + if(! empty( $this->arguments )){ |
|
2021 | 2021 | |
2022 | - foreach($this->arguments as $key => $args){ |
|
2023 | - ?> |
|
2022 | + foreach($this->arguments as $key => $args){ |
|
2023 | + ?> |
|
2024 | 2024 | if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) { |
2025 | 2025 | if ('<?php echo esc_attr( $key );?>' == 'html') { |
2026 | 2026 | $html = attr.<?php echo esc_attr( $key );?>; |
@@ -2029,10 +2029,10 @@ discard block |
||
2029 | 2029 | } |
2030 | 2030 | } |
2031 | 2031 | <?php |
2032 | - } |
|
2033 | - } |
|
2032 | + } |
|
2033 | + } |
|
2034 | 2034 | |
2035 | - ?> |
|
2035 | + ?> |
|
2036 | 2036 | content += "]"; |
2037 | 2037 | |
2038 | 2038 | // if has html element |
@@ -2055,20 +2055,20 @@ discard block |
||
2055 | 2055 | } |
2056 | 2056 | |
2057 | 2057 | <?php |
2058 | - if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){ |
|
2059 | - ?> |
|
2058 | + if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){ |
|
2059 | + ?> |
|
2060 | 2060 | return content; |
2061 | 2061 | <?php |
2062 | - }else{ |
|
2063 | - ?> |
|
2062 | + }else{ |
|
2063 | + ?> |
|
2064 | 2064 | var block_wrap = 'div'; |
2065 | 2065 | if (attr.hasOwnProperty("block_wrap")) { |
2066 | 2066 | block_wrap = attr.block_wrap; |
2067 | 2067 | } |
2068 | 2068 | return el(block_wrap, {dangerouslySetInnerHTML: {__html: content}, className: align}); |
2069 | 2069 | <?php |
2070 | - } |
|
2071 | - ?> |
|
2070 | + } |
|
2071 | + ?> |
|
2072 | 2072 | |
2073 | 2073 | |
2074 | 2074 | } |
@@ -2076,30 +2076,30 @@ discard block |
||
2076 | 2076 | })(); |
2077 | 2077 | </script> |
2078 | 2078 | <?php |
2079 | - $output = ob_get_clean(); |
|
2079 | + $output = ob_get_clean(); |
|
2080 | 2080 | |
2081 | - /* |
|
2081 | + /* |
|
2082 | 2082 | * We only add the <script> tags for code highlighting, so we strip them from the output. |
2083 | 2083 | */ |
2084 | 2084 | |
2085 | - return str_replace( array( |
|
2086 | - '<script>', |
|
2087 | - '</script>' |
|
2088 | - ), '', $output ); |
|
2089 | - } |
|
2085 | + return str_replace( array( |
|
2086 | + '<script>', |
|
2087 | + '</script>' |
|
2088 | + ), '', $output ); |
|
2089 | + } |
|
2090 | 2090 | |
2091 | - public function block_row_start($key, $args){ |
|
2091 | + public function block_row_start($key, $args){ |
|
2092 | 2092 | |
2093 | - // check for row |
|
2094 | - if(!empty($args['row'])){ |
|
2093 | + // check for row |
|
2094 | + if(!empty($args['row'])){ |
|
2095 | 2095 | |
2096 | - if(!empty($args['row']['open'])){ |
|
2096 | + if(!empty($args['row']['open'])){ |
|
2097 | 2097 | |
2098 | - // element require |
|
2099 | - $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : ""; |
|
2100 | - echo $element_require; |
|
2098 | + // element require |
|
2099 | + $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : ""; |
|
2100 | + echo $element_require; |
|
2101 | 2101 | |
2102 | - if(false){?><script><?php }?> |
|
2102 | + if(false){?><script><?php }?> |
|
2103 | 2103 | el('div', { |
2104 | 2104 | className: 'bsui components-base-control', |
2105 | 2105 | }, |
@@ -2129,87 +2129,87 @@ discard block |
||
2129 | 2129 | }, |
2130 | 2130 | |
2131 | 2131 | <?php |
2132 | - if(false){?></script><?php } |
|
2133 | - }elseif(!empty($args['row']['close'])){ |
|
2134 | - if(false){?><script><?php }?> |
|
2132 | + if(false){?></script><?php } |
|
2133 | + }elseif(!empty($args['row']['close'])){ |
|
2134 | + if(false){?><script><?php }?> |
|
2135 | 2135 | el( |
2136 | 2136 | 'div', |
2137 | 2137 | { |
2138 | 2138 | className: 'col pl-0', |
2139 | 2139 | }, |
2140 | 2140 | <?php |
2141 | - if(false){?></script><?php } |
|
2142 | - }else{ |
|
2143 | - if(false){?><script><?php }?> |
|
2141 | + if(false){?></script><?php } |
|
2142 | + }else{ |
|
2143 | + if(false){?><script><?php }?> |
|
2144 | 2144 | el( |
2145 | 2145 | 'div', |
2146 | 2146 | { |
2147 | 2147 | className: 'col pl-0 pr-2', |
2148 | 2148 | }, |
2149 | 2149 | <?php |
2150 | - if(false){?></script><?php } |
|
2151 | - } |
|
2152 | - |
|
2153 | - } |
|
2154 | - |
|
2155 | - } |
|
2156 | - |
|
2157 | - public function block_row_end($key, $args){ |
|
2158 | - |
|
2159 | - if(!empty($args['row'])){ |
|
2160 | - // maybe close |
|
2161 | - if(!empty($args['row']['close'])){ |
|
2162 | - echo "))"; |
|
2163 | - } |
|
2164 | - |
|
2165 | - echo "),"; |
|
2166 | - } |
|
2167 | - } |
|
2168 | - |
|
2169 | - public function build_block_arguments( $key, $args ) { |
|
2170 | - $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : ''; |
|
2171 | - $options = ''; |
|
2172 | - $extra = ''; |
|
2173 | - $require = ''; |
|
2174 | - |
|
2175 | - // `content` is a protected and special argument |
|
2176 | - if ( $key == 'content' ) { |
|
2177 | - return; |
|
2178 | - } |
|
2179 | - |
|
2180 | - |
|
2181 | - // icon |
|
2182 | - $icon = ''; |
|
2183 | - if( !empty( $args['icon'] ) ){ |
|
2184 | - $icon .= "el('div', {"; |
|
2185 | - $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},"; |
|
2186 | - $icon .= "className: 'text-center',"; |
|
2187 | - $icon .= "title: '".addslashes( $args['title'] )."',"; |
|
2188 | - $icon .= "}),"; |
|
2189 | - |
|
2190 | - // blank title as its added to the icon. |
|
2191 | - $args['title'] = ''; |
|
2192 | - } |
|
2193 | - |
|
2194 | - // require advanced |
|
2195 | - $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : ""; |
|
2196 | - |
|
2197 | - // element require |
|
2198 | - $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : ""; |
|
2199 | - |
|
2200 | - |
|
2201 | - $onchange = "props.setAttributes({ $key: $key } )"; |
|
2202 | - $onchangecomplete = ""; |
|
2203 | - $value = "props.attributes.$key"; |
|
2204 | - $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' ); |
|
2205 | - if ( in_array( $args['type'], $text_type ) ) { |
|
2206 | - $type = 'TextControl'; |
|
2207 | - // Save numbers as numbers and not strings |
|
2208 | - if ( $args['type'] == 'number' ) { |
|
2209 | - $onchange = "props.setAttributes({ $key: Number($key) } )"; |
|
2210 | - } |
|
2211 | - } |
|
2212 | - /* |
|
2150 | + if(false){?></script><?php } |
|
2151 | + } |
|
2152 | + |
|
2153 | + } |
|
2154 | + |
|
2155 | + } |
|
2156 | + |
|
2157 | + public function block_row_end($key, $args){ |
|
2158 | + |
|
2159 | + if(!empty($args['row'])){ |
|
2160 | + // maybe close |
|
2161 | + if(!empty($args['row']['close'])){ |
|
2162 | + echo "))"; |
|
2163 | + } |
|
2164 | + |
|
2165 | + echo "),"; |
|
2166 | + } |
|
2167 | + } |
|
2168 | + |
|
2169 | + public function build_block_arguments( $key, $args ) { |
|
2170 | + $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : ''; |
|
2171 | + $options = ''; |
|
2172 | + $extra = ''; |
|
2173 | + $require = ''; |
|
2174 | + |
|
2175 | + // `content` is a protected and special argument |
|
2176 | + if ( $key == 'content' ) { |
|
2177 | + return; |
|
2178 | + } |
|
2179 | + |
|
2180 | + |
|
2181 | + // icon |
|
2182 | + $icon = ''; |
|
2183 | + if( !empty( $args['icon'] ) ){ |
|
2184 | + $icon .= "el('div', {"; |
|
2185 | + $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},"; |
|
2186 | + $icon .= "className: 'text-center',"; |
|
2187 | + $icon .= "title: '".addslashes( $args['title'] )."',"; |
|
2188 | + $icon .= "}),"; |
|
2189 | + |
|
2190 | + // blank title as its added to the icon. |
|
2191 | + $args['title'] = ''; |
|
2192 | + } |
|
2193 | + |
|
2194 | + // require advanced |
|
2195 | + $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : ""; |
|
2196 | + |
|
2197 | + // element require |
|
2198 | + $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : ""; |
|
2199 | + |
|
2200 | + |
|
2201 | + $onchange = "props.setAttributes({ $key: $key } )"; |
|
2202 | + $onchangecomplete = ""; |
|
2203 | + $value = "props.attributes.$key"; |
|
2204 | + $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' ); |
|
2205 | + if ( in_array( $args['type'], $text_type ) ) { |
|
2206 | + $type = 'TextControl'; |
|
2207 | + // Save numbers as numbers and not strings |
|
2208 | + if ( $args['type'] == 'number' ) { |
|
2209 | + $onchange = "props.setAttributes({ $key: Number($key) } )"; |
|
2210 | + } |
|
2211 | + } |
|
2212 | + /* |
|
2213 | 2213 | * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout |
2214 | 2214 | elseif($args['type']=='tabs'){ |
2215 | 2215 | ?> |
@@ -2243,85 +2243,85 @@ discard block |
||
2243 | 2243 | return; |
2244 | 2244 | } |
2245 | 2245 | */ |
2246 | - elseif ( $args['type'] == 'color' ) { |
|
2247 | - $type = 'ColorPicker'; |
|
2248 | - $onchange = ""; |
|
2249 | - $extra = "color: $value,"; |
|
2250 | - if(!empty($args['disable_alpha'])){ |
|
2251 | - $extra .= "disableAlpha: true,"; |
|
2252 | - } |
|
2253 | - $onchangecomplete = "onChangeComplete: function($key) { |
|
2246 | + elseif ( $args['type'] == 'color' ) { |
|
2247 | + $type = 'ColorPicker'; |
|
2248 | + $onchange = ""; |
|
2249 | + $extra = "color: $value,"; |
|
2250 | + if(!empty($args['disable_alpha'])){ |
|
2251 | + $extra .= "disableAlpha: true,"; |
|
2252 | + } |
|
2253 | + $onchangecomplete = "onChangeComplete: function($key) { |
|
2254 | 2254 | value = $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex; |
2255 | 2255 | props.setAttributes({ |
2256 | 2256 | $key: value |
2257 | 2257 | }); |
2258 | 2258 | },"; |
2259 | - } |
|
2260 | - elseif ( $args['type'] == 'checkbox' ) { |
|
2261 | - $type = 'CheckboxControl'; |
|
2262 | - $extra .= "checked: props.attributes.$key,"; |
|
2263 | - $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )"; |
|
2264 | - } elseif ( $args['type'] == 'textarea' ) { |
|
2265 | - $type = 'TextareaControl'; |
|
2266 | - } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) { |
|
2267 | - $type = 'SelectControl'; |
|
2268 | - |
|
2269 | - if($args['name'] == 'category' && !empty($args['post_type_linked'])){ |
|
2270 | - $options .= "options: taxonomies_".str_replace("-","_", $this->id).","; |
|
2271 | - }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){ |
|
2272 | - $options .= "options: sort_by_".str_replace("-","_", $this->id).","; |
|
2273 | - }else { |
|
2274 | - |
|
2275 | - if ( ! empty( $args['options'] ) ) { |
|
2276 | - $options .= "options: ["; |
|
2277 | - foreach ( $args['options'] as $option_val => $option_label ) { |
|
2278 | - $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },"; |
|
2279 | - } |
|
2280 | - $options .= "],"; |
|
2281 | - } |
|
2282 | - } |
|
2283 | - if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550 |
|
2284 | - $extra .= ' multiple: true, '; |
|
2285 | - } |
|
2286 | - } elseif ( $args['type'] == 'alignment' ) { |
|
2287 | - $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example |
|
2288 | - }elseif ( $args['type'] == 'margins' ) { |
|
2289 | - |
|
2290 | - } else { |
|
2291 | - return;// if we have not implemented the control then don't break the JS. |
|
2292 | - } |
|
2293 | - |
|
2294 | - |
|
2295 | - |
|
2296 | - // color input does not show the labels so we add them |
|
2297 | - if($args['type']=='color'){ |
|
2298 | - // add show only if advanced |
|
2299 | - echo $require_advanced; |
|
2300 | - // add setting require if defined |
|
2301 | - echo $element_require; |
|
2302 | - echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),"; |
|
2303 | - } |
|
2304 | - |
|
2305 | - // add show only if advanced |
|
2306 | - echo $require_advanced; |
|
2307 | - // add setting require if defined |
|
2308 | - echo $element_require; |
|
2309 | - |
|
2310 | - // icon |
|
2311 | - echo $icon; |
|
2312 | - ?> |
|
2259 | + } |
|
2260 | + elseif ( $args['type'] == 'checkbox' ) { |
|
2261 | + $type = 'CheckboxControl'; |
|
2262 | + $extra .= "checked: props.attributes.$key,"; |
|
2263 | + $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )"; |
|
2264 | + } elseif ( $args['type'] == 'textarea' ) { |
|
2265 | + $type = 'TextareaControl'; |
|
2266 | + } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) { |
|
2267 | + $type = 'SelectControl'; |
|
2268 | + |
|
2269 | + if($args['name'] == 'category' && !empty($args['post_type_linked'])){ |
|
2270 | + $options .= "options: taxonomies_".str_replace("-","_", $this->id).","; |
|
2271 | + }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){ |
|
2272 | + $options .= "options: sort_by_".str_replace("-","_", $this->id).","; |
|
2273 | + }else { |
|
2274 | + |
|
2275 | + if ( ! empty( $args['options'] ) ) { |
|
2276 | + $options .= "options: ["; |
|
2277 | + foreach ( $args['options'] as $option_val => $option_label ) { |
|
2278 | + $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },"; |
|
2279 | + } |
|
2280 | + $options .= "],"; |
|
2281 | + } |
|
2282 | + } |
|
2283 | + if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550 |
|
2284 | + $extra .= ' multiple: true, '; |
|
2285 | + } |
|
2286 | + } elseif ( $args['type'] == 'alignment' ) { |
|
2287 | + $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example |
|
2288 | + }elseif ( $args['type'] == 'margins' ) { |
|
2289 | + |
|
2290 | + } else { |
|
2291 | + return;// if we have not implemented the control then don't break the JS. |
|
2292 | + } |
|
2293 | + |
|
2294 | + |
|
2295 | + |
|
2296 | + // color input does not show the labels so we add them |
|
2297 | + if($args['type']=='color'){ |
|
2298 | + // add show only if advanced |
|
2299 | + echo $require_advanced; |
|
2300 | + // add setting require if defined |
|
2301 | + echo $element_require; |
|
2302 | + echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),"; |
|
2303 | + } |
|
2304 | + |
|
2305 | + // add show only if advanced |
|
2306 | + echo $require_advanced; |
|
2307 | + // add setting require if defined |
|
2308 | + echo $element_require; |
|
2309 | + |
|
2310 | + // icon |
|
2311 | + echo $icon; |
|
2312 | + ?> |
|
2313 | 2313 | el( wp.components.<?php echo $type; ?>, { |
2314 | 2314 | label: '<?php echo addslashes( $args['title'] ); ?>', |
2315 | 2315 | help: '<?php if ( isset( $args['desc'] ) ) { |
2316 | - echo addslashes( $args['desc'] ); |
|
2317 | - } ?>', |
|
2316 | + echo addslashes( $args['desc'] ); |
|
2317 | + } ?>', |
|
2318 | 2318 | value: <?php echo $value; ?>, |
2319 | 2319 | <?php if ( $type == 'TextControl' && $args['type'] != 'text' ) { |
2320 | - echo "type: '" . addslashes( $args['type'] ) . "',"; |
|
2321 | - } ?> |
|
2320 | + echo "type: '" . addslashes( $args['type'] ) . "',"; |
|
2321 | + } ?> |
|
2322 | 2322 | <?php if ( ! empty( $args['placeholder'] ) ) { |
2323 | - echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',"; |
|
2324 | - } ?> |
|
2323 | + echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',"; |
|
2324 | + } ?> |
|
2325 | 2325 | <?php echo $options; ?> |
2326 | 2326 | <?php echo $extra; ?> |
2327 | 2327 | <?php echo $custom_attributes; ?> |
@@ -2333,601 +2333,601 @@ discard block |
||
2333 | 2333 | <?php |
2334 | 2334 | |
2335 | 2335 | |
2336 | - } |
|
2337 | - |
|
2338 | - /** |
|
2339 | - * Convert an array of attributes to block string. |
|
2340 | - * |
|
2341 | - * @todo there is prob a faster way to do this, also we could add some validation here. |
|
2342 | - * |
|
2343 | - * @param $custom_attributes |
|
2344 | - * |
|
2345 | - * @return string |
|
2346 | - */ |
|
2347 | - public function array_to_attributes( $custom_attributes, $html = false ) { |
|
2348 | - $attributes = ''; |
|
2349 | - if ( ! empty( $custom_attributes ) ) { |
|
2350 | - |
|
2351 | - if ( $html ) { |
|
2352 | - foreach ( $custom_attributes as $key => $val ) { |
|
2353 | - $attributes .= " $key='$val' "; |
|
2354 | - } |
|
2355 | - } else { |
|
2356 | - foreach ( $custom_attributes as $key => $val ) { |
|
2357 | - $attributes .= "'$key': '$val',"; |
|
2358 | - } |
|
2359 | - } |
|
2360 | - } |
|
2361 | - |
|
2362 | - return $attributes; |
|
2363 | - } |
|
2364 | - |
|
2365 | - /** |
|
2366 | - * A self looping function to create the output for JS block elements. |
|
2367 | - * |
|
2368 | - * This is what is output in the WP Editor visual view. |
|
2369 | - * |
|
2370 | - * @param $args |
|
2371 | - */ |
|
2372 | - public function block_element( $args ) { |
|
2373 | - |
|
2374 | - |
|
2375 | - if ( ! empty( $args ) ) { |
|
2376 | - foreach ( $args as $element => $new_args ) { |
|
2377 | - |
|
2378 | - if ( is_array( $new_args ) ) { // its an element |
|
2379 | - |
|
2380 | - |
|
2381 | - if ( isset( $new_args['element'] ) ) { |
|
2382 | - |
|
2383 | - if ( isset( $new_args['element_require'] ) ) { |
|
2384 | - echo str_replace( array( |
|
2385 | - "'+", |
|
2386 | - "+'" |
|
2387 | - ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " && "; |
|
2388 | - unset( $new_args['element_require'] ); |
|
2389 | - } |
|
2390 | - |
|
2391 | - echo "\n el( '" . $new_args['element'] . "', {"; |
|
2392 | - |
|
2393 | - // get the attributes |
|
2394 | - foreach ( $new_args as $new_key => $new_value ) { |
|
2395 | - |
|
2396 | - |
|
2397 | - if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) { |
|
2398 | - // do nothing |
|
2399 | - } else { |
|
2400 | - echo $this->block_element( array( $new_key => $new_value ) ); |
|
2401 | - } |
|
2402 | - } |
|
2403 | - |
|
2404 | - echo "},";// end attributes |
|
2405 | - |
|
2406 | - // get the content |
|
2407 | - $first_item = 0; |
|
2408 | - foreach ( $new_args as $new_key => $new_value ) { |
|
2409 | - if ( $new_key === 'content' || is_array( $new_value ) ) { |
|
2410 | - |
|
2411 | - if ( $new_key === 'content' ) { |
|
2412 | - echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'"; |
|
2413 | - } |
|
2414 | - |
|
2415 | - if ( is_array( $new_value ) ) { |
|
2416 | - |
|
2417 | - if ( isset( $new_value['element_require'] ) ) { |
|
2418 | - echo str_replace( array( |
|
2419 | - "'+", |
|
2420 | - "+'" |
|
2421 | - ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " && "; |
|
2422 | - unset( $new_value['element_require'] ); |
|
2423 | - } |
|
2424 | - |
|
2425 | - if ( isset( $new_value['element_repeat'] ) ) { |
|
2426 | - $x = 1; |
|
2427 | - while ( $x <= absint( $new_value['element_repeat'] ) ) { |
|
2428 | - $this->block_element( array( '' => $new_value ) ); |
|
2429 | - $x ++; |
|
2430 | - } |
|
2431 | - } else { |
|
2432 | - $this->block_element( array( '' => $new_value ) ); |
|
2433 | - } |
|
2434 | - } |
|
2435 | - $first_item ++; |
|
2436 | - } |
|
2437 | - } |
|
2438 | - |
|
2439 | - echo ")";// end content |
|
2440 | - |
|
2441 | - echo ", \n"; |
|
2442 | - |
|
2443 | - } |
|
2444 | - } else { |
|
2445 | - |
|
2446 | - if ( substr( $element, 0, 3 ) === "if_" ) { |
|
2447 | - echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ","; |
|
2448 | - } elseif ( $element == 'style' ) { |
|
2449 | - echo $element . ": " . $this->block_props_replace( $new_args ) . ","; |
|
2450 | - } else { |
|
2451 | - echo $element . ": '" . $this->block_props_replace( $new_args ) . "',"; |
|
2452 | - } |
|
2453 | - |
|
2454 | - } |
|
2455 | - } |
|
2456 | - } |
|
2457 | - } |
|
2458 | - |
|
2459 | - /** |
|
2460 | - * Replace block attributes placeholders with the proper naming. |
|
2461 | - * |
|
2462 | - * @param $string |
|
2463 | - * |
|
2464 | - * @return mixed |
|
2465 | - */ |
|
2466 | - public function block_props_replace( $string, $no_wrap = false ) { |
|
2467 | - |
|
2468 | - if ( $no_wrap ) { |
|
2469 | - $string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string ); |
|
2470 | - } else { |
|
2471 | - $string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string ); |
|
2472 | - } |
|
2473 | - |
|
2474 | - return $string; |
|
2475 | - } |
|
2476 | - |
|
2477 | - /** |
|
2478 | - * Outputs the content of the widget |
|
2479 | - * |
|
2480 | - * @param array $args |
|
2481 | - * @param array $instance |
|
2482 | - */ |
|
2483 | - public function widget( $args, $instance ) { |
|
2484 | - |
|
2485 | - // get the filtered values |
|
2486 | - $argument_values = $this->argument_values( $instance ); |
|
2487 | - $argument_values = $this->string_to_bool( $argument_values ); |
|
2488 | - $output = $this->output( $argument_values, $args ); |
|
2489 | - |
|
2490 | - $no_wrap = false; |
|
2491 | - if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) { |
|
2492 | - $no_wrap = true; |
|
2493 | - } |
|
2494 | - |
|
2495 | - ob_start(); |
|
2496 | - if ( $output && ! $no_wrap ) { |
|
2497 | - |
|
2498 | - $class_original = $this->options['widget_ops']['classname']; |
|
2499 | - $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash(); |
|
2500 | - |
|
2501 | - // Before widget |
|
2502 | - $before_widget = $args['before_widget']; |
|
2503 | - $before_widget = str_replace($class_original,$class,$before_widget); |
|
2504 | - $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this ); |
|
2505 | - $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this ); |
|
2506 | - |
|
2507 | - // After widget |
|
2508 | - $after_widget = $args['after_widget']; |
|
2509 | - $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this ); |
|
2510 | - $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this ); |
|
2511 | - |
|
2512 | - echo $before_widget; |
|
2513 | - // elementor strips the widget wrapping div so we check for and add it back if needed |
|
2514 | - if ( $this->is_elementor_widget_output() ) { |
|
2515 | - echo ! empty( $this->options['widget_ops']['classname'] ) ? "<span class='" . esc_attr( $class ) . "'>" : ''; |
|
2516 | - } |
|
2517 | - echo $this->output_title( $args, $instance ); |
|
2518 | - echo $output; |
|
2519 | - if ( $this->is_elementor_widget_output() ) { |
|
2520 | - echo ! empty( $this->options['widget_ops']['classname'] ) ? "</span>" : ''; |
|
2521 | - } |
|
2522 | - echo $after_widget; |
|
2523 | - } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty |
|
2524 | - $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" ); |
|
2525 | - echo $output; |
|
2526 | - } elseif ( $output && $no_wrap ) { |
|
2527 | - echo $output; |
|
2528 | - } |
|
2529 | - $output = ob_get_clean(); |
|
2530 | - |
|
2531 | - $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this ); |
|
2532 | - |
|
2533 | - echo $output; |
|
2534 | - } |
|
2535 | - |
|
2536 | - /** |
|
2537 | - * Tests if the current output is inside a elementor container. |
|
2538 | - * |
|
2539 | - * @since 1.0.4 |
|
2540 | - * @return bool |
|
2541 | - */ |
|
2542 | - public function is_elementor_widget_output() { |
|
2543 | - $result = false; |
|
2544 | - if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) { |
|
2545 | - $result = true; |
|
2546 | - } |
|
2547 | - |
|
2548 | - return $result; |
|
2549 | - } |
|
2550 | - |
|
2551 | - /** |
|
2552 | - * Tests if the current output is inside a elementor preview. |
|
2553 | - * |
|
2554 | - * @since 1.0.4 |
|
2555 | - * @return bool |
|
2556 | - */ |
|
2557 | - public function is_elementor_preview() { |
|
2558 | - $result = false; |
|
2559 | - if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) { |
|
2560 | - $result = true; |
|
2561 | - } |
|
2562 | - |
|
2563 | - return $result; |
|
2564 | - } |
|
2565 | - |
|
2566 | - /** |
|
2567 | - * Tests if the current output is inside a Divi preview. |
|
2568 | - * |
|
2569 | - * @since 1.0.6 |
|
2570 | - * @return bool |
|
2571 | - */ |
|
2572 | - public function is_divi_preview() { |
|
2573 | - $result = false; |
|
2574 | - if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) { |
|
2575 | - $result = true; |
|
2576 | - } |
|
2577 | - |
|
2578 | - return $result; |
|
2579 | - } |
|
2580 | - |
|
2581 | - /** |
|
2582 | - * Tests if the current output is inside a Beaver builder preview. |
|
2583 | - * |
|
2584 | - * @since 1.0.6 |
|
2585 | - * @return bool |
|
2586 | - */ |
|
2587 | - public function is_beaver_preview() { |
|
2588 | - $result = false; |
|
2589 | - if ( isset( $_REQUEST['fl_builder'] ) ) { |
|
2590 | - $result = true; |
|
2591 | - } |
|
2592 | - |
|
2593 | - return $result; |
|
2594 | - } |
|
2595 | - |
|
2596 | - /** |
|
2597 | - * Tests if the current output is inside a siteorigin builder preview. |
|
2598 | - * |
|
2599 | - * @since 1.0.6 |
|
2600 | - * @return bool |
|
2601 | - */ |
|
2602 | - public function is_siteorigin_preview() { |
|
2603 | - $result = false; |
|
2604 | - if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) { |
|
2605 | - $result = true; |
|
2606 | - } |
|
2607 | - |
|
2608 | - return $result; |
|
2609 | - } |
|
2610 | - |
|
2611 | - /** |
|
2612 | - * Tests if the current output is inside a cornerstone builder preview. |
|
2613 | - * |
|
2614 | - * @since 1.0.8 |
|
2615 | - * @return bool |
|
2616 | - */ |
|
2617 | - public function is_cornerstone_preview() { |
|
2618 | - $result = false; |
|
2619 | - if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) { |
|
2620 | - $result = true; |
|
2621 | - } |
|
2622 | - |
|
2623 | - return $result; |
|
2624 | - } |
|
2625 | - |
|
2626 | - /** |
|
2627 | - * Tests if the current output is inside a fusion builder preview. |
|
2628 | - * |
|
2629 | - * @since 1.1.0 |
|
2630 | - * @return bool |
|
2631 | - */ |
|
2632 | - public function is_fusion_preview() { |
|
2633 | - $result = false; |
|
2634 | - if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) { |
|
2635 | - $result = true; |
|
2636 | - } |
|
2637 | - |
|
2638 | - return $result; |
|
2639 | - } |
|
2640 | - |
|
2641 | - /** |
|
2642 | - * Tests if the current output is inside a Oxygen builder preview. |
|
2643 | - * |
|
2644 | - * @since 1.0.18 |
|
2645 | - * @return bool |
|
2646 | - */ |
|
2647 | - public function is_oxygen_preview() { |
|
2648 | - $result = false; |
|
2649 | - if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) { |
|
2650 | - $result = true; |
|
2651 | - } |
|
2652 | - |
|
2653 | - return $result; |
|
2654 | - } |
|
2655 | - |
|
2656 | - /** |
|
2657 | - * General function to check if we are in a preview situation. |
|
2658 | - * |
|
2659 | - * @since 1.0.6 |
|
2660 | - * @return bool |
|
2661 | - */ |
|
2662 | - public function is_preview() { |
|
2663 | - $preview = false; |
|
2664 | - if ( $this->is_divi_preview() ) { |
|
2665 | - $preview = true; |
|
2666 | - } elseif ( $this->is_elementor_preview() ) { |
|
2667 | - $preview = true; |
|
2668 | - } elseif ( $this->is_beaver_preview() ) { |
|
2669 | - $preview = true; |
|
2670 | - } elseif ( $this->is_siteorigin_preview() ) { |
|
2671 | - $preview = true; |
|
2672 | - } elseif ( $this->is_cornerstone_preview() ) { |
|
2673 | - $preview = true; |
|
2674 | - } elseif ( $this->is_fusion_preview() ) { |
|
2675 | - $preview = true; |
|
2676 | - } elseif ( $this->is_oxygen_preview() ) { |
|
2677 | - $preview = true; |
|
2678 | - } elseif( $this->is_block_content_call() ) { |
|
2679 | - $preview = true; |
|
2680 | - } |
|
2681 | - |
|
2682 | - return $preview; |
|
2683 | - } |
|
2684 | - |
|
2685 | - /** |
|
2686 | - * Output the super title. |
|
2687 | - * |
|
2688 | - * @param $args |
|
2689 | - * @param array $instance |
|
2690 | - * |
|
2691 | - * @return string |
|
2692 | - */ |
|
2693 | - public function output_title( $args, $instance = array() ) { |
|
2694 | - $output = ''; |
|
2695 | - if ( ! empty( $instance['title'] ) ) { |
|
2696 | - /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */ |
|
2697 | - $title = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base ); |
|
2698 | - |
|
2699 | - if(empty($instance['widget_title_tag'])){ |
|
2700 | - $output = $args['before_title'] . $title . $args['after_title']; |
|
2701 | - }else{ |
|
2702 | - $title_tag = esc_attr( $instance['widget_title_tag'] ); |
|
2703 | - |
|
2704 | - // classes |
|
2705 | - $title_classes = array(); |
|
2706 | - $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : ''; |
|
2707 | - $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : ''; |
|
2708 | - $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : ''; |
|
2709 | - $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : ''; |
|
2710 | - $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : ''; |
|
2711 | - $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : ''; |
|
2712 | - $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : ''; |
|
2713 | - $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : ''; |
|
2714 | - $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : ''; |
|
2715 | - $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : ''; |
|
2716 | - $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : ''; |
|
2717 | - $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : ''; |
|
2718 | - $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : ''; |
|
2719 | - |
|
2720 | - $class = !empty( $title_classes ) ? implode(" ",$title_classes) : ''; |
|
2721 | - $output = "<$title_tag class='$class' >$title</$title_tag>"; |
|
2722 | - } |
|
2723 | - |
|
2724 | - } |
|
2725 | - |
|
2726 | - return $output; |
|
2727 | - } |
|
2728 | - |
|
2729 | - /** |
|
2730 | - * Outputs the options form inputs for the widget. |
|
2731 | - * |
|
2732 | - * @param array $instance The widget options. |
|
2733 | - */ |
|
2734 | - public function form( $instance ) { |
|
2735 | - |
|
2736 | - // set widget instance |
|
2737 | - $this->instance = $instance; |
|
2738 | - |
|
2739 | - // set it as a SD widget |
|
2740 | - echo $this->widget_advanced_toggle(); |
|
2741 | - |
|
2742 | - echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>"; |
|
2743 | - $arguments_raw = $this->get_arguments(); |
|
2744 | - |
|
2745 | - if ( is_array( $arguments_raw ) ) { |
|
2746 | - |
|
2747 | - $arguments = $this->group_arguments( $arguments_raw ); |
|
2748 | - |
|
2749 | - // Do we have sections? |
|
2750 | - $has_sections = $arguments == $arguments_raw ? false : true; |
|
2751 | - |
|
2752 | - |
|
2753 | - if ( $has_sections ) { |
|
2754 | - $panel_count = 0; |
|
2755 | - foreach ( $arguments as $key => $args ) { |
|
2756 | - |
|
2757 | - ?> |
|
2336 | + } |
|
2337 | + |
|
2338 | + /** |
|
2339 | + * Convert an array of attributes to block string. |
|
2340 | + * |
|
2341 | + * @todo there is prob a faster way to do this, also we could add some validation here. |
|
2342 | + * |
|
2343 | + * @param $custom_attributes |
|
2344 | + * |
|
2345 | + * @return string |
|
2346 | + */ |
|
2347 | + public function array_to_attributes( $custom_attributes, $html = false ) { |
|
2348 | + $attributes = ''; |
|
2349 | + if ( ! empty( $custom_attributes ) ) { |
|
2350 | + |
|
2351 | + if ( $html ) { |
|
2352 | + foreach ( $custom_attributes as $key => $val ) { |
|
2353 | + $attributes .= " $key='$val' "; |
|
2354 | + } |
|
2355 | + } else { |
|
2356 | + foreach ( $custom_attributes as $key => $val ) { |
|
2357 | + $attributes .= "'$key': '$val',"; |
|
2358 | + } |
|
2359 | + } |
|
2360 | + } |
|
2361 | + |
|
2362 | + return $attributes; |
|
2363 | + } |
|
2364 | + |
|
2365 | + /** |
|
2366 | + * A self looping function to create the output for JS block elements. |
|
2367 | + * |
|
2368 | + * This is what is output in the WP Editor visual view. |
|
2369 | + * |
|
2370 | + * @param $args |
|
2371 | + */ |
|
2372 | + public function block_element( $args ) { |
|
2373 | + |
|
2374 | + |
|
2375 | + if ( ! empty( $args ) ) { |
|
2376 | + foreach ( $args as $element => $new_args ) { |
|
2377 | + |
|
2378 | + if ( is_array( $new_args ) ) { // its an element |
|
2379 | + |
|
2380 | + |
|
2381 | + if ( isset( $new_args['element'] ) ) { |
|
2382 | + |
|
2383 | + if ( isset( $new_args['element_require'] ) ) { |
|
2384 | + echo str_replace( array( |
|
2385 | + "'+", |
|
2386 | + "+'" |
|
2387 | + ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " && "; |
|
2388 | + unset( $new_args['element_require'] ); |
|
2389 | + } |
|
2390 | + |
|
2391 | + echo "\n el( '" . $new_args['element'] . "', {"; |
|
2392 | + |
|
2393 | + // get the attributes |
|
2394 | + foreach ( $new_args as $new_key => $new_value ) { |
|
2395 | + |
|
2396 | + |
|
2397 | + if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) { |
|
2398 | + // do nothing |
|
2399 | + } else { |
|
2400 | + echo $this->block_element( array( $new_key => $new_value ) ); |
|
2401 | + } |
|
2402 | + } |
|
2403 | + |
|
2404 | + echo "},";// end attributes |
|
2405 | + |
|
2406 | + // get the content |
|
2407 | + $first_item = 0; |
|
2408 | + foreach ( $new_args as $new_key => $new_value ) { |
|
2409 | + if ( $new_key === 'content' || is_array( $new_value ) ) { |
|
2410 | + |
|
2411 | + if ( $new_key === 'content' ) { |
|
2412 | + echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'"; |
|
2413 | + } |
|
2414 | + |
|
2415 | + if ( is_array( $new_value ) ) { |
|
2416 | + |
|
2417 | + if ( isset( $new_value['element_require'] ) ) { |
|
2418 | + echo str_replace( array( |
|
2419 | + "'+", |
|
2420 | + "+'" |
|
2421 | + ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " && "; |
|
2422 | + unset( $new_value['element_require'] ); |
|
2423 | + } |
|
2424 | + |
|
2425 | + if ( isset( $new_value['element_repeat'] ) ) { |
|
2426 | + $x = 1; |
|
2427 | + while ( $x <= absint( $new_value['element_repeat'] ) ) { |
|
2428 | + $this->block_element( array( '' => $new_value ) ); |
|
2429 | + $x ++; |
|
2430 | + } |
|
2431 | + } else { |
|
2432 | + $this->block_element( array( '' => $new_value ) ); |
|
2433 | + } |
|
2434 | + } |
|
2435 | + $first_item ++; |
|
2436 | + } |
|
2437 | + } |
|
2438 | + |
|
2439 | + echo ")";// end content |
|
2440 | + |
|
2441 | + echo ", \n"; |
|
2442 | + |
|
2443 | + } |
|
2444 | + } else { |
|
2445 | + |
|
2446 | + if ( substr( $element, 0, 3 ) === "if_" ) { |
|
2447 | + echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ","; |
|
2448 | + } elseif ( $element == 'style' ) { |
|
2449 | + echo $element . ": " . $this->block_props_replace( $new_args ) . ","; |
|
2450 | + } else { |
|
2451 | + echo $element . ": '" . $this->block_props_replace( $new_args ) . "',"; |
|
2452 | + } |
|
2453 | + |
|
2454 | + } |
|
2455 | + } |
|
2456 | + } |
|
2457 | + } |
|
2458 | + |
|
2459 | + /** |
|
2460 | + * Replace block attributes placeholders with the proper naming. |
|
2461 | + * |
|
2462 | + * @param $string |
|
2463 | + * |
|
2464 | + * @return mixed |
|
2465 | + */ |
|
2466 | + public function block_props_replace( $string, $no_wrap = false ) { |
|
2467 | + |
|
2468 | + if ( $no_wrap ) { |
|
2469 | + $string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string ); |
|
2470 | + } else { |
|
2471 | + $string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string ); |
|
2472 | + } |
|
2473 | + |
|
2474 | + return $string; |
|
2475 | + } |
|
2476 | + |
|
2477 | + /** |
|
2478 | + * Outputs the content of the widget |
|
2479 | + * |
|
2480 | + * @param array $args |
|
2481 | + * @param array $instance |
|
2482 | + */ |
|
2483 | + public function widget( $args, $instance ) { |
|
2484 | + |
|
2485 | + // get the filtered values |
|
2486 | + $argument_values = $this->argument_values( $instance ); |
|
2487 | + $argument_values = $this->string_to_bool( $argument_values ); |
|
2488 | + $output = $this->output( $argument_values, $args ); |
|
2489 | + |
|
2490 | + $no_wrap = false; |
|
2491 | + if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) { |
|
2492 | + $no_wrap = true; |
|
2493 | + } |
|
2494 | + |
|
2495 | + ob_start(); |
|
2496 | + if ( $output && ! $no_wrap ) { |
|
2497 | + |
|
2498 | + $class_original = $this->options['widget_ops']['classname']; |
|
2499 | + $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash(); |
|
2500 | + |
|
2501 | + // Before widget |
|
2502 | + $before_widget = $args['before_widget']; |
|
2503 | + $before_widget = str_replace($class_original,$class,$before_widget); |
|
2504 | + $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this ); |
|
2505 | + $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this ); |
|
2506 | + |
|
2507 | + // After widget |
|
2508 | + $after_widget = $args['after_widget']; |
|
2509 | + $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this ); |
|
2510 | + $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this ); |
|
2511 | + |
|
2512 | + echo $before_widget; |
|
2513 | + // elementor strips the widget wrapping div so we check for and add it back if needed |
|
2514 | + if ( $this->is_elementor_widget_output() ) { |
|
2515 | + echo ! empty( $this->options['widget_ops']['classname'] ) ? "<span class='" . esc_attr( $class ) . "'>" : ''; |
|
2516 | + } |
|
2517 | + echo $this->output_title( $args, $instance ); |
|
2518 | + echo $output; |
|
2519 | + if ( $this->is_elementor_widget_output() ) { |
|
2520 | + echo ! empty( $this->options['widget_ops']['classname'] ) ? "</span>" : ''; |
|
2521 | + } |
|
2522 | + echo $after_widget; |
|
2523 | + } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty |
|
2524 | + $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" ); |
|
2525 | + echo $output; |
|
2526 | + } elseif ( $output && $no_wrap ) { |
|
2527 | + echo $output; |
|
2528 | + } |
|
2529 | + $output = ob_get_clean(); |
|
2530 | + |
|
2531 | + $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this ); |
|
2532 | + |
|
2533 | + echo $output; |
|
2534 | + } |
|
2535 | + |
|
2536 | + /** |
|
2537 | + * Tests if the current output is inside a elementor container. |
|
2538 | + * |
|
2539 | + * @since 1.0.4 |
|
2540 | + * @return bool |
|
2541 | + */ |
|
2542 | + public function is_elementor_widget_output() { |
|
2543 | + $result = false; |
|
2544 | + if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) { |
|
2545 | + $result = true; |
|
2546 | + } |
|
2547 | + |
|
2548 | + return $result; |
|
2549 | + } |
|
2550 | + |
|
2551 | + /** |
|
2552 | + * Tests if the current output is inside a elementor preview. |
|
2553 | + * |
|
2554 | + * @since 1.0.4 |
|
2555 | + * @return bool |
|
2556 | + */ |
|
2557 | + public function is_elementor_preview() { |
|
2558 | + $result = false; |
|
2559 | + if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) { |
|
2560 | + $result = true; |
|
2561 | + } |
|
2562 | + |
|
2563 | + return $result; |
|
2564 | + } |
|
2565 | + |
|
2566 | + /** |
|
2567 | + * Tests if the current output is inside a Divi preview. |
|
2568 | + * |
|
2569 | + * @since 1.0.6 |
|
2570 | + * @return bool |
|
2571 | + */ |
|
2572 | + public function is_divi_preview() { |
|
2573 | + $result = false; |
|
2574 | + if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) { |
|
2575 | + $result = true; |
|
2576 | + } |
|
2577 | + |
|
2578 | + return $result; |
|
2579 | + } |
|
2580 | + |
|
2581 | + /** |
|
2582 | + * Tests if the current output is inside a Beaver builder preview. |
|
2583 | + * |
|
2584 | + * @since 1.0.6 |
|
2585 | + * @return bool |
|
2586 | + */ |
|
2587 | + public function is_beaver_preview() { |
|
2588 | + $result = false; |
|
2589 | + if ( isset( $_REQUEST['fl_builder'] ) ) { |
|
2590 | + $result = true; |
|
2591 | + } |
|
2592 | + |
|
2593 | + return $result; |
|
2594 | + } |
|
2595 | + |
|
2596 | + /** |
|
2597 | + * Tests if the current output is inside a siteorigin builder preview. |
|
2598 | + * |
|
2599 | + * @since 1.0.6 |
|
2600 | + * @return bool |
|
2601 | + */ |
|
2602 | + public function is_siteorigin_preview() { |
|
2603 | + $result = false; |
|
2604 | + if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) { |
|
2605 | + $result = true; |
|
2606 | + } |
|
2607 | + |
|
2608 | + return $result; |
|
2609 | + } |
|
2610 | + |
|
2611 | + /** |
|
2612 | + * Tests if the current output is inside a cornerstone builder preview. |
|
2613 | + * |
|
2614 | + * @since 1.0.8 |
|
2615 | + * @return bool |
|
2616 | + */ |
|
2617 | + public function is_cornerstone_preview() { |
|
2618 | + $result = false; |
|
2619 | + if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) { |
|
2620 | + $result = true; |
|
2621 | + } |
|
2622 | + |
|
2623 | + return $result; |
|
2624 | + } |
|
2625 | + |
|
2626 | + /** |
|
2627 | + * Tests if the current output is inside a fusion builder preview. |
|
2628 | + * |
|
2629 | + * @since 1.1.0 |
|
2630 | + * @return bool |
|
2631 | + */ |
|
2632 | + public function is_fusion_preview() { |
|
2633 | + $result = false; |
|
2634 | + if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) { |
|
2635 | + $result = true; |
|
2636 | + } |
|
2637 | + |
|
2638 | + return $result; |
|
2639 | + } |
|
2640 | + |
|
2641 | + /** |
|
2642 | + * Tests if the current output is inside a Oxygen builder preview. |
|
2643 | + * |
|
2644 | + * @since 1.0.18 |
|
2645 | + * @return bool |
|
2646 | + */ |
|
2647 | + public function is_oxygen_preview() { |
|
2648 | + $result = false; |
|
2649 | + if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) { |
|
2650 | + $result = true; |
|
2651 | + } |
|
2652 | + |
|
2653 | + return $result; |
|
2654 | + } |
|
2655 | + |
|
2656 | + /** |
|
2657 | + * General function to check if we are in a preview situation. |
|
2658 | + * |
|
2659 | + * @since 1.0.6 |
|
2660 | + * @return bool |
|
2661 | + */ |
|
2662 | + public function is_preview() { |
|
2663 | + $preview = false; |
|
2664 | + if ( $this->is_divi_preview() ) { |
|
2665 | + $preview = true; |
|
2666 | + } elseif ( $this->is_elementor_preview() ) { |
|
2667 | + $preview = true; |
|
2668 | + } elseif ( $this->is_beaver_preview() ) { |
|
2669 | + $preview = true; |
|
2670 | + } elseif ( $this->is_siteorigin_preview() ) { |
|
2671 | + $preview = true; |
|
2672 | + } elseif ( $this->is_cornerstone_preview() ) { |
|
2673 | + $preview = true; |
|
2674 | + } elseif ( $this->is_fusion_preview() ) { |
|
2675 | + $preview = true; |
|
2676 | + } elseif ( $this->is_oxygen_preview() ) { |
|
2677 | + $preview = true; |
|
2678 | + } elseif( $this->is_block_content_call() ) { |
|
2679 | + $preview = true; |
|
2680 | + } |
|
2681 | + |
|
2682 | + return $preview; |
|
2683 | + } |
|
2684 | + |
|
2685 | + /** |
|
2686 | + * Output the super title. |
|
2687 | + * |
|
2688 | + * @param $args |
|
2689 | + * @param array $instance |
|
2690 | + * |
|
2691 | + * @return string |
|
2692 | + */ |
|
2693 | + public function output_title( $args, $instance = array() ) { |
|
2694 | + $output = ''; |
|
2695 | + if ( ! empty( $instance['title'] ) ) { |
|
2696 | + /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */ |
|
2697 | + $title = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base ); |
|
2698 | + |
|
2699 | + if(empty($instance['widget_title_tag'])){ |
|
2700 | + $output = $args['before_title'] . $title . $args['after_title']; |
|
2701 | + }else{ |
|
2702 | + $title_tag = esc_attr( $instance['widget_title_tag'] ); |
|
2703 | + |
|
2704 | + // classes |
|
2705 | + $title_classes = array(); |
|
2706 | + $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : ''; |
|
2707 | + $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : ''; |
|
2708 | + $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : ''; |
|
2709 | + $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : ''; |
|
2710 | + $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : ''; |
|
2711 | + $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : ''; |
|
2712 | + $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : ''; |
|
2713 | + $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : ''; |
|
2714 | + $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : ''; |
|
2715 | + $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : ''; |
|
2716 | + $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : ''; |
|
2717 | + $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : ''; |
|
2718 | + $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : ''; |
|
2719 | + |
|
2720 | + $class = !empty( $title_classes ) ? implode(" ",$title_classes) : ''; |
|
2721 | + $output = "<$title_tag class='$class' >$title</$title_tag>"; |
|
2722 | + } |
|
2723 | + |
|
2724 | + } |
|
2725 | + |
|
2726 | + return $output; |
|
2727 | + } |
|
2728 | + |
|
2729 | + /** |
|
2730 | + * Outputs the options form inputs for the widget. |
|
2731 | + * |
|
2732 | + * @param array $instance The widget options. |
|
2733 | + */ |
|
2734 | + public function form( $instance ) { |
|
2735 | + |
|
2736 | + // set widget instance |
|
2737 | + $this->instance = $instance; |
|
2738 | + |
|
2739 | + // set it as a SD widget |
|
2740 | + echo $this->widget_advanced_toggle(); |
|
2741 | + |
|
2742 | + echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>"; |
|
2743 | + $arguments_raw = $this->get_arguments(); |
|
2744 | + |
|
2745 | + if ( is_array( $arguments_raw ) ) { |
|
2746 | + |
|
2747 | + $arguments = $this->group_arguments( $arguments_raw ); |
|
2748 | + |
|
2749 | + // Do we have sections? |
|
2750 | + $has_sections = $arguments == $arguments_raw ? false : true; |
|
2751 | + |
|
2752 | + |
|
2753 | + if ( $has_sections ) { |
|
2754 | + $panel_count = 0; |
|
2755 | + foreach ( $arguments as $key => $args ) { |
|
2756 | + |
|
2757 | + ?> |
|
2758 | 2758 | <script> |
2759 | 2759 | // jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle(); |
2760 | 2760 | </script> |
2761 | 2761 | <?php |
2762 | 2762 | |
2763 | - $hide = $panel_count ? ' style="display:none;" ' : ''; |
|
2764 | - $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down'; |
|
2765 | - echo "<button onclick='jQuery(this).find(\"i\").toggleClass(\"fas fa-chevron-up fas fa-chevron-down\");jQuery(this).next().slideToggle();' type='button' class='sd-toggle-group-button sd-input-group-toggle" . sanitize_title_with_dashes( $key ) . "'>" . esc_attr( $key ) . " <i style='float:right;' class='" . $icon_class . "'></i></button>"; |
|
2766 | - echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>"; |
|
2763 | + $hide = $panel_count ? ' style="display:none;" ' : ''; |
|
2764 | + $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down'; |
|
2765 | + echo "<button onclick='jQuery(this).find(\"i\").toggleClass(\"fas fa-chevron-up fas fa-chevron-down\");jQuery(this).next().slideToggle();' type='button' class='sd-toggle-group-button sd-input-group-toggle" . sanitize_title_with_dashes( $key ) . "'>" . esc_attr( $key ) . " <i style='float:right;' class='" . $icon_class . "'></i></button>"; |
|
2766 | + echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>"; |
|
2767 | 2767 | |
2768 | - foreach ( $args as $k => $a ) { |
|
2768 | + foreach ( $args as $k => $a ) { |
|
2769 | 2769 | |
2770 | - $this->widget_inputs_row_start($k, $a); |
|
2771 | - $this->widget_inputs( $a, $instance ); |
|
2772 | - $this->widget_inputs_row_end($k, $a); |
|
2770 | + $this->widget_inputs_row_start($k, $a); |
|
2771 | + $this->widget_inputs( $a, $instance ); |
|
2772 | + $this->widget_inputs_row_end($k, $a); |
|
2773 | 2773 | |
2774 | - } |
|
2774 | + } |
|
2775 | 2775 | |
2776 | - echo "</div>"; |
|
2776 | + echo "</div>"; |
|
2777 | 2777 | |
2778 | - $panel_count ++; |
|
2778 | + $panel_count ++; |
|
2779 | 2779 | |
2780 | - } |
|
2781 | - } else { |
|
2782 | - foreach ( $arguments as $key => $args ) { |
|
2783 | - $this->widget_inputs_row_start($key, $args); |
|
2784 | - $this->widget_inputs( $args, $instance ); |
|
2785 | - $this->widget_inputs_row_end($key, $args); |
|
2786 | - } |
|
2787 | - } |
|
2780 | + } |
|
2781 | + } else { |
|
2782 | + foreach ( $arguments as $key => $args ) { |
|
2783 | + $this->widget_inputs_row_start($key, $args); |
|
2784 | + $this->widget_inputs( $args, $instance ); |
|
2785 | + $this->widget_inputs_row_end($key, $args); |
|
2786 | + } |
|
2787 | + } |
|
2788 | 2788 | |
2789 | - } |
|
2790 | - } |
|
2789 | + } |
|
2790 | + } |
|
2791 | 2791 | |
2792 | - public function widget_inputs_row_start($key, $args){ |
|
2793 | - if(!empty($args['row'])){ |
|
2794 | - // maybe open |
|
2795 | - if(!empty($args['row']['open'])){ |
|
2796 | - ?> |
|
2792 | + public function widget_inputs_row_start($key, $args){ |
|
2793 | + if(!empty($args['row'])){ |
|
2794 | + // maybe open |
|
2795 | + if(!empty($args['row']['open'])){ |
|
2796 | + ?> |
|
2797 | 2797 | <div class='bsui sd-argument ' data-argument='<?php echo esc_attr( $args['row']['key'] ); ?>' data-element_require='<?php if ( !empty($args['row']['element_require'])) { |
2798 | - echo $this->convert_element_require( $args['row']['element_require'] ); |
|
2799 | - } ?>'> |
|
2798 | + echo $this->convert_element_require( $args['row']['element_require'] ); |
|
2799 | + } ?>'> |
|
2800 | 2800 | <?php if(!empty($args['row']['title'])){ ?> |
2801 | 2801 | <label class="mb-0 "><?php echo esc_attr( $args['row']['title'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label> |
2802 | 2802 | <?php }?> |
2803 | 2803 | <div class='row <?php if(!empty($args['row']['class'])){ echo esc_attr($args['row']['class']);} ?>'> |
2804 | 2804 | <div class='col pr-2'> |
2805 | 2805 | <?php |
2806 | - }elseif(!empty($args['row']['close'])){ |
|
2807 | - echo "<div class='col pl-0'>"; |
|
2808 | - }else{ |
|
2809 | - echo "<div class='col pl-0 pr-2'>"; |
|
2810 | - } |
|
2811 | - } |
|
2812 | - } |
|
2813 | - |
|
2814 | - public function widget_inputs_row_end($key, $args){ |
|
2815 | - |
|
2816 | - if(!empty($args['row'])){ |
|
2817 | - // maybe close |
|
2818 | - if(!empty($args['row']['close'])){ |
|
2819 | - echo "</div></div>"; |
|
2820 | - } |
|
2821 | - |
|
2822 | - echo "</div>"; |
|
2823 | - } |
|
2824 | - } |
|
2825 | - |
|
2826 | - /** |
|
2827 | - * Get the hidden input that when added makes the advanced button show on widget settings. |
|
2828 | - * |
|
2829 | - * @return string |
|
2830 | - */ |
|
2831 | - public function widget_advanced_toggle() { |
|
2832 | - |
|
2833 | - $output = ''; |
|
2834 | - if ( $this->block_show_advanced() ) { |
|
2835 | - $val = 1; |
|
2836 | - } else { |
|
2837 | - $val = 0; |
|
2838 | - } |
|
2839 | - |
|
2840 | - $output .= "<input type='hidden' class='sd-show-advanced' value='$val' />"; |
|
2841 | - |
|
2842 | - return $output; |
|
2843 | - } |
|
2844 | - |
|
2845 | - /** |
|
2846 | - * Convert require element. |
|
2847 | - * |
|
2848 | - * @since 1.0.0 |
|
2849 | - * |
|
2850 | - * @param string $input Input element. |
|
2851 | - * |
|
2852 | - * @return string $output |
|
2853 | - */ |
|
2854 | - public function convert_element_require( $input ) { |
|
2855 | - |
|
2856 | - $input = str_replace( "'", '"', $input );// we only want double quotes |
|
2857 | - |
|
2858 | - $output = esc_attr( str_replace( array( "[%", "%]" ), array( |
|
2859 | - "jQuery(form).find('[data-argument=\"", |
|
2860 | - "\"]').find('input,select,textarea').val()" |
|
2861 | - ), $input ) ); |
|
2862 | - |
|
2863 | - return $output; |
|
2864 | - } |
|
2865 | - |
|
2866 | - /** |
|
2867 | - * Builds the inputs for the widget options. |
|
2868 | - * |
|
2869 | - * @param $args |
|
2870 | - * @param $instance |
|
2871 | - */ |
|
2872 | - public function widget_inputs( $args, $instance ) { |
|
2873 | - |
|
2874 | - $class = ""; |
|
2875 | - $element_require = ""; |
|
2876 | - $custom_attributes = ""; |
|
2877 | - |
|
2878 | - // get value |
|
2879 | - if ( isset( $instance[ $args['name'] ] ) ) { |
|
2880 | - $value = $instance[ $args['name'] ]; |
|
2881 | - } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) { |
|
2882 | - $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] ); |
|
2883 | - } else { |
|
2884 | - $value = ''; |
|
2885 | - } |
|
2886 | - |
|
2887 | - // get placeholder |
|
2888 | - if ( ! empty( $args['placeholder'] ) ) { |
|
2889 | - $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'"; |
|
2890 | - } else { |
|
2891 | - $placeholder = ''; |
|
2892 | - } |
|
2893 | - |
|
2894 | - // get if advanced |
|
2895 | - if ( isset( $args['advanced'] ) && $args['advanced'] ) { |
|
2896 | - $class .= " sd-advanced-setting "; |
|
2897 | - } |
|
2898 | - |
|
2899 | - // element_require |
|
2900 | - if ( isset( $args['element_require'] ) && $args['element_require'] ) { |
|
2901 | - $element_require = $args['element_require']; |
|
2902 | - } |
|
2903 | - |
|
2904 | - // custom_attributes |
|
2905 | - if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) { |
|
2906 | - $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true ); |
|
2907 | - } |
|
2908 | - |
|
2909 | - |
|
2910 | - // before wrapper |
|
2911 | - ?> |
|
2806 | + }elseif(!empty($args['row']['close'])){ |
|
2807 | + echo "<div class='col pl-0'>"; |
|
2808 | + }else{ |
|
2809 | + echo "<div class='col pl-0 pr-2'>"; |
|
2810 | + } |
|
2811 | + } |
|
2812 | + } |
|
2813 | + |
|
2814 | + public function widget_inputs_row_end($key, $args){ |
|
2815 | + |
|
2816 | + if(!empty($args['row'])){ |
|
2817 | + // maybe close |
|
2818 | + if(!empty($args['row']['close'])){ |
|
2819 | + echo "</div></div>"; |
|
2820 | + } |
|
2821 | + |
|
2822 | + echo "</div>"; |
|
2823 | + } |
|
2824 | + } |
|
2825 | + |
|
2826 | + /** |
|
2827 | + * Get the hidden input that when added makes the advanced button show on widget settings. |
|
2828 | + * |
|
2829 | + * @return string |
|
2830 | + */ |
|
2831 | + public function widget_advanced_toggle() { |
|
2832 | + |
|
2833 | + $output = ''; |
|
2834 | + if ( $this->block_show_advanced() ) { |
|
2835 | + $val = 1; |
|
2836 | + } else { |
|
2837 | + $val = 0; |
|
2838 | + } |
|
2839 | + |
|
2840 | + $output .= "<input type='hidden' class='sd-show-advanced' value='$val' />"; |
|
2841 | + |
|
2842 | + return $output; |
|
2843 | + } |
|
2844 | + |
|
2845 | + /** |
|
2846 | + * Convert require element. |
|
2847 | + * |
|
2848 | + * @since 1.0.0 |
|
2849 | + * |
|
2850 | + * @param string $input Input element. |
|
2851 | + * |
|
2852 | + * @return string $output |
|
2853 | + */ |
|
2854 | + public function convert_element_require( $input ) { |
|
2855 | + |
|
2856 | + $input = str_replace( "'", '"', $input );// we only want double quotes |
|
2857 | + |
|
2858 | + $output = esc_attr( str_replace( array( "[%", "%]" ), array( |
|
2859 | + "jQuery(form).find('[data-argument=\"", |
|
2860 | + "\"]').find('input,select,textarea').val()" |
|
2861 | + ), $input ) ); |
|
2862 | + |
|
2863 | + return $output; |
|
2864 | + } |
|
2865 | + |
|
2866 | + /** |
|
2867 | + * Builds the inputs for the widget options. |
|
2868 | + * |
|
2869 | + * @param $args |
|
2870 | + * @param $instance |
|
2871 | + */ |
|
2872 | + public function widget_inputs( $args, $instance ) { |
|
2873 | + |
|
2874 | + $class = ""; |
|
2875 | + $element_require = ""; |
|
2876 | + $custom_attributes = ""; |
|
2877 | + |
|
2878 | + // get value |
|
2879 | + if ( isset( $instance[ $args['name'] ] ) ) { |
|
2880 | + $value = $instance[ $args['name'] ]; |
|
2881 | + } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) { |
|
2882 | + $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] ); |
|
2883 | + } else { |
|
2884 | + $value = ''; |
|
2885 | + } |
|
2886 | + |
|
2887 | + // get placeholder |
|
2888 | + if ( ! empty( $args['placeholder'] ) ) { |
|
2889 | + $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'"; |
|
2890 | + } else { |
|
2891 | + $placeholder = ''; |
|
2892 | + } |
|
2893 | + |
|
2894 | + // get if advanced |
|
2895 | + if ( isset( $args['advanced'] ) && $args['advanced'] ) { |
|
2896 | + $class .= " sd-advanced-setting "; |
|
2897 | + } |
|
2898 | + |
|
2899 | + // element_require |
|
2900 | + if ( isset( $args['element_require'] ) && $args['element_require'] ) { |
|
2901 | + $element_require = $args['element_require']; |
|
2902 | + } |
|
2903 | + |
|
2904 | + // custom_attributes |
|
2905 | + if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) { |
|
2906 | + $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true ); |
|
2907 | + } |
|
2908 | + |
|
2909 | + |
|
2910 | + // before wrapper |
|
2911 | + ?> |
|
2912 | 2912 | <p class="sd-argument <?php echo esc_attr( $class ); ?>" |
2913 | 2913 | data-argument='<?php echo esc_attr( $args['name'] ); ?>' |
2914 | 2914 | data-element_require='<?php if ( $element_require ) { |
2915 | - echo $this->convert_element_require( $element_require ); |
|
2916 | - } ?>' |
|
2915 | + echo $this->convert_element_require( $element_require ); |
|
2916 | + } ?>' |
|
2917 | 2917 | > |
2918 | 2918 | <?php |
2919 | 2919 | |
2920 | 2920 | |
2921 | - switch ( $args['type'] ) { |
|
2922 | - //array('text','password','number','email','tel','url','color') |
|
2923 | - case "text": |
|
2924 | - case "password": |
|
2925 | - case "number": |
|
2926 | - case "email": |
|
2927 | - case "tel": |
|
2928 | - case "url": |
|
2929 | - case "color": |
|
2930 | - ?> |
|
2921 | + switch ( $args['type'] ) { |
|
2922 | + //array('text','password','number','email','tel','url','color') |
|
2923 | + case "text": |
|
2924 | + case "password": |
|
2925 | + case "number": |
|
2926 | + case "email": |
|
2927 | + case "tel": |
|
2928 | + case "url": |
|
2929 | + case "color": |
|
2930 | + ?> |
|
2931 | 2931 | <label |
2932 | 2932 | for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args );?><?php echo $this->widget_field_desc( $args ); ?></label> |
2933 | 2933 | <input <?php echo $placeholder; ?> class="widefat" |
@@ -2938,47 +2938,47 @@ discard block |
||
2938 | 2938 | value="<?php echo esc_attr( $value ); ?>"> |
2939 | 2939 | <?php |
2940 | 2940 | |
2941 | - break; |
|
2942 | - case "select": |
|
2943 | - $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false; |
|
2944 | - if ( $multiple ) { |
|
2945 | - if ( empty( $value ) ) { |
|
2946 | - $value = array(); |
|
2947 | - } |
|
2948 | - } |
|
2949 | - ?> |
|
2941 | + break; |
|
2942 | + case "select": |
|
2943 | + $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false; |
|
2944 | + if ( $multiple ) { |
|
2945 | + if ( empty( $value ) ) { |
|
2946 | + $value = array(); |
|
2947 | + } |
|
2948 | + } |
|
2949 | + ?> |
|
2950 | 2950 | <label |
2951 | 2951 | for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args ); ?><?php echo $this->widget_field_desc( $args ); ?></label> |
2952 | 2952 | <select <?php echo $placeholder; ?> class="widefat" |
2953 | 2953 | <?php echo $custom_attributes; ?> |
2954 | 2954 | id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" |
2955 | 2955 | name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); |
2956 | - if ( $multiple ) { |
|
2957 | - echo "[]"; |
|
2958 | - } ?>" |
|
2956 | + if ( $multiple ) { |
|
2957 | + echo "[]"; |
|
2958 | + } ?>" |
|
2959 | 2959 | <?php if ( $multiple ) { |
2960 | - echo "multiple"; |
|
2961 | - } //@todo not implemented yet due to gutenberg not supporting it |
|
2962 | - ?> |
|
2960 | + echo "multiple"; |
|
2961 | + } //@todo not implemented yet due to gutenberg not supporting it |
|
2962 | + ?> |
|
2963 | 2963 | > |
2964 | 2964 | <?php |
2965 | 2965 | |
2966 | - if ( ! empty( $args['options'] ) ) { |
|
2967 | - foreach ( $args['options'] as $val => $label ) { |
|
2968 | - if ( $multiple ) { |
|
2969 | - $selected = in_array( $val, $value ) ? 'selected="selected"' : ''; |
|
2970 | - } else { |
|
2971 | - $selected = selected( $value, $val, false ); |
|
2972 | - } |
|
2973 | - echo "<option value='$val' " . $selected . ">$label</option>"; |
|
2974 | - } |
|
2975 | - } |
|
2976 | - ?> |
|
2966 | + if ( ! empty( $args['options'] ) ) { |
|
2967 | + foreach ( $args['options'] as $val => $label ) { |
|
2968 | + if ( $multiple ) { |
|
2969 | + $selected = in_array( $val, $value ) ? 'selected="selected"' : ''; |
|
2970 | + } else { |
|
2971 | + $selected = selected( $value, $val, false ); |
|
2972 | + } |
|
2973 | + echo "<option value='$val' " . $selected . ">$label</option>"; |
|
2974 | + } |
|
2975 | + } |
|
2976 | + ?> |
|
2977 | 2977 | </select> |
2978 | 2978 | <?php |
2979 | - break; |
|
2980 | - case "checkbox": |
|
2981 | - ?> |
|
2979 | + break; |
|
2980 | + case "checkbox": |
|
2981 | + ?> |
|
2982 | 2982 | <input <?php echo $placeholder; ?> |
2983 | 2983 | <?php checked( 1, $value, true ) ?> |
2984 | 2984 | <?php echo $custom_attributes; ?> |
@@ -2988,9 +2988,9 @@ discard block |
||
2988 | 2988 | <label |
2989 | 2989 | for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args );?><?php echo $this->widget_field_desc( $args ); ?></label> |
2990 | 2990 | <?php |
2991 | - break; |
|
2992 | - case "textarea": |
|
2993 | - ?> |
|
2991 | + break; |
|
2992 | + case "textarea": |
|
2993 | + ?> |
|
2994 | 2994 | <label |
2995 | 2995 | for="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>"><?php echo $this->widget_field_title( $args ); ?><?php echo $this->widget_field_desc( $args ); ?></label> |
2996 | 2996 | <textarea <?php echo $placeholder; ?> class="widefat" |
@@ -3000,207 +3000,207 @@ discard block |
||
3000 | 3000 | ><?php echo esc_attr( $value ); ?></textarea> |
3001 | 3001 | <?php |
3002 | 3002 | |
3003 | - break; |
|
3004 | - case "hidden": |
|
3005 | - ?> |
|
3003 | + break; |
|
3004 | + case "hidden": |
|
3005 | + ?> |
|
3006 | 3006 | <input id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" |
3007 | 3007 | name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="hidden" |
3008 | 3008 | value="<?php echo esc_attr( $value ); ?>"> |
3009 | 3009 | <?php |
3010 | - break; |
|
3011 | - default: |
|
3012 | - echo "No input type found!"; // @todo we need to add more input types. |
|
3013 | - } |
|
3010 | + break; |
|
3011 | + default: |
|
3012 | + echo "No input type found!"; // @todo we need to add more input types. |
|
3013 | + } |
|
3014 | 3014 | |
3015 | - // after wrapper |
|
3016 | - ?> |
|
3015 | + // after wrapper |
|
3016 | + ?> |
|
3017 | 3017 | </p> |
3018 | 3018 | <?php |
3019 | 3019 | |
3020 | 3020 | |
3021 | - } |
|
3022 | - |
|
3023 | - public function get_widget_icon($icon = 'box-top', $title = ''){ |
|
3024 | - if($icon=='box-top'){ |
|
3025 | - return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.048" height="9.017" fill="#555D66"></rect><rect x="16.265" y="5.498" width="1.023" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.186" width="8.964" height="2.482" fill="#272B2F"></rect><rect x="5.487" y="16.261" width="9.026" height="1.037" fill="#555D66"></rect></svg>'; |
|
3026 | - }elseif($icon=='box-right'){ |
|
3027 | - return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.046" height="9.017" fill="#555D66"></rect><rect x="15.244" y="5.498" width="2.518" height="9.003" fill="#272B2F"></rect><rect x="5.518" y="2.719" width="8.964" height="0.954" fill="#555D66"></rect><rect x="5.487" y="16.308" width="9.026" height="0.99" fill="#555D66"></rect></svg>'; |
|
3028 | - }elseif($icon=='box-bottom'){ |
|
3029 | - return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1" height="9.017" fill="#555D66"></rect><rect x="16.261" y="5.498" width="1.027" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.968" fill="#555D66"></rect><rect x="5.487" y="15.28" width="9.026" height="2.499" fill="#272B2F"></rect></svg>'; |
|
3030 | - }elseif($icon=='box-left'){ |
|
3031 | - return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.202" y="5.492" width="2.503" height="9.017" fill="#272B2F"></rect><rect x="16.276" y="5.498" width="1.012" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.966" fill="#555D66"></rect><rect x="5.487" y="16.303" width="9.026" height="0.995" fill="#555D66"></rect></svg>'; |
|
3032 | - } |
|
3033 | - } |
|
3034 | - |
|
3035 | - /** |
|
3036 | - * Get the widget input description html. |
|
3037 | - * |
|
3038 | - * @param $args |
|
3039 | - * |
|
3040 | - * @return string |
|
3041 | - * @todo, need to make its own tooltip script |
|
3042 | - */ |
|
3043 | - public function widget_field_desc( $args ) { |
|
3044 | - |
|
3045 | - $description = ''; |
|
3046 | - if ( isset( $args['desc'] ) && $args['desc'] ) { |
|
3047 | - if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) { |
|
3048 | - $description = $this->desc_tip( $args['desc'] ); |
|
3049 | - } else { |
|
3050 | - $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>'; |
|
3051 | - } |
|
3052 | - } |
|
3053 | - |
|
3054 | - return $description; |
|
3055 | - } |
|
3056 | - |
|
3057 | - /** |
|
3058 | - * Get the widget input title html. |
|
3059 | - * |
|
3060 | - * @param $args |
|
3061 | - * |
|
3062 | - * @return string |
|
3063 | - */ |
|
3064 | - public function widget_field_title( $args ) { |
|
3065 | - |
|
3066 | - $title = ''; |
|
3067 | - if ( isset( $args['title'] ) && $args['title'] ) { |
|
3068 | - if ( isset( $args['icon'] ) && $args['icon'] ) { |
|
3069 | - $title = self::get_widget_icon( $args['icon'], $args['title'] ); |
|
3070 | - } else { |
|
3071 | - $title = esc_attr($args['title']); |
|
3072 | - } |
|
3073 | - } |
|
3074 | - |
|
3075 | - return $title; |
|
3076 | - } |
|
3077 | - |
|
3078 | - /** |
|
3079 | - * Get the tool tip html. |
|
3080 | - * |
|
3081 | - * @param $tip |
|
3082 | - * @param bool $allow_html |
|
3083 | - * |
|
3084 | - * @return string |
|
3085 | - */ |
|
3086 | - function desc_tip( $tip, $allow_html = false ) { |
|
3087 | - if ( $allow_html ) { |
|
3088 | - $tip = $this->sanitize_tooltip( $tip ); |
|
3089 | - } else { |
|
3090 | - $tip = esc_attr( $tip ); |
|
3091 | - } |
|
3092 | - |
|
3093 | - return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>'; |
|
3094 | - } |
|
3095 | - |
|
3096 | - /** |
|
3097 | - * Sanitize a string destined to be a tooltip. |
|
3098 | - * |
|
3099 | - * @param string $var |
|
3100 | - * |
|
3101 | - * @return string |
|
3102 | - */ |
|
3103 | - public function sanitize_tooltip( $var ) { |
|
3104 | - return htmlspecialchars( wp_kses( html_entity_decode( $var ), array( |
|
3105 | - 'br' => array(), |
|
3106 | - 'em' => array(), |
|
3107 | - 'strong' => array(), |
|
3108 | - 'small' => array(), |
|
3109 | - 'span' => array(), |
|
3110 | - 'ul' => array(), |
|
3111 | - 'li' => array(), |
|
3112 | - 'ol' => array(), |
|
3113 | - 'p' => array(), |
|
3114 | - ) ) ); |
|
3115 | - } |
|
3116 | - |
|
3117 | - /** |
|
3118 | - * Processing widget options on save |
|
3119 | - * |
|
3120 | - * @param array $new_instance The new options |
|
3121 | - * @param array $old_instance The previous options |
|
3122 | - * |
|
3123 | - * @return array |
|
3124 | - * @todo we should add some sanitation here. |
|
3125 | - */ |
|
3126 | - public function update( $new_instance, $old_instance ) { |
|
3127 | - |
|
3128 | - //save the widget |
|
3129 | - $instance = array_merge( (array) $old_instance, (array) $new_instance ); |
|
3130 | - |
|
3131 | - // set widget instance |
|
3132 | - $this->instance = $instance; |
|
3133 | - |
|
3134 | - if ( empty( $this->arguments ) ) { |
|
3135 | - $this->get_arguments(); |
|
3136 | - } |
|
3137 | - |
|
3138 | - // check for checkboxes |
|
3139 | - if ( ! empty( $this->arguments ) ) { |
|
3140 | - foreach ( $this->arguments as $argument ) { |
|
3141 | - if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) { |
|
3142 | - $instance[ $argument['name'] ] = '0'; |
|
3143 | - } |
|
3144 | - } |
|
3145 | - } |
|
3146 | - |
|
3147 | - return $instance; |
|
3148 | - } |
|
3149 | - |
|
3150 | - /** |
|
3151 | - * Checks if the current call is a ajax call to get the block content. |
|
3152 | - * |
|
3153 | - * This can be used in your widget to return different content as the block content. |
|
3154 | - * |
|
3155 | - * @since 1.0.3 |
|
3156 | - * @return bool |
|
3157 | - */ |
|
3158 | - public function is_block_content_call() { |
|
3159 | - $result = false; |
|
3160 | - if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) { |
|
3161 | - $result = true; |
|
3162 | - } |
|
3163 | - |
|
3164 | - return $result; |
|
3165 | - } |
|
3166 | - |
|
3167 | - /** |
|
3168 | - * Get an instance hash that will be unique to the type and settings. |
|
3169 | - * |
|
3170 | - * @since 1.0.20 |
|
3171 | - * @return string |
|
3172 | - */ |
|
3173 | - public function get_instance_hash(){ |
|
3174 | - $instance_string = $this->base_id.serialize($this->instance); |
|
3175 | - return hash('crc32b',$instance_string); |
|
3176 | - } |
|
3177 | - |
|
3178 | - /** |
|
3179 | - * Generate and return inline styles from CSS rules that will match the unique class of the instance. |
|
3180 | - * |
|
3181 | - * @param array $rules |
|
3182 | - * |
|
3183 | - * @since 1.0.20 |
|
3184 | - * @return string |
|
3185 | - */ |
|
3186 | - public function get_instance_style($rules = array()){ |
|
3187 | - $css = ''; |
|
3188 | - |
|
3189 | - if(!empty($rules)){ |
|
3190 | - $rules = array_unique($rules); |
|
3191 | - $instance_hash = $this->get_instance_hash(); |
|
3192 | - $css .= "<style>"; |
|
3193 | - foreach($rules as $rule){ |
|
3194 | - $css .= ".sdel-$instance_hash $rule"; |
|
3195 | - } |
|
3196 | - $css .= "</style>"; |
|
3197 | - } |
|
3198 | - |
|
3199 | - |
|
3200 | - return $css; |
|
3201 | - |
|
3202 | - } |
|
3203 | - |
|
3204 | - } |
|
3021 | + } |
|
3022 | + |
|
3023 | + public function get_widget_icon($icon = 'box-top', $title = ''){ |
|
3024 | + if($icon=='box-top'){ |
|
3025 | + return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.048" height="9.017" fill="#555D66"></rect><rect x="16.265" y="5.498" width="1.023" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.186" width="8.964" height="2.482" fill="#272B2F"></rect><rect x="5.487" y="16.261" width="9.026" height="1.037" fill="#555D66"></rect></svg>'; |
|
3026 | + }elseif($icon=='box-right'){ |
|
3027 | + return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1.046" height="9.017" fill="#555D66"></rect><rect x="15.244" y="5.498" width="2.518" height="9.003" fill="#272B2F"></rect><rect x="5.518" y="2.719" width="8.964" height="0.954" fill="#555D66"></rect><rect x="5.487" y="16.308" width="9.026" height="0.99" fill="#555D66"></rect></svg>'; |
|
3028 | + }elseif($icon=='box-bottom'){ |
|
3029 | + return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.714" y="5.492" width="1" height="9.017" fill="#555D66"></rect><rect x="16.261" y="5.498" width="1.027" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.968" fill="#555D66"></rect><rect x="5.487" y="15.28" width="9.026" height="2.499" fill="#272B2F"></rect></svg>'; |
|
3030 | + }elseif($icon=='box-left'){ |
|
3031 | + return '<svg title="'.esc_attr($title).'" width="20px" height="20px" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg" fill-rule="evenodd" clip-rule="evenodd" stroke-linejoin="round" stroke-miterlimit="1.414" role="img" aria-hidden="true" focusable="false"><rect x="2.202" y="5.492" width="2.503" height="9.017" fill="#272B2F"></rect><rect x="16.276" y="5.498" width="1.012" height="9.003" fill="#555D66"></rect><rect x="5.518" y="2.719" width="8.964" height="0.966" fill="#555D66"></rect><rect x="5.487" y="16.303" width="9.026" height="0.995" fill="#555D66"></rect></svg>'; |
|
3032 | + } |
|
3033 | + } |
|
3034 | + |
|
3035 | + /** |
|
3036 | + * Get the widget input description html. |
|
3037 | + * |
|
3038 | + * @param $args |
|
3039 | + * |
|
3040 | + * @return string |
|
3041 | + * @todo, need to make its own tooltip script |
|
3042 | + */ |
|
3043 | + public function widget_field_desc( $args ) { |
|
3044 | + |
|
3045 | + $description = ''; |
|
3046 | + if ( isset( $args['desc'] ) && $args['desc'] ) { |
|
3047 | + if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) { |
|
3048 | + $description = $this->desc_tip( $args['desc'] ); |
|
3049 | + } else { |
|
3050 | + $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>'; |
|
3051 | + } |
|
3052 | + } |
|
3053 | + |
|
3054 | + return $description; |
|
3055 | + } |
|
3056 | + |
|
3057 | + /** |
|
3058 | + * Get the widget input title html. |
|
3059 | + * |
|
3060 | + * @param $args |
|
3061 | + * |
|
3062 | + * @return string |
|
3063 | + */ |
|
3064 | + public function widget_field_title( $args ) { |
|
3065 | + |
|
3066 | + $title = ''; |
|
3067 | + if ( isset( $args['title'] ) && $args['title'] ) { |
|
3068 | + if ( isset( $args['icon'] ) && $args['icon'] ) { |
|
3069 | + $title = self::get_widget_icon( $args['icon'], $args['title'] ); |
|
3070 | + } else { |
|
3071 | + $title = esc_attr($args['title']); |
|
3072 | + } |
|
3073 | + } |
|
3074 | + |
|
3075 | + return $title; |
|
3076 | + } |
|
3077 | + |
|
3078 | + /** |
|
3079 | + * Get the tool tip html. |
|
3080 | + * |
|
3081 | + * @param $tip |
|
3082 | + * @param bool $allow_html |
|
3083 | + * |
|
3084 | + * @return string |
|
3085 | + */ |
|
3086 | + function desc_tip( $tip, $allow_html = false ) { |
|
3087 | + if ( $allow_html ) { |
|
3088 | + $tip = $this->sanitize_tooltip( $tip ); |
|
3089 | + } else { |
|
3090 | + $tip = esc_attr( $tip ); |
|
3091 | + } |
|
3092 | + |
|
3093 | + return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>'; |
|
3094 | + } |
|
3095 | + |
|
3096 | + /** |
|
3097 | + * Sanitize a string destined to be a tooltip. |
|
3098 | + * |
|
3099 | + * @param string $var |
|
3100 | + * |
|
3101 | + * @return string |
|
3102 | + */ |
|
3103 | + public function sanitize_tooltip( $var ) { |
|
3104 | + return htmlspecialchars( wp_kses( html_entity_decode( $var ), array( |
|
3105 | + 'br' => array(), |
|
3106 | + 'em' => array(), |
|
3107 | + 'strong' => array(), |
|
3108 | + 'small' => array(), |
|
3109 | + 'span' => array(), |
|
3110 | + 'ul' => array(), |
|
3111 | + 'li' => array(), |
|
3112 | + 'ol' => array(), |
|
3113 | + 'p' => array(), |
|
3114 | + ) ) ); |
|
3115 | + } |
|
3116 | + |
|
3117 | + /** |
|
3118 | + * Processing widget options on save |
|
3119 | + * |
|
3120 | + * @param array $new_instance The new options |
|
3121 | + * @param array $old_instance The previous options |
|
3122 | + * |
|
3123 | + * @return array |
|
3124 | + * @todo we should add some sanitation here. |
|
3125 | + */ |
|
3126 | + public function update( $new_instance, $old_instance ) { |
|
3127 | + |
|
3128 | + //save the widget |
|
3129 | + $instance = array_merge( (array) $old_instance, (array) $new_instance ); |
|
3130 | + |
|
3131 | + // set widget instance |
|
3132 | + $this->instance = $instance; |
|
3133 | + |
|
3134 | + if ( empty( $this->arguments ) ) { |
|
3135 | + $this->get_arguments(); |
|
3136 | + } |
|
3137 | + |
|
3138 | + // check for checkboxes |
|
3139 | + if ( ! empty( $this->arguments ) ) { |
|
3140 | + foreach ( $this->arguments as $argument ) { |
|
3141 | + if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) { |
|
3142 | + $instance[ $argument['name'] ] = '0'; |
|
3143 | + } |
|
3144 | + } |
|
3145 | + } |
|
3146 | + |
|
3147 | + return $instance; |
|
3148 | + } |
|
3149 | + |
|
3150 | + /** |
|
3151 | + * Checks if the current call is a ajax call to get the block content. |
|
3152 | + * |
|
3153 | + * This can be used in your widget to return different content as the block content. |
|
3154 | + * |
|
3155 | + * @since 1.0.3 |
|
3156 | + * @return bool |
|
3157 | + */ |
|
3158 | + public function is_block_content_call() { |
|
3159 | + $result = false; |
|
3160 | + if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) { |
|
3161 | + $result = true; |
|
3162 | + } |
|
3163 | + |
|
3164 | + return $result; |
|
3165 | + } |
|
3166 | + |
|
3167 | + /** |
|
3168 | + * Get an instance hash that will be unique to the type and settings. |
|
3169 | + * |
|
3170 | + * @since 1.0.20 |
|
3171 | + * @return string |
|
3172 | + */ |
|
3173 | + public function get_instance_hash(){ |
|
3174 | + $instance_string = $this->base_id.serialize($this->instance); |
|
3175 | + return hash('crc32b',$instance_string); |
|
3176 | + } |
|
3177 | + |
|
3178 | + /** |
|
3179 | + * Generate and return inline styles from CSS rules that will match the unique class of the instance. |
|
3180 | + * |
|
3181 | + * @param array $rules |
|
3182 | + * |
|
3183 | + * @since 1.0.20 |
|
3184 | + * @return string |
|
3185 | + */ |
|
3186 | + public function get_instance_style($rules = array()){ |
|
3187 | + $css = ''; |
|
3188 | + |
|
3189 | + if(!empty($rules)){ |
|
3190 | + $rules = array_unique($rules); |
|
3191 | + $instance_hash = $this->get_instance_hash(); |
|
3192 | + $css .= "<style>"; |
|
3193 | + foreach($rules as $rule){ |
|
3194 | + $css .= ".sdel-$instance_hash $rule"; |
|
3195 | + } |
|
3196 | + $css .= "</style>"; |
|
3197 | + } |
|
3198 | + |
|
3199 | + |
|
3200 | + return $css; |
|
3201 | + |
|
3202 | + } |
|
3203 | + |
|
3204 | + } |
|
3205 | 3205 | |
3206 | 3206 | } |