@@ -9,31 +9,31 @@ |
||
9 | 9 | defined( 'ABSPATH' ) || exit; |
10 | 10 | |
11 | 11 | return array( |
12 | - 'AT', |
|
13 | - 'BE', |
|
14 | - 'BG', |
|
15 | - 'HR', |
|
16 | - 'CY', |
|
17 | - 'CZ', |
|
18 | - 'DK', |
|
19 | - 'EE', |
|
20 | - 'FI', |
|
21 | - 'FR', |
|
22 | - 'DE', |
|
23 | - 'GR', |
|
24 | - 'HU', |
|
25 | - 'IE', |
|
26 | - 'IT', |
|
27 | - 'LV', |
|
28 | - 'LT', |
|
29 | - 'LU', |
|
30 | - 'MT', |
|
31 | - 'NL', |
|
32 | - 'PL', |
|
33 | - 'PT', |
|
34 | - 'RO', |
|
35 | - 'SK', |
|
36 | - 'SI', |
|
37 | - 'ES', |
|
38 | - 'SE' |
|
12 | + 'AT', |
|
13 | + 'BE', |
|
14 | + 'BG', |
|
15 | + 'HR', |
|
16 | + 'CY', |
|
17 | + 'CZ', |
|
18 | + 'DK', |
|
19 | + 'EE', |
|
20 | + 'FI', |
|
21 | + 'FR', |
|
22 | + 'DE', |
|
23 | + 'GR', |
|
24 | + 'HU', |
|
25 | + 'IE', |
|
26 | + 'IT', |
|
27 | + 'LV', |
|
28 | + 'LT', |
|
29 | + 'LU', |
|
30 | + 'MT', |
|
31 | + 'NL', |
|
32 | + 'PL', |
|
33 | + 'PT', |
|
34 | + 'RO', |
|
35 | + 'SK', |
|
36 | + 'SI', |
|
37 | + 'ES', |
|
38 | + 'SE' |
|
39 | 39 | ); |
@@ -34,11 +34,11 @@ discard block |
||
34 | 34 | */ |
35 | 35 | function wpinv_get_capability( $capalibilty = 'manage_invoicing' ) { |
36 | 36 | |
37 | - if ( current_user_can( 'manage_options' ) ) { |
|
38 | - return 'manage_options'; |
|
39 | - }; |
|
37 | + if ( current_user_can( 'manage_options' ) ) { |
|
38 | + return 'manage_options'; |
|
39 | + }; |
|
40 | 40 | |
41 | - return $capalibilty; |
|
41 | + return $capalibilty; |
|
42 | 42 | } |
43 | 43 | |
44 | 44 | /** |
@@ -62,10 +62,10 @@ discard block |
||
62 | 62 | // Prepare user values. |
63 | 63 | $prefix = preg_replace( '/\s+/', '', $prefix ); |
64 | 64 | $prefix = empty( $prefix ) ? $email : $prefix; |
65 | - $args = array( |
|
66 | - 'user_login' => wpinv_generate_user_name( $prefix ), |
|
67 | - 'user_pass' => wp_generate_password(), |
|
68 | - 'user_email' => $email, |
|
65 | + $args = array( |
|
66 | + 'user_login' => wpinv_generate_user_name( $prefix ), |
|
67 | + 'user_pass' => wp_generate_password(), |
|
68 | + 'user_email' => $email, |
|
69 | 69 | 'role' => 'subscriber', |
70 | 70 | ); |
71 | 71 | |
@@ -82,16 +82,16 @@ discard block |
||
82 | 82 | function wpinv_generate_user_name( $prefix = '' ) { |
83 | 83 | |
84 | 84 | // If prefix is an email, retrieve the part before the email. |
85 | - $prefix = strtok( $prefix, '@' ); |
|
85 | + $prefix = strtok( $prefix, '@' ); |
|
86 | 86 | $prefix = trim( $prefix, '.' ); |
87 | 87 | |
88 | - // Sanitize the username. |
|
89 | - $prefix = sanitize_user( $prefix, true ); |
|
88 | + // Sanitize the username. |
|
89 | + $prefix = sanitize_user( $prefix, true ); |
|
90 | 90 | |
91 | - $illegal_logins = (array) apply_filters( 'illegal_user_logins', array() ); |
|
92 | - if ( empty( $prefix ) || in_array( strtolower( $prefix ), array_map( 'strtolower', $illegal_logins ), true ) ) { |
|
93 | - $prefix = 'gtp_' . zeroise( wp_rand( 0, 9999 ), 4 ); |
|
94 | - } |
|
91 | + $illegal_logins = (array) apply_filters( 'illegal_user_logins', array() ); |
|
92 | + if ( empty( $prefix ) || in_array( strtolower( $prefix ), array_map( 'strtolower', $illegal_logins ), true ) ) { |
|
93 | + $prefix = 'gtp_' . zeroise( wp_rand( 0, 9999 ), 4 ); |
|
94 | + } |
|
95 | 95 | |
96 | 96 | $username = $prefix; |
97 | 97 | $postfix = 2; |
@@ -1,6 +1,6 @@ discard block |
||
1 | 1 | <?php |
2 | 2 | if ( ! defined( 'ABSPATH' ) ) { |
3 | - exit; |
|
3 | + exit; |
|
4 | 4 | } |
5 | 5 | |
6 | 6 | /** |
@@ -10,187 +10,187 @@ discard block |
||
10 | 10 | class GetPaid_Payment_Form_Submission { |
11 | 11 | |
12 | 12 | /** |
13 | - * Submission ID |
|
14 | - * |
|
15 | - * @var string |
|
16 | - */ |
|
17 | - public $id = null; |
|
18 | - |
|
19 | - /** |
|
20 | - * The raw submission data. |
|
21 | - * |
|
22 | - * @var array |
|
23 | - */ |
|
24 | - protected $data = null; |
|
25 | - |
|
26 | - /** |
|
27 | - * Submission totals |
|
28 | - * |
|
29 | - * @var array |
|
30 | - */ |
|
31 | - protected $totals = array( |
|
32 | - |
|
33 | - 'subtotal' => array( |
|
34 | - 'initial' => 0, |
|
35 | - 'recurring' => 0, |
|
36 | - ), |
|
37 | - |
|
38 | - 'discount' => array( |
|
39 | - 'initial' => 0, |
|
40 | - 'recurring' => 0, |
|
41 | - ), |
|
42 | - |
|
43 | - 'fees' => array( |
|
44 | - 'initial' => 0, |
|
45 | - 'recurring' => 0, |
|
46 | - ), |
|
47 | - |
|
48 | - 'taxes' => array( |
|
49 | - 'initial' => 0, |
|
50 | - 'recurring' => 0, |
|
51 | - ), |
|
52 | - |
|
53 | - ); |
|
54 | - |
|
55 | - /** |
|
56 | - * Sets the associated payment form. |
|
57 | - * |
|
58 | - * @var GetPaid_Payment_Form |
|
59 | - */ |
|
13 | + * Submission ID |
|
14 | + * |
|
15 | + * @var string |
|
16 | + */ |
|
17 | + public $id = null; |
|
18 | + |
|
19 | + /** |
|
20 | + * The raw submission data. |
|
21 | + * |
|
22 | + * @var array |
|
23 | + */ |
|
24 | + protected $data = null; |
|
25 | + |
|
26 | + /** |
|
27 | + * Submission totals |
|
28 | + * |
|
29 | + * @var array |
|
30 | + */ |
|
31 | + protected $totals = array( |
|
32 | + |
|
33 | + 'subtotal' => array( |
|
34 | + 'initial' => 0, |
|
35 | + 'recurring' => 0, |
|
36 | + ), |
|
37 | + |
|
38 | + 'discount' => array( |
|
39 | + 'initial' => 0, |
|
40 | + 'recurring' => 0, |
|
41 | + ), |
|
42 | + |
|
43 | + 'fees' => array( |
|
44 | + 'initial' => 0, |
|
45 | + 'recurring' => 0, |
|
46 | + ), |
|
47 | + |
|
48 | + 'taxes' => array( |
|
49 | + 'initial' => 0, |
|
50 | + 'recurring' => 0, |
|
51 | + ), |
|
52 | + |
|
53 | + ); |
|
54 | + |
|
55 | + /** |
|
56 | + * Sets the associated payment form. |
|
57 | + * |
|
58 | + * @var GetPaid_Payment_Form |
|
59 | + */ |
|
60 | 60 | protected $payment_form = null; |
61 | 61 | |
62 | 62 | /** |
63 | - * The country for the submission. |
|
64 | - * |
|
65 | - * @var string |
|
66 | - */ |
|
67 | - public $country = null; |
|
68 | - |
|
69 | - /** |
|
70 | - * The state for the submission. |
|
71 | - * |
|
72 | - * @since 1.0.19 |
|
73 | - * @var string |
|
74 | - */ |
|
75 | - public $state = null; |
|
76 | - |
|
77 | - /** |
|
78 | - * The invoice associated with the submission. |
|
79 | - * |
|
80 | - * @var WPInv_Invoice |
|
81 | - */ |
|
82 | - protected $invoice = null; |
|
83 | - |
|
84 | - /** |
|
85 | - * The recurring item for the submission. |
|
86 | - * |
|
87 | - * @var int |
|
88 | - */ |
|
89 | - public $has_recurring = 0; |
|
90 | - |
|
91 | - /** |
|
92 | - * An array of fees for the submission. |
|
93 | - * |
|
94 | - * @var array |
|
95 | - */ |
|
96 | - protected $fees = array(); |
|
97 | - |
|
98 | - /** |
|
99 | - * An array of discounts for the submission. |
|
100 | - * |
|
101 | - * @var array |
|
102 | - */ |
|
103 | - protected $discounts = array(); |
|
104 | - |
|
105 | - /** |
|
106 | - * An array of taxes for the submission. |
|
107 | - * |
|
108 | - * @var array |
|
109 | - */ |
|
110 | - protected $taxes = array(); |
|
111 | - |
|
112 | - /** |
|
113 | - * An array of items for the submission. |
|
114 | - * |
|
115 | - * @var GetPaid_Form_Item[] |
|
116 | - */ |
|
117 | - protected $items = array(); |
|
118 | - |
|
119 | - /** |
|
120 | - * The last error. |
|
121 | - * |
|
122 | - * @var string |
|
123 | - */ |
|
124 | - public $last_error = null; |
|
125 | - |
|
126 | - /** |
|
127 | - * Class constructor. |
|
128 | - * |
|
129 | - */ |
|
130 | - public function __construct() { |
|
131 | - |
|
132 | - // Set the state and country to the default state and country. |
|
133 | - $this->country = wpinv_default_billing_country(); |
|
134 | - $this->state = wpinv_get_default_state(); |
|
135 | - |
|
136 | - // Do we have an actual submission? |
|
137 | - if ( isset( $_POST['getpaid_payment_form_submission'] ) ) { |
|
138 | - $this->load_data( $_POST ); |
|
139 | - } |
|
140 | - |
|
141 | - } |
|
142 | - |
|
143 | - /** |
|
144 | - * Loads submission data. |
|
145 | - * |
|
146 | - * @param array $data |
|
147 | - */ |
|
148 | - public function load_data( $data ) { |
|
149 | - |
|
150 | - // Remove slashes from the submitted data... |
|
151 | - $data = wp_unslash( $data ); |
|
152 | - |
|
153 | - // Allow plugins to filter the data. |
|
154 | - $data = apply_filters( 'getpaid_submission_data', $data, $this ); |
|
155 | - |
|
156 | - // Cache it... |
|
157 | - $this->data = $data; |
|
158 | - |
|
159 | - // Then generate a unique id from the data. |
|
160 | - $this->id = md5( wp_json_encode( $data ) ); |
|
161 | - |
|
162 | - // Finally, process the submission. |
|
163 | - try { |
|
164 | - |
|
165 | - // Each process is passed an instance of the class (with reference) |
|
166 | - // and should throw an Exception whenever it encounters one. |
|
167 | - $processors = apply_filters( |
|
168 | - 'getpaid_payment_form_submission_processors', |
|
169 | - array( |
|
170 | - array( $this, 'process_payment_form' ), |
|
171 | - array( $this, 'process_invoice' ), |
|
172 | - array( $this, 'process_fees' ), |
|
173 | - array( $this, 'process_items' ), |
|
174 | - array( $this, 'process_discount' ), |
|
175 | - array( $this, 'process_taxes' ), |
|
176 | - ), |
|
177 | - $this |
|
178 | - ); |
|
179 | - |
|
180 | - foreach ( $processors as $processor ) { |
|
181 | - call_user_func_array( $processor, array( &$this ) ); |
|
182 | - } |
|
183 | - |
|
184 | - } catch ( Exception $e ) { |
|
185 | - $this->last_error = $e->getMessage(); |
|
186 | - } |
|
187 | - |
|
188 | - // Fired when we are done processing a submission. |
|
189 | - do_action_ref_array( 'getpaid_process_submission', array( &$this ) ); |
|
190 | - |
|
191 | - } |
|
192 | - |
|
193 | - /* |
|
63 | + * The country for the submission. |
|
64 | + * |
|
65 | + * @var string |
|
66 | + */ |
|
67 | + public $country = null; |
|
68 | + |
|
69 | + /** |
|
70 | + * The state for the submission. |
|
71 | + * |
|
72 | + * @since 1.0.19 |
|
73 | + * @var string |
|
74 | + */ |
|
75 | + public $state = null; |
|
76 | + |
|
77 | + /** |
|
78 | + * The invoice associated with the submission. |
|
79 | + * |
|
80 | + * @var WPInv_Invoice |
|
81 | + */ |
|
82 | + protected $invoice = null; |
|
83 | + |
|
84 | + /** |
|
85 | + * The recurring item for the submission. |
|
86 | + * |
|
87 | + * @var int |
|
88 | + */ |
|
89 | + public $has_recurring = 0; |
|
90 | + |
|
91 | + /** |
|
92 | + * An array of fees for the submission. |
|
93 | + * |
|
94 | + * @var array |
|
95 | + */ |
|
96 | + protected $fees = array(); |
|
97 | + |
|
98 | + /** |
|
99 | + * An array of discounts for the submission. |
|
100 | + * |
|
101 | + * @var array |
|
102 | + */ |
|
103 | + protected $discounts = array(); |
|
104 | + |
|
105 | + /** |
|
106 | + * An array of taxes for the submission. |
|
107 | + * |
|
108 | + * @var array |
|
109 | + */ |
|
110 | + protected $taxes = array(); |
|
111 | + |
|
112 | + /** |
|
113 | + * An array of items for the submission. |
|
114 | + * |
|
115 | + * @var GetPaid_Form_Item[] |
|
116 | + */ |
|
117 | + protected $items = array(); |
|
118 | + |
|
119 | + /** |
|
120 | + * The last error. |
|
121 | + * |
|
122 | + * @var string |
|
123 | + */ |
|
124 | + public $last_error = null; |
|
125 | + |
|
126 | + /** |
|
127 | + * Class constructor. |
|
128 | + * |
|
129 | + */ |
|
130 | + public function __construct() { |
|
131 | + |
|
132 | + // Set the state and country to the default state and country. |
|
133 | + $this->country = wpinv_default_billing_country(); |
|
134 | + $this->state = wpinv_get_default_state(); |
|
135 | + |
|
136 | + // Do we have an actual submission? |
|
137 | + if ( isset( $_POST['getpaid_payment_form_submission'] ) ) { |
|
138 | + $this->load_data( $_POST ); |
|
139 | + } |
|
140 | + |
|
141 | + } |
|
142 | + |
|
143 | + /** |
|
144 | + * Loads submission data. |
|
145 | + * |
|
146 | + * @param array $data |
|
147 | + */ |
|
148 | + public function load_data( $data ) { |
|
149 | + |
|
150 | + // Remove slashes from the submitted data... |
|
151 | + $data = wp_unslash( $data ); |
|
152 | + |
|
153 | + // Allow plugins to filter the data. |
|
154 | + $data = apply_filters( 'getpaid_submission_data', $data, $this ); |
|
155 | + |
|
156 | + // Cache it... |
|
157 | + $this->data = $data; |
|
158 | + |
|
159 | + // Then generate a unique id from the data. |
|
160 | + $this->id = md5( wp_json_encode( $data ) ); |
|
161 | + |
|
162 | + // Finally, process the submission. |
|
163 | + try { |
|
164 | + |
|
165 | + // Each process is passed an instance of the class (with reference) |
|
166 | + // and should throw an Exception whenever it encounters one. |
|
167 | + $processors = apply_filters( |
|
168 | + 'getpaid_payment_form_submission_processors', |
|
169 | + array( |
|
170 | + array( $this, 'process_payment_form' ), |
|
171 | + array( $this, 'process_invoice' ), |
|
172 | + array( $this, 'process_fees' ), |
|
173 | + array( $this, 'process_items' ), |
|
174 | + array( $this, 'process_discount' ), |
|
175 | + array( $this, 'process_taxes' ), |
|
176 | + ), |
|
177 | + $this |
|
178 | + ); |
|
179 | + |
|
180 | + foreach ( $processors as $processor ) { |
|
181 | + call_user_func_array( $processor, array( &$this ) ); |
|
182 | + } |
|
183 | + |
|
184 | + } catch ( Exception $e ) { |
|
185 | + $this->last_error = $e->getMessage(); |
|
186 | + } |
|
187 | + |
|
188 | + // Fired when we are done processing a submission. |
|
189 | + do_action_ref_array( 'getpaid_process_submission', array( &$this ) ); |
|
190 | + |
|
191 | + } |
|
192 | + |
|
193 | + /* |
|
194 | 194 | |-------------------------------------------------------------------------- |
195 | 195 | | Payment Forms. |
196 | 196 | |-------------------------------------------------------------------------- |
@@ -199,39 +199,39 @@ discard block |
||
199 | 199 | | submission has an active payment form etc. |
200 | 200 | */ |
201 | 201 | |
202 | - /** |
|
203 | - * Prepares the submission's payment form. |
|
204 | - * |
|
205 | - * @since 1.0.19 |
|
206 | - */ |
|
207 | - public function process_payment_form() { |
|
202 | + /** |
|
203 | + * Prepares the submission's payment form. |
|
204 | + * |
|
205 | + * @since 1.0.19 |
|
206 | + */ |
|
207 | + public function process_payment_form() { |
|
208 | 208 | |
209 | - // Every submission needs an active payment form. |
|
210 | - if ( empty( $this->data['form_id'] ) ) { |
|
211 | - throw new Exception( __( 'Missing payment form', 'invoicing' ) ); |
|
212 | - } |
|
209 | + // Every submission needs an active payment form. |
|
210 | + if ( empty( $this->data['form_id'] ) ) { |
|
211 | + throw new Exception( __( 'Missing payment form', 'invoicing' ) ); |
|
212 | + } |
|
213 | 213 | |
214 | - // Fetch the payment form. |
|
215 | - $this->payment_form = new GetPaid_Payment_Form( $this->data['form_id'] ); |
|
214 | + // Fetch the payment form. |
|
215 | + $this->payment_form = new GetPaid_Payment_Form( $this->data['form_id'] ); |
|
216 | 216 | |
217 | - if ( ! $this->payment_form->is_active() ) { |
|
218 | - throw new Exception( __( 'Payment form not active', 'invoicing' ) ); |
|
219 | - } |
|
217 | + if ( ! $this->payment_form->is_active() ) { |
|
218 | + throw new Exception( __( 'Payment form not active', 'invoicing' ) ); |
|
219 | + } |
|
220 | 220 | |
221 | - do_action_ref_array( 'getpaid_submissions_process_payment_form', array( &$this ) ); |
|
222 | - } |
|
221 | + do_action_ref_array( 'getpaid_submissions_process_payment_form', array( &$this ) ); |
|
222 | + } |
|
223 | 223 | |
224 | 224 | /** |
225 | - * Returns the payment form. |
|
226 | - * |
|
227 | - * @since 1.0.19 |
|
228 | - * @return GetPaid_Payment_Form |
|
229 | - */ |
|
230 | - public function get_payment_form() { |
|
231 | - return $this->payment_form; |
|
232 | - } |
|
225 | + * Returns the payment form. |
|
226 | + * |
|
227 | + * @since 1.0.19 |
|
228 | + * @return GetPaid_Payment_Form |
|
229 | + */ |
|
230 | + public function get_payment_form() { |
|
231 | + return $this->payment_form; |
|
232 | + } |
|
233 | 233 | |
234 | - /* |
|
234 | + /* |
|
235 | 235 | |-------------------------------------------------------------------------- |
236 | 236 | | Invoices. |
237 | 237 | |-------------------------------------------------------------------------- |
@@ -240,61 +240,61 @@ discard block |
||
240 | 240 | | might be for an existing invoice. |
241 | 241 | */ |
242 | 242 | |
243 | - /** |
|
244 | - * Prepares the submission's invoice. |
|
245 | - * |
|
246 | - * @since 1.0.19 |
|
247 | - */ |
|
248 | - public function process_invoice() { |
|
243 | + /** |
|
244 | + * Prepares the submission's invoice. |
|
245 | + * |
|
246 | + * @since 1.0.19 |
|
247 | + */ |
|
248 | + public function process_invoice() { |
|
249 | 249 | |
250 | - // Abort if there is no invoice. |
|
251 | - if ( empty( $this->data['invoice_id'] ) ) { |
|
252 | - return; |
|
253 | - } |
|
250 | + // Abort if there is no invoice. |
|
251 | + if ( empty( $this->data['invoice_id'] ) ) { |
|
252 | + return; |
|
253 | + } |
|
254 | 254 | |
255 | - // If the submission is for an existing invoice, ensure that it exists |
|
256 | - // and that it is not paid for. |
|
257 | - $invoice = wpinv_get_invoice( $this->data['invoice_id'] ); |
|
255 | + // If the submission is for an existing invoice, ensure that it exists |
|
256 | + // and that it is not paid for. |
|
257 | + $invoice = wpinv_get_invoice( $this->data['invoice_id'] ); |
|
258 | 258 | |
259 | 259 | if ( empty( $invoice ) ) { |
260 | - throw new Exception( __( 'Invalid invoice', 'invoicing' ) ); |
|
261 | - } |
|
262 | - |
|
263 | - if ( $invoice->is_paid() ) { |
|
264 | - throw new Exception( __( 'This invoice is already paid for.', 'invoicing' ) ); |
|
265 | - } |
|
266 | - |
|
267 | - $this->payment_form->set_items( $invoice->get_items() ); |
|
268 | - $this->payment_form->invoice = $invoice; |
|
269 | - |
|
270 | - $this->country = $invoice->get_country(); |
|
271 | - $this->state = $invoice->get_state(); |
|
272 | - $this->invoice = $invoice; |
|
273 | - |
|
274 | - do_action_ref_array( 'getpaid_submissions_process_invoice', array( &$this ) ); |
|
275 | - } |
|
276 | - |
|
277 | - /** |
|
278 | - * Returns the associated invoice. |
|
279 | - * |
|
280 | - * @since 1.0.19 |
|
281 | - * @return WPInv_Invoice |
|
282 | - */ |
|
283 | - public function get_invoice() { |
|
284 | - return $this->invoice; |
|
285 | - } |
|
286 | - |
|
287 | - /** |
|
288 | - * Checks whether there is an invoice associated with this submission. |
|
289 | - * |
|
290 | - * @since 1.0.19 |
|
291 | - * @return bool |
|
292 | - */ |
|
293 | - public function has_invoice() { |
|
294 | - return ! empty( $this->invoice ); |
|
295 | - } |
|
296 | - |
|
297 | - /* |
|
260 | + throw new Exception( __( 'Invalid invoice', 'invoicing' ) ); |
|
261 | + } |
|
262 | + |
|
263 | + if ( $invoice->is_paid() ) { |
|
264 | + throw new Exception( __( 'This invoice is already paid for.', 'invoicing' ) ); |
|
265 | + } |
|
266 | + |
|
267 | + $this->payment_form->set_items( $invoice->get_items() ); |
|
268 | + $this->payment_form->invoice = $invoice; |
|
269 | + |
|
270 | + $this->country = $invoice->get_country(); |
|
271 | + $this->state = $invoice->get_state(); |
|
272 | + $this->invoice = $invoice; |
|
273 | + |
|
274 | + do_action_ref_array( 'getpaid_submissions_process_invoice', array( &$this ) ); |
|
275 | + } |
|
276 | + |
|
277 | + /** |
|
278 | + * Returns the associated invoice. |
|
279 | + * |
|
280 | + * @since 1.0.19 |
|
281 | + * @return WPInv_Invoice |
|
282 | + */ |
|
283 | + public function get_invoice() { |
|
284 | + return $this->invoice; |
|
285 | + } |
|
286 | + |
|
287 | + /** |
|
288 | + * Checks whether there is an invoice associated with this submission. |
|
289 | + * |
|
290 | + * @since 1.0.19 |
|
291 | + * @return bool |
|
292 | + */ |
|
293 | + public function has_invoice() { |
|
294 | + return ! empty( $this->invoice ); |
|
295 | + } |
|
296 | + |
|
297 | + /* |
|
298 | 298 | |-------------------------------------------------------------------------- |
299 | 299 | | Items. |
300 | 300 | |-------------------------------------------------------------------------- |
@@ -303,115 +303,115 @@ discard block |
||
303 | 303 | | recurring item. But can have an unlimited number of non-recurring items. |
304 | 304 | */ |
305 | 305 | |
306 | - /** |
|
307 | - * Prepares the submission's items. |
|
308 | - * |
|
309 | - * @since 1.0.19 |
|
310 | - */ |
|
311 | - public function process_items() { |
|
312 | - |
|
313 | - $processor = new GetPaid_Payment_Form_Submission_Items( $this ); |
|
314 | - |
|
315 | - foreach ( $processor->items as $item ) { |
|
316 | - $this->add_item( $item ); |
|
317 | - } |
|
318 | - |
|
319 | - do_action_ref_array( 'getpaid_submissions_process_items', array( &$this ) ); |
|
320 | - } |
|
321 | - |
|
322 | - /** |
|
323 | - * Adds an item to the submission. |
|
324 | - * |
|
325 | - * @since 1.0.19 |
|
326 | - * @param GetPaid_Form_Item $item |
|
327 | - */ |
|
328 | - public function add_item( $item ) { |
|
329 | - |
|
330 | - // Make sure that it is available for purchase. |
|
331 | - if ( ! $item->can_purchase() || isset( $this->items[ $item->get_id() ] ) ) { |
|
332 | - return; |
|
333 | - } |
|
334 | - |
|
335 | - // Each submission can only contain one recurring item. |
|
336 | - if ( $item->is_recurring() ) { |
|
337 | - |
|
338 | - if ( $this->has_recurring != 0 ) { |
|
339 | - throw new Exception( __( 'You can only buy one recurring item at a time.', 'invoicing' ) ); |
|
340 | - } |
|
341 | - |
|
342 | - $this->has_recurring = $item->get_id(); |
|
343 | - |
|
344 | - } |
|
345 | - |
|
346 | - // Update the items and totals. |
|
347 | - $this->items[ $item->get_id() ] = $item; |
|
348 | - $this->totals['subtotal']['initial'] += $item->get_sub_total(); |
|
349 | - $this->totals['subtotal']['recurring'] += $item->get_recurring_sub_total(); |
|
350 | - |
|
351 | - } |
|
352 | - |
|
353 | - /** |
|
354 | - * Removes a specific item. |
|
355 | - * |
|
356 | - * You should not call this method after the discounts and taxes |
|
357 | - * have been calculated. |
|
358 | - * |
|
359 | - * @since 1.0.19 |
|
360 | - */ |
|
361 | - public function remove_item( $item_id ) { |
|
362 | - |
|
363 | - if ( isset( $this->items[ $item_id ] ) ) { |
|
364 | - $this->totals['subtotal']['initial'] -= $this->items[ $item_id ]->get_sub_total(); |
|
365 | - $this->totals['subtotal']['recurring'] -= $this->items[ $item_id ]->get_recurring_sub_total(); |
|
366 | - |
|
367 | - if ( $this->items[ $item_id ]->is_recurring() ) { |
|
368 | - $this->has_recurring = 0; |
|
369 | - } |
|
370 | - |
|
371 | - unset( $this->items[ $item_id ] ); |
|
372 | - } |
|
373 | - |
|
374 | - } |
|
375 | - |
|
376 | - /** |
|
377 | - * Returns the subtotal. |
|
378 | - * |
|
379 | - * @since 1.0.19 |
|
380 | - */ |
|
381 | - public function get_subtotal() { |
|
382 | - |
|
383 | - if ( wpinv_prices_include_tax() ) { |
|
384 | - return $this->totals['subtotal']['initial'] - $this->totals['taxes']['initial']; |
|
385 | - } |
|
386 | - |
|
387 | - return $this->totals['subtotal']['initial']; |
|
388 | - } |
|
389 | - |
|
390 | - /** |
|
391 | - * Returns the recurring subtotal. |
|
392 | - * |
|
393 | - * @since 1.0.19 |
|
394 | - */ |
|
395 | - public function get_recurring_subtotal() { |
|
396 | - |
|
397 | - if ( wpinv_prices_include_tax() ) { |
|
398 | - return $this->totals['subtotal']['recurring'] - $this->totals['taxes']['recurring']; |
|
399 | - } |
|
400 | - |
|
401 | - return $this->totals['subtotal']['recurring']; |
|
402 | - } |
|
403 | - |
|
404 | - /** |
|
405 | - * Returns all items. |
|
406 | - * |
|
407 | - * @since 1.0.19 |
|
408 | - * @return GetPaid_Form_Item[] |
|
409 | - */ |
|
410 | - public function get_items() { |
|
411 | - return $this->items; |
|
412 | - } |
|
413 | - |
|
414 | - /* |
|
306 | + /** |
|
307 | + * Prepares the submission's items. |
|
308 | + * |
|
309 | + * @since 1.0.19 |
|
310 | + */ |
|
311 | + public function process_items() { |
|
312 | + |
|
313 | + $processor = new GetPaid_Payment_Form_Submission_Items( $this ); |
|
314 | + |
|
315 | + foreach ( $processor->items as $item ) { |
|
316 | + $this->add_item( $item ); |
|
317 | + } |
|
318 | + |
|
319 | + do_action_ref_array( 'getpaid_submissions_process_items', array( &$this ) ); |
|
320 | + } |
|
321 | + |
|
322 | + /** |
|
323 | + * Adds an item to the submission. |
|
324 | + * |
|
325 | + * @since 1.0.19 |
|
326 | + * @param GetPaid_Form_Item $item |
|
327 | + */ |
|
328 | + public function add_item( $item ) { |
|
329 | + |
|
330 | + // Make sure that it is available for purchase. |
|
331 | + if ( ! $item->can_purchase() || isset( $this->items[ $item->get_id() ] ) ) { |
|
332 | + return; |
|
333 | + } |
|
334 | + |
|
335 | + // Each submission can only contain one recurring item. |
|
336 | + if ( $item->is_recurring() ) { |
|
337 | + |
|
338 | + if ( $this->has_recurring != 0 ) { |
|
339 | + throw new Exception( __( 'You can only buy one recurring item at a time.', 'invoicing' ) ); |
|
340 | + } |
|
341 | + |
|
342 | + $this->has_recurring = $item->get_id(); |
|
343 | + |
|
344 | + } |
|
345 | + |
|
346 | + // Update the items and totals. |
|
347 | + $this->items[ $item->get_id() ] = $item; |
|
348 | + $this->totals['subtotal']['initial'] += $item->get_sub_total(); |
|
349 | + $this->totals['subtotal']['recurring'] += $item->get_recurring_sub_total(); |
|
350 | + |
|
351 | + } |
|
352 | + |
|
353 | + /** |
|
354 | + * Removes a specific item. |
|
355 | + * |
|
356 | + * You should not call this method after the discounts and taxes |
|
357 | + * have been calculated. |
|
358 | + * |
|
359 | + * @since 1.0.19 |
|
360 | + */ |
|
361 | + public function remove_item( $item_id ) { |
|
362 | + |
|
363 | + if ( isset( $this->items[ $item_id ] ) ) { |
|
364 | + $this->totals['subtotal']['initial'] -= $this->items[ $item_id ]->get_sub_total(); |
|
365 | + $this->totals['subtotal']['recurring'] -= $this->items[ $item_id ]->get_recurring_sub_total(); |
|
366 | + |
|
367 | + if ( $this->items[ $item_id ]->is_recurring() ) { |
|
368 | + $this->has_recurring = 0; |
|
369 | + } |
|
370 | + |
|
371 | + unset( $this->items[ $item_id ] ); |
|
372 | + } |
|
373 | + |
|
374 | + } |
|
375 | + |
|
376 | + /** |
|
377 | + * Returns the subtotal. |
|
378 | + * |
|
379 | + * @since 1.0.19 |
|
380 | + */ |
|
381 | + public function get_subtotal() { |
|
382 | + |
|
383 | + if ( wpinv_prices_include_tax() ) { |
|
384 | + return $this->totals['subtotal']['initial'] - $this->totals['taxes']['initial']; |
|
385 | + } |
|
386 | + |
|
387 | + return $this->totals['subtotal']['initial']; |
|
388 | + } |
|
389 | + |
|
390 | + /** |
|
391 | + * Returns the recurring subtotal. |
|
392 | + * |
|
393 | + * @since 1.0.19 |
|
394 | + */ |
|
395 | + public function get_recurring_subtotal() { |
|
396 | + |
|
397 | + if ( wpinv_prices_include_tax() ) { |
|
398 | + return $this->totals['subtotal']['recurring'] - $this->totals['taxes']['recurring']; |
|
399 | + } |
|
400 | + |
|
401 | + return $this->totals['subtotal']['recurring']; |
|
402 | + } |
|
403 | + |
|
404 | + /** |
|
405 | + * Returns all items. |
|
406 | + * |
|
407 | + * @since 1.0.19 |
|
408 | + * @return GetPaid_Form_Item[] |
|
409 | + */ |
|
410 | + public function get_items() { |
|
411 | + return $this->items; |
|
412 | + } |
|
413 | + |
|
414 | + /* |
|
415 | 415 | |-------------------------------------------------------------------------- |
416 | 416 | | Taxes |
417 | 417 | |-------------------------------------------------------------------------- |
@@ -420,128 +420,128 @@ discard block |
||
420 | 420 | | or only one-time. |
421 | 421 | */ |
422 | 422 | |
423 | - /** |
|
424 | - * Prepares the submission's taxes. |
|
425 | - * |
|
426 | - * @since 1.0.19 |
|
427 | - */ |
|
428 | - public function process_taxes() { |
|
429 | - |
|
430 | - // Abort if we're not using taxes. |
|
431 | - if ( ! $this->use_taxes() ) { |
|
432 | - return; |
|
433 | - } |
|
434 | - |
|
435 | - // If a custom country && state has been passed in, use it to calculate taxes. |
|
436 | - $country = $this->get_field( 'wpinv_country', 'billing' ); |
|
437 | - if ( ! empty( $country ) ) { |
|
438 | - $this->country = $country; |
|
439 | - } |
|
440 | - |
|
441 | - $state = $this->get_field( 'wpinv_state', 'billing' ); |
|
442 | - if ( ! empty( $state ) ) { |
|
443 | - $this->state = $state; |
|
444 | - } |
|
445 | - |
|
446 | - // Confirm if the provided country and the ip country are similar. |
|
447 | - $address_confirmed = $this->get_field( 'confirm-address' ); |
|
448 | - if ( wpinv_should_validate_vat_number() && getpaid_get_ip_country() != $this->country && empty( $address_confirmed ) ) { |
|
449 | - throw new Exception( __( 'The country of your current location must be the same as the country of your billing location or you must confirm the billing address is your home country.', 'invoicing' ) ); |
|
450 | - } |
|
451 | - |
|
452 | - // Abort if the country is not taxable. |
|
453 | - if ( ! wpinv_is_country_taxable( $this->country ) ) { |
|
454 | - return; |
|
455 | - } |
|
456 | - |
|
457 | - $processor = new GetPaid_Payment_Form_Submission_Taxes( $this ); |
|
458 | - |
|
459 | - foreach ( $processor->taxes as $tax ) { |
|
460 | - $this->add_tax( $tax ); |
|
461 | - } |
|
462 | - |
|
463 | - do_action_ref_array( 'getpaid_submissions_process_taxes', array( &$this ) ); |
|
464 | - } |
|
465 | - |
|
466 | - /** |
|
467 | - * Adds a tax to the submission. |
|
468 | - * |
|
469 | - * @param array $tax An array of tax details. name, initial_tax, and recurring_tax are required. |
|
470 | - * @since 1.0.19 |
|
471 | - */ |
|
472 | - public function add_tax( $tax ) { |
|
473 | - |
|
474 | - if ( wpinv_round_tax_per_tax_rate() ) { |
|
475 | - $tax['initial_tax'] = wpinv_round_amount( $tax['initial_tax'] ); |
|
476 | - $tax['recurring_tax'] = wpinv_round_amount( $tax['recurring_tax'] ); |
|
477 | - } |
|
478 | - |
|
479 | - $this->taxes[ $tax['name'] ] = $tax; |
|
480 | - $this->totals['taxes']['initial'] += wpinv_sanitize_amount( $tax['initial_tax'] ); |
|
481 | - $this->totals['taxes']['recurring'] += wpinv_sanitize_amount( $tax['recurring_tax'] ); |
|
482 | - |
|
483 | - } |
|
484 | - |
|
485 | - /** |
|
486 | - * Removes a specific tax. |
|
487 | - * |
|
488 | - * @since 1.0.19 |
|
489 | - */ |
|
490 | - public function remove_tax( $tax_name ) { |
|
491 | - |
|
492 | - if ( isset( $this->taxes[ $tax_name ] ) ) { |
|
493 | - $this->totals['taxes']['initial'] -= $this->taxes[ $tax_name ]['initial_tax']; |
|
494 | - $this->totals['taxes']['recurring'] -= $this->taxes[ $tax_name ]['recurring_tax']; |
|
495 | - unset( $this->taxes[ $tax_name ] ); |
|
496 | - } |
|
497 | - |
|
498 | - } |
|
499 | - |
|
500 | - /** |
|
501 | - * Whether or not we'll use taxes for the submission. |
|
502 | - * |
|
503 | - * @since 1.0.19 |
|
504 | - */ |
|
505 | - public function use_taxes() { |
|
506 | - |
|
507 | - $use_taxes = wpinv_use_taxes(); |
|
508 | - |
|
509 | - if ( $this->has_invoice() && ! $this->invoice->is_taxable() ) { |
|
510 | - $use_taxes = false; |
|
511 | - } |
|
512 | - |
|
513 | - return apply_filters( 'getpaid_submission_use_taxes', $use_taxes, $this ); |
|
514 | - |
|
515 | - } |
|
516 | - |
|
517 | - /** |
|
518 | - * Returns the tax. |
|
519 | - * |
|
520 | - * @since 1.0.19 |
|
521 | - */ |
|
522 | - public function get_tax() { |
|
523 | - return $this->totals['taxes']['initial']; |
|
524 | - } |
|
525 | - |
|
526 | - /** |
|
527 | - * Returns the recurring tax. |
|
528 | - * |
|
529 | - * @since 1.0.19 |
|
530 | - */ |
|
531 | - public function get_recurring_tax() { |
|
532 | - return $this->totals['taxes']['recurring']; |
|
533 | - } |
|
534 | - |
|
535 | - /** |
|
536 | - * Returns all taxes. |
|
537 | - * |
|
538 | - * @since 1.0.19 |
|
539 | - */ |
|
540 | - public function get_taxes() { |
|
541 | - return $this->taxes; |
|
542 | - } |
|
543 | - |
|
544 | - /* |
|
423 | + /** |
|
424 | + * Prepares the submission's taxes. |
|
425 | + * |
|
426 | + * @since 1.0.19 |
|
427 | + */ |
|
428 | + public function process_taxes() { |
|
429 | + |
|
430 | + // Abort if we're not using taxes. |
|
431 | + if ( ! $this->use_taxes() ) { |
|
432 | + return; |
|
433 | + } |
|
434 | + |
|
435 | + // If a custom country && state has been passed in, use it to calculate taxes. |
|
436 | + $country = $this->get_field( 'wpinv_country', 'billing' ); |
|
437 | + if ( ! empty( $country ) ) { |
|
438 | + $this->country = $country; |
|
439 | + } |
|
440 | + |
|
441 | + $state = $this->get_field( 'wpinv_state', 'billing' ); |
|
442 | + if ( ! empty( $state ) ) { |
|
443 | + $this->state = $state; |
|
444 | + } |
|
445 | + |
|
446 | + // Confirm if the provided country and the ip country are similar. |
|
447 | + $address_confirmed = $this->get_field( 'confirm-address' ); |
|
448 | + if ( wpinv_should_validate_vat_number() && getpaid_get_ip_country() != $this->country && empty( $address_confirmed ) ) { |
|
449 | + throw new Exception( __( 'The country of your current location must be the same as the country of your billing location or you must confirm the billing address is your home country.', 'invoicing' ) ); |
|
450 | + } |
|
451 | + |
|
452 | + // Abort if the country is not taxable. |
|
453 | + if ( ! wpinv_is_country_taxable( $this->country ) ) { |
|
454 | + return; |
|
455 | + } |
|
456 | + |
|
457 | + $processor = new GetPaid_Payment_Form_Submission_Taxes( $this ); |
|
458 | + |
|
459 | + foreach ( $processor->taxes as $tax ) { |
|
460 | + $this->add_tax( $tax ); |
|
461 | + } |
|
462 | + |
|
463 | + do_action_ref_array( 'getpaid_submissions_process_taxes', array( &$this ) ); |
|
464 | + } |
|
465 | + |
|
466 | + /** |
|
467 | + * Adds a tax to the submission. |
|
468 | + * |
|
469 | + * @param array $tax An array of tax details. name, initial_tax, and recurring_tax are required. |
|
470 | + * @since 1.0.19 |
|
471 | + */ |
|
472 | + public function add_tax( $tax ) { |
|
473 | + |
|
474 | + if ( wpinv_round_tax_per_tax_rate() ) { |
|
475 | + $tax['initial_tax'] = wpinv_round_amount( $tax['initial_tax'] ); |
|
476 | + $tax['recurring_tax'] = wpinv_round_amount( $tax['recurring_tax'] ); |
|
477 | + } |
|
478 | + |
|
479 | + $this->taxes[ $tax['name'] ] = $tax; |
|
480 | + $this->totals['taxes']['initial'] += wpinv_sanitize_amount( $tax['initial_tax'] ); |
|
481 | + $this->totals['taxes']['recurring'] += wpinv_sanitize_amount( $tax['recurring_tax'] ); |
|
482 | + |
|
483 | + } |
|
484 | + |
|
485 | + /** |
|
486 | + * Removes a specific tax. |
|
487 | + * |
|
488 | + * @since 1.0.19 |
|
489 | + */ |
|
490 | + public function remove_tax( $tax_name ) { |
|
491 | + |
|
492 | + if ( isset( $this->taxes[ $tax_name ] ) ) { |
|
493 | + $this->totals['taxes']['initial'] -= $this->taxes[ $tax_name ]['initial_tax']; |
|
494 | + $this->totals['taxes']['recurring'] -= $this->taxes[ $tax_name ]['recurring_tax']; |
|
495 | + unset( $this->taxes[ $tax_name ] ); |
|
496 | + } |
|
497 | + |
|
498 | + } |
|
499 | + |
|
500 | + /** |
|
501 | + * Whether or not we'll use taxes for the submission. |
|
502 | + * |
|
503 | + * @since 1.0.19 |
|
504 | + */ |
|
505 | + public function use_taxes() { |
|
506 | + |
|
507 | + $use_taxes = wpinv_use_taxes(); |
|
508 | + |
|
509 | + if ( $this->has_invoice() && ! $this->invoice->is_taxable() ) { |
|
510 | + $use_taxes = false; |
|
511 | + } |
|
512 | + |
|
513 | + return apply_filters( 'getpaid_submission_use_taxes', $use_taxes, $this ); |
|
514 | + |
|
515 | + } |
|
516 | + |
|
517 | + /** |
|
518 | + * Returns the tax. |
|
519 | + * |
|
520 | + * @since 1.0.19 |
|
521 | + */ |
|
522 | + public function get_tax() { |
|
523 | + return $this->totals['taxes']['initial']; |
|
524 | + } |
|
525 | + |
|
526 | + /** |
|
527 | + * Returns the recurring tax. |
|
528 | + * |
|
529 | + * @since 1.0.19 |
|
530 | + */ |
|
531 | + public function get_recurring_tax() { |
|
532 | + return $this->totals['taxes']['recurring']; |
|
533 | + } |
|
534 | + |
|
535 | + /** |
|
536 | + * Returns all taxes. |
|
537 | + * |
|
538 | + * @since 1.0.19 |
|
539 | + */ |
|
540 | + public function get_taxes() { |
|
541 | + return $this->taxes; |
|
542 | + } |
|
543 | + |
|
544 | + /* |
|
545 | 545 | |-------------------------------------------------------------------------- |
546 | 546 | | Discounts |
547 | 547 | |-------------------------------------------------------------------------- |
@@ -550,99 +550,99 @@ discard block |
||
550 | 550 | | or only one-time. They also do not have to come from a discount code. |
551 | 551 | */ |
552 | 552 | |
553 | - /** |
|
554 | - * Prepares the submission's discount. |
|
555 | - * |
|
556 | - * @since 1.0.19 |
|
557 | - */ |
|
558 | - public function process_discount() { |
|
559 | - |
|
560 | - $initial_total = $this->get_subtotal() + $this->get_fee() + $this->get_tax(); |
|
561 | - $recurring_total = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax(); |
|
562 | - $processor = new GetPaid_Payment_Form_Submission_Discount( $this, $initial_total, $recurring_total ); |
|
563 | - |
|
564 | - foreach ( $processor->discounts as $discount ) { |
|
565 | - $this->add_discount( $discount ); |
|
566 | - } |
|
567 | - |
|
568 | - do_action_ref_array( 'getpaid_submissions_process_discounts', array( &$this ) ); |
|
569 | - } |
|
570 | - |
|
571 | - /** |
|
572 | - * Adds a discount to the submission. |
|
573 | - * |
|
574 | - * @param array $discount An array of discount details. name, initial_discount, and recurring_discount are required. Include discount_code if the discount is from a discount code. |
|
575 | - * @since 1.0.19 |
|
576 | - */ |
|
577 | - public function add_discount( $discount ) { |
|
578 | - $this->discounts[ $discount['name'] ] = $discount; |
|
579 | - $this->totals['discount']['initial'] += wpinv_sanitize_amount( $discount['initial_discount'] ); |
|
580 | - $this->totals['discount']['recurring'] += wpinv_sanitize_amount( $discount['recurring_discount'] ); |
|
581 | - } |
|
582 | - |
|
583 | - /** |
|
584 | - * Removes a discount from the submission. |
|
585 | - * |
|
586 | - * @since 1.0.19 |
|
587 | - */ |
|
588 | - public function remove_discount( $name ) { |
|
589 | - |
|
590 | - if ( isset( $this->discounts[ $name ] ) ) { |
|
591 | - $this->totals['discount']['initial'] -= $this->discounts[ $name ]['initial_discount']; |
|
592 | - $this->totals['discount']['recurring'] -= $this->discounts[ $name ]['recurring_discount']; |
|
593 | - unset( $this->discounts[ $name ] ); |
|
594 | - } |
|
595 | - |
|
596 | - } |
|
597 | - |
|
598 | - /** |
|
599 | - * Checks whether there is a discount code associated with this submission. |
|
600 | - * |
|
601 | - * @since 1.0.19 |
|
602 | - * @return bool |
|
603 | - */ |
|
604 | - public function has_discount_code() { |
|
605 | - return ! empty( $this->discounts['discount_code'] ); |
|
606 | - } |
|
607 | - |
|
608 | - /** |
|
609 | - * Returns the discount code. |
|
610 | - * |
|
611 | - * @since 1.0.19 |
|
612 | - * @return string |
|
613 | - */ |
|
614 | - public function get_discount_code() { |
|
615 | - return $this->has_discount_code() ? $this->discounts['discount_code']['discount_code'] : ''; |
|
616 | - } |
|
617 | - |
|
618 | - /** |
|
619 | - * Returns the discount. |
|
620 | - * |
|
621 | - * @since 1.0.19 |
|
622 | - */ |
|
623 | - public function get_discount() { |
|
624 | - return $this->totals['discount']['initial']; |
|
625 | - } |
|
626 | - |
|
627 | - /** |
|
628 | - * Returns the recurring discount. |
|
629 | - * |
|
630 | - * @since 1.0.19 |
|
631 | - */ |
|
632 | - public function get_recurring_discount() { |
|
633 | - return $this->totals['discount']['recurring']; |
|
634 | - } |
|
635 | - |
|
636 | - /** |
|
637 | - * Returns all discounts. |
|
638 | - * |
|
639 | - * @since 1.0.19 |
|
640 | - */ |
|
641 | - public function get_discounts() { |
|
642 | - return $this->discounts; |
|
643 | - } |
|
644 | - |
|
645 | - /* |
|
553 | + /** |
|
554 | + * Prepares the submission's discount. |
|
555 | + * |
|
556 | + * @since 1.0.19 |
|
557 | + */ |
|
558 | + public function process_discount() { |
|
559 | + |
|
560 | + $initial_total = $this->get_subtotal() + $this->get_fee() + $this->get_tax(); |
|
561 | + $recurring_total = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax(); |
|
562 | + $processor = new GetPaid_Payment_Form_Submission_Discount( $this, $initial_total, $recurring_total ); |
|
563 | + |
|
564 | + foreach ( $processor->discounts as $discount ) { |
|
565 | + $this->add_discount( $discount ); |
|
566 | + } |
|
567 | + |
|
568 | + do_action_ref_array( 'getpaid_submissions_process_discounts', array( &$this ) ); |
|
569 | + } |
|
570 | + |
|
571 | + /** |
|
572 | + * Adds a discount to the submission. |
|
573 | + * |
|
574 | + * @param array $discount An array of discount details. name, initial_discount, and recurring_discount are required. Include discount_code if the discount is from a discount code. |
|
575 | + * @since 1.0.19 |
|
576 | + */ |
|
577 | + public function add_discount( $discount ) { |
|
578 | + $this->discounts[ $discount['name'] ] = $discount; |
|
579 | + $this->totals['discount']['initial'] += wpinv_sanitize_amount( $discount['initial_discount'] ); |
|
580 | + $this->totals['discount']['recurring'] += wpinv_sanitize_amount( $discount['recurring_discount'] ); |
|
581 | + } |
|
582 | + |
|
583 | + /** |
|
584 | + * Removes a discount from the submission. |
|
585 | + * |
|
586 | + * @since 1.0.19 |
|
587 | + */ |
|
588 | + public function remove_discount( $name ) { |
|
589 | + |
|
590 | + if ( isset( $this->discounts[ $name ] ) ) { |
|
591 | + $this->totals['discount']['initial'] -= $this->discounts[ $name ]['initial_discount']; |
|
592 | + $this->totals['discount']['recurring'] -= $this->discounts[ $name ]['recurring_discount']; |
|
593 | + unset( $this->discounts[ $name ] ); |
|
594 | + } |
|
595 | + |
|
596 | + } |
|
597 | + |
|
598 | + /** |
|
599 | + * Checks whether there is a discount code associated with this submission. |
|
600 | + * |
|
601 | + * @since 1.0.19 |
|
602 | + * @return bool |
|
603 | + */ |
|
604 | + public function has_discount_code() { |
|
605 | + return ! empty( $this->discounts['discount_code'] ); |
|
606 | + } |
|
607 | + |
|
608 | + /** |
|
609 | + * Returns the discount code. |
|
610 | + * |
|
611 | + * @since 1.0.19 |
|
612 | + * @return string |
|
613 | + */ |
|
614 | + public function get_discount_code() { |
|
615 | + return $this->has_discount_code() ? $this->discounts['discount_code']['discount_code'] : ''; |
|
616 | + } |
|
617 | + |
|
618 | + /** |
|
619 | + * Returns the discount. |
|
620 | + * |
|
621 | + * @since 1.0.19 |
|
622 | + */ |
|
623 | + public function get_discount() { |
|
624 | + return $this->totals['discount']['initial']; |
|
625 | + } |
|
626 | + |
|
627 | + /** |
|
628 | + * Returns the recurring discount. |
|
629 | + * |
|
630 | + * @since 1.0.19 |
|
631 | + */ |
|
632 | + public function get_recurring_discount() { |
|
633 | + return $this->totals['discount']['recurring']; |
|
634 | + } |
|
635 | + |
|
636 | + /** |
|
637 | + * Returns all discounts. |
|
638 | + * |
|
639 | + * @since 1.0.19 |
|
640 | + */ |
|
641 | + public function get_discounts() { |
|
642 | + return $this->discounts; |
|
643 | + } |
|
644 | + |
|
645 | + /* |
|
646 | 646 | |-------------------------------------------------------------------------- |
647 | 647 | | Fees |
648 | 648 | |-------------------------------------------------------------------------- |
@@ -652,89 +652,89 @@ discard block |
||
652 | 652 | | fees. |
653 | 653 | */ |
654 | 654 | |
655 | - /** |
|
656 | - * Prepares the submission's fees. |
|
657 | - * |
|
658 | - * @since 1.0.19 |
|
659 | - */ |
|
660 | - public function process_fees() { |
|
661 | - |
|
662 | - $fees_processor = new GetPaid_Payment_Form_Submission_Fees( $this ); |
|
663 | - |
|
664 | - foreach ( $fees_processor->fees as $fee ) { |
|
665 | - $this->add_fee( $fee ); |
|
666 | - } |
|
667 | - |
|
668 | - do_action_ref_array( 'getpaid_submissions_process_fees', array( &$this ) ); |
|
669 | - } |
|
670 | - |
|
671 | - /** |
|
672 | - * Adds a fee to the submission. |
|
673 | - * |
|
674 | - * @param array $fee An array of fee details. name, initial_fee, and recurring_fee are required. |
|
675 | - * @since 1.0.19 |
|
676 | - */ |
|
677 | - public function add_fee( $fee ) { |
|
678 | - |
|
679 | - $this->fees[ $fee['name'] ] = $fee; |
|
680 | - $this->totals['fees']['initial'] += wpinv_sanitize_amount( $fee['initial_fee'] ); |
|
681 | - $this->totals['fees']['recurring'] += wpinv_sanitize_amount( $fee['recurring_fee'] ); |
|
682 | - |
|
683 | - } |
|
684 | - |
|
685 | - /** |
|
686 | - * Removes a fee from the submission. |
|
687 | - * |
|
688 | - * @since 1.0.19 |
|
689 | - */ |
|
690 | - public function remove_fee( $name ) { |
|
691 | - |
|
692 | - if ( isset( $this->fees[ $name ] ) ) { |
|
693 | - $this->totals['fees']['initial'] -= $this->fees[ $name ]['initial_fee']; |
|
694 | - $this->totals['fees']['recurring'] -= $this->fees[ $name ]['recurring_fee']; |
|
695 | - unset( $this->fees[ $name ] ); |
|
696 | - } |
|
697 | - |
|
698 | - } |
|
699 | - |
|
700 | - /** |
|
701 | - * Returns the fees. |
|
702 | - * |
|
703 | - * @since 1.0.19 |
|
704 | - */ |
|
705 | - public function get_fee() { |
|
706 | - return $this->totals['fees']['initial']; |
|
707 | - } |
|
708 | - |
|
709 | - /** |
|
710 | - * Returns the recurring fees. |
|
711 | - * |
|
712 | - * @since 1.0.19 |
|
713 | - */ |
|
714 | - public function get_recurring_fee() { |
|
715 | - return $this->totals['fees']['recurring']; |
|
716 | - } |
|
717 | - |
|
718 | - /** |
|
719 | - * Returns all fees. |
|
720 | - * |
|
721 | - * @since 1.0.19 |
|
722 | - */ |
|
723 | - public function get_fees() { |
|
724 | - return $this->fees; |
|
725 | - } |
|
726 | - |
|
727 | - /** |
|
728 | - * Checks if there are any fees for the form. |
|
729 | - * |
|
730 | - * @return bool |
|
731 | - * @since 1.0.19 |
|
732 | - */ |
|
733 | - public function has_fees() { |
|
734 | - return count( $this->fees ) !== 0; |
|
735 | - } |
|
736 | - |
|
737 | - /* |
|
655 | + /** |
|
656 | + * Prepares the submission's fees. |
|
657 | + * |
|
658 | + * @since 1.0.19 |
|
659 | + */ |
|
660 | + public function process_fees() { |
|
661 | + |
|
662 | + $fees_processor = new GetPaid_Payment_Form_Submission_Fees( $this ); |
|
663 | + |
|
664 | + foreach ( $fees_processor->fees as $fee ) { |
|
665 | + $this->add_fee( $fee ); |
|
666 | + } |
|
667 | + |
|
668 | + do_action_ref_array( 'getpaid_submissions_process_fees', array( &$this ) ); |
|
669 | + } |
|
670 | + |
|
671 | + /** |
|
672 | + * Adds a fee to the submission. |
|
673 | + * |
|
674 | + * @param array $fee An array of fee details. name, initial_fee, and recurring_fee are required. |
|
675 | + * @since 1.0.19 |
|
676 | + */ |
|
677 | + public function add_fee( $fee ) { |
|
678 | + |
|
679 | + $this->fees[ $fee['name'] ] = $fee; |
|
680 | + $this->totals['fees']['initial'] += wpinv_sanitize_amount( $fee['initial_fee'] ); |
|
681 | + $this->totals['fees']['recurring'] += wpinv_sanitize_amount( $fee['recurring_fee'] ); |
|
682 | + |
|
683 | + } |
|
684 | + |
|
685 | + /** |
|
686 | + * Removes a fee from the submission. |
|
687 | + * |
|
688 | + * @since 1.0.19 |
|
689 | + */ |
|
690 | + public function remove_fee( $name ) { |
|
691 | + |
|
692 | + if ( isset( $this->fees[ $name ] ) ) { |
|
693 | + $this->totals['fees']['initial'] -= $this->fees[ $name ]['initial_fee']; |
|
694 | + $this->totals['fees']['recurring'] -= $this->fees[ $name ]['recurring_fee']; |
|
695 | + unset( $this->fees[ $name ] ); |
|
696 | + } |
|
697 | + |
|
698 | + } |
|
699 | + |
|
700 | + /** |
|
701 | + * Returns the fees. |
|
702 | + * |
|
703 | + * @since 1.0.19 |
|
704 | + */ |
|
705 | + public function get_fee() { |
|
706 | + return $this->totals['fees']['initial']; |
|
707 | + } |
|
708 | + |
|
709 | + /** |
|
710 | + * Returns the recurring fees. |
|
711 | + * |
|
712 | + * @since 1.0.19 |
|
713 | + */ |
|
714 | + public function get_recurring_fee() { |
|
715 | + return $this->totals['fees']['recurring']; |
|
716 | + } |
|
717 | + |
|
718 | + /** |
|
719 | + * Returns all fees. |
|
720 | + * |
|
721 | + * @since 1.0.19 |
|
722 | + */ |
|
723 | + public function get_fees() { |
|
724 | + return $this->fees; |
|
725 | + } |
|
726 | + |
|
727 | + /** |
|
728 | + * Checks if there are any fees for the form. |
|
729 | + * |
|
730 | + * @return bool |
|
731 | + * @since 1.0.19 |
|
732 | + */ |
|
733 | + public function has_fees() { |
|
734 | + return count( $this->fees ) !== 0; |
|
735 | + } |
|
736 | + |
|
737 | + /* |
|
738 | 738 | |-------------------------------------------------------------------------- |
739 | 739 | | MISC |
740 | 740 | |-------------------------------------------------------------------------- |
@@ -742,119 +742,119 @@ discard block |
||
742 | 742 | | Extra submission functions. |
743 | 743 | */ |
744 | 744 | |
745 | - /** |
|
746 | - * Checks if this is the initial fetch. |
|
747 | - * |
|
748 | - * @return bool |
|
749 | - * @since 1.0.19 |
|
750 | - */ |
|
751 | - public function is_initial_fetch() { |
|
752 | - return empty( $this->data['initial_state'] ); |
|
753 | - } |
|
754 | - |
|
755 | - /** |
|
756 | - * Returns the total amount to collect for this submission. |
|
757 | - * |
|
758 | - * @since 1.0.19 |
|
759 | - */ |
|
760 | - public function get_total() { |
|
761 | - $total = $this->get_subtotal() + $this->get_fee() + $this->get_tax() - $this->get_discount(); |
|
762 | - return max( $total, 0 ); |
|
763 | - } |
|
764 | - |
|
765 | - /** |
|
766 | - * Returns the recurring total amount to collect for this submission. |
|
767 | - * |
|
768 | - * @since 1.0.19 |
|
769 | - */ |
|
770 | - public function get_recurring_total() { |
|
771 | - $total = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax() - $this->get_recurring_discount(); |
|
772 | - return max( $total, 0 ); |
|
773 | - } |
|
774 | - |
|
775 | - /** |
|
776 | - * Whether payment details should be collected for this submission. |
|
777 | - * |
|
778 | - * @since 1.0.19 |
|
779 | - */ |
|
780 | - public function should_collect_payment_details() { |
|
781 | - $initial = $this->get_total(); |
|
782 | - $recurring = $this->get_recurring_total(); |
|
783 | - |
|
784 | - if ( $this->has_recurring == 0 ) { |
|
785 | - $recurring = 0; |
|
786 | - } |
|
787 | - |
|
788 | - $collect = $initial > 0 || $recurring > 0; |
|
789 | - return apply_filters( 'getpaid_submission_should_collect_payment_details', $collect, $this ); |
|
790 | - } |
|
791 | - |
|
792 | - /** |
|
793 | - * Returns the billing email of the user. |
|
794 | - * |
|
795 | - * @since 1.0.19 |
|
796 | - */ |
|
797 | - public function get_billing_email() { |
|
798 | - return apply_filters( 'getpaid_get_submission_billing_email', $this->get_field( 'billing_email' ), $this ); |
|
799 | - } |
|
800 | - |
|
801 | - /** |
|
802 | - * Checks if the submitter has a billing email. |
|
803 | - * |
|
804 | - * @since 1.0.19 |
|
805 | - */ |
|
806 | - public function has_billing_email() { |
|
807 | - $billing_email = $this->get_billing_email(); |
|
808 | - return ! empty( $billing_email ) && is_email( $billing_email ); |
|
809 | - } |
|
810 | - |
|
811 | - /** |
|
812 | - * Returns the appropriate currency for the submission. |
|
813 | - * |
|
814 | - * @since 1.0.19 |
|
815 | - * @return string |
|
816 | - */ |
|
817 | - public function get_currency() { |
|
818 | - return $this->has_invoice() ? $this->invoice->get_currency() : wpinv_get_currency(); |
|
819 | - } |
|
820 | - |
|
821 | - /** |
|
822 | - * Returns the raw submission data. |
|
823 | - * |
|
824 | - * @since 1.0.19 |
|
825 | - * @return array |
|
826 | - */ |
|
827 | - public function get_data() { |
|
828 | - return $this->data; |
|
829 | - } |
|
830 | - |
|
831 | - /** |
|
832 | - * Returns a field from the submission data |
|
833 | - * |
|
834 | - * @param string $field |
|
835 | - * @since 1.0.19 |
|
836 | - * @return mixed|null |
|
837 | - */ |
|
838 | - public function get_field( $field, $sub_array_key = null ) { |
|
839 | - return getpaid_get_array_field( $this->data, $field, $sub_array_key ); |
|
840 | - } |
|
841 | - |
|
842 | - /** |
|
843 | - * Checks if a required field is set. |
|
844 | - * |
|
845 | - * @since 1.0.19 |
|
846 | - */ |
|
847 | - public function is_required_field_set( $field ) { |
|
848 | - return empty( $field['required'] ) || ! empty( $this->data[ $field['id'] ] ); |
|
849 | - } |
|
850 | - |
|
851 | - /** |
|
852 | - * Formats an amount |
|
853 | - * |
|
854 | - * @since 1.0.19 |
|
855 | - */ |
|
856 | - public function format_amount( $amount ) { |
|
857 | - return wpinv_price( $amount, $this->get_currency() ); |
|
858 | - } |
|
745 | + /** |
|
746 | + * Checks if this is the initial fetch. |
|
747 | + * |
|
748 | + * @return bool |
|
749 | + * @since 1.0.19 |
|
750 | + */ |
|
751 | + public function is_initial_fetch() { |
|
752 | + return empty( $this->data['initial_state'] ); |
|
753 | + } |
|
754 | + |
|
755 | + /** |
|
756 | + * Returns the total amount to collect for this submission. |
|
757 | + * |
|
758 | + * @since 1.0.19 |
|
759 | + */ |
|
760 | + public function get_total() { |
|
761 | + $total = $this->get_subtotal() + $this->get_fee() + $this->get_tax() - $this->get_discount(); |
|
762 | + return max( $total, 0 ); |
|
763 | + } |
|
764 | + |
|
765 | + /** |
|
766 | + * Returns the recurring total amount to collect for this submission. |
|
767 | + * |
|
768 | + * @since 1.0.19 |
|
769 | + */ |
|
770 | + public function get_recurring_total() { |
|
771 | + $total = $this->get_recurring_subtotal() + $this->get_recurring_fee() + $this->get_recurring_tax() - $this->get_recurring_discount(); |
|
772 | + return max( $total, 0 ); |
|
773 | + } |
|
774 | + |
|
775 | + /** |
|
776 | + * Whether payment details should be collected for this submission. |
|
777 | + * |
|
778 | + * @since 1.0.19 |
|
779 | + */ |
|
780 | + public function should_collect_payment_details() { |
|
781 | + $initial = $this->get_total(); |
|
782 | + $recurring = $this->get_recurring_total(); |
|
783 | + |
|
784 | + if ( $this->has_recurring == 0 ) { |
|
785 | + $recurring = 0; |
|
786 | + } |
|
787 | + |
|
788 | + $collect = $initial > 0 || $recurring > 0; |
|
789 | + return apply_filters( 'getpaid_submission_should_collect_payment_details', $collect, $this ); |
|
790 | + } |
|
791 | + |
|
792 | + /** |
|
793 | + * Returns the billing email of the user. |
|
794 | + * |
|
795 | + * @since 1.0.19 |
|
796 | + */ |
|
797 | + public function get_billing_email() { |
|
798 | + return apply_filters( 'getpaid_get_submission_billing_email', $this->get_field( 'billing_email' ), $this ); |
|
799 | + } |
|
800 | + |
|
801 | + /** |
|
802 | + * Checks if the submitter has a billing email. |
|
803 | + * |
|
804 | + * @since 1.0.19 |
|
805 | + */ |
|
806 | + public function has_billing_email() { |
|
807 | + $billing_email = $this->get_billing_email(); |
|
808 | + return ! empty( $billing_email ) && is_email( $billing_email ); |
|
809 | + } |
|
810 | + |
|
811 | + /** |
|
812 | + * Returns the appropriate currency for the submission. |
|
813 | + * |
|
814 | + * @since 1.0.19 |
|
815 | + * @return string |
|
816 | + */ |
|
817 | + public function get_currency() { |
|
818 | + return $this->has_invoice() ? $this->invoice->get_currency() : wpinv_get_currency(); |
|
819 | + } |
|
820 | + |
|
821 | + /** |
|
822 | + * Returns the raw submission data. |
|
823 | + * |
|
824 | + * @since 1.0.19 |
|
825 | + * @return array |
|
826 | + */ |
|
827 | + public function get_data() { |
|
828 | + return $this->data; |
|
829 | + } |
|
830 | + |
|
831 | + /** |
|
832 | + * Returns a field from the submission data |
|
833 | + * |
|
834 | + * @param string $field |
|
835 | + * @since 1.0.19 |
|
836 | + * @return mixed|null |
|
837 | + */ |
|
838 | + public function get_field( $field, $sub_array_key = null ) { |
|
839 | + return getpaid_get_array_field( $this->data, $field, $sub_array_key ); |
|
840 | + } |
|
841 | + |
|
842 | + /** |
|
843 | + * Checks if a required field is set. |
|
844 | + * |
|
845 | + * @since 1.0.19 |
|
846 | + */ |
|
847 | + public function is_required_field_set( $field ) { |
|
848 | + return empty( $field['required'] ) || ! empty( $this->data[ $field['id'] ] ); |
|
849 | + } |
|
850 | + |
|
851 | + /** |
|
852 | + * Formats an amount |
|
853 | + * |
|
854 | + * @since 1.0.19 |
|
855 | + */ |
|
856 | + public function format_amount( $amount ) { |
|
857 | + return wpinv_price( $amount, $this->get_currency() ); |
|
858 | + } |
|
859 | 859 | |
860 | 860 | } |
@@ -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 class='font-weight-bold'>$label</th><td class='w-75'>$value</td></tr>" . PHP_EOL; |
|
183 | - } |
|
182 | + echo "<tr class='getpaid-bank-transfer-$key'><th class='font-weight-bold'>$label</th><td class='w-75'>$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 | } |
@@ -24,64 +24,64 @@ discard block |
||
24 | 24 | |
25 | 25 | <?php |
26 | 26 | |
27 | - // Fires before printing a line item column. |
|
28 | - do_action( "getpaid_form_cart_item_before_$key", $item, $form ); |
|
27 | + // Fires before printing a line item column. |
|
28 | + do_action( "getpaid_form_cart_item_before_$key", $item, $form ); |
|
29 | 29 | |
30 | - // Item name. |
|
31 | - if ( 'name' == $key ) { |
|
30 | + // Item name. |
|
31 | + if ( 'name' == $key ) { |
|
32 | 32 | |
33 | - // Display the name. |
|
34 | - echo '<div class="mb-1">' . sanitize_text_field( $item->get_name() ) . '</div>'; |
|
33 | + // Display the name. |
|
34 | + echo '<div class="mb-1">' . sanitize_text_field( $item->get_name() ) . '</div>'; |
|
35 | 35 | |
36 | - // And an optional description. |
|
36 | + // And an optional description. |
|
37 | 37 | $description = $item->get_description(); |
38 | 38 | |
39 | 39 | if ( ! empty( $description ) ) { |
40 | 40 | $description = wp_kses_post( $description ); |
41 | 41 | echo "<small class='form-text text-muted pr-2 m-0'>$description</small>"; |
42 | - } |
|
42 | + } |
|
43 | 43 | |
44 | - // Price help text. |
|
44 | + // Price help text. |
|
45 | 45 | $description = getpaid_item_recurring_price_help_text( $item, $currency ); |
46 | 46 | if ( $description ) { |
47 | 47 | echo "<small class='getpaid-form-item-price-desc form-text text-muted pr-2 m-0'>$description</small>"; |
48 | - } |
|
48 | + } |
|
49 | 49 | |
50 | - } |
|
50 | + } |
|
51 | 51 | |
52 | - // Item price. |
|
53 | - if ( 'price' == $key ) { |
|
52 | + // Item price. |
|
53 | + if ( 'price' == $key ) { |
|
54 | 54 | |
55 | - // Set the currency position. |
|
56 | - $position = wpinv_currency_position(); |
|
55 | + // Set the currency position. |
|
56 | + $position = wpinv_currency_position(); |
|
57 | 57 | |
58 | - if ( $position == 'left_space' ) { |
|
59 | - $position = 'left'; |
|
60 | - } |
|
58 | + if ( $position == 'left_space' ) { |
|
59 | + $position = 'left'; |
|
60 | + } |
|
61 | 61 | |
62 | - if ( $position == 'right_space' ) { |
|
63 | - $position = 'right'; |
|
64 | - } |
|
62 | + if ( $position == 'right_space' ) { |
|
63 | + $position = 'right'; |
|
64 | + } |
|
65 | 65 | |
66 | - if ( $item->user_can_set_their_price() ) { |
|
67 | - $price = max( (float) $item->get_price(), (float) $item->get_minimum_price() ); |
|
68 | - $minimum = (float) $item->get_minimum_price(); |
|
69 | - $validate_minimum = ''; |
|
70 | - $class = ''; |
|
71 | - $data_minimum = ''; |
|
66 | + if ( $item->user_can_set_their_price() ) { |
|
67 | + $price = max( (float) $item->get_price(), (float) $item->get_minimum_price() ); |
|
68 | + $minimum = (float) $item->get_minimum_price(); |
|
69 | + $validate_minimum = ''; |
|
70 | + $class = ''; |
|
71 | + $data_minimum = ''; |
|
72 | 72 | |
73 | - if ( $minimum > 0 ) { |
|
74 | - $validate_minimum = sprintf( |
|
75 | - esc_attr__( 'The minimum allowed amount is %s', 'invoicing' ), |
|
76 | - sanitize_text_field( wpinv_price( $minimum, $currency ) ) |
|
77 | - ); |
|
73 | + if ( $minimum > 0 ) { |
|
74 | + $validate_minimum = sprintf( |
|
75 | + esc_attr__( 'The minimum allowed amount is %s', 'invoicing' ), |
|
76 | + sanitize_text_field( wpinv_price( $minimum, $currency ) ) |
|
77 | + ); |
|
78 | 78 | |
79 | - $class = 'getpaid-validate-minimum-amount'; |
|
79 | + $class = 'getpaid-validate-minimum-amount'; |
|
80 | 80 | |
81 | - $data_minimum = "data-minimum-amount='$minimum'"; |
|
82 | - } |
|
81 | + $data_minimum = "data-minimum-amount='$minimum'"; |
|
82 | + } |
|
83 | 83 | |
84 | - ?> |
|
84 | + ?> |
|
85 | 85 | <div class="input-group input-group-sm"> |
86 | 86 | <?php if( 'left' == $position ) : ?> |
87 | 87 | <div class="input-group-prepend"> |
@@ -105,37 +105,37 @@ discard block |
||
105 | 105 | </div> |
106 | 106 | |
107 | 107 | <?php |
108 | - } else { |
|
109 | - echo wpinv_price( $item->get_price(), $currency ); |
|
110 | - ?> |
|
108 | + } else { |
|
109 | + echo wpinv_price( $item->get_price(), $currency ); |
|
110 | + ?> |
|
111 | 111 | <input name='getpaid-items[<?php echo (int) $item->get_id(); ?>][price]' type='hidden' class='getpaid-item-price-input' value='<?php echo esc_attr( $item->get_price() ); ?>'> |
112 | 112 | <?php |
113 | - } |
|
114 | - } |
|
113 | + } |
|
114 | + } |
|
115 | 115 | |
116 | - // Item quantity. |
|
117 | - if ( 'quantity' == $key ) { |
|
116 | + // Item quantity. |
|
117 | + if ( 'quantity' == $key ) { |
|
118 | 118 | |
119 | - if ( $item->allows_quantities() ) { |
|
120 | - ?> |
|
119 | + if ( $item->allows_quantities() ) { |
|
120 | + ?> |
|
121 | 121 | <input name='getpaid-items[<?php echo (int) $item->get_id(); ?>][quantity]' type='text' style='width: 64px; line-height: 1; min-height: 35px;' class='getpaid-item-quantity-input p-1 align-middle font-weight-normal shadow-none m-0 rounded-0 text-center border' value='<?php echo (float) $item->get_quantity(); ?>' min='1' required> |
122 | 122 | <?php |
123 | - } else { |
|
124 | - echo (float) $item->get_quantity(); |
|
125 | - echo ' '; |
|
126 | - ?> |
|
123 | + } else { |
|
124 | + echo (float) $item->get_quantity(); |
|
125 | + echo ' '; |
|
126 | + ?> |
|
127 | 127 | <input type='hidden' name='getpaid-items[<?php echo (int) $item->get_id(); ?>][quantity]' class='getpaid-item-quantity-input' value='<?php echo (float) $item->get_quantity(); ?>'> |
128 | 128 | <?php |
129 | - } |
|
130 | - } |
|
129 | + } |
|
130 | + } |
|
131 | 131 | |
132 | - // Item sub total. |
|
133 | - if ( 'subtotal' == $key ) { |
|
134 | - echo wpinv_price( $item->get_sub_total(), $currency ); |
|
135 | - } |
|
132 | + // Item sub total. |
|
133 | + if ( 'subtotal' == $key ) { |
|
134 | + echo wpinv_price( $item->get_sub_total(), $currency ); |
|
135 | + } |
|
136 | 136 | |
137 | - do_action( "getpaid_payment_form_cart_item_$key", $item, $form ); |
|
138 | - ?> |
|
137 | + do_action( "getpaid_payment_form_cart_item_$key", $item, $form ); |
|
138 | + ?> |
|
139 | 139 | |
140 | 140 | </div> |
141 | 141 |
@@ -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.24"; |
|
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.24"; |
|
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 | /** |
@@ -1233,402 +1233,402 @@ discard block |
||
1233 | 1233 | <?php do_action( 'wp_super_duper_widget_js', $this ); ?> |
1234 | 1234 | </script> |
1235 | 1235 | <?php |
1236 | - $output = ob_get_clean(); |
|
1236 | + $output = ob_get_clean(); |
|
1237 | 1237 | |
1238 | - /* |
|
1238 | + /* |
|
1239 | 1239 | * We only add the <script> tags for code highlighting, so we strip them from the output. |
1240 | 1240 | */ |
1241 | 1241 | |
1242 | - return str_replace( array( |
|
1243 | - '<script>', |
|
1244 | - '</script>' |
|
1245 | - ), '', $output ); |
|
1246 | - } |
|
1247 | - |
|
1248 | - |
|
1249 | - /** |
|
1250 | - * Set the name from the argument key. |
|
1251 | - * |
|
1252 | - * @param $options |
|
1253 | - * |
|
1254 | - * @return mixed |
|
1255 | - */ |
|
1256 | - private function add_name_from_key( $options, $arguments = false ) { |
|
1257 | - if ( ! empty( $options['arguments'] ) ) { |
|
1258 | - foreach ( $options['arguments'] as $key => $val ) { |
|
1259 | - $options['arguments'][ $key ]['name'] = $key; |
|
1260 | - } |
|
1261 | - } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) { |
|
1262 | - foreach ( $options as $key => $val ) { |
|
1263 | - $options[ $key ]['name'] = $key; |
|
1264 | - } |
|
1265 | - } |
|
1266 | - |
|
1267 | - return $options; |
|
1268 | - } |
|
1269 | - |
|
1270 | - /** |
|
1271 | - * Register the parent shortcode. |
|
1272 | - * |
|
1273 | - * @since 1.0.0 |
|
1274 | - */ |
|
1275 | - public function register_shortcode() { |
|
1276 | - add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) ); |
|
1277 | - add_action( 'wp_ajax_super_duper_output_shortcode', array( __CLASS__, 'render_shortcode' ) ); |
|
1278 | - } |
|
1279 | - |
|
1280 | - /** |
|
1281 | - * Render the shortcode via ajax so we can return it to Gutenberg. |
|
1282 | - * |
|
1283 | - * @since 1.0.0 |
|
1284 | - */ |
|
1285 | - public static function render_shortcode() { |
|
1286 | - |
|
1287 | - check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true ); |
|
1288 | - if ( ! current_user_can( 'manage_options' ) ) { |
|
1289 | - wp_die(); |
|
1290 | - } |
|
1291 | - |
|
1292 | - // we might need the $post value here so lets set it. |
|
1293 | - if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) { |
|
1294 | - $post_obj = get_post( absint( $_POST['post_id'] ) ); |
|
1295 | - if ( ! empty( $post_obj ) && empty( $post ) ) { |
|
1296 | - global $post; |
|
1297 | - $post = $post_obj; |
|
1298 | - } |
|
1299 | - } |
|
1300 | - |
|
1301 | - if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) { |
|
1302 | - $shortcode_name = sanitize_title_with_dashes( $_POST['shortcode'] ); |
|
1303 | - $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array(); |
|
1304 | - $attributes = ''; |
|
1305 | - if ( ! empty( $attributes_array ) ) { |
|
1306 | - foreach ( $attributes_array as $key => $value ) { |
|
1307 | - $attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . wp_slash( $value ) . "' "; |
|
1308 | - } |
|
1309 | - } |
|
1310 | - |
|
1311 | - $shortcode = "[" . $shortcode_name . " " . $attributes . "]"; |
|
1312 | - |
|
1313 | - echo do_shortcode( $shortcode ); |
|
1314 | - |
|
1315 | - } |
|
1316 | - wp_die(); |
|
1317 | - } |
|
1318 | - |
|
1319 | - /** |
|
1320 | - * Output the shortcode. |
|
1321 | - * |
|
1322 | - * @param array $args |
|
1323 | - * @param string $content |
|
1324 | - * |
|
1325 | - * @return string |
|
1326 | - */ |
|
1327 | - public function shortcode_output( $args = array(), $content = '' ) { |
|
1328 | - $args = $this->argument_values( $args ); |
|
1329 | - |
|
1330 | - // add extra argument so we know its a output to gutenberg |
|
1331 | - //$args |
|
1332 | - $args = $this->string_to_bool( $args ); |
|
1333 | - |
|
1334 | - // if we have a enclosed shortcode we add it to the special `html` argument |
|
1335 | - if ( ! empty( $content ) ) { |
|
1336 | - $args['html'] = $content; |
|
1337 | - } |
|
1338 | - |
|
1339 | - $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : ''; |
|
1340 | - $class .= " sdel-".$this->get_instance_hash(); |
|
1341 | - |
|
1342 | - $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this ); |
|
1343 | - $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this ); |
|
1344 | - |
|
1345 | - $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this ); |
|
1346 | - $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this ); //@todo this does not seem right @kiran? |
|
1347 | - |
|
1348 | - $shortcode_args = array(); |
|
1349 | - $output = ''; |
|
1350 | - $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false; |
|
1351 | - if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) { |
|
1352 | - $no_wrap = true; |
|
1353 | - } |
|
1354 | - $main_content = $this->output( $args, $shortcode_args, $content ); |
|
1355 | - if ( $main_content && ! $no_wrap ) { |
|
1356 | - // wrap the shortcode in a div with the same class as the widget |
|
1357 | - $output .= '<div class="' . $class . '" ' . $attrs . '>'; |
|
1358 | - if ( ! empty( $args['title'] ) ) { |
|
1359 | - // if its a shortcode and there is a title try to grab the title wrappers |
|
1360 | - $shortcode_args = array( 'before_title' => '', 'after_title' => '' ); |
|
1361 | - if ( empty( $instance ) ) { |
|
1362 | - global $wp_registered_sidebars; |
|
1363 | - if ( ! empty( $wp_registered_sidebars ) ) { |
|
1364 | - foreach ( $wp_registered_sidebars as $sidebar ) { |
|
1365 | - if ( ! empty( $sidebar['before_title'] ) ) { |
|
1366 | - $shortcode_args['before_title'] = $sidebar['before_title']; |
|
1367 | - $shortcode_args['after_title'] = $sidebar['after_title']; |
|
1368 | - break; |
|
1369 | - } |
|
1370 | - } |
|
1371 | - } |
|
1372 | - } |
|
1373 | - $output .= $this->output_title( $shortcode_args, $args ); |
|
1374 | - } |
|
1375 | - $output .= $main_content; |
|
1376 | - $output .= '</div>'; |
|
1377 | - } elseif ( $main_content && $no_wrap ) { |
|
1378 | - $output .= $main_content; |
|
1379 | - } |
|
1380 | - |
|
1381 | - // if preview show a placeholder if empty |
|
1382 | - if ( $this->is_preview() && $output == '' ) { |
|
1383 | - $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" ); |
|
1384 | - } |
|
1385 | - |
|
1386 | - return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this ); |
|
1387 | - } |
|
1388 | - |
|
1389 | - /** |
|
1390 | - * Placeholder text to show if output is empty and we are on a preview/builder page. |
|
1391 | - * |
|
1392 | - * @param string $name |
|
1393 | - * |
|
1394 | - * @return string |
|
1395 | - */ |
|
1396 | - public function preview_placeholder_text( $name = '' ) { |
|
1397 | - return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>"; |
|
1398 | - } |
|
1399 | - |
|
1400 | - /** |
|
1401 | - * Sometimes booleans values can be turned to strings, so we fix that. |
|
1402 | - * |
|
1403 | - * @param $options |
|
1404 | - * |
|
1405 | - * @return mixed |
|
1406 | - */ |
|
1407 | - public function string_to_bool( $options ) { |
|
1408 | - // convert bool strings to booleans |
|
1409 | - foreach ( $options as $key => $val ) { |
|
1410 | - if ( $val == 'false' ) { |
|
1411 | - $options[ $key ] = false; |
|
1412 | - } elseif ( $val == 'true' ) { |
|
1413 | - $options[ $key ] = true; |
|
1414 | - } |
|
1415 | - } |
|
1416 | - |
|
1417 | - return $options; |
|
1418 | - } |
|
1419 | - |
|
1420 | - /** |
|
1421 | - * Get the argument values that are also filterable. |
|
1422 | - * |
|
1423 | - * @param $instance |
|
1424 | - * |
|
1425 | - * @since 1.0.12 Don't set checkbox default value if the value is empty. |
|
1426 | - * |
|
1427 | - * @return array |
|
1428 | - */ |
|
1429 | - public function argument_values( $instance ) { |
|
1430 | - $argument_values = array(); |
|
1431 | - |
|
1432 | - // set widget instance |
|
1433 | - $this->instance = $instance; |
|
1434 | - |
|
1435 | - if ( empty( $this->arguments ) ) { |
|
1436 | - $this->arguments = $this->get_arguments(); |
|
1437 | - } |
|
1438 | - |
|
1439 | - if ( ! empty( $this->arguments ) ) { |
|
1440 | - foreach ( $this->arguments as $key => $args ) { |
|
1441 | - // set the input name from the key |
|
1442 | - $args['name'] = $key; |
|
1443 | - // |
|
1444 | - $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : ''; |
|
1445 | - if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) { |
|
1446 | - // don't set default for an empty checkbox |
|
1447 | - } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) { |
|
1448 | - $argument_values[ $key ] = $args['default']; |
|
1449 | - } |
|
1450 | - } |
|
1451 | - } |
|
1452 | - |
|
1453 | - return $argument_values; |
|
1454 | - } |
|
1455 | - |
|
1456 | - /** |
|
1457 | - * Set arguments in super duper. |
|
1458 | - * |
|
1459 | - * @since 1.0.0 |
|
1460 | - * |
|
1461 | - * @return array Set arguments. |
|
1462 | - */ |
|
1463 | - public function set_arguments() { |
|
1464 | - return $this->arguments; |
|
1465 | - } |
|
1466 | - |
|
1467 | - /** |
|
1468 | - * Get arguments in super duper. |
|
1469 | - * |
|
1470 | - * @since 1.0.0 |
|
1471 | - * |
|
1472 | - * @return array Get arguments. |
|
1473 | - */ |
|
1474 | - public function get_arguments() { |
|
1475 | - if ( empty( $this->arguments ) ) { |
|
1476 | - $this->arguments = $this->set_arguments(); |
|
1477 | - } |
|
1478 | - |
|
1479 | - $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance ); |
|
1480 | - $this->arguments = $this->add_name_from_key( $this->arguments, true ); |
|
1481 | - |
|
1482 | - return $this->arguments; |
|
1483 | - } |
|
1484 | - |
|
1485 | - /** |
|
1486 | - * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class. |
|
1487 | - * |
|
1488 | - * @param array $args |
|
1489 | - * @param array $widget_args |
|
1490 | - * @param string $content |
|
1491 | - */ |
|
1492 | - public function output( $args = array(), $widget_args = array(), $content = '' ) { |
|
1493 | - |
|
1494 | - } |
|
1495 | - |
|
1496 | - /** |
|
1497 | - * Add the dynamic block code inline when the wp-block in enqueued. |
|
1498 | - */ |
|
1499 | - public function register_block() { |
|
1500 | - wp_add_inline_script( 'wp-blocks', $this->block() ); |
|
1501 | - if ( class_exists( 'SiteOrigin_Panels' ) ) { |
|
1502 | - wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() ); |
|
1503 | - } |
|
1504 | - } |
|
1505 | - |
|
1506 | - /** |
|
1507 | - * Check if we need to show advanced options. |
|
1508 | - * |
|
1509 | - * @return bool |
|
1510 | - */ |
|
1511 | - public function block_show_advanced() { |
|
1512 | - |
|
1513 | - $show = false; |
|
1514 | - $arguments = $this->arguments; |
|
1515 | - |
|
1516 | - if ( empty( $arguments ) ) { |
|
1517 | - $arguments = $this->get_arguments(); |
|
1518 | - } |
|
1519 | - |
|
1520 | - if ( ! empty( $arguments ) ) { |
|
1521 | - foreach ( $arguments as $argument ) { |
|
1522 | - if ( isset( $argument['advanced'] ) && $argument['advanced'] ) { |
|
1523 | - $show = true; |
|
1524 | - break; // no need to continue if we know we have it |
|
1525 | - } |
|
1526 | - } |
|
1527 | - } |
|
1528 | - |
|
1529 | - return $show; |
|
1530 | - } |
|
1531 | - |
|
1532 | - /** |
|
1533 | - * Get the url path to the current folder. |
|
1534 | - * |
|
1535 | - * @return string |
|
1536 | - */ |
|
1537 | - public function get_url() { |
|
1538 | - |
|
1539 | - $url = $this->url; |
|
1540 | - |
|
1541 | - if ( ! $url ) { |
|
1542 | - // check if we are inside a plugin |
|
1543 | - $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) ); |
|
1544 | - |
|
1545 | - $dir_parts = explode( "/wp-content/", $file_dir ); |
|
1546 | - $url_parts = explode( "/wp-content/", plugins_url() ); |
|
1547 | - |
|
1548 | - if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) { |
|
1549 | - $url = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] ); |
|
1550 | - $this->url = $url; |
|
1551 | - } |
|
1552 | - } |
|
1553 | - |
|
1554 | - |
|
1555 | - return $url; |
|
1556 | - } |
|
1557 | - |
|
1558 | - /** |
|
1559 | - * Generate the block icon. |
|
1560 | - * |
|
1561 | - * Enables the use of Font Awesome icons. |
|
1562 | - * |
|
1563 | - * @note xlink:href is actually deprecated but href is not supported by all so we use both. |
|
1564 | - * |
|
1565 | - * @param $icon |
|
1566 | - * |
|
1567 | - * @since 1.1.0 |
|
1568 | - * @return string |
|
1569 | - */ |
|
1570 | - public function get_block_icon( $icon ) { |
|
1571 | - |
|
1572 | - // check if we have a Font Awesome icon |
|
1573 | - $fa_type = ''; |
|
1574 | - if ( substr( $icon, 0, 7 ) === "fas fa-" ) { |
|
1575 | - $fa_type = 'solid'; |
|
1576 | - } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) { |
|
1577 | - $fa_type = 'regular'; |
|
1578 | - } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) { |
|
1579 | - $fa_type = 'brands'; |
|
1580 | - } else { |
|
1581 | - $icon = "'" . $icon . "'"; |
|
1582 | - } |
|
1583 | - |
|
1584 | - // set the icon if we found one |
|
1585 | - if ( $fa_type ) { |
|
1586 | - $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon ); |
|
1587 | - $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 . "'}))"; |
|
1588 | - } |
|
1589 | - |
|
1590 | - return $icon; |
|
1591 | - } |
|
1592 | - |
|
1593 | - public function group_arguments( $arguments ) { |
|
1242 | + return str_replace( array( |
|
1243 | + '<script>', |
|
1244 | + '</script>' |
|
1245 | + ), '', $output ); |
|
1246 | + } |
|
1247 | + |
|
1248 | + |
|
1249 | + /** |
|
1250 | + * Set the name from the argument key. |
|
1251 | + * |
|
1252 | + * @param $options |
|
1253 | + * |
|
1254 | + * @return mixed |
|
1255 | + */ |
|
1256 | + private function add_name_from_key( $options, $arguments = false ) { |
|
1257 | + if ( ! empty( $options['arguments'] ) ) { |
|
1258 | + foreach ( $options['arguments'] as $key => $val ) { |
|
1259 | + $options['arguments'][ $key ]['name'] = $key; |
|
1260 | + } |
|
1261 | + } elseif ( $arguments && is_array( $options ) && ! empty( $options ) ) { |
|
1262 | + foreach ( $options as $key => $val ) { |
|
1263 | + $options[ $key ]['name'] = $key; |
|
1264 | + } |
|
1265 | + } |
|
1266 | + |
|
1267 | + return $options; |
|
1268 | + } |
|
1269 | + |
|
1270 | + /** |
|
1271 | + * Register the parent shortcode. |
|
1272 | + * |
|
1273 | + * @since 1.0.0 |
|
1274 | + */ |
|
1275 | + public function register_shortcode() { |
|
1276 | + add_shortcode( $this->base_id, array( $this, 'shortcode_output' ) ); |
|
1277 | + add_action( 'wp_ajax_super_duper_output_shortcode', array( __CLASS__, 'render_shortcode' ) ); |
|
1278 | + } |
|
1279 | + |
|
1280 | + /** |
|
1281 | + * Render the shortcode via ajax so we can return it to Gutenberg. |
|
1282 | + * |
|
1283 | + * @since 1.0.0 |
|
1284 | + */ |
|
1285 | + public static function render_shortcode() { |
|
1286 | + |
|
1287 | + check_ajax_referer( 'super_duper_output_shortcode', '_ajax_nonce', true ); |
|
1288 | + if ( ! current_user_can( 'manage_options' ) ) { |
|
1289 | + wp_die(); |
|
1290 | + } |
|
1291 | + |
|
1292 | + // we might need the $post value here so lets set it. |
|
1293 | + if ( isset( $_POST['post_id'] ) && $_POST['post_id'] ) { |
|
1294 | + $post_obj = get_post( absint( $_POST['post_id'] ) ); |
|
1295 | + if ( ! empty( $post_obj ) && empty( $post ) ) { |
|
1296 | + global $post; |
|
1297 | + $post = $post_obj; |
|
1298 | + } |
|
1299 | + } |
|
1300 | + |
|
1301 | + if ( isset( $_POST['shortcode'] ) && $_POST['shortcode'] ) { |
|
1302 | + $shortcode_name = sanitize_title_with_dashes( $_POST['shortcode'] ); |
|
1303 | + $attributes_array = isset( $_POST['attributes'] ) && $_POST['attributes'] ? $_POST['attributes'] : array(); |
|
1304 | + $attributes = ''; |
|
1305 | + if ( ! empty( $attributes_array ) ) { |
|
1306 | + foreach ( $attributes_array as $key => $value ) { |
|
1307 | + $attributes .= " " . sanitize_title_with_dashes( $key ) . "='" . wp_slash( $value ) . "' "; |
|
1308 | + } |
|
1309 | + } |
|
1310 | + |
|
1311 | + $shortcode = "[" . $shortcode_name . " " . $attributes . "]"; |
|
1312 | + |
|
1313 | + echo do_shortcode( $shortcode ); |
|
1314 | + |
|
1315 | + } |
|
1316 | + wp_die(); |
|
1317 | + } |
|
1318 | + |
|
1319 | + /** |
|
1320 | + * Output the shortcode. |
|
1321 | + * |
|
1322 | + * @param array $args |
|
1323 | + * @param string $content |
|
1324 | + * |
|
1325 | + * @return string |
|
1326 | + */ |
|
1327 | + public function shortcode_output( $args = array(), $content = '' ) { |
|
1328 | + $args = $this->argument_values( $args ); |
|
1329 | + |
|
1330 | + // add extra argument so we know its a output to gutenberg |
|
1331 | + //$args |
|
1332 | + $args = $this->string_to_bool( $args ); |
|
1333 | + |
|
1334 | + // if we have a enclosed shortcode we add it to the special `html` argument |
|
1335 | + if ( ! empty( $content ) ) { |
|
1336 | + $args['html'] = $content; |
|
1337 | + } |
|
1338 | + |
|
1339 | + $class = isset( $this->options['widget_ops']['classname'] ) ? esc_attr( $this->options['widget_ops']['classname'] ) : ''; |
|
1340 | + $class .= " sdel-".$this->get_instance_hash(); |
|
1341 | + |
|
1342 | + $class = apply_filters( 'wp_super_duper_div_classname', $class, $args, $this ); |
|
1343 | + $class = apply_filters( 'wp_super_duper_div_classname_' . $this->base_id, $class, $args, $this ); |
|
1344 | + |
|
1345 | + $attrs = apply_filters( 'wp_super_duper_div_attrs', '', $args, $this ); |
|
1346 | + $attrs = apply_filters( 'wp_super_duper_div_attrs_' . $this->base_id, '', $args, $this ); //@todo this does not seem right @kiran? |
|
1347 | + |
|
1348 | + $shortcode_args = array(); |
|
1349 | + $output = ''; |
|
1350 | + $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false; |
|
1351 | + if ( isset( $args['no_wrap'] ) && $args['no_wrap'] ) { |
|
1352 | + $no_wrap = true; |
|
1353 | + } |
|
1354 | + $main_content = $this->output( $args, $shortcode_args, $content ); |
|
1355 | + if ( $main_content && ! $no_wrap ) { |
|
1356 | + // wrap the shortcode in a div with the same class as the widget |
|
1357 | + $output .= '<div class="' . $class . '" ' . $attrs . '>'; |
|
1358 | + if ( ! empty( $args['title'] ) ) { |
|
1359 | + // if its a shortcode and there is a title try to grab the title wrappers |
|
1360 | + $shortcode_args = array( 'before_title' => '', 'after_title' => '' ); |
|
1361 | + if ( empty( $instance ) ) { |
|
1362 | + global $wp_registered_sidebars; |
|
1363 | + if ( ! empty( $wp_registered_sidebars ) ) { |
|
1364 | + foreach ( $wp_registered_sidebars as $sidebar ) { |
|
1365 | + if ( ! empty( $sidebar['before_title'] ) ) { |
|
1366 | + $shortcode_args['before_title'] = $sidebar['before_title']; |
|
1367 | + $shortcode_args['after_title'] = $sidebar['after_title']; |
|
1368 | + break; |
|
1369 | + } |
|
1370 | + } |
|
1371 | + } |
|
1372 | + } |
|
1373 | + $output .= $this->output_title( $shortcode_args, $args ); |
|
1374 | + } |
|
1375 | + $output .= $main_content; |
|
1376 | + $output .= '</div>'; |
|
1377 | + } elseif ( $main_content && $no_wrap ) { |
|
1378 | + $output .= $main_content; |
|
1379 | + } |
|
1380 | + |
|
1381 | + // if preview show a placeholder if empty |
|
1382 | + if ( $this->is_preview() && $output == '' ) { |
|
1383 | + $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" ); |
|
1384 | + } |
|
1385 | + |
|
1386 | + return apply_filters( 'wp_super_duper_widget_output', $output, $args, $shortcode_args, $this ); |
|
1387 | + } |
|
1388 | + |
|
1389 | + /** |
|
1390 | + * Placeholder text to show if output is empty and we are on a preview/builder page. |
|
1391 | + * |
|
1392 | + * @param string $name |
|
1393 | + * |
|
1394 | + * @return string |
|
1395 | + */ |
|
1396 | + public function preview_placeholder_text( $name = '' ) { |
|
1397 | + return "<div style='background:#0185ba33;padding: 10px;border: 4px #ccc dashed;'>" . sprintf( __( 'Placeholder for: %s' ), $name ) . "</div>"; |
|
1398 | + } |
|
1399 | + |
|
1400 | + /** |
|
1401 | + * Sometimes booleans values can be turned to strings, so we fix that. |
|
1402 | + * |
|
1403 | + * @param $options |
|
1404 | + * |
|
1405 | + * @return mixed |
|
1406 | + */ |
|
1407 | + public function string_to_bool( $options ) { |
|
1408 | + // convert bool strings to booleans |
|
1409 | + foreach ( $options as $key => $val ) { |
|
1410 | + if ( $val == 'false' ) { |
|
1411 | + $options[ $key ] = false; |
|
1412 | + } elseif ( $val == 'true' ) { |
|
1413 | + $options[ $key ] = true; |
|
1414 | + } |
|
1415 | + } |
|
1416 | + |
|
1417 | + return $options; |
|
1418 | + } |
|
1419 | + |
|
1420 | + /** |
|
1421 | + * Get the argument values that are also filterable. |
|
1422 | + * |
|
1423 | + * @param $instance |
|
1424 | + * |
|
1425 | + * @since 1.0.12 Don't set checkbox default value if the value is empty. |
|
1426 | + * |
|
1427 | + * @return array |
|
1428 | + */ |
|
1429 | + public function argument_values( $instance ) { |
|
1430 | + $argument_values = array(); |
|
1431 | + |
|
1432 | + // set widget instance |
|
1433 | + $this->instance = $instance; |
|
1434 | + |
|
1435 | + if ( empty( $this->arguments ) ) { |
|
1436 | + $this->arguments = $this->get_arguments(); |
|
1437 | + } |
|
1438 | + |
|
1439 | + if ( ! empty( $this->arguments ) ) { |
|
1440 | + foreach ( $this->arguments as $key => $args ) { |
|
1441 | + // set the input name from the key |
|
1442 | + $args['name'] = $key; |
|
1443 | + // |
|
1444 | + $argument_values[ $key ] = isset( $instance[ $key ] ) ? $instance[ $key ] : ''; |
|
1445 | + if ( $args['type'] == 'checkbox' && $argument_values[ $key ] == '' ) { |
|
1446 | + // don't set default for an empty checkbox |
|
1447 | + } elseif ( $argument_values[ $key ] == '' && isset( $args['default'] ) ) { |
|
1448 | + $argument_values[ $key ] = $args['default']; |
|
1449 | + } |
|
1450 | + } |
|
1451 | + } |
|
1452 | + |
|
1453 | + return $argument_values; |
|
1454 | + } |
|
1455 | + |
|
1456 | + /** |
|
1457 | + * Set arguments in super duper. |
|
1458 | + * |
|
1459 | + * @since 1.0.0 |
|
1460 | + * |
|
1461 | + * @return array Set arguments. |
|
1462 | + */ |
|
1463 | + public function set_arguments() { |
|
1464 | + return $this->arguments; |
|
1465 | + } |
|
1466 | + |
|
1467 | + /** |
|
1468 | + * Get arguments in super duper. |
|
1469 | + * |
|
1470 | + * @since 1.0.0 |
|
1471 | + * |
|
1472 | + * @return array Get arguments. |
|
1473 | + */ |
|
1474 | + public function get_arguments() { |
|
1475 | + if ( empty( $this->arguments ) ) { |
|
1476 | + $this->arguments = $this->set_arguments(); |
|
1477 | + } |
|
1478 | + |
|
1479 | + $this->arguments = apply_filters( 'wp_super_duper_arguments', $this->arguments, $this->options, $this->instance ); |
|
1480 | + $this->arguments = $this->add_name_from_key( $this->arguments, true ); |
|
1481 | + |
|
1482 | + return $this->arguments; |
|
1483 | + } |
|
1484 | + |
|
1485 | + /** |
|
1486 | + * This is the main output class for all 3 items, widget, shortcode and block, it is extended in the calling class. |
|
1487 | + * |
|
1488 | + * @param array $args |
|
1489 | + * @param array $widget_args |
|
1490 | + * @param string $content |
|
1491 | + */ |
|
1492 | + public function output( $args = array(), $widget_args = array(), $content = '' ) { |
|
1493 | + |
|
1494 | + } |
|
1495 | + |
|
1496 | + /** |
|
1497 | + * Add the dynamic block code inline when the wp-block in enqueued. |
|
1498 | + */ |
|
1499 | + public function register_block() { |
|
1500 | + wp_add_inline_script( 'wp-blocks', $this->block() ); |
|
1501 | + if ( class_exists( 'SiteOrigin_Panels' ) ) { |
|
1502 | + wp_add_inline_script( 'wp-blocks', $this->siteorigin_js() ); |
|
1503 | + } |
|
1504 | + } |
|
1505 | + |
|
1506 | + /** |
|
1507 | + * Check if we need to show advanced options. |
|
1508 | + * |
|
1509 | + * @return bool |
|
1510 | + */ |
|
1511 | + public function block_show_advanced() { |
|
1512 | + |
|
1513 | + $show = false; |
|
1514 | + $arguments = $this->arguments; |
|
1515 | + |
|
1516 | + if ( empty( $arguments ) ) { |
|
1517 | + $arguments = $this->get_arguments(); |
|
1518 | + } |
|
1519 | + |
|
1520 | + if ( ! empty( $arguments ) ) { |
|
1521 | + foreach ( $arguments as $argument ) { |
|
1522 | + if ( isset( $argument['advanced'] ) && $argument['advanced'] ) { |
|
1523 | + $show = true; |
|
1524 | + break; // no need to continue if we know we have it |
|
1525 | + } |
|
1526 | + } |
|
1527 | + } |
|
1528 | + |
|
1529 | + return $show; |
|
1530 | + } |
|
1531 | + |
|
1532 | + /** |
|
1533 | + * Get the url path to the current folder. |
|
1534 | + * |
|
1535 | + * @return string |
|
1536 | + */ |
|
1537 | + public function get_url() { |
|
1538 | + |
|
1539 | + $url = $this->url; |
|
1540 | + |
|
1541 | + if ( ! $url ) { |
|
1542 | + // check if we are inside a plugin |
|
1543 | + $file_dir = str_replace( "/includes", "", dirname( __FILE__ ) ); |
|
1544 | + |
|
1545 | + $dir_parts = explode( "/wp-content/", $file_dir ); |
|
1546 | + $url_parts = explode( "/wp-content/", plugins_url() ); |
|
1547 | + |
|
1548 | + if ( ! empty( $url_parts[0] ) && ! empty( $dir_parts[1] ) ) { |
|
1549 | + $url = trailingslashit( $url_parts[0] . "/wp-content/" . $dir_parts[1] ); |
|
1550 | + $this->url = $url; |
|
1551 | + } |
|
1552 | + } |
|
1553 | + |
|
1554 | + |
|
1555 | + return $url; |
|
1556 | + } |
|
1557 | + |
|
1558 | + /** |
|
1559 | + * Generate the block icon. |
|
1560 | + * |
|
1561 | + * Enables the use of Font Awesome icons. |
|
1562 | + * |
|
1563 | + * @note xlink:href is actually deprecated but href is not supported by all so we use both. |
|
1564 | + * |
|
1565 | + * @param $icon |
|
1566 | + * |
|
1567 | + * @since 1.1.0 |
|
1568 | + * @return string |
|
1569 | + */ |
|
1570 | + public function get_block_icon( $icon ) { |
|
1571 | + |
|
1572 | + // check if we have a Font Awesome icon |
|
1573 | + $fa_type = ''; |
|
1574 | + if ( substr( $icon, 0, 7 ) === "fas fa-" ) { |
|
1575 | + $fa_type = 'solid'; |
|
1576 | + } elseif ( substr( $icon, 0, 7 ) === "far fa-" ) { |
|
1577 | + $fa_type = 'regular'; |
|
1578 | + } elseif ( substr( $icon, 0, 7 ) === "fab fa-" ) { |
|
1579 | + $fa_type = 'brands'; |
|
1580 | + } else { |
|
1581 | + $icon = "'" . $icon . "'"; |
|
1582 | + } |
|
1583 | + |
|
1584 | + // set the icon if we found one |
|
1585 | + if ( $fa_type ) { |
|
1586 | + $fa_icon = str_replace( array( "fas fa-", "far fa-", "fab fa-" ), "", $icon ); |
|
1587 | + $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 . "'}))"; |
|
1588 | + } |
|
1589 | + |
|
1590 | + return $icon; |
|
1591 | + } |
|
1592 | + |
|
1593 | + public function group_arguments( $arguments ) { |
|
1594 | 1594 | // echo '###';print_r($arguments); |
1595 | - if ( ! empty( $arguments ) ) { |
|
1596 | - $temp_arguments = array(); |
|
1597 | - $general = __( "General" ); |
|
1598 | - $add_sections = false; |
|
1599 | - foreach ( $arguments as $key => $args ) { |
|
1600 | - if ( isset( $args['group'] ) ) { |
|
1601 | - $temp_arguments[ $args['group'] ][ $key ] = $args; |
|
1602 | - $add_sections = true; |
|
1603 | - } else { |
|
1604 | - $temp_arguments[ $general ][ $key ] = $args; |
|
1605 | - } |
|
1606 | - } |
|
1607 | - |
|
1608 | - // only add sections if more than one |
|
1609 | - if ( $add_sections ) { |
|
1610 | - $arguments = $temp_arguments; |
|
1611 | - } |
|
1612 | - } |
|
1595 | + if ( ! empty( $arguments ) ) { |
|
1596 | + $temp_arguments = array(); |
|
1597 | + $general = __( "General" ); |
|
1598 | + $add_sections = false; |
|
1599 | + foreach ( $arguments as $key => $args ) { |
|
1600 | + if ( isset( $args['group'] ) ) { |
|
1601 | + $temp_arguments[ $args['group'] ][ $key ] = $args; |
|
1602 | + $add_sections = true; |
|
1603 | + } else { |
|
1604 | + $temp_arguments[ $general ][ $key ] = $args; |
|
1605 | + } |
|
1606 | + } |
|
1607 | + |
|
1608 | + // only add sections if more than one |
|
1609 | + if ( $add_sections ) { |
|
1610 | + $arguments = $temp_arguments; |
|
1611 | + } |
|
1612 | + } |
|
1613 | 1613 | |
1614 | 1614 | // echo '###';print_r($arguments); |
1615 | - return $arguments; |
|
1616 | - } |
|
1617 | - |
|
1618 | - |
|
1619 | - /** |
|
1620 | - * Output the JS for building the dynamic Guntenberg block. |
|
1621 | - * |
|
1622 | - * @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. |
|
1623 | - * @since 1.0.9 Save numbers as numbers and not strings. |
|
1624 | - * @since 1.1.0 Font Awesome classes can be used for icons. |
|
1625 | - * @return mixed |
|
1626 | - */ |
|
1627 | - public function block() { |
|
1628 | - ob_start(); |
|
1629 | - |
|
1630 | - $show_advanced = $this->block_show_advanced(); |
|
1631 | - ?> |
|
1615 | + return $arguments; |
|
1616 | + } |
|
1617 | + |
|
1618 | + |
|
1619 | + /** |
|
1620 | + * Output the JS for building the dynamic Guntenberg block. |
|
1621 | + * |
|
1622 | + * @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. |
|
1623 | + * @since 1.0.9 Save numbers as numbers and not strings. |
|
1624 | + * @since 1.1.0 Font Awesome classes can be used for icons. |
|
1625 | + * @return mixed |
|
1626 | + */ |
|
1627 | + public function block() { |
|
1628 | + ob_start(); |
|
1629 | + |
|
1630 | + $show_advanced = $this->block_show_advanced(); |
|
1631 | + ?> |
|
1632 | 1632 | <script> |
1633 | 1633 | /** |
1634 | 1634 | * BLOCK: Basic |
@@ -1672,97 +1672,97 @@ discard block |
||
1672 | 1672 | 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/. |
1673 | 1673 | supports: { |
1674 | 1674 | <?php |
1675 | - if ( isset( $this->options['block-supports'] ) ) { |
|
1676 | - echo $this->array_to_attributes( $this->options['block-supports'] ); |
|
1677 | - } |
|
1678 | - ?> |
|
1675 | + if ( isset( $this->options['block-supports'] ) ) { |
|
1676 | + echo $this->array_to_attributes( $this->options['block-supports'] ); |
|
1677 | + } |
|
1678 | + ?> |
|
1679 | 1679 | }, |
1680 | 1680 | 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. |
1681 | 1681 | <?php if ( isset( $this->options['block-keywords'] ) ) { |
1682 | - echo "keywords : " . $this->options['block-keywords'] . ","; |
|
1683 | - }?> |
|
1682 | + echo "keywords : " . $this->options['block-keywords'] . ","; |
|
1683 | + }?> |
|
1684 | 1684 | |
1685 | 1685 | <?php |
1686 | 1686 | |
1687 | - // maybe set no_wrap |
|
1688 | - $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false; |
|
1689 | - if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) { |
|
1690 | - $no_wrap = true; |
|
1691 | - } |
|
1692 | - if ( $no_wrap ) { |
|
1693 | - $this->options['block-wrap'] = ''; |
|
1694 | - } |
|
1687 | + // maybe set no_wrap |
|
1688 | + $no_wrap = isset( $this->options['no_wrap'] ) && $this->options['no_wrap'] ? true : false; |
|
1689 | + if ( isset( $this->arguments['no_wrap'] ) && $this->arguments['no_wrap'] ) { |
|
1690 | + $no_wrap = true; |
|
1691 | + } |
|
1692 | + if ( $no_wrap ) { |
|
1693 | + $this->options['block-wrap'] = ''; |
|
1694 | + } |
|
1695 | 1695 | |
1696 | 1696 | |
1697 | 1697 | |
1698 | - $show_alignment = false; |
|
1699 | - // align feature |
|
1700 | - /*echo "supports: {"; |
|
1698 | + $show_alignment = false; |
|
1699 | + // align feature |
|
1700 | + /*echo "supports: {"; |
|
1701 | 1701 | echo " align: true,"; |
1702 | 1702 | echo " html: false"; |
1703 | 1703 | echo "},";*/ |
1704 | 1704 | |
1705 | - if ( ! empty( $this->arguments ) ) { |
|
1706 | - echo "attributes : {"; |
|
1707 | - |
|
1708 | - if ( $show_advanced ) { |
|
1709 | - echo "show_advanced: {"; |
|
1710 | - echo " type: 'boolean',"; |
|
1711 | - echo " default: false,"; |
|
1712 | - echo "},"; |
|
1713 | - } |
|
1714 | - |
|
1715 | - // block wrap element |
|
1716 | - if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this? |
|
1717 | - echo "block_wrap: {"; |
|
1718 | - echo " type: 'string',"; |
|
1719 | - echo " default: '" . esc_attr( $this->options['block-wrap'] ) . "',"; |
|
1720 | - echo "},"; |
|
1721 | - } |
|
1722 | - |
|
1723 | - foreach ( $this->arguments as $key => $args ) { |
|
1724 | - |
|
1725 | - // set if we should show alignment |
|
1726 | - if ( $key == 'alignment' ) { |
|
1727 | - $show_alignment = true; |
|
1728 | - } |
|
1729 | - |
|
1730 | - $extra = ''; |
|
1731 | - |
|
1732 | - if ( $args['type'] == 'checkbox' ) { |
|
1733 | - $type = 'boolean'; |
|
1734 | - $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false'; |
|
1735 | - } elseif ( $args['type'] == 'number' ) { |
|
1736 | - $type = 'number'; |
|
1737 | - $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1738 | - } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) { |
|
1739 | - $type = 'array'; |
|
1740 | - if ( is_array( $args['default'] ) ) { |
|
1741 | - $default = isset( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]"; |
|
1742 | - } else { |
|
1743 | - $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1744 | - } |
|
1745 | - } elseif ( $args['type'] == 'multiselect' ) { |
|
1746 | - $type = 'array'; |
|
1747 | - $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1748 | - } else { |
|
1749 | - $type = 'string'; |
|
1750 | - $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1751 | - } |
|
1752 | - echo $key . " : {"; |
|
1753 | - echo "type : '$type',"; |
|
1754 | - echo "default : $default,"; |
|
1755 | - echo "},"; |
|
1756 | - } |
|
1757 | - |
|
1758 | - echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},"; |
|
1759 | - echo "className: { type: 'string', default: '' },"; |
|
1760 | - |
|
1761 | - echo "},"; |
|
1762 | - |
|
1763 | - } |
|
1764 | - |
|
1765 | - ?> |
|
1705 | + if ( ! empty( $this->arguments ) ) { |
|
1706 | + echo "attributes : {"; |
|
1707 | + |
|
1708 | + if ( $show_advanced ) { |
|
1709 | + echo "show_advanced: {"; |
|
1710 | + echo " type: 'boolean',"; |
|
1711 | + echo " default: false,"; |
|
1712 | + echo "},"; |
|
1713 | + } |
|
1714 | + |
|
1715 | + // block wrap element |
|
1716 | + if ( ! empty( $this->options['block-wrap'] ) ) { //@todo we should validate this? |
|
1717 | + echo "block_wrap: {"; |
|
1718 | + echo " type: 'string',"; |
|
1719 | + echo " default: '" . esc_attr( $this->options['block-wrap'] ) . "',"; |
|
1720 | + echo "},"; |
|
1721 | + } |
|
1722 | + |
|
1723 | + foreach ( $this->arguments as $key => $args ) { |
|
1724 | + |
|
1725 | + // set if we should show alignment |
|
1726 | + if ( $key == 'alignment' ) { |
|
1727 | + $show_alignment = true; |
|
1728 | + } |
|
1729 | + |
|
1730 | + $extra = ''; |
|
1731 | + |
|
1732 | + if ( $args['type'] == 'checkbox' ) { |
|
1733 | + $type = 'boolean'; |
|
1734 | + $default = isset( $args['default'] ) && $args['default'] ? 'true' : 'false'; |
|
1735 | + } elseif ( $args['type'] == 'number' ) { |
|
1736 | + $type = 'number'; |
|
1737 | + $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1738 | + } elseif ( $args['type'] == 'select' && ! empty( $args['multiple'] ) ) { |
|
1739 | + $type = 'array'; |
|
1740 | + if ( is_array( $args['default'] ) ) { |
|
1741 | + $default = isset( $args['default'] ) ? "['" . implode( "','", $args['default'] ) . "']" : "[]"; |
|
1742 | + } else { |
|
1743 | + $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1744 | + } |
|
1745 | + } elseif ( $args['type'] == 'multiselect' ) { |
|
1746 | + $type = 'array'; |
|
1747 | + $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1748 | + } else { |
|
1749 | + $type = 'string'; |
|
1750 | + $default = isset( $args['default'] ) ? "'" . $args['default'] . "'" : "''"; |
|
1751 | + } |
|
1752 | + echo $key . " : {"; |
|
1753 | + echo "type : '$type',"; |
|
1754 | + echo "default : $default,"; |
|
1755 | + echo "},"; |
|
1756 | + } |
|
1757 | + |
|
1758 | + echo "content : {type : 'string',default: 'Please select the attributes in the block settings'},"; |
|
1759 | + echo "className: { type: 'string', default: '' },"; |
|
1760 | + |
|
1761 | + echo "},"; |
|
1762 | + |
|
1763 | + } |
|
1764 | + |
|
1765 | + ?> |
|
1766 | 1766 | |
1767 | 1767 | // The "edit" property must be a valid function. |
1768 | 1768 | edit: function (props) { |
@@ -1770,9 +1770,9 @@ discard block |
||
1770 | 1770 | |
1771 | 1771 | var $value = ''; |
1772 | 1772 | <?php |
1773 | - // if we have a post_type and a category then link them |
|
1774 | - if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){ |
|
1775 | - ?> |
|
1773 | + // if we have a post_type and a category then link them |
|
1774 | + if( isset($this->arguments['post_type']) && isset($this->arguments['category']) && !empty($this->arguments['category']['post_type_linked']) ){ |
|
1775 | + ?> |
|
1776 | 1776 | if(typeof(prev_attributes[props.id]) != 'undefined' ){ |
1777 | 1777 | $pt = props.attributes.post_type; |
1778 | 1778 | if(post_type_rest_slugs.length){ |
@@ -1856,8 +1856,8 @@ discard block |
||
1856 | 1856 | 'shortcode': '<?php echo $this->options['base_id'];?>', |
1857 | 1857 | 'attributes': props.attributes, |
1858 | 1858 | 'post_id': <?php global $post; if ( isset( $post->ID ) ) { |
1859 | - echo $post->ID; |
|
1860 | - }else{echo '0';}?>, |
|
1859 | + echo $post->ID; |
|
1860 | + }else{echo '0';}?>, |
|
1861 | 1861 | '_ajax_nonce': '<?php echo wp_create_nonce( 'super_duper_output_shortcode' );?>' |
1862 | 1862 | }; |
1863 | 1863 | |
@@ -1909,10 +1909,10 @@ discard block |
||
1909 | 1909 | |
1910 | 1910 | <?php |
1911 | 1911 | |
1912 | - if(! empty( $this->arguments )){ |
|
1912 | + if(! empty( $this->arguments )){ |
|
1913 | 1913 | |
1914 | - if ( $show_advanced ) { |
|
1915 | - ?> |
|
1914 | + if ( $show_advanced ) { |
|
1915 | + ?> |
|
1916 | 1916 | el('div', { |
1917 | 1917 | style: {'padding-left': '16px','padding-right': '16px'} |
1918 | 1918 | }, |
@@ -1930,79 +1930,79 @@ discard block |
||
1930 | 1930 | , |
1931 | 1931 | <?php |
1932 | 1932 | |
1933 | - } |
|
1933 | + } |
|
1934 | 1934 | |
1935 | - $arguments = $this->group_arguments( $this->arguments ); |
|
1935 | + $arguments = $this->group_arguments( $this->arguments ); |
|
1936 | 1936 | |
1937 | - // Do we have sections? |
|
1938 | - $has_sections = $arguments == $this->arguments ? false : true; |
|
1937 | + // Do we have sections? |
|
1938 | + $has_sections = $arguments == $this->arguments ? false : true; |
|
1939 | 1939 | |
1940 | 1940 | |
1941 | - if($has_sections){ |
|
1942 | - $panel_count = 0; |
|
1943 | - foreach($arguments as $key => $args){ |
|
1944 | - ?> |
|
1941 | + if($has_sections){ |
|
1942 | + $panel_count = 0; |
|
1943 | + foreach($arguments as $key => $args){ |
|
1944 | + ?> |
|
1945 | 1945 | el(wp.components.PanelBody, { |
1946 | 1946 | title: '<?php esc_attr_e( $key ); ?>', |
1947 | 1947 | initialOpen: <?php if ( $panel_count ) { |
1948 | - echo "false"; |
|
1949 | - } else { |
|
1950 | - echo "true"; |
|
1951 | - }?> |
|
1948 | + echo "false"; |
|
1949 | + } else { |
|
1950 | + echo "true"; |
|
1951 | + }?> |
|
1952 | 1952 | }, |
1953 | 1953 | <?php |
1954 | 1954 | |
1955 | 1955 | |
1956 | 1956 | |
1957 | - foreach ( $args as $k => $a ) { |
|
1957 | + foreach ( $args as $k => $a ) { |
|
1958 | 1958 | |
1959 | - $this->block_row_start( $k, $a ); |
|
1960 | - $this->build_block_arguments( $k, $a ); |
|
1961 | - $this->block_row_end( $k, $a ); |
|
1962 | - } |
|
1963 | - ?> |
|
1959 | + $this->block_row_start( $k, $a ); |
|
1960 | + $this->build_block_arguments( $k, $a ); |
|
1961 | + $this->block_row_end( $k, $a ); |
|
1962 | + } |
|
1963 | + ?> |
|
1964 | 1964 | ), |
1965 | 1965 | <?php |
1966 | - $panel_count ++; |
|
1966 | + $panel_count ++; |
|
1967 | 1967 | |
1968 | - } |
|
1969 | - }else { |
|
1970 | - ?> |
|
1968 | + } |
|
1969 | + }else { |
|
1970 | + ?> |
|
1971 | 1971 | el(wp.components.PanelBody, { |
1972 | 1972 | title: '<?php esc_attr_e( "Settings" ); ?>', |
1973 | 1973 | initialOpen: true |
1974 | 1974 | }, |
1975 | 1975 | <?php |
1976 | - foreach ( $this->arguments as $key => $args ) { |
|
1977 | - $this->block_row_start( $key, $args ); |
|
1978 | - $this->build_block_arguments( $key, $args ); |
|
1979 | - $this->block_row_end( $key, $args ); |
|
1980 | - } |
|
1981 | - ?> |
|
1976 | + foreach ( $this->arguments as $key => $args ) { |
|
1977 | + $this->block_row_start( $key, $args ); |
|
1978 | + $this->build_block_arguments( $key, $args ); |
|
1979 | + $this->block_row_end( $key, $args ); |
|
1980 | + } |
|
1981 | + ?> |
|
1982 | 1982 | ), |
1983 | 1983 | <?php |
1984 | - } |
|
1984 | + } |
|
1985 | 1985 | |
1986 | - } |
|
1987 | - ?> |
|
1986 | + } |
|
1987 | + ?> |
|
1988 | 1988 | |
1989 | 1989 | ), |
1990 | 1990 | |
1991 | 1991 | <?php |
1992 | - // If the user sets block-output array then build it |
|
1993 | - if ( ! empty( $this->options['block-output'] ) ) { |
|
1994 | - $this->block_element( $this->options['block-output'] ); |
|
1995 | - }else{ |
|
1996 | - // if no block-output is set then we try and get the shortcode html output via ajax. |
|
1997 | - ?> |
|
1992 | + // If the user sets block-output array then build it |
|
1993 | + if ( ! empty( $this->options['block-output'] ) ) { |
|
1994 | + $this->block_element( $this->options['block-output'] ); |
|
1995 | + }else{ |
|
1996 | + // if no block-output is set then we try and get the shortcode html output via ajax. |
|
1997 | + ?> |
|
1998 | 1998 | el('div', { |
1999 | 1999 | dangerouslySetInnerHTML: {__html: onChangeContent()}, |
2000 | 2000 | className: props.className, |
2001 | 2001 | style: {'minHeight': '30px'} |
2002 | 2002 | }) |
2003 | 2003 | <?php |
2004 | - } |
|
2005 | - ?> |
|
2004 | + } |
|
2005 | + ?> |
|
2006 | 2006 | ]; // end return |
2007 | 2007 | }, |
2008 | 2008 | |
@@ -2020,10 +2020,10 @@ discard block |
||
2020 | 2020 | $html = ''; |
2021 | 2021 | <?php |
2022 | 2022 | |
2023 | - if(! empty( $this->arguments )){ |
|
2023 | + if(! empty( $this->arguments )){ |
|
2024 | 2024 | |
2025 | - foreach($this->arguments as $key => $args){ |
|
2026 | - ?> |
|
2025 | + foreach($this->arguments as $key => $args){ |
|
2026 | + ?> |
|
2027 | 2027 | if (attr.hasOwnProperty("<?php echo esc_attr( $key );?>")) { |
2028 | 2028 | if ('<?php echo esc_attr( $key );?>' == 'html') { |
2029 | 2029 | $html = attr.<?php echo esc_attr( $key );?>; |
@@ -2032,10 +2032,10 @@ discard block |
||
2032 | 2032 | } |
2033 | 2033 | } |
2034 | 2034 | <?php |
2035 | - } |
|
2036 | - } |
|
2035 | + } |
|
2036 | + } |
|
2037 | 2037 | |
2038 | - ?> |
|
2038 | + ?> |
|
2039 | 2039 | content += "]"; |
2040 | 2040 | |
2041 | 2041 | // if has html element |
@@ -2058,20 +2058,20 @@ discard block |
||
2058 | 2058 | } |
2059 | 2059 | |
2060 | 2060 | <?php |
2061 | - if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){ |
|
2062 | - ?> |
|
2061 | + if(isset( $this->options['block-wrap'] ) && $this->options['block-wrap'] == ''){ |
|
2062 | + ?> |
|
2063 | 2063 | return content; |
2064 | 2064 | <?php |
2065 | - }else{ |
|
2066 | - ?> |
|
2065 | + }else{ |
|
2066 | + ?> |
|
2067 | 2067 | var block_wrap = 'div'; |
2068 | 2068 | if (attr.hasOwnProperty("block_wrap")) { |
2069 | 2069 | block_wrap = attr.block_wrap; |
2070 | 2070 | } |
2071 | 2071 | return el(block_wrap, {dangerouslySetInnerHTML: {__html: content}, className: align}); |
2072 | 2072 | <?php |
2073 | - } |
|
2074 | - ?> |
|
2073 | + } |
|
2074 | + ?> |
|
2075 | 2075 | |
2076 | 2076 | |
2077 | 2077 | } |
@@ -2079,30 +2079,30 @@ discard block |
||
2079 | 2079 | })(); |
2080 | 2080 | </script> |
2081 | 2081 | <?php |
2082 | - $output = ob_get_clean(); |
|
2082 | + $output = ob_get_clean(); |
|
2083 | 2083 | |
2084 | - /* |
|
2084 | + /* |
|
2085 | 2085 | * We only add the <script> tags for code highlighting, so we strip them from the output. |
2086 | 2086 | */ |
2087 | 2087 | |
2088 | - return str_replace( array( |
|
2089 | - '<script>', |
|
2090 | - '</script>' |
|
2091 | - ), '', $output ); |
|
2092 | - } |
|
2088 | + return str_replace( array( |
|
2089 | + '<script>', |
|
2090 | + '</script>' |
|
2091 | + ), '', $output ); |
|
2092 | + } |
|
2093 | 2093 | |
2094 | - public function block_row_start($key, $args){ |
|
2094 | + public function block_row_start($key, $args){ |
|
2095 | 2095 | |
2096 | - // check for row |
|
2097 | - if(!empty($args['row'])){ |
|
2096 | + // check for row |
|
2097 | + if(!empty($args['row'])){ |
|
2098 | 2098 | |
2099 | - if(!empty($args['row']['open'])){ |
|
2099 | + if(!empty($args['row']['open'])){ |
|
2100 | 2100 | |
2101 | - // element require |
|
2102 | - $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : ""; |
|
2103 | - echo $element_require; |
|
2101 | + // element require |
|
2102 | + $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : ""; |
|
2103 | + echo $element_require; |
|
2104 | 2104 | |
2105 | - if(false){?><script><?php }?> |
|
2105 | + if(false){?><script><?php }?> |
|
2106 | 2106 | el('div', { |
2107 | 2107 | className: 'bsui components-base-control', |
2108 | 2108 | }, |
@@ -2132,87 +2132,87 @@ discard block |
||
2132 | 2132 | }, |
2133 | 2133 | |
2134 | 2134 | <?php |
2135 | - if(false){?></script><?php } |
|
2136 | - }elseif(!empty($args['row']['close'])){ |
|
2137 | - if(false){?><script><?php }?> |
|
2135 | + if(false){?></script><?php } |
|
2136 | + }elseif(!empty($args['row']['close'])){ |
|
2137 | + if(false){?><script><?php }?> |
|
2138 | 2138 | el( |
2139 | 2139 | 'div', |
2140 | 2140 | { |
2141 | 2141 | className: 'col pl-0', |
2142 | 2142 | }, |
2143 | 2143 | <?php |
2144 | - if(false){?></script><?php } |
|
2145 | - }else{ |
|
2146 | - if(false){?><script><?php }?> |
|
2144 | + if(false){?></script><?php } |
|
2145 | + }else{ |
|
2146 | + if(false){?><script><?php }?> |
|
2147 | 2147 | el( |
2148 | 2148 | 'div', |
2149 | 2149 | { |
2150 | 2150 | className: 'col pl-0 pr-2', |
2151 | 2151 | }, |
2152 | 2152 | <?php |
2153 | - if(false){?></script><?php } |
|
2154 | - } |
|
2155 | - |
|
2156 | - } |
|
2157 | - |
|
2158 | - } |
|
2159 | - |
|
2160 | - public function block_row_end($key, $args){ |
|
2161 | - |
|
2162 | - if(!empty($args['row'])){ |
|
2163 | - // maybe close |
|
2164 | - if(!empty($args['row']['close'])){ |
|
2165 | - echo "))"; |
|
2166 | - } |
|
2167 | - |
|
2168 | - echo "),"; |
|
2169 | - } |
|
2170 | - } |
|
2171 | - |
|
2172 | - public function build_block_arguments( $key, $args ) { |
|
2173 | - $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : ''; |
|
2174 | - $options = ''; |
|
2175 | - $extra = ''; |
|
2176 | - $require = ''; |
|
2177 | - |
|
2178 | - // `content` is a protected and special argument |
|
2179 | - if ( $key == 'content' ) { |
|
2180 | - return; |
|
2181 | - } |
|
2182 | - |
|
2183 | - |
|
2184 | - // icon |
|
2185 | - $icon = ''; |
|
2186 | - if( !empty( $args['icon'] ) ){ |
|
2187 | - $icon .= "el('div', {"; |
|
2188 | - $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},"; |
|
2189 | - $icon .= "className: 'text-center',"; |
|
2190 | - $icon .= "title: '".addslashes( $args['title'] )."',"; |
|
2191 | - $icon .= "}),"; |
|
2192 | - |
|
2193 | - // blank title as its added to the icon. |
|
2194 | - $args['title'] = ''; |
|
2195 | - } |
|
2196 | - |
|
2197 | - // require advanced |
|
2198 | - $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : ""; |
|
2199 | - |
|
2200 | - // element require |
|
2201 | - $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : ""; |
|
2202 | - |
|
2203 | - |
|
2204 | - $onchange = "props.setAttributes({ $key: $key } )"; |
|
2205 | - $onchangecomplete = ""; |
|
2206 | - $value = "props.attributes.$key"; |
|
2207 | - $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' ); |
|
2208 | - if ( in_array( $args['type'], $text_type ) ) { |
|
2209 | - $type = 'TextControl'; |
|
2210 | - // Save numbers as numbers and not strings |
|
2211 | - if ( $args['type'] == 'number' ) { |
|
2212 | - $onchange = "props.setAttributes({ $key: Number($key) } )"; |
|
2213 | - } |
|
2214 | - } |
|
2215 | - /* |
|
2153 | + if(false){?></script><?php } |
|
2154 | + } |
|
2155 | + |
|
2156 | + } |
|
2157 | + |
|
2158 | + } |
|
2159 | + |
|
2160 | + public function block_row_end($key, $args){ |
|
2161 | + |
|
2162 | + if(!empty($args['row'])){ |
|
2163 | + // maybe close |
|
2164 | + if(!empty($args['row']['close'])){ |
|
2165 | + echo "))"; |
|
2166 | + } |
|
2167 | + |
|
2168 | + echo "),"; |
|
2169 | + } |
|
2170 | + } |
|
2171 | + |
|
2172 | + public function build_block_arguments( $key, $args ) { |
|
2173 | + $custom_attributes = ! empty( $args['custom_attributes'] ) ? $this->array_to_attributes( $args['custom_attributes'] ) : ''; |
|
2174 | + $options = ''; |
|
2175 | + $extra = ''; |
|
2176 | + $require = ''; |
|
2177 | + |
|
2178 | + // `content` is a protected and special argument |
|
2179 | + if ( $key == 'content' ) { |
|
2180 | + return; |
|
2181 | + } |
|
2182 | + |
|
2183 | + |
|
2184 | + // icon |
|
2185 | + $icon = ''; |
|
2186 | + if( !empty( $args['icon'] ) ){ |
|
2187 | + $icon .= "el('div', {"; |
|
2188 | + $icon .= "dangerouslySetInnerHTML: {__html: '".self::get_widget_icon( esc_attr($args['icon']))."'},"; |
|
2189 | + $icon .= "className: 'text-center',"; |
|
2190 | + $icon .= "title: '".addslashes( $args['title'] )."',"; |
|
2191 | + $icon .= "}),"; |
|
2192 | + |
|
2193 | + // blank title as its added to the icon. |
|
2194 | + $args['title'] = ''; |
|
2195 | + } |
|
2196 | + |
|
2197 | + // require advanced |
|
2198 | + $require_advanced = ! empty( $args['advanced'] ) ? "props.attributes.show_advanced && " : ""; |
|
2199 | + |
|
2200 | + // element require |
|
2201 | + $element_require = ! empty( $args['element_require'] ) ? $this->block_props_replace( $args['element_require'], true ) . " && " : ""; |
|
2202 | + |
|
2203 | + |
|
2204 | + $onchange = "props.setAttributes({ $key: $key } )"; |
|
2205 | + $onchangecomplete = ""; |
|
2206 | + $value = "props.attributes.$key"; |
|
2207 | + $text_type = array( 'text', 'password', 'number', 'email', 'tel', 'url', 'colorx' ); |
|
2208 | + if ( in_array( $args['type'], $text_type ) ) { |
|
2209 | + $type = 'TextControl'; |
|
2210 | + // Save numbers as numbers and not strings |
|
2211 | + if ( $args['type'] == 'number' ) { |
|
2212 | + $onchange = "props.setAttributes({ $key: Number($key) } )"; |
|
2213 | + } |
|
2214 | + } |
|
2215 | + /* |
|
2216 | 2216 | * https://www.wptricks.com/question/set-current-tab-on-a-gutenberg-tabpanel-component-from-outside-that-component/ es5 layout |
2217 | 2217 | elseif($args['type']=='tabs'){ |
2218 | 2218 | ?> |
@@ -2246,85 +2246,85 @@ discard block |
||
2246 | 2246 | return; |
2247 | 2247 | } |
2248 | 2248 | */ |
2249 | - elseif ( $args['type'] == 'color' ) { |
|
2250 | - $type = 'ColorPicker'; |
|
2251 | - $onchange = ""; |
|
2252 | - $extra = "color: $value,"; |
|
2253 | - if(!empty($args['disable_alpha'])){ |
|
2254 | - $extra .= "disableAlpha: true,"; |
|
2255 | - } |
|
2256 | - $onchangecomplete = "onChangeComplete: function($key) { |
|
2249 | + elseif ( $args['type'] == 'color' ) { |
|
2250 | + $type = 'ColorPicker'; |
|
2251 | + $onchange = ""; |
|
2252 | + $extra = "color: $value,"; |
|
2253 | + if(!empty($args['disable_alpha'])){ |
|
2254 | + $extra .= "disableAlpha: true,"; |
|
2255 | + } |
|
2256 | + $onchangecomplete = "onChangeComplete: function($key) { |
|
2257 | 2257 | value = $key.rgb.a && $key.rgb.a < 1 ? \"rgba(\"+$key.rgb.r+\",\"+$key.rgb.g+\",\"+$key.rgb.b+\",\"+$key.rgb.a+\")\" : $key.hex; |
2258 | 2258 | props.setAttributes({ |
2259 | 2259 | $key: value |
2260 | 2260 | }); |
2261 | 2261 | },"; |
2262 | - } |
|
2263 | - elseif ( $args['type'] == 'checkbox' ) { |
|
2264 | - $type = 'CheckboxControl'; |
|
2265 | - $extra .= "checked: props.attributes.$key,"; |
|
2266 | - $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )"; |
|
2267 | - } elseif ( $args['type'] == 'textarea' ) { |
|
2268 | - $type = 'TextareaControl'; |
|
2269 | - } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) { |
|
2270 | - $type = 'SelectControl'; |
|
2271 | - |
|
2272 | - if($args['name'] == 'category' && !empty($args['post_type_linked'])){ |
|
2273 | - $options .= "options: taxonomies_".str_replace("-","_", $this->id).","; |
|
2274 | - }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){ |
|
2275 | - $options .= "options: sort_by_".str_replace("-","_", $this->id).","; |
|
2276 | - }else { |
|
2277 | - |
|
2278 | - if ( ! empty( $args['options'] ) ) { |
|
2279 | - $options .= "options: ["; |
|
2280 | - foreach ( $args['options'] as $option_val => $option_label ) { |
|
2281 | - $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },"; |
|
2282 | - } |
|
2283 | - $options .= "],"; |
|
2284 | - } |
|
2285 | - } |
|
2286 | - if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550 |
|
2287 | - $extra .= ' multiple: true, '; |
|
2288 | - } |
|
2289 | - } elseif ( $args['type'] == 'alignment' ) { |
|
2290 | - $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example |
|
2291 | - }elseif ( $args['type'] == 'margins' ) { |
|
2292 | - |
|
2293 | - } else { |
|
2294 | - return;// if we have not implemented the control then don't break the JS. |
|
2295 | - } |
|
2296 | - |
|
2297 | - |
|
2298 | - |
|
2299 | - // color input does not show the labels so we add them |
|
2300 | - if($args['type']=='color'){ |
|
2301 | - // add show only if advanced |
|
2302 | - echo $require_advanced; |
|
2303 | - // add setting require if defined |
|
2304 | - echo $element_require; |
|
2305 | - echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),"; |
|
2306 | - } |
|
2307 | - |
|
2308 | - // add show only if advanced |
|
2309 | - echo $require_advanced; |
|
2310 | - // add setting require if defined |
|
2311 | - echo $element_require; |
|
2312 | - |
|
2313 | - // icon |
|
2314 | - echo $icon; |
|
2315 | - ?> |
|
2262 | + } |
|
2263 | + elseif ( $args['type'] == 'checkbox' ) { |
|
2264 | + $type = 'CheckboxControl'; |
|
2265 | + $extra .= "checked: props.attributes.$key,"; |
|
2266 | + $onchange = "props.setAttributes({ $key: ! props.attributes.$key } )"; |
|
2267 | + } elseif ( $args['type'] == 'textarea' ) { |
|
2268 | + $type = 'TextareaControl'; |
|
2269 | + } elseif ( $args['type'] == 'select' || $args['type'] == 'multiselect' ) { |
|
2270 | + $type = 'SelectControl'; |
|
2271 | + |
|
2272 | + if($args['name'] == 'category' && !empty($args['post_type_linked'])){ |
|
2273 | + $options .= "options: taxonomies_".str_replace("-","_", $this->id).","; |
|
2274 | + }elseif($args['name'] == 'sort_by' && !empty($args['post_type_linked'])){ |
|
2275 | + $options .= "options: sort_by_".str_replace("-","_", $this->id).","; |
|
2276 | + }else { |
|
2277 | + |
|
2278 | + if ( ! empty( $args['options'] ) ) { |
|
2279 | + $options .= "options: ["; |
|
2280 | + foreach ( $args['options'] as $option_val => $option_label ) { |
|
2281 | + $options .= "{ value: '" . esc_attr( $option_val ) . "', label: '" . addslashes( $option_label ) . "' },"; |
|
2282 | + } |
|
2283 | + $options .= "],"; |
|
2284 | + } |
|
2285 | + } |
|
2286 | + if ( isset( $args['multiple'] ) && $args['multiple'] ) { //@todo multiselect does not work at the moment: https://github.com/WordPress/gutenberg/issues/5550 |
|
2287 | + $extra .= ' multiple: true, '; |
|
2288 | + } |
|
2289 | + } elseif ( $args['type'] == 'alignment' ) { |
|
2290 | + $type = 'AlignmentToolbar'; // @todo this does not seem to work but cant find a example |
|
2291 | + }elseif ( $args['type'] == 'margins' ) { |
|
2292 | + |
|
2293 | + } else { |
|
2294 | + return;// if we have not implemented the control then don't break the JS. |
|
2295 | + } |
|
2296 | + |
|
2297 | + |
|
2298 | + |
|
2299 | + // color input does not show the labels so we add them |
|
2300 | + if($args['type']=='color'){ |
|
2301 | + // add show only if advanced |
|
2302 | + echo $require_advanced; |
|
2303 | + // add setting require if defined |
|
2304 | + echo $element_require; |
|
2305 | + echo "el('div', {style: {'marginBottom': '8px'}}, '".addslashes( $args['title'] )."'),"; |
|
2306 | + } |
|
2307 | + |
|
2308 | + // add show only if advanced |
|
2309 | + echo $require_advanced; |
|
2310 | + // add setting require if defined |
|
2311 | + echo $element_require; |
|
2312 | + |
|
2313 | + // icon |
|
2314 | + echo $icon; |
|
2315 | + ?> |
|
2316 | 2316 | el( wp.components.<?php echo $type; ?>, { |
2317 | 2317 | label: '<?php echo addslashes( $args['title'] ); ?>', |
2318 | 2318 | help: '<?php if ( isset( $args['desc'] ) ) { |
2319 | - echo addslashes( $args['desc'] ); |
|
2320 | - } ?>', |
|
2319 | + echo addslashes( $args['desc'] ); |
|
2320 | + } ?>', |
|
2321 | 2321 | value: <?php echo $value; ?>, |
2322 | 2322 | <?php if ( $type == 'TextControl' && $args['type'] != 'text' ) { |
2323 | - echo "type: '" . addslashes( $args['type'] ) . "',"; |
|
2324 | - } ?> |
|
2323 | + echo "type: '" . addslashes( $args['type'] ) . "',"; |
|
2324 | + } ?> |
|
2325 | 2325 | <?php if ( ! empty( $args['placeholder'] ) ) { |
2326 | - echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',"; |
|
2327 | - } ?> |
|
2326 | + echo "placeholder: '" . addslashes( $args['placeholder'] ) . "',"; |
|
2327 | + } ?> |
|
2328 | 2328 | <?php echo $options; ?> |
2329 | 2329 | <?php echo $extra; ?> |
2330 | 2330 | <?php echo $custom_attributes; ?> |
@@ -2336,601 +2336,601 @@ discard block |
||
2336 | 2336 | <?php |
2337 | 2337 | |
2338 | 2338 | |
2339 | - } |
|
2340 | - |
|
2341 | - /** |
|
2342 | - * Convert an array of attributes to block string. |
|
2343 | - * |
|
2344 | - * @todo there is prob a faster way to do this, also we could add some validation here. |
|
2345 | - * |
|
2346 | - * @param $custom_attributes |
|
2347 | - * |
|
2348 | - * @return string |
|
2349 | - */ |
|
2350 | - public function array_to_attributes( $custom_attributes, $html = false ) { |
|
2351 | - $attributes = ''; |
|
2352 | - if ( ! empty( $custom_attributes ) ) { |
|
2353 | - |
|
2354 | - if ( $html ) { |
|
2355 | - foreach ( $custom_attributes as $key => $val ) { |
|
2356 | - $attributes .= " $key='$val' "; |
|
2357 | - } |
|
2358 | - } else { |
|
2359 | - foreach ( $custom_attributes as $key => $val ) { |
|
2360 | - $attributes .= "'$key': '$val',"; |
|
2361 | - } |
|
2362 | - } |
|
2363 | - } |
|
2364 | - |
|
2365 | - return $attributes; |
|
2366 | - } |
|
2367 | - |
|
2368 | - /** |
|
2369 | - * A self looping function to create the output for JS block elements. |
|
2370 | - * |
|
2371 | - * This is what is output in the WP Editor visual view. |
|
2372 | - * |
|
2373 | - * @param $args |
|
2374 | - */ |
|
2375 | - public function block_element( $args ) { |
|
2376 | - |
|
2377 | - |
|
2378 | - if ( ! empty( $args ) ) { |
|
2379 | - foreach ( $args as $element => $new_args ) { |
|
2380 | - |
|
2381 | - if ( is_array( $new_args ) ) { // its an element |
|
2382 | - |
|
2383 | - |
|
2384 | - if ( isset( $new_args['element'] ) ) { |
|
2385 | - |
|
2386 | - if ( isset( $new_args['element_require'] ) ) { |
|
2387 | - echo str_replace( array( |
|
2388 | - "'+", |
|
2389 | - "+'" |
|
2390 | - ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " && "; |
|
2391 | - unset( $new_args['element_require'] ); |
|
2392 | - } |
|
2393 | - |
|
2394 | - echo "\n el( '" . $new_args['element'] . "', {"; |
|
2395 | - |
|
2396 | - // get the attributes |
|
2397 | - foreach ( $new_args as $new_key => $new_value ) { |
|
2398 | - |
|
2399 | - |
|
2400 | - if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) { |
|
2401 | - // do nothing |
|
2402 | - } else { |
|
2403 | - echo $this->block_element( array( $new_key => $new_value ) ); |
|
2404 | - } |
|
2405 | - } |
|
2406 | - |
|
2407 | - echo "},";// end attributes |
|
2408 | - |
|
2409 | - // get the content |
|
2410 | - $first_item = 0; |
|
2411 | - foreach ( $new_args as $new_key => $new_value ) { |
|
2412 | - if ( $new_key === 'content' || is_array( $new_value ) ) { |
|
2413 | - |
|
2414 | - if ( $new_key === 'content' ) { |
|
2415 | - echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'"; |
|
2416 | - } |
|
2417 | - |
|
2418 | - if ( is_array( $new_value ) ) { |
|
2419 | - |
|
2420 | - if ( isset( $new_value['element_require'] ) ) { |
|
2421 | - echo str_replace( array( |
|
2422 | - "'+", |
|
2423 | - "+'" |
|
2424 | - ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " && "; |
|
2425 | - unset( $new_value['element_require'] ); |
|
2426 | - } |
|
2427 | - |
|
2428 | - if ( isset( $new_value['element_repeat'] ) ) { |
|
2429 | - $x = 1; |
|
2430 | - while ( $x <= absint( $new_value['element_repeat'] ) ) { |
|
2431 | - $this->block_element( array( '' => $new_value ) ); |
|
2432 | - $x ++; |
|
2433 | - } |
|
2434 | - } else { |
|
2435 | - $this->block_element( array( '' => $new_value ) ); |
|
2436 | - } |
|
2437 | - } |
|
2438 | - $first_item ++; |
|
2439 | - } |
|
2440 | - } |
|
2441 | - |
|
2442 | - echo ")";// end content |
|
2443 | - |
|
2444 | - echo ", \n"; |
|
2445 | - |
|
2446 | - } |
|
2447 | - } else { |
|
2448 | - |
|
2449 | - if ( substr( $element, 0, 3 ) === "if_" ) { |
|
2450 | - echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ","; |
|
2451 | - } elseif ( $element == 'style' ) { |
|
2452 | - echo $element . ": " . $this->block_props_replace( $new_args ) . ","; |
|
2453 | - } else { |
|
2454 | - echo $element . ": '" . $this->block_props_replace( $new_args ) . "',"; |
|
2455 | - } |
|
2456 | - |
|
2457 | - } |
|
2458 | - } |
|
2459 | - } |
|
2460 | - } |
|
2461 | - |
|
2462 | - /** |
|
2463 | - * Replace block attributes placeholders with the proper naming. |
|
2464 | - * |
|
2465 | - * @param $string |
|
2466 | - * |
|
2467 | - * @return mixed |
|
2468 | - */ |
|
2469 | - public function block_props_replace( $string, $no_wrap = false ) { |
|
2470 | - |
|
2471 | - if ( $no_wrap ) { |
|
2472 | - $string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string ); |
|
2473 | - } else { |
|
2474 | - $string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string ); |
|
2475 | - } |
|
2476 | - |
|
2477 | - return $string; |
|
2478 | - } |
|
2479 | - |
|
2480 | - /** |
|
2481 | - * Outputs the content of the widget |
|
2482 | - * |
|
2483 | - * @param array $args |
|
2484 | - * @param array $instance |
|
2485 | - */ |
|
2486 | - public function widget( $args, $instance ) { |
|
2487 | - |
|
2488 | - // get the filtered values |
|
2489 | - $argument_values = $this->argument_values( $instance ); |
|
2490 | - $argument_values = $this->string_to_bool( $argument_values ); |
|
2491 | - $output = $this->output( $argument_values, $args ); |
|
2492 | - |
|
2493 | - $no_wrap = false; |
|
2494 | - if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) { |
|
2495 | - $no_wrap = true; |
|
2496 | - } |
|
2497 | - |
|
2498 | - ob_start(); |
|
2499 | - if ( $output && ! $no_wrap ) { |
|
2500 | - |
|
2501 | - $class_original = $this->options['widget_ops']['classname']; |
|
2502 | - $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash(); |
|
2503 | - |
|
2504 | - // Before widget |
|
2505 | - $before_widget = $args['before_widget']; |
|
2506 | - $before_widget = str_replace($class_original,$class,$before_widget); |
|
2507 | - $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this ); |
|
2508 | - $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this ); |
|
2509 | - |
|
2510 | - // After widget |
|
2511 | - $after_widget = $args['after_widget']; |
|
2512 | - $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this ); |
|
2513 | - $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this ); |
|
2514 | - |
|
2515 | - echo $before_widget; |
|
2516 | - // elementor strips the widget wrapping div so we check for and add it back if needed |
|
2517 | - if ( $this->is_elementor_widget_output() ) { |
|
2518 | - echo ! empty( $this->options['widget_ops']['classname'] ) ? "<span class='" . esc_attr( $class ) . "'>" : ''; |
|
2519 | - } |
|
2520 | - echo $this->output_title( $args, $instance ); |
|
2521 | - echo $output; |
|
2522 | - if ( $this->is_elementor_widget_output() ) { |
|
2523 | - echo ! empty( $this->options['widget_ops']['classname'] ) ? "</span>" : ''; |
|
2524 | - } |
|
2525 | - echo $after_widget; |
|
2526 | - } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty |
|
2527 | - $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" ); |
|
2528 | - echo $output; |
|
2529 | - } elseif ( $output && $no_wrap ) { |
|
2530 | - echo $output; |
|
2531 | - } |
|
2532 | - $output = ob_get_clean(); |
|
2533 | - |
|
2534 | - $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this ); |
|
2535 | - |
|
2536 | - echo $output; |
|
2537 | - } |
|
2538 | - |
|
2539 | - /** |
|
2540 | - * Tests if the current output is inside a elementor container. |
|
2541 | - * |
|
2542 | - * @since 1.0.4 |
|
2543 | - * @return bool |
|
2544 | - */ |
|
2545 | - public function is_elementor_widget_output() { |
|
2546 | - $result = false; |
|
2547 | - if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) { |
|
2548 | - $result = true; |
|
2549 | - } |
|
2550 | - |
|
2551 | - return $result; |
|
2552 | - } |
|
2553 | - |
|
2554 | - /** |
|
2555 | - * Tests if the current output is inside a elementor preview. |
|
2556 | - * |
|
2557 | - * @since 1.0.4 |
|
2558 | - * @return bool |
|
2559 | - */ |
|
2560 | - public function is_elementor_preview() { |
|
2561 | - $result = false; |
|
2562 | - if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) { |
|
2563 | - $result = true; |
|
2564 | - } |
|
2565 | - |
|
2566 | - return $result; |
|
2567 | - } |
|
2568 | - |
|
2569 | - /** |
|
2570 | - * Tests if the current output is inside a Divi preview. |
|
2571 | - * |
|
2572 | - * @since 1.0.6 |
|
2573 | - * @return bool |
|
2574 | - */ |
|
2575 | - public function is_divi_preview() { |
|
2576 | - $result = false; |
|
2577 | - if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) { |
|
2578 | - $result = true; |
|
2579 | - } |
|
2580 | - |
|
2581 | - return $result; |
|
2582 | - } |
|
2583 | - |
|
2584 | - /** |
|
2585 | - * Tests if the current output is inside a Beaver builder preview. |
|
2586 | - * |
|
2587 | - * @since 1.0.6 |
|
2588 | - * @return bool |
|
2589 | - */ |
|
2590 | - public function is_beaver_preview() { |
|
2591 | - $result = false; |
|
2592 | - if ( isset( $_REQUEST['fl_builder'] ) ) { |
|
2593 | - $result = true; |
|
2594 | - } |
|
2595 | - |
|
2596 | - return $result; |
|
2597 | - } |
|
2598 | - |
|
2599 | - /** |
|
2600 | - * Tests if the current output is inside a siteorigin builder preview. |
|
2601 | - * |
|
2602 | - * @since 1.0.6 |
|
2603 | - * @return bool |
|
2604 | - */ |
|
2605 | - public function is_siteorigin_preview() { |
|
2606 | - $result = false; |
|
2607 | - if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) { |
|
2608 | - $result = true; |
|
2609 | - } |
|
2610 | - |
|
2611 | - return $result; |
|
2612 | - } |
|
2613 | - |
|
2614 | - /** |
|
2615 | - * Tests if the current output is inside a cornerstone builder preview. |
|
2616 | - * |
|
2617 | - * @since 1.0.8 |
|
2618 | - * @return bool |
|
2619 | - */ |
|
2620 | - public function is_cornerstone_preview() { |
|
2621 | - $result = false; |
|
2622 | - if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) { |
|
2623 | - $result = true; |
|
2624 | - } |
|
2625 | - |
|
2626 | - return $result; |
|
2627 | - } |
|
2628 | - |
|
2629 | - /** |
|
2630 | - * Tests if the current output is inside a fusion builder preview. |
|
2631 | - * |
|
2632 | - * @since 1.1.0 |
|
2633 | - * @return bool |
|
2634 | - */ |
|
2635 | - public function is_fusion_preview() { |
|
2636 | - $result = false; |
|
2637 | - if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) { |
|
2638 | - $result = true; |
|
2639 | - } |
|
2640 | - |
|
2641 | - return $result; |
|
2642 | - } |
|
2643 | - |
|
2644 | - /** |
|
2645 | - * Tests if the current output is inside a Oxygen builder preview. |
|
2646 | - * |
|
2647 | - * @since 1.0.18 |
|
2648 | - * @return bool |
|
2649 | - */ |
|
2650 | - public function is_oxygen_preview() { |
|
2651 | - $result = false; |
|
2652 | - if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) { |
|
2653 | - $result = true; |
|
2654 | - } |
|
2655 | - |
|
2656 | - return $result; |
|
2657 | - } |
|
2658 | - |
|
2659 | - /** |
|
2660 | - * General function to check if we are in a preview situation. |
|
2661 | - * |
|
2662 | - * @since 1.0.6 |
|
2663 | - * @return bool |
|
2664 | - */ |
|
2665 | - public function is_preview() { |
|
2666 | - $preview = false; |
|
2667 | - if ( $this->is_divi_preview() ) { |
|
2668 | - $preview = true; |
|
2669 | - } elseif ( $this->is_elementor_preview() ) { |
|
2670 | - $preview = true; |
|
2671 | - } elseif ( $this->is_beaver_preview() ) { |
|
2672 | - $preview = true; |
|
2673 | - } elseif ( $this->is_siteorigin_preview() ) { |
|
2674 | - $preview = true; |
|
2675 | - } elseif ( $this->is_cornerstone_preview() ) { |
|
2676 | - $preview = true; |
|
2677 | - } elseif ( $this->is_fusion_preview() ) { |
|
2678 | - $preview = true; |
|
2679 | - } elseif ( $this->is_oxygen_preview() ) { |
|
2680 | - $preview = true; |
|
2681 | - } elseif( $this->is_block_content_call() ) { |
|
2682 | - $preview = true; |
|
2683 | - } |
|
2684 | - |
|
2685 | - return $preview; |
|
2686 | - } |
|
2687 | - |
|
2688 | - /** |
|
2689 | - * Output the super title. |
|
2690 | - * |
|
2691 | - * @param $args |
|
2692 | - * @param array $instance |
|
2693 | - * |
|
2694 | - * @return string |
|
2695 | - */ |
|
2696 | - public function output_title( $args, $instance = array() ) { |
|
2697 | - $output = ''; |
|
2698 | - if ( ! empty( $instance['title'] ) ) { |
|
2699 | - /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */ |
|
2700 | - $title = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base ); |
|
2701 | - |
|
2702 | - if(empty($instance['widget_title_tag'])){ |
|
2703 | - $output = $args['before_title'] . $title . $args['after_title']; |
|
2704 | - }else{ |
|
2705 | - $title_tag = esc_attr( $instance['widget_title_tag'] ); |
|
2706 | - |
|
2707 | - // classes |
|
2708 | - $title_classes = array(); |
|
2709 | - $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : ''; |
|
2710 | - $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : ''; |
|
2711 | - $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : ''; |
|
2712 | - $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : ''; |
|
2713 | - $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : ''; |
|
2714 | - $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : ''; |
|
2715 | - $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : ''; |
|
2716 | - $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : ''; |
|
2717 | - $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : ''; |
|
2718 | - $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : ''; |
|
2719 | - $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : ''; |
|
2720 | - $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : ''; |
|
2721 | - $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : ''; |
|
2722 | - |
|
2723 | - $class = !empty( $title_classes ) ? implode(" ",$title_classes) : ''; |
|
2724 | - $output = "<$title_tag class='$class' >$title</$title_tag>"; |
|
2725 | - } |
|
2726 | - |
|
2727 | - } |
|
2728 | - |
|
2729 | - return $output; |
|
2730 | - } |
|
2731 | - |
|
2732 | - /** |
|
2733 | - * Outputs the options form inputs for the widget. |
|
2734 | - * |
|
2735 | - * @param array $instance The widget options. |
|
2736 | - */ |
|
2737 | - public function form( $instance ) { |
|
2738 | - |
|
2739 | - // set widget instance |
|
2740 | - $this->instance = $instance; |
|
2741 | - |
|
2742 | - // set it as a SD widget |
|
2743 | - echo $this->widget_advanced_toggle(); |
|
2744 | - |
|
2745 | - echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>"; |
|
2746 | - $arguments_raw = $this->get_arguments(); |
|
2747 | - |
|
2748 | - if ( is_array( $arguments_raw ) ) { |
|
2749 | - |
|
2750 | - $arguments = $this->group_arguments( $arguments_raw ); |
|
2751 | - |
|
2752 | - // Do we have sections? |
|
2753 | - $has_sections = $arguments == $arguments_raw ? false : true; |
|
2754 | - |
|
2755 | - |
|
2756 | - if ( $has_sections ) { |
|
2757 | - $panel_count = 0; |
|
2758 | - foreach ( $arguments as $key => $args ) { |
|
2759 | - |
|
2760 | - ?> |
|
2339 | + } |
|
2340 | + |
|
2341 | + /** |
|
2342 | + * Convert an array of attributes to block string. |
|
2343 | + * |
|
2344 | + * @todo there is prob a faster way to do this, also we could add some validation here. |
|
2345 | + * |
|
2346 | + * @param $custom_attributes |
|
2347 | + * |
|
2348 | + * @return string |
|
2349 | + */ |
|
2350 | + public function array_to_attributes( $custom_attributes, $html = false ) { |
|
2351 | + $attributes = ''; |
|
2352 | + if ( ! empty( $custom_attributes ) ) { |
|
2353 | + |
|
2354 | + if ( $html ) { |
|
2355 | + foreach ( $custom_attributes as $key => $val ) { |
|
2356 | + $attributes .= " $key='$val' "; |
|
2357 | + } |
|
2358 | + } else { |
|
2359 | + foreach ( $custom_attributes as $key => $val ) { |
|
2360 | + $attributes .= "'$key': '$val',"; |
|
2361 | + } |
|
2362 | + } |
|
2363 | + } |
|
2364 | + |
|
2365 | + return $attributes; |
|
2366 | + } |
|
2367 | + |
|
2368 | + /** |
|
2369 | + * A self looping function to create the output for JS block elements. |
|
2370 | + * |
|
2371 | + * This is what is output in the WP Editor visual view. |
|
2372 | + * |
|
2373 | + * @param $args |
|
2374 | + */ |
|
2375 | + public function block_element( $args ) { |
|
2376 | + |
|
2377 | + |
|
2378 | + if ( ! empty( $args ) ) { |
|
2379 | + foreach ( $args as $element => $new_args ) { |
|
2380 | + |
|
2381 | + if ( is_array( $new_args ) ) { // its an element |
|
2382 | + |
|
2383 | + |
|
2384 | + if ( isset( $new_args['element'] ) ) { |
|
2385 | + |
|
2386 | + if ( isset( $new_args['element_require'] ) ) { |
|
2387 | + echo str_replace( array( |
|
2388 | + "'+", |
|
2389 | + "+'" |
|
2390 | + ), '', $this->block_props_replace( $new_args['element_require'] ) ) . " && "; |
|
2391 | + unset( $new_args['element_require'] ); |
|
2392 | + } |
|
2393 | + |
|
2394 | + echo "\n el( '" . $new_args['element'] . "', {"; |
|
2395 | + |
|
2396 | + // get the attributes |
|
2397 | + foreach ( $new_args as $new_key => $new_value ) { |
|
2398 | + |
|
2399 | + |
|
2400 | + if ( $new_key == 'element' || $new_key == 'content' || $new_key == 'element_require' || $new_key == 'element_repeat' || is_array( $new_value ) ) { |
|
2401 | + // do nothing |
|
2402 | + } else { |
|
2403 | + echo $this->block_element( array( $new_key => $new_value ) ); |
|
2404 | + } |
|
2405 | + } |
|
2406 | + |
|
2407 | + echo "},";// end attributes |
|
2408 | + |
|
2409 | + // get the content |
|
2410 | + $first_item = 0; |
|
2411 | + foreach ( $new_args as $new_key => $new_value ) { |
|
2412 | + if ( $new_key === 'content' || is_array( $new_value ) ) { |
|
2413 | + |
|
2414 | + if ( $new_key === 'content' ) { |
|
2415 | + echo "'" . $this->block_props_replace( wp_slash( $new_value ) ) . "'"; |
|
2416 | + } |
|
2417 | + |
|
2418 | + if ( is_array( $new_value ) ) { |
|
2419 | + |
|
2420 | + if ( isset( $new_value['element_require'] ) ) { |
|
2421 | + echo str_replace( array( |
|
2422 | + "'+", |
|
2423 | + "+'" |
|
2424 | + ), '', $this->block_props_replace( $new_value['element_require'] ) ) . " && "; |
|
2425 | + unset( $new_value['element_require'] ); |
|
2426 | + } |
|
2427 | + |
|
2428 | + if ( isset( $new_value['element_repeat'] ) ) { |
|
2429 | + $x = 1; |
|
2430 | + while ( $x <= absint( $new_value['element_repeat'] ) ) { |
|
2431 | + $this->block_element( array( '' => $new_value ) ); |
|
2432 | + $x ++; |
|
2433 | + } |
|
2434 | + } else { |
|
2435 | + $this->block_element( array( '' => $new_value ) ); |
|
2436 | + } |
|
2437 | + } |
|
2438 | + $first_item ++; |
|
2439 | + } |
|
2440 | + } |
|
2441 | + |
|
2442 | + echo ")";// end content |
|
2443 | + |
|
2444 | + echo ", \n"; |
|
2445 | + |
|
2446 | + } |
|
2447 | + } else { |
|
2448 | + |
|
2449 | + if ( substr( $element, 0, 3 ) === "if_" ) { |
|
2450 | + echo str_replace( "if_", "", $element ) . ": " . $this->block_props_replace( $new_args, true ) . ","; |
|
2451 | + } elseif ( $element == 'style' ) { |
|
2452 | + echo $element . ": " . $this->block_props_replace( $new_args ) . ","; |
|
2453 | + } else { |
|
2454 | + echo $element . ": '" . $this->block_props_replace( $new_args ) . "',"; |
|
2455 | + } |
|
2456 | + |
|
2457 | + } |
|
2458 | + } |
|
2459 | + } |
|
2460 | + } |
|
2461 | + |
|
2462 | + /** |
|
2463 | + * Replace block attributes placeholders with the proper naming. |
|
2464 | + * |
|
2465 | + * @param $string |
|
2466 | + * |
|
2467 | + * @return mixed |
|
2468 | + */ |
|
2469 | + public function block_props_replace( $string, $no_wrap = false ) { |
|
2470 | + |
|
2471 | + if ( $no_wrap ) { |
|
2472 | + $string = str_replace( array( "[%", "%]" ), array( "props.attributes.", "" ), $string ); |
|
2473 | + } else { |
|
2474 | + $string = str_replace( array( "[%", "%]" ), array( "'+props.attributes.", "+'" ), $string ); |
|
2475 | + } |
|
2476 | + |
|
2477 | + return $string; |
|
2478 | + } |
|
2479 | + |
|
2480 | + /** |
|
2481 | + * Outputs the content of the widget |
|
2482 | + * |
|
2483 | + * @param array $args |
|
2484 | + * @param array $instance |
|
2485 | + */ |
|
2486 | + public function widget( $args, $instance ) { |
|
2487 | + |
|
2488 | + // get the filtered values |
|
2489 | + $argument_values = $this->argument_values( $instance ); |
|
2490 | + $argument_values = $this->string_to_bool( $argument_values ); |
|
2491 | + $output = $this->output( $argument_values, $args ); |
|
2492 | + |
|
2493 | + $no_wrap = false; |
|
2494 | + if ( isset( $argument_values['no_wrap'] ) && $argument_values['no_wrap'] ) { |
|
2495 | + $no_wrap = true; |
|
2496 | + } |
|
2497 | + |
|
2498 | + ob_start(); |
|
2499 | + if ( $output && ! $no_wrap ) { |
|
2500 | + |
|
2501 | + $class_original = $this->options['widget_ops']['classname']; |
|
2502 | + $class = $this->options['widget_ops']['classname']." sdel-".$this->get_instance_hash(); |
|
2503 | + |
|
2504 | + // Before widget |
|
2505 | + $before_widget = $args['before_widget']; |
|
2506 | + $before_widget = str_replace($class_original,$class,$before_widget); |
|
2507 | + $before_widget = apply_filters( 'wp_super_duper_before_widget', $before_widget, $args, $instance, $this ); |
|
2508 | + $before_widget = apply_filters( 'wp_super_duper_before_widget_' . $this->base_id, $before_widget, $args, $instance, $this ); |
|
2509 | + |
|
2510 | + // After widget |
|
2511 | + $after_widget = $args['after_widget']; |
|
2512 | + $after_widget = apply_filters( 'wp_super_duper_after_widget', $after_widget, $args, $instance, $this ); |
|
2513 | + $after_widget = apply_filters( 'wp_super_duper_after_widget_' . $this->base_id, $after_widget, $args, $instance, $this ); |
|
2514 | + |
|
2515 | + echo $before_widget; |
|
2516 | + // elementor strips the widget wrapping div so we check for and add it back if needed |
|
2517 | + if ( $this->is_elementor_widget_output() ) { |
|
2518 | + echo ! empty( $this->options['widget_ops']['classname'] ) ? "<span class='" . esc_attr( $class ) . "'>" : ''; |
|
2519 | + } |
|
2520 | + echo $this->output_title( $args, $instance ); |
|
2521 | + echo $output; |
|
2522 | + if ( $this->is_elementor_widget_output() ) { |
|
2523 | + echo ! empty( $this->options['widget_ops']['classname'] ) ? "</span>" : ''; |
|
2524 | + } |
|
2525 | + echo $after_widget; |
|
2526 | + } elseif ( $this->is_preview() && $output == '' ) {// if preview show a placeholder if empty |
|
2527 | + $output = $this->preview_placeholder_text( "{{" . $this->base_id . "}}" ); |
|
2528 | + echo $output; |
|
2529 | + } elseif ( $output && $no_wrap ) { |
|
2530 | + echo $output; |
|
2531 | + } |
|
2532 | + $output = ob_get_clean(); |
|
2533 | + |
|
2534 | + $output = apply_filters( 'wp_super_duper_widget_output', $output, $instance, $args, $this ); |
|
2535 | + |
|
2536 | + echo $output; |
|
2537 | + } |
|
2538 | + |
|
2539 | + /** |
|
2540 | + * Tests if the current output is inside a elementor container. |
|
2541 | + * |
|
2542 | + * @since 1.0.4 |
|
2543 | + * @return bool |
|
2544 | + */ |
|
2545 | + public function is_elementor_widget_output() { |
|
2546 | + $result = false; |
|
2547 | + if ( defined( 'ELEMENTOR_VERSION' ) && isset( $this->number ) && $this->number == 'REPLACE_TO_ID' ) { |
|
2548 | + $result = true; |
|
2549 | + } |
|
2550 | + |
|
2551 | + return $result; |
|
2552 | + } |
|
2553 | + |
|
2554 | + /** |
|
2555 | + * Tests if the current output is inside a elementor preview. |
|
2556 | + * |
|
2557 | + * @since 1.0.4 |
|
2558 | + * @return bool |
|
2559 | + */ |
|
2560 | + public function is_elementor_preview() { |
|
2561 | + $result = false; |
|
2562 | + if ( isset( $_REQUEST['elementor-preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) || ( isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor_ajax' ) ) { |
|
2563 | + $result = true; |
|
2564 | + } |
|
2565 | + |
|
2566 | + return $result; |
|
2567 | + } |
|
2568 | + |
|
2569 | + /** |
|
2570 | + * Tests if the current output is inside a Divi preview. |
|
2571 | + * |
|
2572 | + * @since 1.0.6 |
|
2573 | + * @return bool |
|
2574 | + */ |
|
2575 | + public function is_divi_preview() { |
|
2576 | + $result = false; |
|
2577 | + if ( isset( $_REQUEST['et_fb'] ) || isset( $_REQUEST['et_pb_preview'] ) || ( is_admin() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'elementor' ) ) { |
|
2578 | + $result = true; |
|
2579 | + } |
|
2580 | + |
|
2581 | + return $result; |
|
2582 | + } |
|
2583 | + |
|
2584 | + /** |
|
2585 | + * Tests if the current output is inside a Beaver builder preview. |
|
2586 | + * |
|
2587 | + * @since 1.0.6 |
|
2588 | + * @return bool |
|
2589 | + */ |
|
2590 | + public function is_beaver_preview() { |
|
2591 | + $result = false; |
|
2592 | + if ( isset( $_REQUEST['fl_builder'] ) ) { |
|
2593 | + $result = true; |
|
2594 | + } |
|
2595 | + |
|
2596 | + return $result; |
|
2597 | + } |
|
2598 | + |
|
2599 | + /** |
|
2600 | + * Tests if the current output is inside a siteorigin builder preview. |
|
2601 | + * |
|
2602 | + * @since 1.0.6 |
|
2603 | + * @return bool |
|
2604 | + */ |
|
2605 | + public function is_siteorigin_preview() { |
|
2606 | + $result = false; |
|
2607 | + if ( ! empty( $_REQUEST['siteorigin_panels_live_editor'] ) ) { |
|
2608 | + $result = true; |
|
2609 | + } |
|
2610 | + |
|
2611 | + return $result; |
|
2612 | + } |
|
2613 | + |
|
2614 | + /** |
|
2615 | + * Tests if the current output is inside a cornerstone builder preview. |
|
2616 | + * |
|
2617 | + * @since 1.0.8 |
|
2618 | + * @return bool |
|
2619 | + */ |
|
2620 | + public function is_cornerstone_preview() { |
|
2621 | + $result = false; |
|
2622 | + if ( ! empty( $_REQUEST['cornerstone_preview'] ) || basename( $_SERVER['REQUEST_URI'] ) == 'cornerstone-endpoint' ) { |
|
2623 | + $result = true; |
|
2624 | + } |
|
2625 | + |
|
2626 | + return $result; |
|
2627 | + } |
|
2628 | + |
|
2629 | + /** |
|
2630 | + * Tests if the current output is inside a fusion builder preview. |
|
2631 | + * |
|
2632 | + * @since 1.1.0 |
|
2633 | + * @return bool |
|
2634 | + */ |
|
2635 | + public function is_fusion_preview() { |
|
2636 | + $result = false; |
|
2637 | + if ( ! empty( $_REQUEST['fb-edit'] ) || ! empty( $_REQUEST['fusion_load_nonce'] ) ) { |
|
2638 | + $result = true; |
|
2639 | + } |
|
2640 | + |
|
2641 | + return $result; |
|
2642 | + } |
|
2643 | + |
|
2644 | + /** |
|
2645 | + * Tests if the current output is inside a Oxygen builder preview. |
|
2646 | + * |
|
2647 | + * @since 1.0.18 |
|
2648 | + * @return bool |
|
2649 | + */ |
|
2650 | + public function is_oxygen_preview() { |
|
2651 | + $result = false; |
|
2652 | + if ( ! empty( $_REQUEST['ct_builder'] ) || ( ! empty( $_REQUEST['action'] ) && ( substr( $_REQUEST['action'], 0, 11 ) === "oxy_render_" || substr( $_REQUEST['action'], 0, 10 ) === "ct_render_" ) ) ) { |
|
2653 | + $result = true; |
|
2654 | + } |
|
2655 | + |
|
2656 | + return $result; |
|
2657 | + } |
|
2658 | + |
|
2659 | + /** |
|
2660 | + * General function to check if we are in a preview situation. |
|
2661 | + * |
|
2662 | + * @since 1.0.6 |
|
2663 | + * @return bool |
|
2664 | + */ |
|
2665 | + public function is_preview() { |
|
2666 | + $preview = false; |
|
2667 | + if ( $this->is_divi_preview() ) { |
|
2668 | + $preview = true; |
|
2669 | + } elseif ( $this->is_elementor_preview() ) { |
|
2670 | + $preview = true; |
|
2671 | + } elseif ( $this->is_beaver_preview() ) { |
|
2672 | + $preview = true; |
|
2673 | + } elseif ( $this->is_siteorigin_preview() ) { |
|
2674 | + $preview = true; |
|
2675 | + } elseif ( $this->is_cornerstone_preview() ) { |
|
2676 | + $preview = true; |
|
2677 | + } elseif ( $this->is_fusion_preview() ) { |
|
2678 | + $preview = true; |
|
2679 | + } elseif ( $this->is_oxygen_preview() ) { |
|
2680 | + $preview = true; |
|
2681 | + } elseif( $this->is_block_content_call() ) { |
|
2682 | + $preview = true; |
|
2683 | + } |
|
2684 | + |
|
2685 | + return $preview; |
|
2686 | + } |
|
2687 | + |
|
2688 | + /** |
|
2689 | + * Output the super title. |
|
2690 | + * |
|
2691 | + * @param $args |
|
2692 | + * @param array $instance |
|
2693 | + * |
|
2694 | + * @return string |
|
2695 | + */ |
|
2696 | + public function output_title( $args, $instance = array() ) { |
|
2697 | + $output = ''; |
|
2698 | + if ( ! empty( $instance['title'] ) ) { |
|
2699 | + /** This filter is documented in wp-includes/widgets/class-wp-widget-pages.php */ |
|
2700 | + $title = apply_filters( 'widget_title', $instance['title'], $instance, $this->id_base ); |
|
2701 | + |
|
2702 | + if(empty($instance['widget_title_tag'])){ |
|
2703 | + $output = $args['before_title'] . $title . $args['after_title']; |
|
2704 | + }else{ |
|
2705 | + $title_tag = esc_attr( $instance['widget_title_tag'] ); |
|
2706 | + |
|
2707 | + // classes |
|
2708 | + $title_classes = array(); |
|
2709 | + $title_classes[] = !empty( $instance['widget_title_size_class'] ) ? sanitize_html_class( $instance['widget_title_size_class'] ) : ''; |
|
2710 | + $title_classes[] = !empty( $instance['widget_title_align_class'] ) ? sanitize_html_class( $instance['widget_title_align_class'] ) : ''; |
|
2711 | + $title_classes[] = !empty( $instance['widget_title_color_class'] ) ? "text-".sanitize_html_class( $instance['widget_title_color_class'] ) : ''; |
|
2712 | + $title_classes[] = !empty( $instance['widget_title_border_class'] ) ? sanitize_html_class( $instance['widget_title_border_class'] ) : ''; |
|
2713 | + $title_classes[] = !empty( $instance['widget_title_border_color_class'] ) ? "border-".sanitize_html_class( $instance['widget_title_border_color_class'] ) : ''; |
|
2714 | + $title_classes[] = !empty( $instance['widget_title_mt_class'] ) ? "mt-".absint( $instance['widget_title_mt_class'] ) : ''; |
|
2715 | + $title_classes[] = !empty( $instance['widget_title_mr_class'] ) ? "mr-".absint( $instance['widget_title_mr_class'] ) : ''; |
|
2716 | + $title_classes[] = !empty( $instance['widget_title_mb_class'] ) ? "mb-".absint( $instance['widget_title_mb_class'] ) : ''; |
|
2717 | + $title_classes[] = !empty( $instance['widget_title_ml_class'] ) ? "ml-".absint( $instance['widget_title_ml_class'] ) : ''; |
|
2718 | + $title_classes[] = !empty( $instance['widget_title_pt_class'] ) ? "pt-".absint( $instance['widget_title_pt_class'] ) : ''; |
|
2719 | + $title_classes[] = !empty( $instance['widget_title_pr_class'] ) ? "pr-".absint( $instance['widget_title_pr_class'] ) : ''; |
|
2720 | + $title_classes[] = !empty( $instance['widget_title_pb_class'] ) ? "pb-".absint( $instance['widget_title_pb_class'] ) : ''; |
|
2721 | + $title_classes[] = !empty( $instance['widget_title_pl_class'] ) ? "pl-".absint( $instance['widget_title_pl_class'] ) : ''; |
|
2722 | + |
|
2723 | + $class = !empty( $title_classes ) ? implode(" ",$title_classes) : ''; |
|
2724 | + $output = "<$title_tag class='$class' >$title</$title_tag>"; |
|
2725 | + } |
|
2726 | + |
|
2727 | + } |
|
2728 | + |
|
2729 | + return $output; |
|
2730 | + } |
|
2731 | + |
|
2732 | + /** |
|
2733 | + * Outputs the options form inputs for the widget. |
|
2734 | + * |
|
2735 | + * @param array $instance The widget options. |
|
2736 | + */ |
|
2737 | + public function form( $instance ) { |
|
2738 | + |
|
2739 | + // set widget instance |
|
2740 | + $this->instance = $instance; |
|
2741 | + |
|
2742 | + // set it as a SD widget |
|
2743 | + echo $this->widget_advanced_toggle(); |
|
2744 | + |
|
2745 | + echo "<p>" . esc_attr( $this->options['widget_ops']['description'] ) . "</p>"; |
|
2746 | + $arguments_raw = $this->get_arguments(); |
|
2747 | + |
|
2748 | + if ( is_array( $arguments_raw ) ) { |
|
2749 | + |
|
2750 | + $arguments = $this->group_arguments( $arguments_raw ); |
|
2751 | + |
|
2752 | + // Do we have sections? |
|
2753 | + $has_sections = $arguments == $arguments_raw ? false : true; |
|
2754 | + |
|
2755 | + |
|
2756 | + if ( $has_sections ) { |
|
2757 | + $panel_count = 0; |
|
2758 | + foreach ( $arguments as $key => $args ) { |
|
2759 | + |
|
2760 | + ?> |
|
2761 | 2761 | <script> |
2762 | 2762 | // jQuery(this).find("i").toggleClass("fas fa-chevron-up fas fa-chevron-down");jQuery(this).next().toggle(); |
2763 | 2763 | </script> |
2764 | 2764 | <?php |
2765 | 2765 | |
2766 | - $hide = $panel_count ? ' style="display:none;" ' : ''; |
|
2767 | - $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down'; |
|
2768 | - 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>"; |
|
2769 | - echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>"; |
|
2766 | + $hide = $panel_count ? ' style="display:none;" ' : ''; |
|
2767 | + $icon_class = $panel_count ? 'fas fa-chevron-up' : 'fas fa-chevron-down'; |
|
2768 | + 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>"; |
|
2769 | + echo "<div class='sd-toggle-group sd-input-group-" . sanitize_title_with_dashes( $key ) . "' $hide>"; |
|
2770 | 2770 | |
2771 | - foreach ( $args as $k => $a ) { |
|
2771 | + foreach ( $args as $k => $a ) { |
|
2772 | 2772 | |
2773 | - $this->widget_inputs_row_start($k, $a); |
|
2774 | - $this->widget_inputs( $a, $instance ); |
|
2775 | - $this->widget_inputs_row_end($k, $a); |
|
2773 | + $this->widget_inputs_row_start($k, $a); |
|
2774 | + $this->widget_inputs( $a, $instance ); |
|
2775 | + $this->widget_inputs_row_end($k, $a); |
|
2776 | 2776 | |
2777 | - } |
|
2777 | + } |
|
2778 | 2778 | |
2779 | - echo "</div>"; |
|
2779 | + echo "</div>"; |
|
2780 | 2780 | |
2781 | - $panel_count ++; |
|
2781 | + $panel_count ++; |
|
2782 | 2782 | |
2783 | - } |
|
2784 | - } else { |
|
2785 | - foreach ( $arguments as $key => $args ) { |
|
2786 | - $this->widget_inputs_row_start($key, $args); |
|
2787 | - $this->widget_inputs( $args, $instance ); |
|
2788 | - $this->widget_inputs_row_end($key, $args); |
|
2789 | - } |
|
2790 | - } |
|
2783 | + } |
|
2784 | + } else { |
|
2785 | + foreach ( $arguments as $key => $args ) { |
|
2786 | + $this->widget_inputs_row_start($key, $args); |
|
2787 | + $this->widget_inputs( $args, $instance ); |
|
2788 | + $this->widget_inputs_row_end($key, $args); |
|
2789 | + } |
|
2790 | + } |
|
2791 | 2791 | |
2792 | - } |
|
2793 | - } |
|
2792 | + } |
|
2793 | + } |
|
2794 | 2794 | |
2795 | - public function widget_inputs_row_start($key, $args){ |
|
2796 | - if(!empty($args['row'])){ |
|
2797 | - // maybe open |
|
2798 | - if(!empty($args['row']['open'])){ |
|
2799 | - ?> |
|
2795 | + public function widget_inputs_row_start($key, $args){ |
|
2796 | + if(!empty($args['row'])){ |
|
2797 | + // maybe open |
|
2798 | + if(!empty($args['row']['open'])){ |
|
2799 | + ?> |
|
2800 | 2800 | <div class='bsui sd-argument ' data-argument='<?php echo esc_attr( $args['row']['key'] ); ?>' data-element_require='<?php if ( !empty($args['row']['element_require'])) { |
2801 | - echo $this->convert_element_require( $args['row']['element_require'] ); |
|
2802 | - } ?>'> |
|
2801 | + echo $this->convert_element_require( $args['row']['element_require'] ); |
|
2802 | + } ?>'> |
|
2803 | 2803 | <?php if(!empty($args['row']['title'])){ ?> |
2804 | 2804 | <label class="mb-0 "><?php echo esc_attr( $args['row']['title'] ); ?><?php echo $this->widget_field_desc( $args['row'] ); ?></label> |
2805 | 2805 | <?php }?> |
2806 | 2806 | <div class='row <?php if(!empty($args['row']['class'])){ echo esc_attr($args['row']['class']);} ?>'> |
2807 | 2807 | <div class='col pr-2'> |
2808 | 2808 | <?php |
2809 | - }elseif(!empty($args['row']['close'])){ |
|
2810 | - echo "<div class='col pl-0'>"; |
|
2811 | - }else{ |
|
2812 | - echo "<div class='col pl-0 pr-2'>"; |
|
2813 | - } |
|
2814 | - } |
|
2815 | - } |
|
2816 | - |
|
2817 | - public function widget_inputs_row_end($key, $args){ |
|
2818 | - |
|
2819 | - if(!empty($args['row'])){ |
|
2820 | - // maybe close |
|
2821 | - if(!empty($args['row']['close'])){ |
|
2822 | - echo "</div></div>"; |
|
2823 | - } |
|
2824 | - |
|
2825 | - echo "</div>"; |
|
2826 | - } |
|
2827 | - } |
|
2828 | - |
|
2829 | - /** |
|
2830 | - * Get the hidden input that when added makes the advanced button show on widget settings. |
|
2831 | - * |
|
2832 | - * @return string |
|
2833 | - */ |
|
2834 | - public function widget_advanced_toggle() { |
|
2835 | - |
|
2836 | - $output = ''; |
|
2837 | - if ( $this->block_show_advanced() ) { |
|
2838 | - $val = 1; |
|
2839 | - } else { |
|
2840 | - $val = 0; |
|
2841 | - } |
|
2842 | - |
|
2843 | - $output .= "<input type='hidden' class='sd-show-advanced' value='$val' />"; |
|
2844 | - |
|
2845 | - return $output; |
|
2846 | - } |
|
2847 | - |
|
2848 | - /** |
|
2849 | - * Convert require element. |
|
2850 | - * |
|
2851 | - * @since 1.0.0 |
|
2852 | - * |
|
2853 | - * @param string $input Input element. |
|
2854 | - * |
|
2855 | - * @return string $output |
|
2856 | - */ |
|
2857 | - public function convert_element_require( $input ) { |
|
2858 | - |
|
2859 | - $input = str_replace( "'", '"', $input );// we only want double quotes |
|
2860 | - |
|
2861 | - $output = esc_attr( str_replace( array( "[%", "%]" ), array( |
|
2862 | - "jQuery(form).find('[data-argument=\"", |
|
2863 | - "\"]').find('input,select,textarea').val()" |
|
2864 | - ), $input ) ); |
|
2865 | - |
|
2866 | - return $output; |
|
2867 | - } |
|
2868 | - |
|
2869 | - /** |
|
2870 | - * Builds the inputs for the widget options. |
|
2871 | - * |
|
2872 | - * @param $args |
|
2873 | - * @param $instance |
|
2874 | - */ |
|
2875 | - public function widget_inputs( $args, $instance ) { |
|
2876 | - |
|
2877 | - $class = ""; |
|
2878 | - $element_require = ""; |
|
2879 | - $custom_attributes = ""; |
|
2880 | - |
|
2881 | - // get value |
|
2882 | - if ( isset( $instance[ $args['name'] ] ) ) { |
|
2883 | - $value = $instance[ $args['name'] ]; |
|
2884 | - } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) { |
|
2885 | - $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] ); |
|
2886 | - } else { |
|
2887 | - $value = ''; |
|
2888 | - } |
|
2889 | - |
|
2890 | - // get placeholder |
|
2891 | - if ( ! empty( $args['placeholder'] ) ) { |
|
2892 | - $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'"; |
|
2893 | - } else { |
|
2894 | - $placeholder = ''; |
|
2895 | - } |
|
2896 | - |
|
2897 | - // get if advanced |
|
2898 | - if ( isset( $args['advanced'] ) && $args['advanced'] ) { |
|
2899 | - $class .= " sd-advanced-setting "; |
|
2900 | - } |
|
2901 | - |
|
2902 | - // element_require |
|
2903 | - if ( isset( $args['element_require'] ) && $args['element_require'] ) { |
|
2904 | - $element_require = $args['element_require']; |
|
2905 | - } |
|
2906 | - |
|
2907 | - // custom_attributes |
|
2908 | - if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) { |
|
2909 | - $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true ); |
|
2910 | - } |
|
2911 | - |
|
2912 | - |
|
2913 | - // before wrapper |
|
2914 | - ?> |
|
2809 | + }elseif(!empty($args['row']['close'])){ |
|
2810 | + echo "<div class='col pl-0'>"; |
|
2811 | + }else{ |
|
2812 | + echo "<div class='col pl-0 pr-2'>"; |
|
2813 | + } |
|
2814 | + } |
|
2815 | + } |
|
2816 | + |
|
2817 | + public function widget_inputs_row_end($key, $args){ |
|
2818 | + |
|
2819 | + if(!empty($args['row'])){ |
|
2820 | + // maybe close |
|
2821 | + if(!empty($args['row']['close'])){ |
|
2822 | + echo "</div></div>"; |
|
2823 | + } |
|
2824 | + |
|
2825 | + echo "</div>"; |
|
2826 | + } |
|
2827 | + } |
|
2828 | + |
|
2829 | + /** |
|
2830 | + * Get the hidden input that when added makes the advanced button show on widget settings. |
|
2831 | + * |
|
2832 | + * @return string |
|
2833 | + */ |
|
2834 | + public function widget_advanced_toggle() { |
|
2835 | + |
|
2836 | + $output = ''; |
|
2837 | + if ( $this->block_show_advanced() ) { |
|
2838 | + $val = 1; |
|
2839 | + } else { |
|
2840 | + $val = 0; |
|
2841 | + } |
|
2842 | + |
|
2843 | + $output .= "<input type='hidden' class='sd-show-advanced' value='$val' />"; |
|
2844 | + |
|
2845 | + return $output; |
|
2846 | + } |
|
2847 | + |
|
2848 | + /** |
|
2849 | + * Convert require element. |
|
2850 | + * |
|
2851 | + * @since 1.0.0 |
|
2852 | + * |
|
2853 | + * @param string $input Input element. |
|
2854 | + * |
|
2855 | + * @return string $output |
|
2856 | + */ |
|
2857 | + public function convert_element_require( $input ) { |
|
2858 | + |
|
2859 | + $input = str_replace( "'", '"', $input );// we only want double quotes |
|
2860 | + |
|
2861 | + $output = esc_attr( str_replace( array( "[%", "%]" ), array( |
|
2862 | + "jQuery(form).find('[data-argument=\"", |
|
2863 | + "\"]').find('input,select,textarea').val()" |
|
2864 | + ), $input ) ); |
|
2865 | + |
|
2866 | + return $output; |
|
2867 | + } |
|
2868 | + |
|
2869 | + /** |
|
2870 | + * Builds the inputs for the widget options. |
|
2871 | + * |
|
2872 | + * @param $args |
|
2873 | + * @param $instance |
|
2874 | + */ |
|
2875 | + public function widget_inputs( $args, $instance ) { |
|
2876 | + |
|
2877 | + $class = ""; |
|
2878 | + $element_require = ""; |
|
2879 | + $custom_attributes = ""; |
|
2880 | + |
|
2881 | + // get value |
|
2882 | + if ( isset( $instance[ $args['name'] ] ) ) { |
|
2883 | + $value = $instance[ $args['name'] ]; |
|
2884 | + } elseif ( ! isset( $instance[ $args['name'] ] ) && ! empty( $args['default'] ) ) { |
|
2885 | + $value = is_array( $args['default'] ) ? array_map( "esc_html", $args['default'] ) : esc_html( $args['default'] ); |
|
2886 | + } else { |
|
2887 | + $value = ''; |
|
2888 | + } |
|
2889 | + |
|
2890 | + // get placeholder |
|
2891 | + if ( ! empty( $args['placeholder'] ) ) { |
|
2892 | + $placeholder = "placeholder='" . esc_html( $args['placeholder'] ) . "'"; |
|
2893 | + } else { |
|
2894 | + $placeholder = ''; |
|
2895 | + } |
|
2896 | + |
|
2897 | + // get if advanced |
|
2898 | + if ( isset( $args['advanced'] ) && $args['advanced'] ) { |
|
2899 | + $class .= " sd-advanced-setting "; |
|
2900 | + } |
|
2901 | + |
|
2902 | + // element_require |
|
2903 | + if ( isset( $args['element_require'] ) && $args['element_require'] ) { |
|
2904 | + $element_require = $args['element_require']; |
|
2905 | + } |
|
2906 | + |
|
2907 | + // custom_attributes |
|
2908 | + if ( isset( $args['custom_attributes'] ) && $args['custom_attributes'] ) { |
|
2909 | + $custom_attributes = $this->array_to_attributes( $args['custom_attributes'], true ); |
|
2910 | + } |
|
2911 | + |
|
2912 | + |
|
2913 | + // before wrapper |
|
2914 | + ?> |
|
2915 | 2915 | <p class="sd-argument <?php echo esc_attr( $class ); ?>" |
2916 | 2916 | data-argument='<?php echo esc_attr( $args['name'] ); ?>' |
2917 | 2917 | data-element_require='<?php if ( $element_require ) { |
2918 | - echo $this->convert_element_require( $element_require ); |
|
2919 | - } ?>' |
|
2918 | + echo $this->convert_element_require( $element_require ); |
|
2919 | + } ?>' |
|
2920 | 2920 | > |
2921 | 2921 | <?php |
2922 | 2922 | |
2923 | 2923 | |
2924 | - switch ( $args['type'] ) { |
|
2925 | - //array('text','password','number','email','tel','url','color') |
|
2926 | - case "text": |
|
2927 | - case "password": |
|
2928 | - case "number": |
|
2929 | - case "email": |
|
2930 | - case "tel": |
|
2931 | - case "url": |
|
2932 | - case "color": |
|
2933 | - ?> |
|
2924 | + switch ( $args['type'] ) { |
|
2925 | + //array('text','password','number','email','tel','url','color') |
|
2926 | + case "text": |
|
2927 | + case "password": |
|
2928 | + case "number": |
|
2929 | + case "email": |
|
2930 | + case "tel": |
|
2931 | + case "url": |
|
2932 | + case "color": |
|
2933 | + ?> |
|
2934 | 2934 | <label |
2935 | 2935 | 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> |
2936 | 2936 | <input <?php echo $placeholder; ?> class="widefat" |
@@ -2941,47 +2941,47 @@ discard block |
||
2941 | 2941 | value="<?php echo esc_attr( $value ); ?>"> |
2942 | 2942 | <?php |
2943 | 2943 | |
2944 | - break; |
|
2945 | - case "select": |
|
2946 | - $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false; |
|
2947 | - if ( $multiple ) { |
|
2948 | - if ( empty( $value ) ) { |
|
2949 | - $value = array(); |
|
2950 | - } |
|
2951 | - } |
|
2952 | - ?> |
|
2944 | + break; |
|
2945 | + case "select": |
|
2946 | + $multiple = isset( $args['multiple'] ) && $args['multiple'] ? true : false; |
|
2947 | + if ( $multiple ) { |
|
2948 | + if ( empty( $value ) ) { |
|
2949 | + $value = array(); |
|
2950 | + } |
|
2951 | + } |
|
2952 | + ?> |
|
2953 | 2953 | <label |
2954 | 2954 | 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> |
2955 | 2955 | <select <?php echo $placeholder; ?> class="widefat" |
2956 | 2956 | <?php echo $custom_attributes; ?> |
2957 | 2957 | id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" |
2958 | 2958 | name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); |
2959 | - if ( $multiple ) { |
|
2960 | - echo "[]"; |
|
2961 | - } ?>" |
|
2959 | + if ( $multiple ) { |
|
2960 | + echo "[]"; |
|
2961 | + } ?>" |
|
2962 | 2962 | <?php if ( $multiple ) { |
2963 | - echo "multiple"; |
|
2964 | - } //@todo not implemented yet due to gutenberg not supporting it |
|
2965 | - ?> |
|
2963 | + echo "multiple"; |
|
2964 | + } //@todo not implemented yet due to gutenberg not supporting it |
|
2965 | + ?> |
|
2966 | 2966 | > |
2967 | 2967 | <?php |
2968 | 2968 | |
2969 | - if ( ! empty( $args['options'] ) ) { |
|
2970 | - foreach ( $args['options'] as $val => $label ) { |
|
2971 | - if ( $multiple ) { |
|
2972 | - $selected = in_array( $val, $value ) ? 'selected="selected"' : ''; |
|
2973 | - } else { |
|
2974 | - $selected = selected( $value, $val, false ); |
|
2975 | - } |
|
2976 | - echo "<option value='$val' " . $selected . ">$label</option>"; |
|
2977 | - } |
|
2978 | - } |
|
2979 | - ?> |
|
2969 | + if ( ! empty( $args['options'] ) ) { |
|
2970 | + foreach ( $args['options'] as $val => $label ) { |
|
2971 | + if ( $multiple ) { |
|
2972 | + $selected = in_array( $val, $value ) ? 'selected="selected"' : ''; |
|
2973 | + } else { |
|
2974 | + $selected = selected( $value, $val, false ); |
|
2975 | + } |
|
2976 | + echo "<option value='$val' " . $selected . ">$label</option>"; |
|
2977 | + } |
|
2978 | + } |
|
2979 | + ?> |
|
2980 | 2980 | </select> |
2981 | 2981 | <?php |
2982 | - break; |
|
2983 | - case "checkbox": |
|
2984 | - ?> |
|
2982 | + break; |
|
2983 | + case "checkbox": |
|
2984 | + ?> |
|
2985 | 2985 | <input <?php echo $placeholder; ?> |
2986 | 2986 | <?php checked( 1, $value, true ) ?> |
2987 | 2987 | <?php echo $custom_attributes; ?> |
@@ -2991,9 +2991,9 @@ discard block |
||
2991 | 2991 | <label |
2992 | 2992 | 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> |
2993 | 2993 | <?php |
2994 | - break; |
|
2995 | - case "textarea": |
|
2996 | - ?> |
|
2994 | + break; |
|
2995 | + case "textarea": |
|
2996 | + ?> |
|
2997 | 2997 | <label |
2998 | 2998 | 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> |
2999 | 2999 | <textarea <?php echo $placeholder; ?> class="widefat" |
@@ -3003,207 +3003,207 @@ discard block |
||
3003 | 3003 | ><?php echo esc_attr( $value ); ?></textarea> |
3004 | 3004 | <?php |
3005 | 3005 | |
3006 | - break; |
|
3007 | - case "hidden": |
|
3008 | - ?> |
|
3006 | + break; |
|
3007 | + case "hidden": |
|
3008 | + ?> |
|
3009 | 3009 | <input id="<?php echo esc_attr( $this->get_field_id( $args['name'] ) ); ?>" |
3010 | 3010 | name="<?php echo esc_attr( $this->get_field_name( $args['name'] ) ); ?>" type="hidden" |
3011 | 3011 | value="<?php echo esc_attr( $value ); ?>"> |
3012 | 3012 | <?php |
3013 | - break; |
|
3014 | - default: |
|
3015 | - echo "No input type found!"; // @todo we need to add more input types. |
|
3016 | - } |
|
3013 | + break; |
|
3014 | + default: |
|
3015 | + echo "No input type found!"; // @todo we need to add more input types. |
|
3016 | + } |
|
3017 | 3017 | |
3018 | - // after wrapper |
|
3019 | - ?> |
|
3018 | + // after wrapper |
|
3019 | + ?> |
|
3020 | 3020 | </p> |
3021 | 3021 | <?php |
3022 | 3022 | |
3023 | 3023 | |
3024 | - } |
|
3025 | - |
|
3026 | - public function get_widget_icon($icon = 'box-top', $title = ''){ |
|
3027 | - if($icon=='box-top'){ |
|
3028 | - 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>'; |
|
3029 | - }elseif($icon=='box-right'){ |
|
3030 | - 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>'; |
|
3031 | - }elseif($icon=='box-bottom'){ |
|
3032 | - 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>'; |
|
3033 | - }elseif($icon=='box-left'){ |
|
3034 | - 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>'; |
|
3035 | - } |
|
3036 | - } |
|
3037 | - |
|
3038 | - /** |
|
3039 | - * Get the widget input description html. |
|
3040 | - * |
|
3041 | - * @param $args |
|
3042 | - * |
|
3043 | - * @return string |
|
3044 | - * @todo, need to make its own tooltip script |
|
3045 | - */ |
|
3046 | - public function widget_field_desc( $args ) { |
|
3047 | - |
|
3048 | - $description = ''; |
|
3049 | - if ( isset( $args['desc'] ) && $args['desc'] ) { |
|
3050 | - if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) { |
|
3051 | - $description = $this->desc_tip( $args['desc'] ); |
|
3052 | - } else { |
|
3053 | - $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>'; |
|
3054 | - } |
|
3055 | - } |
|
3056 | - |
|
3057 | - return $description; |
|
3058 | - } |
|
3059 | - |
|
3060 | - /** |
|
3061 | - * Get the widget input title html. |
|
3062 | - * |
|
3063 | - * @param $args |
|
3064 | - * |
|
3065 | - * @return string |
|
3066 | - */ |
|
3067 | - public function widget_field_title( $args ) { |
|
3068 | - |
|
3069 | - $title = ''; |
|
3070 | - if ( isset( $args['title'] ) && $args['title'] ) { |
|
3071 | - if ( isset( $args['icon'] ) && $args['icon'] ) { |
|
3072 | - $title = self::get_widget_icon( $args['icon'], $args['title'] ); |
|
3073 | - } else { |
|
3074 | - $title = esc_attr($args['title']); |
|
3075 | - } |
|
3076 | - } |
|
3077 | - |
|
3078 | - return $title; |
|
3079 | - } |
|
3080 | - |
|
3081 | - /** |
|
3082 | - * Get the tool tip html. |
|
3083 | - * |
|
3084 | - * @param $tip |
|
3085 | - * @param bool $allow_html |
|
3086 | - * |
|
3087 | - * @return string |
|
3088 | - */ |
|
3089 | - function desc_tip( $tip, $allow_html = false ) { |
|
3090 | - if ( $allow_html ) { |
|
3091 | - $tip = $this->sanitize_tooltip( $tip ); |
|
3092 | - } else { |
|
3093 | - $tip = esc_attr( $tip ); |
|
3094 | - } |
|
3095 | - |
|
3096 | - return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>'; |
|
3097 | - } |
|
3098 | - |
|
3099 | - /** |
|
3100 | - * Sanitize a string destined to be a tooltip. |
|
3101 | - * |
|
3102 | - * @param string $var |
|
3103 | - * |
|
3104 | - * @return string |
|
3105 | - */ |
|
3106 | - public function sanitize_tooltip( $var ) { |
|
3107 | - return htmlspecialchars( wp_kses( html_entity_decode( $var ), array( |
|
3108 | - 'br' => array(), |
|
3109 | - 'em' => array(), |
|
3110 | - 'strong' => array(), |
|
3111 | - 'small' => array(), |
|
3112 | - 'span' => array(), |
|
3113 | - 'ul' => array(), |
|
3114 | - 'li' => array(), |
|
3115 | - 'ol' => array(), |
|
3116 | - 'p' => array(), |
|
3117 | - ) ) ); |
|
3118 | - } |
|
3119 | - |
|
3120 | - /** |
|
3121 | - * Processing widget options on save |
|
3122 | - * |
|
3123 | - * @param array $new_instance The new options |
|
3124 | - * @param array $old_instance The previous options |
|
3125 | - * |
|
3126 | - * @return array |
|
3127 | - * @todo we should add some sanitation here. |
|
3128 | - */ |
|
3129 | - public function update( $new_instance, $old_instance ) { |
|
3130 | - |
|
3131 | - //save the widget |
|
3132 | - $instance = array_merge( (array) $old_instance, (array) $new_instance ); |
|
3133 | - |
|
3134 | - // set widget instance |
|
3135 | - $this->instance = $instance; |
|
3136 | - |
|
3137 | - if ( empty( $this->arguments ) ) { |
|
3138 | - $this->get_arguments(); |
|
3139 | - } |
|
3140 | - |
|
3141 | - // check for checkboxes |
|
3142 | - if ( ! empty( $this->arguments ) ) { |
|
3143 | - foreach ( $this->arguments as $argument ) { |
|
3144 | - if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) { |
|
3145 | - $instance[ $argument['name'] ] = '0'; |
|
3146 | - } |
|
3147 | - } |
|
3148 | - } |
|
3149 | - |
|
3150 | - return $instance; |
|
3151 | - } |
|
3152 | - |
|
3153 | - /** |
|
3154 | - * Checks if the current call is a ajax call to get the block content. |
|
3155 | - * |
|
3156 | - * This can be used in your widget to return different content as the block content. |
|
3157 | - * |
|
3158 | - * @since 1.0.3 |
|
3159 | - * @return bool |
|
3160 | - */ |
|
3161 | - public function is_block_content_call() { |
|
3162 | - $result = false; |
|
3163 | - if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) { |
|
3164 | - $result = true; |
|
3165 | - } |
|
3166 | - |
|
3167 | - return $result; |
|
3168 | - } |
|
3169 | - |
|
3170 | - /** |
|
3171 | - * Get an instance hash that will be unique to the type and settings. |
|
3172 | - * |
|
3173 | - * @since 1.0.20 |
|
3174 | - * @return string |
|
3175 | - */ |
|
3176 | - public function get_instance_hash(){ |
|
3177 | - $instance_string = $this->base_id.serialize($this->instance); |
|
3178 | - return hash('crc32b',$instance_string); |
|
3179 | - } |
|
3180 | - |
|
3181 | - /** |
|
3182 | - * Generate and return inline styles from CSS rules that will match the unique class of the instance. |
|
3183 | - * |
|
3184 | - * @param array $rules |
|
3185 | - * |
|
3186 | - * @since 1.0.20 |
|
3187 | - * @return string |
|
3188 | - */ |
|
3189 | - public function get_instance_style($rules = array()){ |
|
3190 | - $css = ''; |
|
3191 | - |
|
3192 | - if(!empty($rules)){ |
|
3193 | - $rules = array_unique($rules); |
|
3194 | - $instance_hash = $this->get_instance_hash(); |
|
3195 | - $css .= "<style>"; |
|
3196 | - foreach($rules as $rule){ |
|
3197 | - $css .= ".sdel-$instance_hash $rule"; |
|
3198 | - } |
|
3199 | - $css .= "</style>"; |
|
3200 | - } |
|
3201 | - |
|
3202 | - |
|
3203 | - return $css; |
|
3204 | - |
|
3205 | - } |
|
3206 | - |
|
3207 | - } |
|
3024 | + } |
|
3025 | + |
|
3026 | + public function get_widget_icon($icon = 'box-top', $title = ''){ |
|
3027 | + if($icon=='box-top'){ |
|
3028 | + 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>'; |
|
3029 | + }elseif($icon=='box-right'){ |
|
3030 | + 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>'; |
|
3031 | + }elseif($icon=='box-bottom'){ |
|
3032 | + 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>'; |
|
3033 | + }elseif($icon=='box-left'){ |
|
3034 | + 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>'; |
|
3035 | + } |
|
3036 | + } |
|
3037 | + |
|
3038 | + /** |
|
3039 | + * Get the widget input description html. |
|
3040 | + * |
|
3041 | + * @param $args |
|
3042 | + * |
|
3043 | + * @return string |
|
3044 | + * @todo, need to make its own tooltip script |
|
3045 | + */ |
|
3046 | + public function widget_field_desc( $args ) { |
|
3047 | + |
|
3048 | + $description = ''; |
|
3049 | + if ( isset( $args['desc'] ) && $args['desc'] ) { |
|
3050 | + if ( isset( $args['desc_tip'] ) && $args['desc_tip'] ) { |
|
3051 | + $description = $this->desc_tip( $args['desc'] ); |
|
3052 | + } else { |
|
3053 | + $description = '<span class="description">' . wp_kses_post( $args['desc'] ) . '</span>'; |
|
3054 | + } |
|
3055 | + } |
|
3056 | + |
|
3057 | + return $description; |
|
3058 | + } |
|
3059 | + |
|
3060 | + /** |
|
3061 | + * Get the widget input title html. |
|
3062 | + * |
|
3063 | + * @param $args |
|
3064 | + * |
|
3065 | + * @return string |
|
3066 | + */ |
|
3067 | + public function widget_field_title( $args ) { |
|
3068 | + |
|
3069 | + $title = ''; |
|
3070 | + if ( isset( $args['title'] ) && $args['title'] ) { |
|
3071 | + if ( isset( $args['icon'] ) && $args['icon'] ) { |
|
3072 | + $title = self::get_widget_icon( $args['icon'], $args['title'] ); |
|
3073 | + } else { |
|
3074 | + $title = esc_attr($args['title']); |
|
3075 | + } |
|
3076 | + } |
|
3077 | + |
|
3078 | + return $title; |
|
3079 | + } |
|
3080 | + |
|
3081 | + /** |
|
3082 | + * Get the tool tip html. |
|
3083 | + * |
|
3084 | + * @param $tip |
|
3085 | + * @param bool $allow_html |
|
3086 | + * |
|
3087 | + * @return string |
|
3088 | + */ |
|
3089 | + function desc_tip( $tip, $allow_html = false ) { |
|
3090 | + if ( $allow_html ) { |
|
3091 | + $tip = $this->sanitize_tooltip( $tip ); |
|
3092 | + } else { |
|
3093 | + $tip = esc_attr( $tip ); |
|
3094 | + } |
|
3095 | + |
|
3096 | + return '<span class="gd-help-tip dashicons dashicons-editor-help" title="' . $tip . '"></span>'; |
|
3097 | + } |
|
3098 | + |
|
3099 | + /** |
|
3100 | + * Sanitize a string destined to be a tooltip. |
|
3101 | + * |
|
3102 | + * @param string $var |
|
3103 | + * |
|
3104 | + * @return string |
|
3105 | + */ |
|
3106 | + public function sanitize_tooltip( $var ) { |
|
3107 | + return htmlspecialchars( wp_kses( html_entity_decode( $var ), array( |
|
3108 | + 'br' => array(), |
|
3109 | + 'em' => array(), |
|
3110 | + 'strong' => array(), |
|
3111 | + 'small' => array(), |
|
3112 | + 'span' => array(), |
|
3113 | + 'ul' => array(), |
|
3114 | + 'li' => array(), |
|
3115 | + 'ol' => array(), |
|
3116 | + 'p' => array(), |
|
3117 | + ) ) ); |
|
3118 | + } |
|
3119 | + |
|
3120 | + /** |
|
3121 | + * Processing widget options on save |
|
3122 | + * |
|
3123 | + * @param array $new_instance The new options |
|
3124 | + * @param array $old_instance The previous options |
|
3125 | + * |
|
3126 | + * @return array |
|
3127 | + * @todo we should add some sanitation here. |
|
3128 | + */ |
|
3129 | + public function update( $new_instance, $old_instance ) { |
|
3130 | + |
|
3131 | + //save the widget |
|
3132 | + $instance = array_merge( (array) $old_instance, (array) $new_instance ); |
|
3133 | + |
|
3134 | + // set widget instance |
|
3135 | + $this->instance = $instance; |
|
3136 | + |
|
3137 | + if ( empty( $this->arguments ) ) { |
|
3138 | + $this->get_arguments(); |
|
3139 | + } |
|
3140 | + |
|
3141 | + // check for checkboxes |
|
3142 | + if ( ! empty( $this->arguments ) ) { |
|
3143 | + foreach ( $this->arguments as $argument ) { |
|
3144 | + if ( isset( $argument['type'] ) && $argument['type'] == 'checkbox' && ! isset( $new_instance[ $argument['name'] ] ) ) { |
|
3145 | + $instance[ $argument['name'] ] = '0'; |
|
3146 | + } |
|
3147 | + } |
|
3148 | + } |
|
3149 | + |
|
3150 | + return $instance; |
|
3151 | + } |
|
3152 | + |
|
3153 | + /** |
|
3154 | + * Checks if the current call is a ajax call to get the block content. |
|
3155 | + * |
|
3156 | + * This can be used in your widget to return different content as the block content. |
|
3157 | + * |
|
3158 | + * @since 1.0.3 |
|
3159 | + * @return bool |
|
3160 | + */ |
|
3161 | + public function is_block_content_call() { |
|
3162 | + $result = false; |
|
3163 | + if ( wp_doing_ajax() && isset( $_REQUEST['action'] ) && $_REQUEST['action'] == 'super_duper_output_shortcode' ) { |
|
3164 | + $result = true; |
|
3165 | + } |
|
3166 | + |
|
3167 | + return $result; |
|
3168 | + } |
|
3169 | + |
|
3170 | + /** |
|
3171 | + * Get an instance hash that will be unique to the type and settings. |
|
3172 | + * |
|
3173 | + * @since 1.0.20 |
|
3174 | + * @return string |
|
3175 | + */ |
|
3176 | + public function get_instance_hash(){ |
|
3177 | + $instance_string = $this->base_id.serialize($this->instance); |
|
3178 | + return hash('crc32b',$instance_string); |
|
3179 | + } |
|
3180 | + |
|
3181 | + /** |
|
3182 | + * Generate and return inline styles from CSS rules that will match the unique class of the instance. |
|
3183 | + * |
|
3184 | + * @param array $rules |
|
3185 | + * |
|
3186 | + * @since 1.0.20 |
|
3187 | + * @return string |
|
3188 | + */ |
|
3189 | + public function get_instance_style($rules = array()){ |
|
3190 | + $css = ''; |
|
3191 | + |
|
3192 | + if(!empty($rules)){ |
|
3193 | + $rules = array_unique($rules); |
|
3194 | + $instance_hash = $this->get_instance_hash(); |
|
3195 | + $css .= "<style>"; |
|
3196 | + foreach($rules as $rule){ |
|
3197 | + $css .= ".sdel-$instance_hash $rule"; |
|
3198 | + } |
|
3199 | + $css .= "</style>"; |
|
3200 | + } |
|
3201 | + |
|
3202 | + |
|
3203 | + return $css; |
|
3204 | + |
|
3205 | + } |
|
3206 | + |
|
3207 | + } |
|
3208 | 3208 | |
3209 | 3209 | } |
@@ -17,45 +17,45 @@ discard block |
||
17 | 17 | */ |
18 | 18 | class BP_GetPaid_Component extends BP_Component { |
19 | 19 | |
20 | - /** |
|
21 | - * Start the component setup process. |
|
22 | - * |
|
23 | - * @since 2.1.5 |
|
24 | - */ |
|
25 | - public function __construct() { |
|
26 | - parent::start( |
|
27 | - 'getpaid', |
|
28 | - 'GetPaid', |
|
29 | - buddypress()->plugin_dir, |
|
30 | - array( |
|
31 | - 'adminbar_myaccount_order' => 30, |
|
32 | - ) |
|
33 | - ); |
|
34 | - } |
|
20 | + /** |
|
21 | + * Start the component setup process. |
|
22 | + * |
|
23 | + * @since 2.1.5 |
|
24 | + */ |
|
25 | + public function __construct() { |
|
26 | + parent::start( |
|
27 | + 'getpaid', |
|
28 | + 'GetPaid', |
|
29 | + buddypress()->plugin_dir, |
|
30 | + array( |
|
31 | + 'adminbar_myaccount_order' => 30, |
|
32 | + ) |
|
33 | + ); |
|
34 | + } |
|
35 | 35 | |
36 | 36 | /** |
37 | - * Set up component global variables. |
|
38 | - * |
|
39 | - * @since 2.1.5 |
|
40 | - * |
|
41 | - * |
|
42 | - * @param array $args { |
|
43 | - * All values are optional. |
|
44 | - * @type string $slug The component slug. Used to construct certain URLs, such as 'friends' in |
|
45 | - * http://example.com/members/joe/friends/. Default: the value of $this->id. |
|
46 | - * @type string $root_slug The component root slug. Note that this value is generally unused if the |
|
47 | - * component has a root directory (the slug will be overridden by the |
|
48 | - * post_name of the directory page). Default: the slug of the directory page |
|
49 | - * if one is found, otherwise an empty string. |
|
50 | - * @type bool $has_directory Set to true if the component requires an associated WordPress page. |
|
51 | - * @type callable $notification_callback Optional. The callable function that formats the component's notifications. |
|
52 | - * @type string $search_term Optional. The placeholder text in the component directory search box. Eg, |
|
53 | - * 'Search Groups...'. |
|
54 | - * @type array $global_tables Optional. An array of database table names. |
|
55 | - * @type array $meta_tables Optional. An array of metadata table names. |
|
56 | - * } |
|
57 | - */ |
|
58 | - public function setup_globals( $args = array() ) { |
|
37 | + * Set up component global variables. |
|
38 | + * |
|
39 | + * @since 2.1.5 |
|
40 | + * |
|
41 | + * |
|
42 | + * @param array $args { |
|
43 | + * All values are optional. |
|
44 | + * @type string $slug The component slug. Used to construct certain URLs, such as 'friends' in |
|
45 | + * http://example.com/members/joe/friends/. Default: the value of $this->id. |
|
46 | + * @type string $root_slug The component root slug. Note that this value is generally unused if the |
|
47 | + * component has a root directory (the slug will be overridden by the |
|
48 | + * post_name of the directory page). Default: the slug of the directory page |
|
49 | + * if one is found, otherwise an empty string. |
|
50 | + * @type bool $has_directory Set to true if the component requires an associated WordPress page. |
|
51 | + * @type callable $notification_callback Optional. The callable function that formats the component's notifications. |
|
52 | + * @type string $search_term Optional. The placeholder text in the component directory search box. Eg, |
|
53 | + * 'Search Groups...'. |
|
54 | + * @type array $global_tables Optional. An array of database table names. |
|
55 | + * @type array $meta_tables Optional. An array of metadata table names. |
|
56 | + * } |
|
57 | + */ |
|
58 | + public function setup_globals( $args = array() ) { |
|
59 | 59 | parent::setup_globals( |
60 | 60 | array( |
61 | 61 | 'id' => 'getpaid', |
@@ -64,21 +64,21 @@ discard block |
||
64 | 64 | 'has_directory' => false |
65 | 65 | ) |
66 | 66 | ); |
67 | - } |
|
68 | - |
|
69 | - /** |
|
70 | - * Set up component navigation. |
|
71 | - * |
|
72 | - * @since 2.1.5 |
|
73 | - * |
|
74 | - * @see BP_Component::setup_nav() for a description of arguments. |
|
75 | - * |
|
76 | - * @param array $main_nav Optional. See BP_Component::setup_nav() for description. |
|
77 | - * @param array $sub_nav Optional. See BP_Component::setup_nav() for description. |
|
78 | - */ |
|
79 | - public function setup_nav( $main_nav = array(), $sub_nav = array() ) { |
|
80 | - |
|
81 | - // Abort if the integration is inactive. |
|
67 | + } |
|
68 | + |
|
69 | + /** |
|
70 | + * Set up component navigation. |
|
71 | + * |
|
72 | + * @since 2.1.5 |
|
73 | + * |
|
74 | + * @see BP_Component::setup_nav() for a description of arguments. |
|
75 | + * |
|
76 | + * @param array $main_nav Optional. See BP_Component::setup_nav() for description. |
|
77 | + * @param array $sub_nav Optional. See BP_Component::setup_nav() for description. |
|
78 | + */ |
|
79 | + public function setup_nav( $main_nav = array(), $sub_nav = array() ) { |
|
80 | + |
|
81 | + // Abort if the integration is inactive. |
|
82 | 82 | if ( ! getpaid_is_buddypress_integration_active() || ! is_user_logged_in() ) { |
83 | 83 | return; |
84 | 84 | } |
@@ -88,25 +88,25 @@ discard block |
||
88 | 88 | return; |
89 | 89 | } |
90 | 90 | |
91 | - // Determine user to use. |
|
92 | - $user_domain = bp_loggedin_user_domain(); |
|
93 | - $slug = 'getpaid'; |
|
94 | - $payments_link = trailingslashit( $user_domain . $slug ); |
|
95 | - |
|
96 | - // Add 'Payments' to the main navigation. |
|
97 | - $main_nav = array( |
|
98 | - 'name' => _x( 'Billing', 'BuddyPress profile payments screen nav', 'invoicing' ), |
|
99 | - 'slug' => $slug, |
|
100 | - 'position' => apply_filters( 'wpinv_bp_nav_position', wpinv_get_option( 'wpinv_menu_position', 91 ), $slug ), |
|
101 | - 'screen_function' => array( $this, 'display_current_tab' ), |
|
102 | - 'default_subnav_slug' => 'gp-edit-address', |
|
91 | + // Determine user to use. |
|
92 | + $user_domain = bp_loggedin_user_domain(); |
|
93 | + $slug = 'getpaid'; |
|
94 | + $payments_link = trailingslashit( $user_domain . $slug ); |
|
95 | + |
|
96 | + // Add 'Payments' to the main navigation. |
|
97 | + $main_nav = array( |
|
98 | + 'name' => _x( 'Billing', 'BuddyPress profile payments screen nav', 'invoicing' ), |
|
99 | + 'slug' => $slug, |
|
100 | + 'position' => apply_filters( 'wpinv_bp_nav_position', wpinv_get_option( 'wpinv_menu_position', 91 ), $slug ), |
|
101 | + 'screen_function' => array( $this, 'display_current_tab' ), |
|
102 | + 'default_subnav_slug' => 'gp-edit-address', |
|
103 | 103 | 'show_for_displayed_user' => false, |
104 | - 'item_css_id' => $this->id, |
|
105 | - 'parent_url' => $user_domain, |
|
106 | - 'parent_slug' => buddypress()->slug, |
|
107 | - ); |
|
104 | + 'item_css_id' => $this->id, |
|
105 | + 'parent_url' => $user_domain, |
|
106 | + 'parent_slug' => buddypress()->slug, |
|
107 | + ); |
|
108 | 108 | |
109 | - // Add the subnav items to the payments nav item if we are using a theme that supports this. |
|
109 | + // Add the subnav items to the payments nav item if we are using a theme that supports this. |
|
110 | 110 | foreach ( getpaid_get_user_content_tabs() as $_slug => $tab ) { |
111 | 111 | |
112 | 112 | $sub_nav[] = array( |
@@ -116,8 +116,8 @@ discard block |
||
116 | 116 | 'parent_slug' => $slug, |
117 | 117 | 'position' => 10, |
118 | 118 | 'screen_function' => function() use ( $tab ) { |
119 | - $GLOBALS['getpaid_bp_current_tab'] = $tab; |
|
120 | - $this->display_current_tab(); |
|
119 | + $GLOBALS['getpaid_bp_current_tab'] = $tab; |
|
120 | + $this->display_current_tab(); |
|
121 | 121 | }, |
122 | 122 | 'show_for_displayed_user' => false, |
123 | 123 | 'item_css_id' => "getpaid-bp-$_slug", |
@@ -125,27 +125,27 @@ discard block |
||
125 | 125 | |
126 | 126 | } |
127 | 127 | |
128 | - parent::setup_nav( $main_nav, $sub_nav ); |
|
129 | - } |
|
130 | - |
|
131 | - /** |
|
132 | - * Set up the component entries in the WordPress Admin Bar. |
|
133 | - * |
|
134 | - * @since 2.1.5 |
|
135 | - * |
|
136 | - * @see BP_Component::setup_nav() for a description of the $wp_admin_nav |
|
137 | - * parameter array. |
|
138 | - * |
|
139 | - * @param array $wp_admin_nav See BP_Component::setup_admin_bar() for a |
|
140 | - * description. |
|
141 | - */ |
|
142 | - public function setup_admin_bar( $wp_admin_nav = array() ) { |
|
143 | - |
|
144 | - // Menus for logged in user. |
|
145 | - if ( is_user_logged_in() ) { |
|
128 | + parent::setup_nav( $main_nav, $sub_nav ); |
|
129 | + } |
|
146 | 130 | |
147 | - // Setup the logged in user variables. |
|
148 | - $payments_link = trailingslashit( bp_loggedin_user_domain() . 'getpaid/' ); |
|
131 | + /** |
|
132 | + * Set up the component entries in the WordPress Admin Bar. |
|
133 | + * |
|
134 | + * @since 2.1.5 |
|
135 | + * |
|
136 | + * @see BP_Component::setup_nav() for a description of the $wp_admin_nav |
|
137 | + * parameter array. |
|
138 | + * |
|
139 | + * @param array $wp_admin_nav See BP_Component::setup_admin_bar() for a |
|
140 | + * description. |
|
141 | + */ |
|
142 | + public function setup_admin_bar( $wp_admin_nav = array() ) { |
|
143 | + |
|
144 | + // Menus for logged in user. |
|
145 | + if ( is_user_logged_in() ) { |
|
146 | + |
|
147 | + // Setup the logged in user variables. |
|
148 | + $payments_link = trailingslashit( bp_loggedin_user_domain() . 'getpaid/' ); |
|
149 | 149 | |
150 | 150 | // Add the "Payments" sub menu. |
151 | 151 | $wp_admin_nav[] = array( |
@@ -167,50 +167,50 @@ discard block |
||
167 | 167 | |
168 | 168 | } |
169 | 169 | |
170 | - } |
|
171 | - |
|
172 | - parent::setup_admin_bar( $wp_admin_nav ); |
|
173 | - } |
|
170 | + } |
|
174 | 171 | |
175 | - /** |
|
176 | - * Retrieves the current tab. |
|
177 | - * |
|
178 | - * @since 2.1.5 |
|
179 | - */ |
|
180 | - public function get_current_tab() { |
|
181 | - global $getpaid_bp_current_tab; |
|
172 | + parent::setup_admin_bar( $wp_admin_nav ); |
|
173 | + } |
|
182 | 174 | |
183 | - if ( empty( $getpaid_bp_current_tab ) ) { |
|
184 | - return array( |
|
185 | - 'label' => __( 'Invoices', 'invoicing' ), |
|
186 | - 'content' => '[wpinv_history]', |
|
187 | - 'icon' => 'fas fa-file-invoice', |
|
188 | - ); |
|
189 | - } |
|
175 | + /** |
|
176 | + * Retrieves the current tab. |
|
177 | + * |
|
178 | + * @since 2.1.5 |
|
179 | + */ |
|
180 | + public function get_current_tab() { |
|
181 | + global $getpaid_bp_current_tab; |
|
182 | + |
|
183 | + if ( empty( $getpaid_bp_current_tab ) ) { |
|
184 | + return array( |
|
185 | + 'label' => __( 'Invoices', 'invoicing' ), |
|
186 | + 'content' => '[wpinv_history]', |
|
187 | + 'icon' => 'fas fa-file-invoice', |
|
188 | + ); |
|
189 | + } |
|
190 | 190 | |
191 | - return $getpaid_bp_current_tab; |
|
192 | - } |
|
191 | + return $getpaid_bp_current_tab; |
|
192 | + } |
|
193 | 193 | |
194 | - /** |
|
195 | - * Displays the current tab. |
|
196 | - * |
|
197 | - * @since 2.1.5 |
|
198 | - */ |
|
199 | - public function display_current_tab() { |
|
194 | + /** |
|
195 | + * Displays the current tab. |
|
196 | + * |
|
197 | + * @since 2.1.5 |
|
198 | + */ |
|
199 | + public function display_current_tab() { |
|
200 | 200 | |
201 | - add_action( 'bp_template_content', array( $this, 'handle_display_current_tab' ) ); |
|
202 | - $template = apply_filters( 'bp_core_template_plugin', 'members/single/plugins' ); |
|
201 | + add_action( 'bp_template_content', array( $this, 'handle_display_current_tab' ) ); |
|
202 | + $template = apply_filters( 'bp_core_template_plugin', 'members/single/plugins' ); |
|
203 | 203 | |
204 | 204 | bp_core_load_template( apply_filters( 'wpinv_bp_core_template_plugin', $template ) ); |
205 | - } |
|
206 | - |
|
207 | - /** |
|
208 | - * Handles the actual display of the current tab. |
|
209 | - * |
|
210 | - * @since 2.1.5 |
|
211 | - */ |
|
212 | - public function handle_display_current_tab() { |
|
213 | - echo getpaid_prepare_user_content_tab( $this->get_current_tab() ); |
|
214 | - } |
|
205 | + } |
|
206 | + |
|
207 | + /** |
|
208 | + * Handles the actual display of the current tab. |
|
209 | + * |
|
210 | + * @since 2.1.5 |
|
211 | + */ |
|
212 | + public function handle_display_current_tab() { |
|
213 | + echo getpaid_prepare_user_content_tab( $this->get_current_tab() ); |
|
214 | + } |
|
215 | 215 | |
216 | 216 | } |
@@ -6,7 +6,7 @@ discard block |
||
6 | 6 | if ( ! defined( 'ABSPATH' ) ) exit; |
7 | 7 | |
8 | 8 | if ( ! class_exists( 'WP_List_Table' ) ) { |
9 | - include_once ABSPATH . 'wp-admin/includes/class-wp-list-table.php'; |
|
9 | + include_once ABSPATH . 'wp-admin/includes/class-wp-list-table.php'; |
|
10 | 10 | } |
11 | 11 | |
12 | 12 | /** |
@@ -14,387 +14,387 @@ discard block |
||
14 | 14 | */ |
15 | 15 | class WPInv_Subscriptions_List_Table extends WP_List_Table { |
16 | 16 | |
17 | - /** |
|
18 | - * URL of this page |
|
19 | - * |
|
20 | - * @var string |
|
21 | - * @since 1.0.19 |
|
22 | - */ |
|
23 | - public $base_url; |
|
24 | - |
|
25 | - /** |
|
26 | - * Query |
|
27 | - * |
|
28 | - * @var GetPaid_Subscriptions_Query |
|
29 | - * @since 1.0.19 |
|
30 | - */ |
|
31 | - public $query; |
|
32 | - |
|
33 | - /** |
|
34 | - * Total subscriptions |
|
35 | - * |
|
36 | - * @var string |
|
37 | - * @since 1.0.0 |
|
38 | - */ |
|
39 | - public $total_count; |
|
40 | - |
|
41 | - /** |
|
42 | - * Current status subscriptions |
|
43 | - * |
|
44 | - * @var string |
|
45 | - * @since 1.0.0 |
|
46 | - */ |
|
47 | - public $current_total_count; |
|
48 | - |
|
49 | - /** |
|
50 | - * Status counts |
|
51 | - * |
|
52 | - * @var array |
|
53 | - * @since 1.0.19 |
|
54 | - */ |
|
55 | - public $status_counts; |
|
56 | - |
|
57 | - /** |
|
58 | - * Number of results to show per page |
|
59 | - * |
|
60 | - * @var int |
|
61 | - * @since 1.0.0 |
|
62 | - */ |
|
63 | - public $per_page = 10; |
|
64 | - |
|
65 | - /** |
|
66 | - * Constructor function. |
|
67 | - */ |
|
68 | - public function __construct() { |
|
69 | - |
|
70 | - parent::__construct( |
|
71 | - array( |
|
72 | - 'singular' => 'subscription', |
|
73 | - 'plural' => 'subscriptions', |
|
74 | - ) |
|
75 | - ); |
|
76 | - |
|
77 | - $this->process_bulk_action(); |
|
78 | - |
|
79 | - $this->prepare_query(); |
|
80 | - |
|
81 | - $this->base_url = remove_query_arg( 'status' ); |
|
82 | - |
|
83 | - } |
|
84 | - |
|
85 | - /** |
|
86 | - * Prepares the display query |
|
87 | - */ |
|
88 | - public function prepare_query() { |
|
89 | - |
|
90 | - // Prepare query args. |
|
91 | - $query = array( |
|
92 | - 'number' => $this->per_page, |
|
93 | - 'paged' => $this->get_paged(), |
|
94 | - 'status' => ( isset( $_GET['status'] ) && array_key_exists( $_GET['status'], getpaid_get_subscription_statuses() ) ) ? $_GET['status'] : 'all', |
|
95 | - 'orderby' => ( isset( $_GET['orderby'] ) ) ? $_GET['orderby'] : 'id', |
|
96 | - 'order' => ( isset( $_GET['order'] ) ) ? $_GET['order'] : 'DESC', |
|
97 | - ); |
|
98 | - |
|
99 | - // Prepare class properties. |
|
100 | - $this->query = new GetPaid_Subscriptions_Query( $query ); |
|
101 | - $this->total_count = $this->query->get_total(); |
|
102 | - $this->current_total_count = $this->query->get_total(); |
|
103 | - $this->items = $this->query->get_results(); |
|
104 | - $this->status_counts = getpaid_get_subscription_status_counts( $query ); |
|
105 | - |
|
106 | - if ( 'all' != $query['status'] ) { |
|
107 | - unset( $query['status'] ); |
|
108 | - $this->total_count = getpaid_get_subscriptions( $query, 'count' ); |
|
109 | - } |
|
110 | - |
|
111 | - } |
|
112 | - |
|
113 | - /** |
|
114 | - * Gets the list of views available on this table. |
|
115 | - * |
|
116 | - * The format is an associative array: |
|
117 | - * - `'id' => 'link'` |
|
118 | - * |
|
119 | - * @since 1.0.0 |
|
120 | - * |
|
121 | - * @return array |
|
122 | - */ |
|
123 | - public function get_views() { |
|
124 | - |
|
125 | - $current = isset( $_GET['status'] ) ? $_GET['status'] : 'all'; |
|
126 | - $views = array( |
|
127 | - |
|
128 | - 'all' => sprintf( |
|
129 | - '<a href="%s" %s>%s <span class="count">(%d)</span></a>', |
|
130 | - esc_url( add_query_arg( 'status', false, $this->base_url ) ), |
|
131 | - $current === 'all' ? ' class="current"' : '', |
|
132 | - __('All','invoicing' ), |
|
133 | - $this->total_count |
|
134 | - ) |
|
135 | - |
|
136 | - ); |
|
137 | - |
|
138 | - foreach ( array_filter( $this->status_counts ) as $status => $count ) { |
|
139 | - |
|
140 | - $views[ $status ] = sprintf( |
|
141 | - '<a href="%s" %s>%s <span class="count">(%d)</span></a>', |
|
142 | - esc_url( add_query_arg( 'status', urlencode( $status ), $this->base_url ) ), |
|
143 | - $current === $status ? ' class="current"' : '', |
|
144 | - sanitize_text_field( getpaid_get_subscription_status_label( $status ) ), |
|
145 | - $count |
|
146 | - ); |
|
147 | - |
|
148 | - } |
|
149 | - |
|
150 | - return $views; |
|
151 | - |
|
152 | - } |
|
153 | - |
|
154 | - /** |
|
155 | - * Render most columns |
|
156 | - * |
|
157 | - * @access private |
|
158 | - * @since 1.0.0 |
|
159 | - * @return string |
|
160 | - */ |
|
161 | - public function column_default( $item, $column_name ) { |
|
162 | - return apply_filters( "getpaid_subscriptions_table_column_$column_name", $item->$column_name ); |
|
163 | - } |
|
164 | - |
|
165 | - /** |
|
166 | - * This is how checkbox column renders. |
|
167 | - * |
|
168 | - * @param WPInv_Subscription $item |
|
169 | - * @return string |
|
170 | - */ |
|
171 | - public function column_cb( $item ) { |
|
172 | - return sprintf( '<input type="checkbox" name="id[]" value="%s" />', esc_html( $item->get_id() ) ); |
|
173 | - } |
|
174 | - |
|
175 | - /** |
|
176 | - * Status column |
|
177 | - * |
|
178 | - * @param WPInv_Subscription $item |
|
179 | - * @since 1.0.0 |
|
180 | - * @return string |
|
181 | - */ |
|
182 | - public function column_status( $item ) { |
|
183 | - return $item->get_status_label_html(); |
|
184 | - } |
|
185 | - |
|
186 | - /** |
|
187 | - * Subscription column |
|
188 | - * |
|
189 | - * @param WPInv_Subscription $item |
|
190 | - * @since 1.0.0 |
|
191 | - * @return string |
|
192 | - */ |
|
193 | - public function column_subscription( $item ) { |
|
194 | - |
|
195 | - $username = __( '(Missing User)', 'invoicing' ); |
|
196 | - |
|
197 | - $user = get_userdata( $item->get_customer_id() ); |
|
198 | - if ( $user ) { |
|
199 | - |
|
200 | - $username = sprintf( |
|
201 | - '<a href="user-edit.php?user_id=%s">%s</a>', |
|
202 | - absint( $user->ID ), |
|
203 | - ! empty( $user->display_name ) ? sanitize_text_field( $user->display_name ) : sanitize_email( $user->user_email ) |
|
204 | - ); |
|
205 | - |
|
206 | - } |
|
207 | - |
|
208 | - // translators: $1: is opening link, $2: is subscription id number, $3: is closing link tag, $4: is user's name |
|
209 | - $column_content = sprintf( |
|
210 | - _x( '%1$s#%2$s%3$s for %4$s', 'Subscription title on admin table. (e.g.: #211 for John Doe)', 'invoicing' ), |
|
211 | - '<a href="' . esc_url( admin_url( 'admin.php?page=wpinv-subscriptions&id=' . absint( $item->get_id() ) ) ) . '">', |
|
212 | - '<strong>' . esc_attr( $item->get_id() ) . '</strong>', '</a>', |
|
213 | - $username |
|
214 | - ); |
|
215 | - |
|
216 | - $row_actions = array(); |
|
217 | - |
|
218 | - // View subscription. |
|
219 | - $view_url = esc_url( add_query_arg( 'id', $item->get_id(), admin_url( 'admin.php?page=wpinv-subscriptions' ) )); |
|
220 | - $row_actions['view'] = '<a href="' . $view_url . '">' . __( 'View Subscription', 'invoicing' ) . '</a>'; |
|
221 | - |
|
222 | - // View invoice. |
|
223 | - $invoice = get_post( $item->get_parent_invoice_id() ); |
|
224 | - |
|
225 | - if ( ! empty( $invoice ) ) { |
|
226 | - $invoice_url = get_edit_post_link( $invoice ); |
|
227 | - $row_actions['invoice'] = '<a href="' . $invoice_url . '">' . __( 'View Invoice', 'invoicing' ) . '</a>'; |
|
228 | - } |
|
229 | - |
|
230 | - $delete_url = esc_url( |
|
231 | - wp_nonce_url( |
|
232 | - add_query_arg( |
|
233 | - array( |
|
234 | - 'getpaid-admin-action' => 'subscription_manual_delete', |
|
235 | - 'id' => $item->get_id(), |
|
236 | - ) |
|
237 | - ), |
|
238 | - 'getpaid-nonce', |
|
239 | - 'getpaid-nonce' |
|
240 | - ) |
|
241 | - ); |
|
242 | - $row_actions['delete'] = '<a class="text-danger" href="' . $delete_url . '">' . __( 'Delete Subscription', 'invoicing' ) . '</a>'; |
|
243 | - |
|
244 | - $row_actions = $this->row_actions( apply_filters( 'getpaid_subscription_table_row_actions', $row_actions, $item ) ); |
|
245 | - |
|
246 | - return "<strong>$column_content</strong>" . $this->column_amount( $item ) . $row_actions; |
|
247 | - } |
|
248 | - |
|
249 | - /** |
|
250 | - * Renewal date column |
|
251 | - * |
|
252 | - * @param WPInv_Subscription $item |
|
253 | - * @since 1.0.0 |
|
254 | - * @return string |
|
255 | - */ |
|
256 | - public function column_renewal_date( $item ) { |
|
257 | - return getpaid_format_date_value( $item->get_expiration() ); |
|
258 | - } |
|
259 | - |
|
260 | - /** |
|
261 | - * Start date column |
|
262 | - * |
|
263 | - * @param WPInv_Subscription $item |
|
264 | - * @since 1.0.0 |
|
265 | - * @return string |
|
266 | - */ |
|
267 | - public function column_start_date( $item ) { |
|
268 | - return getpaid_format_date_value( $item->get_date_created() ); |
|
269 | - } |
|
270 | - |
|
271 | - /** |
|
272 | - * Amount column |
|
273 | - * |
|
274 | - * @param WPInv_Subscription $item |
|
275 | - * @since 1.0.19 |
|
276 | - * @return string |
|
277 | - */ |
|
278 | - public function column_amount( $item ) { |
|
279 | - $amount = getpaid_get_formatted_subscription_amount( $item ); |
|
280 | - return "<span class='text-muted form-text mt-2 mb-2'>$amount</span>"; |
|
281 | - } |
|
282 | - |
|
283 | - /** |
|
284 | - * Billing Times column |
|
285 | - * |
|
286 | - * @param WPInv_Subscription $item |
|
287 | - * @since 1.0.0 |
|
288 | - * @return string |
|
289 | - */ |
|
290 | - public function column_renewals( $item ) { |
|
291 | - $max_bills = $item->get_bill_times(); |
|
292 | - return $item->get_times_billed() . ' / ' . ( empty( $max_bills ) ? "∞" : $max_bills ); |
|
293 | - } |
|
294 | - |
|
295 | - /** |
|
296 | - * Product ID column |
|
297 | - * |
|
298 | - * @param WPInv_Subscription $item |
|
299 | - * @since 1.0.0 |
|
300 | - * @return string |
|
301 | - */ |
|
302 | - public function column_item( $item ) { |
|
303 | - $_item = get_post( $item->get_product_id() ); |
|
304 | - |
|
305 | - if ( ! empty( $_item ) ) { |
|
306 | - $link = get_edit_post_link( $_item ); |
|
307 | - $link = esc_url( $link ); |
|
308 | - $name = esc_html( get_the_title( $_item ) ); |
|
309 | - return "<a href='$link'>$name</a>"; |
|
310 | - } else { |
|
311 | - return sprintf( __( 'Item #%s', 'invoicing' ), $item->get_product_id() ); |
|
312 | - } |
|
313 | - |
|
314 | - } |
|
315 | - |
|
316 | - /** |
|
317 | - * Retrieve the current page number |
|
318 | - * |
|
319 | - * @return int |
|
320 | - */ |
|
321 | - public function get_paged() { |
|
322 | - return isset( $_GET['paged'] ) ? absint( $_GET['paged'] ) : 1; |
|
323 | - } |
|
324 | - |
|
325 | - /** |
|
326 | - * Setup the final data for the table |
|
327 | - * |
|
328 | - */ |
|
329 | - public function prepare_items() { |
|
330 | - |
|
331 | - $columns = $this->get_columns(); |
|
332 | - $hidden = array(); |
|
333 | - $sortable = $this->get_sortable_columns(); |
|
334 | - |
|
335 | - $this->_column_headers = array( $columns, $hidden, $sortable ); |
|
336 | - |
|
337 | - $this->set_pagination_args( |
|
338 | - array( |
|
339 | - 'total_items' => $this->current_total_count, |
|
340 | - 'per_page' => $this->per_page, |
|
341 | - 'total_pages' => ceil( $this->current_total_count / $this->per_page ) |
|
342 | - ) |
|
343 | - ); |
|
344 | - } |
|
345 | - |
|
346 | - /** |
|
347 | - * Table columns |
|
348 | - * |
|
349 | - * @return array |
|
350 | - */ |
|
351 | - public function get_columns(){ |
|
352 | - $columns = array( |
|
353 | - 'cb' => '<input type="checkbox" />', |
|
354 | - 'subscription' => __( 'Subscription', 'invoicing' ), |
|
355 | - 'start_date' => __( 'Start Date', 'invoicing' ), |
|
356 | - 'renewal_date' => __( 'Next Payment', 'invoicing' ), |
|
357 | - 'renewals' => __( 'Payments', 'invoicing' ), |
|
358 | - 'item' => __( 'Item', 'invoicing' ), |
|
359 | - 'status' => __( 'Status', 'invoicing' ), |
|
360 | - ); |
|
361 | - |
|
362 | - return apply_filters( 'manage_getpaid_subscriptions_table_columns', $columns ); |
|
363 | - } |
|
364 | - |
|
365 | - /** |
|
366 | - * Sortable table columns. |
|
367 | - * |
|
368 | - * @return array |
|
369 | - */ |
|
370 | - public function get_sortable_columns() { |
|
371 | - $sortable = array( |
|
372 | - 'subscription' => array( 'id', true ), |
|
373 | - 'start_date' => array( 'created', true ), |
|
374 | - 'renewal_date' => array( 'expiration', true ), |
|
375 | - 'renewals' => array( 'bill_times', true ), |
|
376 | - 'item' => array( 'product_id', true ), |
|
377 | - 'status' => array( 'status', true ), |
|
378 | - ); |
|
379 | - |
|
380 | - return apply_filters( 'manage_getpaid_subscriptions_sortable_table_columns', $sortable ); |
|
381 | - } |
|
382 | - |
|
383 | - /** |
|
384 | - * Whether the table has items to display or not |
|
385 | - * |
|
386 | - * @return bool |
|
387 | - */ |
|
388 | - public function has_items() { |
|
389 | - return ! empty( $this->current_total_count ); |
|
390 | - } |
|
391 | - |
|
392 | - /** |
|
393 | - * Processes bulk actions. |
|
394 | - * |
|
395 | - */ |
|
396 | - public function process_bulk_action() { |
|
397 | - |
|
398 | - } |
|
17 | + /** |
|
18 | + * URL of this page |
|
19 | + * |
|
20 | + * @var string |
|
21 | + * @since 1.0.19 |
|
22 | + */ |
|
23 | + public $base_url; |
|
24 | + |
|
25 | + /** |
|
26 | + * Query |
|
27 | + * |
|
28 | + * @var GetPaid_Subscriptions_Query |
|
29 | + * @since 1.0.19 |
|
30 | + */ |
|
31 | + public $query; |
|
32 | + |
|
33 | + /** |
|
34 | + * Total subscriptions |
|
35 | + * |
|
36 | + * @var string |
|
37 | + * @since 1.0.0 |
|
38 | + */ |
|
39 | + public $total_count; |
|
40 | + |
|
41 | + /** |
|
42 | + * Current status subscriptions |
|
43 | + * |
|
44 | + * @var string |
|
45 | + * @since 1.0.0 |
|
46 | + */ |
|
47 | + public $current_total_count; |
|
48 | + |
|
49 | + /** |
|
50 | + * Status counts |
|
51 | + * |
|
52 | + * @var array |
|
53 | + * @since 1.0.19 |
|
54 | + */ |
|
55 | + public $status_counts; |
|
56 | + |
|
57 | + /** |
|
58 | + * Number of results to show per page |
|
59 | + * |
|
60 | + * @var int |
|
61 | + * @since 1.0.0 |
|
62 | + */ |
|
63 | + public $per_page = 10; |
|
64 | + |
|
65 | + /** |
|
66 | + * Constructor function. |
|
67 | + */ |
|
68 | + public function __construct() { |
|
69 | + |
|
70 | + parent::__construct( |
|
71 | + array( |
|
72 | + 'singular' => 'subscription', |
|
73 | + 'plural' => 'subscriptions', |
|
74 | + ) |
|
75 | + ); |
|
76 | + |
|
77 | + $this->process_bulk_action(); |
|
78 | + |
|
79 | + $this->prepare_query(); |
|
80 | + |
|
81 | + $this->base_url = remove_query_arg( 'status' ); |
|
82 | + |
|
83 | + } |
|
84 | + |
|
85 | + /** |
|
86 | + * Prepares the display query |
|
87 | + */ |
|
88 | + public function prepare_query() { |
|
89 | + |
|
90 | + // Prepare query args. |
|
91 | + $query = array( |
|
92 | + 'number' => $this->per_page, |
|
93 | + 'paged' => $this->get_paged(), |
|
94 | + 'status' => ( isset( $_GET['status'] ) && array_key_exists( $_GET['status'], getpaid_get_subscription_statuses() ) ) ? $_GET['status'] : 'all', |
|
95 | + 'orderby' => ( isset( $_GET['orderby'] ) ) ? $_GET['orderby'] : 'id', |
|
96 | + 'order' => ( isset( $_GET['order'] ) ) ? $_GET['order'] : 'DESC', |
|
97 | + ); |
|
98 | + |
|
99 | + // Prepare class properties. |
|
100 | + $this->query = new GetPaid_Subscriptions_Query( $query ); |
|
101 | + $this->total_count = $this->query->get_total(); |
|
102 | + $this->current_total_count = $this->query->get_total(); |
|
103 | + $this->items = $this->query->get_results(); |
|
104 | + $this->status_counts = getpaid_get_subscription_status_counts( $query ); |
|
105 | + |
|
106 | + if ( 'all' != $query['status'] ) { |
|
107 | + unset( $query['status'] ); |
|
108 | + $this->total_count = getpaid_get_subscriptions( $query, 'count' ); |
|
109 | + } |
|
110 | + |
|
111 | + } |
|
112 | + |
|
113 | + /** |
|
114 | + * Gets the list of views available on this table. |
|
115 | + * |
|
116 | + * The format is an associative array: |
|
117 | + * - `'id' => 'link'` |
|
118 | + * |
|
119 | + * @since 1.0.0 |
|
120 | + * |
|
121 | + * @return array |
|
122 | + */ |
|
123 | + public function get_views() { |
|
124 | + |
|
125 | + $current = isset( $_GET['status'] ) ? $_GET['status'] : 'all'; |
|
126 | + $views = array( |
|
127 | + |
|
128 | + 'all' => sprintf( |
|
129 | + '<a href="%s" %s>%s <span class="count">(%d)</span></a>', |
|
130 | + esc_url( add_query_arg( 'status', false, $this->base_url ) ), |
|
131 | + $current === 'all' ? ' class="current"' : '', |
|
132 | + __('All','invoicing' ), |
|
133 | + $this->total_count |
|
134 | + ) |
|
135 | + |
|
136 | + ); |
|
137 | + |
|
138 | + foreach ( array_filter( $this->status_counts ) as $status => $count ) { |
|
139 | + |
|
140 | + $views[ $status ] = sprintf( |
|
141 | + '<a href="%s" %s>%s <span class="count">(%d)</span></a>', |
|
142 | + esc_url( add_query_arg( 'status', urlencode( $status ), $this->base_url ) ), |
|
143 | + $current === $status ? ' class="current"' : '', |
|
144 | + sanitize_text_field( getpaid_get_subscription_status_label( $status ) ), |
|
145 | + $count |
|
146 | + ); |
|
147 | + |
|
148 | + } |
|
149 | + |
|
150 | + return $views; |
|
151 | + |
|
152 | + } |
|
153 | + |
|
154 | + /** |
|
155 | + * Render most columns |
|
156 | + * |
|
157 | + * @access private |
|
158 | + * @since 1.0.0 |
|
159 | + * @return string |
|
160 | + */ |
|
161 | + public function column_default( $item, $column_name ) { |
|
162 | + return apply_filters( "getpaid_subscriptions_table_column_$column_name", $item->$column_name ); |
|
163 | + } |
|
164 | + |
|
165 | + /** |
|
166 | + * This is how checkbox column renders. |
|
167 | + * |
|
168 | + * @param WPInv_Subscription $item |
|
169 | + * @return string |
|
170 | + */ |
|
171 | + public function column_cb( $item ) { |
|
172 | + return sprintf( '<input type="checkbox" name="id[]" value="%s" />', esc_html( $item->get_id() ) ); |
|
173 | + } |
|
174 | + |
|
175 | + /** |
|
176 | + * Status column |
|
177 | + * |
|
178 | + * @param WPInv_Subscription $item |
|
179 | + * @since 1.0.0 |
|
180 | + * @return string |
|
181 | + */ |
|
182 | + public function column_status( $item ) { |
|
183 | + return $item->get_status_label_html(); |
|
184 | + } |
|
185 | + |
|
186 | + /** |
|
187 | + * Subscription column |
|
188 | + * |
|
189 | + * @param WPInv_Subscription $item |
|
190 | + * @since 1.0.0 |
|
191 | + * @return string |
|
192 | + */ |
|
193 | + public function column_subscription( $item ) { |
|
194 | + |
|
195 | + $username = __( '(Missing User)', 'invoicing' ); |
|
196 | + |
|
197 | + $user = get_userdata( $item->get_customer_id() ); |
|
198 | + if ( $user ) { |
|
199 | + |
|
200 | + $username = sprintf( |
|
201 | + '<a href="user-edit.php?user_id=%s">%s</a>', |
|
202 | + absint( $user->ID ), |
|
203 | + ! empty( $user->display_name ) ? sanitize_text_field( $user->display_name ) : sanitize_email( $user->user_email ) |
|
204 | + ); |
|
205 | + |
|
206 | + } |
|
207 | + |
|
208 | + // translators: $1: is opening link, $2: is subscription id number, $3: is closing link tag, $4: is user's name |
|
209 | + $column_content = sprintf( |
|
210 | + _x( '%1$s#%2$s%3$s for %4$s', 'Subscription title on admin table. (e.g.: #211 for John Doe)', 'invoicing' ), |
|
211 | + '<a href="' . esc_url( admin_url( 'admin.php?page=wpinv-subscriptions&id=' . absint( $item->get_id() ) ) ) . '">', |
|
212 | + '<strong>' . esc_attr( $item->get_id() ) . '</strong>', '</a>', |
|
213 | + $username |
|
214 | + ); |
|
215 | + |
|
216 | + $row_actions = array(); |
|
217 | + |
|
218 | + // View subscription. |
|
219 | + $view_url = esc_url( add_query_arg( 'id', $item->get_id(), admin_url( 'admin.php?page=wpinv-subscriptions' ) )); |
|
220 | + $row_actions['view'] = '<a href="' . $view_url . '">' . __( 'View Subscription', 'invoicing' ) . '</a>'; |
|
221 | + |
|
222 | + // View invoice. |
|
223 | + $invoice = get_post( $item->get_parent_invoice_id() ); |
|
224 | + |
|
225 | + if ( ! empty( $invoice ) ) { |
|
226 | + $invoice_url = get_edit_post_link( $invoice ); |
|
227 | + $row_actions['invoice'] = '<a href="' . $invoice_url . '">' . __( 'View Invoice', 'invoicing' ) . '</a>'; |
|
228 | + } |
|
229 | + |
|
230 | + $delete_url = esc_url( |
|
231 | + wp_nonce_url( |
|
232 | + add_query_arg( |
|
233 | + array( |
|
234 | + 'getpaid-admin-action' => 'subscription_manual_delete', |
|
235 | + 'id' => $item->get_id(), |
|
236 | + ) |
|
237 | + ), |
|
238 | + 'getpaid-nonce', |
|
239 | + 'getpaid-nonce' |
|
240 | + ) |
|
241 | + ); |
|
242 | + $row_actions['delete'] = '<a class="text-danger" href="' . $delete_url . '">' . __( 'Delete Subscription', 'invoicing' ) . '</a>'; |
|
243 | + |
|
244 | + $row_actions = $this->row_actions( apply_filters( 'getpaid_subscription_table_row_actions', $row_actions, $item ) ); |
|
245 | + |
|
246 | + return "<strong>$column_content</strong>" . $this->column_amount( $item ) . $row_actions; |
|
247 | + } |
|
248 | + |
|
249 | + /** |
|
250 | + * Renewal date column |
|
251 | + * |
|
252 | + * @param WPInv_Subscription $item |
|
253 | + * @since 1.0.0 |
|
254 | + * @return string |
|
255 | + */ |
|
256 | + public function column_renewal_date( $item ) { |
|
257 | + return getpaid_format_date_value( $item->get_expiration() ); |
|
258 | + } |
|
259 | + |
|
260 | + /** |
|
261 | + * Start date column |
|
262 | + * |
|
263 | + * @param WPInv_Subscription $item |
|
264 | + * @since 1.0.0 |
|
265 | + * @return string |
|
266 | + */ |
|
267 | + public function column_start_date( $item ) { |
|
268 | + return getpaid_format_date_value( $item->get_date_created() ); |
|
269 | + } |
|
270 | + |
|
271 | + /** |
|
272 | + * Amount column |
|
273 | + * |
|
274 | + * @param WPInv_Subscription $item |
|
275 | + * @since 1.0.19 |
|
276 | + * @return string |
|
277 | + */ |
|
278 | + public function column_amount( $item ) { |
|
279 | + $amount = getpaid_get_formatted_subscription_amount( $item ); |
|
280 | + return "<span class='text-muted form-text mt-2 mb-2'>$amount</span>"; |
|
281 | + } |
|
282 | + |
|
283 | + /** |
|
284 | + * Billing Times column |
|
285 | + * |
|
286 | + * @param WPInv_Subscription $item |
|
287 | + * @since 1.0.0 |
|
288 | + * @return string |
|
289 | + */ |
|
290 | + public function column_renewals( $item ) { |
|
291 | + $max_bills = $item->get_bill_times(); |
|
292 | + return $item->get_times_billed() . ' / ' . ( empty( $max_bills ) ? "∞" : $max_bills ); |
|
293 | + } |
|
294 | + |
|
295 | + /** |
|
296 | + * Product ID column |
|
297 | + * |
|
298 | + * @param WPInv_Subscription $item |
|
299 | + * @since 1.0.0 |
|
300 | + * @return string |
|
301 | + */ |
|
302 | + public function column_item( $item ) { |
|
303 | + $_item = get_post( $item->get_product_id() ); |
|
304 | + |
|
305 | + if ( ! empty( $_item ) ) { |
|
306 | + $link = get_edit_post_link( $_item ); |
|
307 | + $link = esc_url( $link ); |
|
308 | + $name = esc_html( get_the_title( $_item ) ); |
|
309 | + return "<a href='$link'>$name</a>"; |
|
310 | + } else { |
|
311 | + return sprintf( __( 'Item #%s', 'invoicing' ), $item->get_product_id() ); |
|
312 | + } |
|
313 | + |
|
314 | + } |
|
315 | + |
|
316 | + /** |
|
317 | + * Retrieve the current page number |
|
318 | + * |
|
319 | + * @return int |
|
320 | + */ |
|
321 | + public function get_paged() { |
|
322 | + return isset( $_GET['paged'] ) ? absint( $_GET['paged'] ) : 1; |
|
323 | + } |
|
324 | + |
|
325 | + /** |
|
326 | + * Setup the final data for the table |
|
327 | + * |
|
328 | + */ |
|
329 | + public function prepare_items() { |
|
330 | + |
|
331 | + $columns = $this->get_columns(); |
|
332 | + $hidden = array(); |
|
333 | + $sortable = $this->get_sortable_columns(); |
|
334 | + |
|
335 | + $this->_column_headers = array( $columns, $hidden, $sortable ); |
|
336 | + |
|
337 | + $this->set_pagination_args( |
|
338 | + array( |
|
339 | + 'total_items' => $this->current_total_count, |
|
340 | + 'per_page' => $this->per_page, |
|
341 | + 'total_pages' => ceil( $this->current_total_count / $this->per_page ) |
|
342 | + ) |
|
343 | + ); |
|
344 | + } |
|
345 | + |
|
346 | + /** |
|
347 | + * Table columns |
|
348 | + * |
|
349 | + * @return array |
|
350 | + */ |
|
351 | + public function get_columns(){ |
|
352 | + $columns = array( |
|
353 | + 'cb' => '<input type="checkbox" />', |
|
354 | + 'subscription' => __( 'Subscription', 'invoicing' ), |
|
355 | + 'start_date' => __( 'Start Date', 'invoicing' ), |
|
356 | + 'renewal_date' => __( 'Next Payment', 'invoicing' ), |
|
357 | + 'renewals' => __( 'Payments', 'invoicing' ), |
|
358 | + 'item' => __( 'Item', 'invoicing' ), |
|
359 | + 'status' => __( 'Status', 'invoicing' ), |
|
360 | + ); |
|
361 | + |
|
362 | + return apply_filters( 'manage_getpaid_subscriptions_table_columns', $columns ); |
|
363 | + } |
|
364 | + |
|
365 | + /** |
|
366 | + * Sortable table columns. |
|
367 | + * |
|
368 | + * @return array |
|
369 | + */ |
|
370 | + public function get_sortable_columns() { |
|
371 | + $sortable = array( |
|
372 | + 'subscription' => array( 'id', true ), |
|
373 | + 'start_date' => array( 'created', true ), |
|
374 | + 'renewal_date' => array( 'expiration', true ), |
|
375 | + 'renewals' => array( 'bill_times', true ), |
|
376 | + 'item' => array( 'product_id', true ), |
|
377 | + 'status' => array( 'status', true ), |
|
378 | + ); |
|
379 | + |
|
380 | + return apply_filters( 'manage_getpaid_subscriptions_sortable_table_columns', $sortable ); |
|
381 | + } |
|
382 | + |
|
383 | + /** |
|
384 | + * Whether the table has items to display or not |
|
385 | + * |
|
386 | + * @return bool |
|
387 | + */ |
|
388 | + public function has_items() { |
|
389 | + return ! empty( $this->current_total_count ); |
|
390 | + } |
|
391 | + |
|
392 | + /** |
|
393 | + * Processes bulk actions. |
|
394 | + * |
|
395 | + */ |
|
396 | + public function process_bulk_action() { |
|
397 | + |
|
398 | + } |
|
399 | 399 | |
400 | 400 | } |
@@ -159,7 +159,7 @@ |
||
159 | 159 | function getpaid_calculate_invoice_discount( $invoice, $discount ) { |
160 | 160 | |
161 | 161 | $initial_discount = 0; |
162 | - $recurring_discount = 0; |
|
162 | + $recurring_discount = 0; |
|
163 | 163 | |
164 | 164 | foreach ( $invoice->get_items() as $item ) { |
165 | 165 |