@@ -26,571 +26,571 @@ |
||
26 | 26 | */ |
27 | 27 | class Event extends EventCalculationBase |
28 | 28 | { |
29 | - /** |
|
30 | - * @var EEM_Event |
|
31 | - */ |
|
32 | - protected $event_model; |
|
33 | - |
|
34 | - /** |
|
35 | - * @var EEM_Registration |
|
36 | - */ |
|
37 | - protected $registration_model; |
|
38 | - public function __construct(EEM_Event $event_model, EEM_Registration $registration_model) |
|
39 | - { |
|
40 | - $this->event_model = $event_model; |
|
41 | - $this->registration_model = $registration_model; |
|
42 | - } |
|
43 | - |
|
44 | - /** |
|
45 | - * Calculates the total spaces on the event (not subtracting sales, but taking |
|
46 | - * sales into account; so this is the optimum sales that CAN still be achieved) |
|
47 | - * See EE_Event::total_available_spaces( true ); |
|
48 | - * |
|
49 | - * @param array $wpdb_row |
|
50 | - * @param WP_REST_Request $request |
|
51 | - * @param EventControllerBase $controller |
|
52 | - * @return int |
|
53 | - * @throws EE_Error |
|
54 | - * @throws DomainException |
|
55 | - * @throws InvalidDataTypeException |
|
56 | - * @throws InvalidInterfaceException |
|
57 | - * @throws UnexpectedEntityException |
|
58 | - * @throws InvalidArgumentException |
|
59 | - */ |
|
60 | - public function optimumSalesAtStart($wpdb_row, $request, $controller) |
|
61 | - { |
|
62 | - $event_obj = null; |
|
63 | - if (Event::wpdbRowHasEventId($wpdb_row)) { |
|
64 | - $event_obj = $this->event_model->get_one_by_ID($wpdb_row['Event_CPT.ID']); |
|
65 | - } |
|
66 | - if ($event_obj instanceof EE_Event) { |
|
67 | - return $event_obj->total_available_spaces(); |
|
68 | - } |
|
69 | - throw new EE_Error( |
|
70 | - sprintf( |
|
71 | - esc_html__( |
|
72 | - // @codingStandardsIgnoreStart |
|
73 | - 'Cannot calculate optimum_sales_at_start because the event with ID %1$s (from database row %2$s) was not found', |
|
74 | - // @codingStandardsIgnoreEnd |
|
75 | - 'event_espresso' |
|
76 | - ), |
|
77 | - $wpdb_row['Event_CPT.ID'], |
|
78 | - print_r($wpdb_row, true) |
|
79 | - ) |
|
80 | - ); |
|
81 | - } |
|
82 | - |
|
83 | - |
|
84 | - /** |
|
85 | - * Calculates the total spaces on the event (ignoring all sales; so this is the optimum |
|
86 | - * sales that COULD have been achieved) |
|
87 | - * See EE_Event::total_available_spaces( true ); |
|
88 | - * |
|
89 | - * @param array $wpdb_row |
|
90 | - * @param WP_REST_Request $request |
|
91 | - * @param EventControllerBase $controller |
|
92 | - * @return int |
|
93 | - * @throws DomainException |
|
94 | - * @throws EE_Error |
|
95 | - * @throws InvalidArgumentException |
|
96 | - * @throws InvalidDataTypeException |
|
97 | - * @throws InvalidInterfaceException |
|
98 | - * @throws UnexpectedEntityException |
|
99 | - */ |
|
100 | - public function optimumSalesNow($wpdb_row, $request, $controller) |
|
101 | - { |
|
102 | - $event_obj = null; |
|
103 | - if (Event::wpdbRowHasEventId($wpdb_row)) { |
|
104 | - $event_obj = $this->event_model->get_one_by_ID($wpdb_row['Event_CPT.ID']); |
|
105 | - } |
|
106 | - if ($event_obj instanceof EE_Event) { |
|
107 | - return $event_obj->total_available_spaces(true); |
|
108 | - } |
|
109 | - throw new EE_Error( |
|
110 | - sprintf( |
|
111 | - esc_html__( |
|
112 | - // @codingStandardsIgnoreStart |
|
113 | - 'Cannot calculate optimum_sales_now because the event with ID %1$s (from database row %2$s) was not found', |
|
114 | - // @codingStandardsIgnoreEnd |
|
115 | - 'event_espresso' |
|
116 | - ), |
|
117 | - $wpdb_row['Event_CPT.ID'], |
|
118 | - print_r($wpdb_row, true) |
|
119 | - ) |
|
120 | - ); |
|
121 | - } |
|
122 | - |
|
123 | - |
|
124 | - /** |
|
125 | - * Like optimum_sales_now, but minus total sales so far. |
|
126 | - * See EE_Event::spaces_remaining_for_sale( true ); |
|
127 | - * |
|
128 | - * @param array $wpdb_row |
|
129 | - * @param WP_REST_Request $request |
|
130 | - * @param EventControllerBase $controller |
|
131 | - * @return int |
|
132 | - * @throws DomainException |
|
133 | - * @throws EE_Error |
|
134 | - * @throws InvalidArgumentException |
|
135 | - * @throws InvalidDataTypeException |
|
136 | - * @throws InvalidInterfaceException |
|
137 | - * @throws UnexpectedEntityException |
|
138 | - */ |
|
139 | - public function spacesRemaining($wpdb_row, $request, $controller) |
|
140 | - { |
|
141 | - $event_obj = null; |
|
142 | - if (Event::wpdbRowHasEventId($wpdb_row)) { |
|
143 | - $event_obj = $this->event_model->get_one_by_ID($wpdb_row['Event_CPT.ID']); |
|
144 | - } |
|
145 | - if ($event_obj instanceof EE_Event) { |
|
146 | - return $event_obj->spaces_remaining_for_sale(); |
|
147 | - } |
|
148 | - throw new EE_Error( |
|
149 | - sprintf( |
|
150 | - esc_html__( |
|
151 | - // @codingStandardsIgnoreStart |
|
152 | - 'Cannot calculate spaces_remaining because the event with ID %1$s (from database row %2$s) was not found', |
|
153 | - // @codingStandardsIgnoreEnd |
|
154 | - 'event_espresso' |
|
155 | - ), |
|
156 | - $wpdb_row['Event_CPT.ID'], |
|
157 | - print_r($wpdb_row, true) |
|
158 | - ) |
|
159 | - ); |
|
160 | - } |
|
161 | - |
|
162 | - |
|
163 | - /** |
|
164 | - * Counts the number of approved registrations for this event (regardless |
|
165 | - * of how many datetimes each registrations' ticket purchase is for) |
|
166 | - * |
|
167 | - * @param array $wpdb_row |
|
168 | - * @param WP_REST_Request $request |
|
169 | - * @param EventControllerBase $controller |
|
170 | - * @return int |
|
171 | - * @throws EE_Error |
|
172 | - * @throws InvalidArgumentException |
|
173 | - * @throws InvalidDataTypeException |
|
174 | - * @throws InvalidInterfaceException |
|
175 | - */ |
|
176 | - public function spotsTaken($wpdb_row, $request, $controller) |
|
177 | - { |
|
178 | - if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
179 | - throw new EE_Error( |
|
180 | - sprintf( |
|
181 | - esc_html__( |
|
182 | - // @codingStandardsIgnoreStart |
|
183 | - 'Cannot calculate spots_taken because the database row %1$s does not have a valid entry for "Event_CPT.ID"', |
|
184 | - // @codingStandardsIgnoreEnd |
|
185 | - 'event_espresso' |
|
186 | - ), |
|
187 | - print_r($wpdb_row, true) |
|
188 | - ) |
|
189 | - ); |
|
190 | - } |
|
191 | - return $this->registration_model->count( |
|
192 | - array( |
|
193 | - array( |
|
194 | - 'EVT_ID' => $wpdb_row['Event_CPT.ID'], |
|
195 | - 'STS_ID' => EEM_Registration::status_id_approved, |
|
196 | - ), |
|
197 | - ), |
|
198 | - 'REG_ID', |
|
199 | - true |
|
200 | - ); |
|
201 | - } |
|
202 | - |
|
203 | - |
|
204 | - /** |
|
205 | - * Counts the number of pending-payment registrations for this event (regardless |
|
206 | - * of how many datetimes each registrations' ticket purchase is for) |
|
207 | - * |
|
208 | - * @param array $wpdb_row |
|
209 | - * @param WP_REST_Request $request |
|
210 | - * @param EventControllerBase $controller |
|
211 | - * @return int |
|
212 | - * @throws EE_Error |
|
213 | - * @throws InvalidArgumentException |
|
214 | - * @throws InvalidDataTypeException |
|
215 | - * @throws InvalidInterfaceException |
|
216 | - * @throws RestException |
|
217 | - */ |
|
218 | - public function spotsTakenPendingPayment($wpdb_row, $request, $controller) |
|
219 | - { |
|
220 | - if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
221 | - throw new EE_Error( |
|
222 | - sprintf( |
|
223 | - esc_html__( |
|
224 | - // @codingStandardsIgnoreStart |
|
225 | - 'Cannot calculate spots_taken_pending_payment because the database row %1$s does not have an entry for "Event_CPT.ID"', |
|
226 | - // @codingStandardsIgnoreEnd |
|
227 | - 'event_espresso' |
|
228 | - ), |
|
229 | - print_r($wpdb_row, true) |
|
230 | - ) |
|
231 | - ); |
|
232 | - } |
|
233 | - $this->verifyCurrentUserCan('ee_read_registrations', 'spots_taken_pending_payment'); |
|
234 | - return $this->registration_model->count( |
|
235 | - array( |
|
236 | - array( |
|
237 | - 'EVT_ID' => $wpdb_row['Event_CPT.ID'], |
|
238 | - 'STS_ID' => EEM_Registration::status_id_pending_payment, |
|
239 | - ), |
|
240 | - ), |
|
241 | - 'REG_ID', |
|
242 | - true |
|
243 | - ); |
|
244 | - } |
|
245 | - |
|
246 | - |
|
247 | - /** |
|
248 | - * Counts all the registrations who have checked into one of this events' datetimes |
|
249 | - * See EE_Event::total_available_spaces( false ); |
|
250 | - * |
|
251 | - * @param array $wpdb_row |
|
252 | - * @param WP_REST_Request $request |
|
253 | - * @param EventControllerBase $controller |
|
254 | - * @return int|null if permission denied |
|
255 | - * @throws EE_Error |
|
256 | - * @throws InvalidArgumentException |
|
257 | - * @throws InvalidDataTypeException |
|
258 | - * @throws InvalidInterfaceException |
|
259 | - * @throws RestException |
|
260 | - */ |
|
261 | - public function registrationsCheckedInCount($wpdb_row, $request, $controller) |
|
262 | - { |
|
263 | - if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
264 | - throw new EE_Error( |
|
265 | - sprintf( |
|
266 | - esc_html__( |
|
267 | - // @codingStandardsIgnoreStart |
|
268 | - 'Cannot calculate registrations_checked_in_count because the database row %1$s does not have an entry for "Event_CPT.ID"', |
|
269 | - // @codingStandardsIgnoreEnd |
|
270 | - 'event_espresso' |
|
271 | - ), |
|
272 | - print_r($wpdb_row, true) |
|
273 | - ) |
|
274 | - ); |
|
275 | - } |
|
276 | - $this->verifyCurrentUserCan('ee_read_checkins', 'registrations_checked_in_count'); |
|
277 | - return $this->registration_model->count_registrations_checked_into_event($wpdb_row['Event_CPT.ID'], true); |
|
278 | - } |
|
279 | - |
|
280 | - |
|
281 | - /** |
|
282 | - * Counts all the registrations who have checked out of one of this events' datetimes |
|
283 | - * See EE_Event::total_available_spaces( false ); |
|
284 | - * |
|
285 | - * @param array $wpdb_row |
|
286 | - * @param WP_REST_Request $request |
|
287 | - * @param EventControllerBase $controller |
|
288 | - * @return int |
|
289 | - * @throws EE_Error |
|
290 | - * @throws InvalidArgumentException |
|
291 | - * @throws InvalidDataTypeException |
|
292 | - * @throws InvalidInterfaceException |
|
293 | - * @throws RestException |
|
294 | - */ |
|
295 | - public function registrationsCheckedOutCount($wpdb_row, $request, $controller) |
|
296 | - { |
|
297 | - if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
298 | - throw new EE_Error( |
|
299 | - sprintf( |
|
300 | - esc_html__( |
|
301 | - // @codingStandardsIgnoreStart |
|
302 | - 'Cannot calculate registrations_checked_out_count because the database row %1$s does not have an entry for "Event_CPT.ID"', |
|
303 | - // @codingStandardsIgnoreEnd |
|
304 | - 'event_espresso' |
|
305 | - ), |
|
306 | - print_r($wpdb_row, true) |
|
307 | - ) |
|
308 | - ); |
|
309 | - } |
|
310 | - $this->verifyCurrentUserCan('ee_read_checkins', 'registrations_checked_out_count'); |
|
311 | - return $this->registration_model->count_registrations_checked_into_event($wpdb_row['Event_CPT.ID'], false); |
|
312 | - } |
|
313 | - |
|
314 | - |
|
315 | - /** |
|
316 | - * Gets the thumbnail image |
|
317 | - * |
|
318 | - * @param array $wpdb_row |
|
319 | - * @param WP_REST_Request $request |
|
320 | - * @param EventControllerBase $controller |
|
321 | - * @return array |
|
322 | - * @throws EE_Error |
|
323 | - */ |
|
324 | - public function imageThumbnail($wpdb_row, $request, $controller) |
|
325 | - { |
|
326 | - return self::calculateImageData($wpdb_row, 'thumbnail'); |
|
327 | - } |
|
328 | - |
|
329 | - |
|
330 | - /** |
|
331 | - * Gets the medium image |
|
332 | - * |
|
333 | - * @param array $wpdb_row |
|
334 | - * @param WP_REST_Request $request |
|
335 | - * @param EventControllerBase $controller |
|
336 | - * @return array |
|
337 | - * @throws EE_Error |
|
338 | - */ |
|
339 | - public function imageMedium($wpdb_row, $request, $controller) |
|
340 | - { |
|
341 | - return self::calculateImageData($wpdb_row, 'medium'); |
|
342 | - } |
|
343 | - |
|
344 | - |
|
345 | - /** |
|
346 | - * Gets the medium-large image |
|
347 | - * |
|
348 | - * @param array $wpdb_row |
|
349 | - * @param WP_REST_Request $request |
|
350 | - * @param EventControllerBase $controller |
|
351 | - * @return array |
|
352 | - * @throws EE_Error |
|
353 | - */ |
|
354 | - public function imageMediumLarge($wpdb_row, $request, $controller) |
|
355 | - { |
|
356 | - return self::calculateImageData($wpdb_row, 'medium_large'); |
|
357 | - } |
|
358 | - |
|
359 | - |
|
360 | - /** |
|
361 | - * Gets the large image |
|
362 | - * |
|
363 | - * @param array $wpdb_row |
|
364 | - * @param WP_REST_Request $request |
|
365 | - * @param EventControllerBase $controller |
|
366 | - * @return array |
|
367 | - * @throws EE_Error |
|
368 | - */ |
|
369 | - public function imageLarge($wpdb_row, $request, $controller) |
|
370 | - { |
|
371 | - return self::calculateImageData($wpdb_row, 'large'); |
|
372 | - } |
|
373 | - |
|
374 | - |
|
375 | - /** |
|
376 | - * Gets the post-thumbnail image |
|
377 | - * |
|
378 | - * @param array $wpdb_row |
|
379 | - * @param WP_REST_Request $request |
|
380 | - * @param EventControllerBase $controller |
|
381 | - * @return array |
|
382 | - * @throws EE_Error |
|
383 | - */ |
|
384 | - public function imagePostThumbnail($wpdb_row, $request, $controller) |
|
385 | - { |
|
386 | - return self::calculateImageData($wpdb_row, 'post-thumbnail'); |
|
387 | - } |
|
388 | - |
|
389 | - |
|
390 | - /** |
|
391 | - * Gets the full size image |
|
392 | - * |
|
393 | - * @param array $wpdb_row |
|
394 | - * @param WP_REST_Request $request |
|
395 | - * @param EventControllerBase $controller |
|
396 | - * @return array |
|
397 | - * @throws EE_Error |
|
398 | - */ |
|
399 | - public function imageFull($wpdb_row, $request, $controller) |
|
400 | - { |
|
401 | - return self::calculateImageData($wpdb_row, 'full'); |
|
402 | - } |
|
403 | - |
|
404 | - |
|
405 | - /** |
|
406 | - * Gets image specs and formats them for the display in the API, |
|
407 | - * according to the image size requested |
|
408 | - * |
|
409 | - * @param array $wpdb_row |
|
410 | - * @param string $image_size one of these: thumbnail, medium, medium_large, large, post-thumbnail, full |
|
411 | - * @return array|false if no such image exists. If array it will have keys 'url', 'width', 'height' and 'original' |
|
412 | - * @throws EE_Error |
|
413 | - */ |
|
414 | - protected function calculateImageData($wpdb_row, $image_size) |
|
415 | - { |
|
416 | - if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
417 | - throw new EE_Error( |
|
418 | - sprintf( |
|
419 | - esc_html__( |
|
420 | - // @codingStandardsIgnoreStart |
|
421 | - 'Cannot calculate image because the database row %1$s does not have an entry for "Event_CPT.ID"', |
|
422 | - // @codingStandardsIgnoreEnd |
|
423 | - 'event_espresso' |
|
424 | - ), |
|
425 | - print_r($wpdb_row, true) |
|
426 | - ) |
|
427 | - ); |
|
428 | - } |
|
429 | - $EVT_ID = $wpdb_row['Event_CPT.ID']; |
|
430 | - $attachment_id = get_post_thumbnail_id($EVT_ID); |
|
431 | - $data = wp_get_attachment_image_src($attachment_id, $image_size); |
|
432 | - if (! $data) { |
|
433 | - return null; |
|
434 | - } |
|
435 | - $generated = true; |
|
436 | - if (isset($data[3])) { |
|
437 | - $generated = $data[3]; |
|
438 | - } |
|
439 | - return array( |
|
440 | - 'url' => $data[0], |
|
441 | - 'width' => $data[1], |
|
442 | - 'height' => $data[2], |
|
443 | - 'generated' => $generated, |
|
444 | - ); |
|
445 | - } |
|
446 | - |
|
447 | - |
|
448 | - /** |
|
449 | - * Returns true if the array of data contains 'Event_CPT.ID'. False otherwise |
|
450 | - * |
|
451 | - * @param array $wpdb_row |
|
452 | - * @return bool |
|
453 | - */ |
|
454 | - protected function wpdbRowHasEventId($wpdb_row) |
|
455 | - { |
|
456 | - return (is_array($wpdb_row) && isset($wpdb_row['Event_CPT.ID']) && absint($wpdb_row['Event_CPT.ID'])); |
|
457 | - } |
|
458 | - |
|
459 | - |
|
460 | - /** |
|
461 | - * Provides an array for all the calculations possible that outlines a json schema for those calculations. |
|
462 | - * Array is indexed by calculation (snake case) and value is the schema for that calculation. |
|
463 | - * |
|
464 | - * @since 4.9.68.p |
|
465 | - * @return array |
|
466 | - */ |
|
467 | - public function schemaForCalculations() |
|
468 | - { |
|
469 | - $image_object_properties = array( |
|
470 | - 'url' => array( |
|
471 | - 'type' => 'string', |
|
472 | - ), |
|
473 | - 'width' => array( |
|
474 | - 'type' => 'number', |
|
475 | - ), |
|
476 | - 'height' => array( |
|
477 | - 'type' => 'number', |
|
478 | - ), |
|
479 | - 'generated' => array( |
|
480 | - 'type' => 'boolean', |
|
481 | - ), |
|
482 | - ); |
|
483 | - return array( |
|
484 | - 'optimum_sales_at_start' => array( |
|
485 | - 'description' => esc_html__( |
|
486 | - 'The total spaces on the event (not subtracting sales, but taking sales into account; so this is the optimum sales that CAN still be achieved.', |
|
487 | - 'event_espresso' |
|
488 | - ), |
|
489 | - 'type' => 'number', |
|
490 | - 'protected' => true, |
|
491 | - ), |
|
492 | - 'optimum_sales_now' => array( |
|
493 | - 'description' => esc_html__( |
|
494 | - 'The total spaces on the event (ignoring all sales; so this is the optimum sales that could have been achieved.', |
|
495 | - 'event_espresso' |
|
496 | - ), |
|
497 | - 'type' => 'number', |
|
498 | - 'protected' => true, |
|
499 | - ), |
|
500 | - 'spaces_remaining' => array( |
|
501 | - 'description' => esc_html__( |
|
502 | - 'The optimum_sales_number result, minus total sales so far.', |
|
503 | - 'event_espresso' |
|
504 | - ), |
|
505 | - 'type' => 'number', |
|
506 | - 'protected' => true, |
|
507 | - ), |
|
508 | - 'spots_taken' => array( |
|
509 | - 'description' => esc_html__( |
|
510 | - 'The number of approved registrations for this event (regardless of how many datetimes each registration\'s ticket purchase is for)', |
|
511 | - 'event_espresso' |
|
512 | - ), |
|
513 | - 'type' => 'number', |
|
514 | - 'protected' => true, |
|
515 | - ), |
|
516 | - 'spots_taken_pending_payment' => array( |
|
517 | - 'description' => esc_html__( |
|
518 | - 'The number of pending-payment registrations for this event (regardless of how many datetimes each registration\'s ticket purchase is for)', |
|
519 | - 'event_espresso' |
|
520 | - ), |
|
521 | - 'type' => 'number', |
|
522 | - 'protected' => true, |
|
523 | - ), |
|
524 | - 'registrations_checked_in_count' => array( |
|
525 | - 'description' => esc_html__( |
|
526 | - 'The count of all the registrations who have checked into one of this event\'s datetimes.', |
|
527 | - 'event_espresso' |
|
528 | - ), |
|
529 | - 'type' => 'number', |
|
530 | - 'protected' => true, |
|
531 | - ), |
|
532 | - 'registrations_checked_out_count' => array( |
|
533 | - 'description' => esc_html__( |
|
534 | - 'The count of all registrations who have checked out of one of this event\'s datetimes.', |
|
535 | - 'event_espresso' |
|
536 | - ), |
|
537 | - 'type' => 'number', |
|
538 | - 'protected' => true, |
|
539 | - ), |
|
540 | - 'image_thumbnail' => array( |
|
541 | - 'description' => esc_html__( |
|
542 | - 'The thumbnail image data.', |
|
543 | - 'event_espresso' |
|
544 | - ), |
|
545 | - 'type' => 'object', |
|
546 | - 'properties' => $image_object_properties, |
|
547 | - 'additionalProperties' => false, |
|
548 | - ), |
|
549 | - 'image_medium' => array( |
|
550 | - 'description' => esc_html__( |
|
551 | - 'The medium image data.', |
|
552 | - 'event_espresso' |
|
553 | - ), |
|
554 | - 'type' => 'object', |
|
555 | - 'properties' => $image_object_properties, |
|
556 | - 'additionalProperties' => false, |
|
557 | - ), |
|
558 | - 'image_medium_large' => array( |
|
559 | - 'description' => esc_html__( |
|
560 | - 'The medium-large image data.', |
|
561 | - 'event_espresso' |
|
562 | - ), |
|
563 | - 'type' => 'object', |
|
564 | - 'properties' => $image_object_properties, |
|
565 | - 'additionalProperties' => false, |
|
566 | - ), |
|
567 | - 'image_large' => array( |
|
568 | - 'description' => esc_html__( |
|
569 | - 'The large image data.', |
|
570 | - 'event_espresso' |
|
571 | - ), |
|
572 | - 'type' => 'object', |
|
573 | - 'properties' => $image_object_properties, |
|
574 | - 'additionalProperties' => false, |
|
575 | - ), |
|
576 | - 'image_post_thumbnail' => array( |
|
577 | - 'description' => esc_html__( |
|
578 | - 'The post-thumbnail image data.', |
|
579 | - 'event_espresso' |
|
580 | - ), |
|
581 | - 'type' => 'object', |
|
582 | - 'properties' => $image_object_properties, |
|
583 | - 'additionalProperties' => false, |
|
584 | - ), |
|
585 | - 'image_full' => array( |
|
586 | - 'description' => esc_html__( |
|
587 | - 'The full size image data', |
|
588 | - 'event_espresso' |
|
589 | - ), |
|
590 | - 'type' => 'object', |
|
591 | - 'properties' => $image_object_properties, |
|
592 | - 'additionalProperties' => false, |
|
593 | - ), |
|
594 | - ); |
|
595 | - } |
|
29 | + /** |
|
30 | + * @var EEM_Event |
|
31 | + */ |
|
32 | + protected $event_model; |
|
33 | + |
|
34 | + /** |
|
35 | + * @var EEM_Registration |
|
36 | + */ |
|
37 | + protected $registration_model; |
|
38 | + public function __construct(EEM_Event $event_model, EEM_Registration $registration_model) |
|
39 | + { |
|
40 | + $this->event_model = $event_model; |
|
41 | + $this->registration_model = $registration_model; |
|
42 | + } |
|
43 | + |
|
44 | + /** |
|
45 | + * Calculates the total spaces on the event (not subtracting sales, but taking |
|
46 | + * sales into account; so this is the optimum sales that CAN still be achieved) |
|
47 | + * See EE_Event::total_available_spaces( true ); |
|
48 | + * |
|
49 | + * @param array $wpdb_row |
|
50 | + * @param WP_REST_Request $request |
|
51 | + * @param EventControllerBase $controller |
|
52 | + * @return int |
|
53 | + * @throws EE_Error |
|
54 | + * @throws DomainException |
|
55 | + * @throws InvalidDataTypeException |
|
56 | + * @throws InvalidInterfaceException |
|
57 | + * @throws UnexpectedEntityException |
|
58 | + * @throws InvalidArgumentException |
|
59 | + */ |
|
60 | + public function optimumSalesAtStart($wpdb_row, $request, $controller) |
|
61 | + { |
|
62 | + $event_obj = null; |
|
63 | + if (Event::wpdbRowHasEventId($wpdb_row)) { |
|
64 | + $event_obj = $this->event_model->get_one_by_ID($wpdb_row['Event_CPT.ID']); |
|
65 | + } |
|
66 | + if ($event_obj instanceof EE_Event) { |
|
67 | + return $event_obj->total_available_spaces(); |
|
68 | + } |
|
69 | + throw new EE_Error( |
|
70 | + sprintf( |
|
71 | + esc_html__( |
|
72 | + // @codingStandardsIgnoreStart |
|
73 | + 'Cannot calculate optimum_sales_at_start because the event with ID %1$s (from database row %2$s) was not found', |
|
74 | + // @codingStandardsIgnoreEnd |
|
75 | + 'event_espresso' |
|
76 | + ), |
|
77 | + $wpdb_row['Event_CPT.ID'], |
|
78 | + print_r($wpdb_row, true) |
|
79 | + ) |
|
80 | + ); |
|
81 | + } |
|
82 | + |
|
83 | + |
|
84 | + /** |
|
85 | + * Calculates the total spaces on the event (ignoring all sales; so this is the optimum |
|
86 | + * sales that COULD have been achieved) |
|
87 | + * See EE_Event::total_available_spaces( true ); |
|
88 | + * |
|
89 | + * @param array $wpdb_row |
|
90 | + * @param WP_REST_Request $request |
|
91 | + * @param EventControllerBase $controller |
|
92 | + * @return int |
|
93 | + * @throws DomainException |
|
94 | + * @throws EE_Error |
|
95 | + * @throws InvalidArgumentException |
|
96 | + * @throws InvalidDataTypeException |
|
97 | + * @throws InvalidInterfaceException |
|
98 | + * @throws UnexpectedEntityException |
|
99 | + */ |
|
100 | + public function optimumSalesNow($wpdb_row, $request, $controller) |
|
101 | + { |
|
102 | + $event_obj = null; |
|
103 | + if (Event::wpdbRowHasEventId($wpdb_row)) { |
|
104 | + $event_obj = $this->event_model->get_one_by_ID($wpdb_row['Event_CPT.ID']); |
|
105 | + } |
|
106 | + if ($event_obj instanceof EE_Event) { |
|
107 | + return $event_obj->total_available_spaces(true); |
|
108 | + } |
|
109 | + throw new EE_Error( |
|
110 | + sprintf( |
|
111 | + esc_html__( |
|
112 | + // @codingStandardsIgnoreStart |
|
113 | + 'Cannot calculate optimum_sales_now because the event with ID %1$s (from database row %2$s) was not found', |
|
114 | + // @codingStandardsIgnoreEnd |
|
115 | + 'event_espresso' |
|
116 | + ), |
|
117 | + $wpdb_row['Event_CPT.ID'], |
|
118 | + print_r($wpdb_row, true) |
|
119 | + ) |
|
120 | + ); |
|
121 | + } |
|
122 | + |
|
123 | + |
|
124 | + /** |
|
125 | + * Like optimum_sales_now, but minus total sales so far. |
|
126 | + * See EE_Event::spaces_remaining_for_sale( true ); |
|
127 | + * |
|
128 | + * @param array $wpdb_row |
|
129 | + * @param WP_REST_Request $request |
|
130 | + * @param EventControllerBase $controller |
|
131 | + * @return int |
|
132 | + * @throws DomainException |
|
133 | + * @throws EE_Error |
|
134 | + * @throws InvalidArgumentException |
|
135 | + * @throws InvalidDataTypeException |
|
136 | + * @throws InvalidInterfaceException |
|
137 | + * @throws UnexpectedEntityException |
|
138 | + */ |
|
139 | + public function spacesRemaining($wpdb_row, $request, $controller) |
|
140 | + { |
|
141 | + $event_obj = null; |
|
142 | + if (Event::wpdbRowHasEventId($wpdb_row)) { |
|
143 | + $event_obj = $this->event_model->get_one_by_ID($wpdb_row['Event_CPT.ID']); |
|
144 | + } |
|
145 | + if ($event_obj instanceof EE_Event) { |
|
146 | + return $event_obj->spaces_remaining_for_sale(); |
|
147 | + } |
|
148 | + throw new EE_Error( |
|
149 | + sprintf( |
|
150 | + esc_html__( |
|
151 | + // @codingStandardsIgnoreStart |
|
152 | + 'Cannot calculate spaces_remaining because the event with ID %1$s (from database row %2$s) was not found', |
|
153 | + // @codingStandardsIgnoreEnd |
|
154 | + 'event_espresso' |
|
155 | + ), |
|
156 | + $wpdb_row['Event_CPT.ID'], |
|
157 | + print_r($wpdb_row, true) |
|
158 | + ) |
|
159 | + ); |
|
160 | + } |
|
161 | + |
|
162 | + |
|
163 | + /** |
|
164 | + * Counts the number of approved registrations for this event (regardless |
|
165 | + * of how many datetimes each registrations' ticket purchase is for) |
|
166 | + * |
|
167 | + * @param array $wpdb_row |
|
168 | + * @param WP_REST_Request $request |
|
169 | + * @param EventControllerBase $controller |
|
170 | + * @return int |
|
171 | + * @throws EE_Error |
|
172 | + * @throws InvalidArgumentException |
|
173 | + * @throws InvalidDataTypeException |
|
174 | + * @throws InvalidInterfaceException |
|
175 | + */ |
|
176 | + public function spotsTaken($wpdb_row, $request, $controller) |
|
177 | + { |
|
178 | + if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
179 | + throw new EE_Error( |
|
180 | + sprintf( |
|
181 | + esc_html__( |
|
182 | + // @codingStandardsIgnoreStart |
|
183 | + 'Cannot calculate spots_taken because the database row %1$s does not have a valid entry for "Event_CPT.ID"', |
|
184 | + // @codingStandardsIgnoreEnd |
|
185 | + 'event_espresso' |
|
186 | + ), |
|
187 | + print_r($wpdb_row, true) |
|
188 | + ) |
|
189 | + ); |
|
190 | + } |
|
191 | + return $this->registration_model->count( |
|
192 | + array( |
|
193 | + array( |
|
194 | + 'EVT_ID' => $wpdb_row['Event_CPT.ID'], |
|
195 | + 'STS_ID' => EEM_Registration::status_id_approved, |
|
196 | + ), |
|
197 | + ), |
|
198 | + 'REG_ID', |
|
199 | + true |
|
200 | + ); |
|
201 | + } |
|
202 | + |
|
203 | + |
|
204 | + /** |
|
205 | + * Counts the number of pending-payment registrations for this event (regardless |
|
206 | + * of how many datetimes each registrations' ticket purchase is for) |
|
207 | + * |
|
208 | + * @param array $wpdb_row |
|
209 | + * @param WP_REST_Request $request |
|
210 | + * @param EventControllerBase $controller |
|
211 | + * @return int |
|
212 | + * @throws EE_Error |
|
213 | + * @throws InvalidArgumentException |
|
214 | + * @throws InvalidDataTypeException |
|
215 | + * @throws InvalidInterfaceException |
|
216 | + * @throws RestException |
|
217 | + */ |
|
218 | + public function spotsTakenPendingPayment($wpdb_row, $request, $controller) |
|
219 | + { |
|
220 | + if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
221 | + throw new EE_Error( |
|
222 | + sprintf( |
|
223 | + esc_html__( |
|
224 | + // @codingStandardsIgnoreStart |
|
225 | + 'Cannot calculate spots_taken_pending_payment because the database row %1$s does not have an entry for "Event_CPT.ID"', |
|
226 | + // @codingStandardsIgnoreEnd |
|
227 | + 'event_espresso' |
|
228 | + ), |
|
229 | + print_r($wpdb_row, true) |
|
230 | + ) |
|
231 | + ); |
|
232 | + } |
|
233 | + $this->verifyCurrentUserCan('ee_read_registrations', 'spots_taken_pending_payment'); |
|
234 | + return $this->registration_model->count( |
|
235 | + array( |
|
236 | + array( |
|
237 | + 'EVT_ID' => $wpdb_row['Event_CPT.ID'], |
|
238 | + 'STS_ID' => EEM_Registration::status_id_pending_payment, |
|
239 | + ), |
|
240 | + ), |
|
241 | + 'REG_ID', |
|
242 | + true |
|
243 | + ); |
|
244 | + } |
|
245 | + |
|
246 | + |
|
247 | + /** |
|
248 | + * Counts all the registrations who have checked into one of this events' datetimes |
|
249 | + * See EE_Event::total_available_spaces( false ); |
|
250 | + * |
|
251 | + * @param array $wpdb_row |
|
252 | + * @param WP_REST_Request $request |
|
253 | + * @param EventControllerBase $controller |
|
254 | + * @return int|null if permission denied |
|
255 | + * @throws EE_Error |
|
256 | + * @throws InvalidArgumentException |
|
257 | + * @throws InvalidDataTypeException |
|
258 | + * @throws InvalidInterfaceException |
|
259 | + * @throws RestException |
|
260 | + */ |
|
261 | + public function registrationsCheckedInCount($wpdb_row, $request, $controller) |
|
262 | + { |
|
263 | + if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
264 | + throw new EE_Error( |
|
265 | + sprintf( |
|
266 | + esc_html__( |
|
267 | + // @codingStandardsIgnoreStart |
|
268 | + 'Cannot calculate registrations_checked_in_count because the database row %1$s does not have an entry for "Event_CPT.ID"', |
|
269 | + // @codingStandardsIgnoreEnd |
|
270 | + 'event_espresso' |
|
271 | + ), |
|
272 | + print_r($wpdb_row, true) |
|
273 | + ) |
|
274 | + ); |
|
275 | + } |
|
276 | + $this->verifyCurrentUserCan('ee_read_checkins', 'registrations_checked_in_count'); |
|
277 | + return $this->registration_model->count_registrations_checked_into_event($wpdb_row['Event_CPT.ID'], true); |
|
278 | + } |
|
279 | + |
|
280 | + |
|
281 | + /** |
|
282 | + * Counts all the registrations who have checked out of one of this events' datetimes |
|
283 | + * See EE_Event::total_available_spaces( false ); |
|
284 | + * |
|
285 | + * @param array $wpdb_row |
|
286 | + * @param WP_REST_Request $request |
|
287 | + * @param EventControllerBase $controller |
|
288 | + * @return int |
|
289 | + * @throws EE_Error |
|
290 | + * @throws InvalidArgumentException |
|
291 | + * @throws InvalidDataTypeException |
|
292 | + * @throws InvalidInterfaceException |
|
293 | + * @throws RestException |
|
294 | + */ |
|
295 | + public function registrationsCheckedOutCount($wpdb_row, $request, $controller) |
|
296 | + { |
|
297 | + if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
298 | + throw new EE_Error( |
|
299 | + sprintf( |
|
300 | + esc_html__( |
|
301 | + // @codingStandardsIgnoreStart |
|
302 | + 'Cannot calculate registrations_checked_out_count because the database row %1$s does not have an entry for "Event_CPT.ID"', |
|
303 | + // @codingStandardsIgnoreEnd |
|
304 | + 'event_espresso' |
|
305 | + ), |
|
306 | + print_r($wpdb_row, true) |
|
307 | + ) |
|
308 | + ); |
|
309 | + } |
|
310 | + $this->verifyCurrentUserCan('ee_read_checkins', 'registrations_checked_out_count'); |
|
311 | + return $this->registration_model->count_registrations_checked_into_event($wpdb_row['Event_CPT.ID'], false); |
|
312 | + } |
|
313 | + |
|
314 | + |
|
315 | + /** |
|
316 | + * Gets the thumbnail image |
|
317 | + * |
|
318 | + * @param array $wpdb_row |
|
319 | + * @param WP_REST_Request $request |
|
320 | + * @param EventControllerBase $controller |
|
321 | + * @return array |
|
322 | + * @throws EE_Error |
|
323 | + */ |
|
324 | + public function imageThumbnail($wpdb_row, $request, $controller) |
|
325 | + { |
|
326 | + return self::calculateImageData($wpdb_row, 'thumbnail'); |
|
327 | + } |
|
328 | + |
|
329 | + |
|
330 | + /** |
|
331 | + * Gets the medium image |
|
332 | + * |
|
333 | + * @param array $wpdb_row |
|
334 | + * @param WP_REST_Request $request |
|
335 | + * @param EventControllerBase $controller |
|
336 | + * @return array |
|
337 | + * @throws EE_Error |
|
338 | + */ |
|
339 | + public function imageMedium($wpdb_row, $request, $controller) |
|
340 | + { |
|
341 | + return self::calculateImageData($wpdb_row, 'medium'); |
|
342 | + } |
|
343 | + |
|
344 | + |
|
345 | + /** |
|
346 | + * Gets the medium-large image |
|
347 | + * |
|
348 | + * @param array $wpdb_row |
|
349 | + * @param WP_REST_Request $request |
|
350 | + * @param EventControllerBase $controller |
|
351 | + * @return array |
|
352 | + * @throws EE_Error |
|
353 | + */ |
|
354 | + public function imageMediumLarge($wpdb_row, $request, $controller) |
|
355 | + { |
|
356 | + return self::calculateImageData($wpdb_row, 'medium_large'); |
|
357 | + } |
|
358 | + |
|
359 | + |
|
360 | + /** |
|
361 | + * Gets the large image |
|
362 | + * |
|
363 | + * @param array $wpdb_row |
|
364 | + * @param WP_REST_Request $request |
|
365 | + * @param EventControllerBase $controller |
|
366 | + * @return array |
|
367 | + * @throws EE_Error |
|
368 | + */ |
|
369 | + public function imageLarge($wpdb_row, $request, $controller) |
|
370 | + { |
|
371 | + return self::calculateImageData($wpdb_row, 'large'); |
|
372 | + } |
|
373 | + |
|
374 | + |
|
375 | + /** |
|
376 | + * Gets the post-thumbnail image |
|
377 | + * |
|
378 | + * @param array $wpdb_row |
|
379 | + * @param WP_REST_Request $request |
|
380 | + * @param EventControllerBase $controller |
|
381 | + * @return array |
|
382 | + * @throws EE_Error |
|
383 | + */ |
|
384 | + public function imagePostThumbnail($wpdb_row, $request, $controller) |
|
385 | + { |
|
386 | + return self::calculateImageData($wpdb_row, 'post-thumbnail'); |
|
387 | + } |
|
388 | + |
|
389 | + |
|
390 | + /** |
|
391 | + * Gets the full size image |
|
392 | + * |
|
393 | + * @param array $wpdb_row |
|
394 | + * @param WP_REST_Request $request |
|
395 | + * @param EventControllerBase $controller |
|
396 | + * @return array |
|
397 | + * @throws EE_Error |
|
398 | + */ |
|
399 | + public function imageFull($wpdb_row, $request, $controller) |
|
400 | + { |
|
401 | + return self::calculateImageData($wpdb_row, 'full'); |
|
402 | + } |
|
403 | + |
|
404 | + |
|
405 | + /** |
|
406 | + * Gets image specs and formats them for the display in the API, |
|
407 | + * according to the image size requested |
|
408 | + * |
|
409 | + * @param array $wpdb_row |
|
410 | + * @param string $image_size one of these: thumbnail, medium, medium_large, large, post-thumbnail, full |
|
411 | + * @return array|false if no such image exists. If array it will have keys 'url', 'width', 'height' and 'original' |
|
412 | + * @throws EE_Error |
|
413 | + */ |
|
414 | + protected function calculateImageData($wpdb_row, $image_size) |
|
415 | + { |
|
416 | + if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
417 | + throw new EE_Error( |
|
418 | + sprintf( |
|
419 | + esc_html__( |
|
420 | + // @codingStandardsIgnoreStart |
|
421 | + 'Cannot calculate image because the database row %1$s does not have an entry for "Event_CPT.ID"', |
|
422 | + // @codingStandardsIgnoreEnd |
|
423 | + 'event_espresso' |
|
424 | + ), |
|
425 | + print_r($wpdb_row, true) |
|
426 | + ) |
|
427 | + ); |
|
428 | + } |
|
429 | + $EVT_ID = $wpdb_row['Event_CPT.ID']; |
|
430 | + $attachment_id = get_post_thumbnail_id($EVT_ID); |
|
431 | + $data = wp_get_attachment_image_src($attachment_id, $image_size); |
|
432 | + if (! $data) { |
|
433 | + return null; |
|
434 | + } |
|
435 | + $generated = true; |
|
436 | + if (isset($data[3])) { |
|
437 | + $generated = $data[3]; |
|
438 | + } |
|
439 | + return array( |
|
440 | + 'url' => $data[0], |
|
441 | + 'width' => $data[1], |
|
442 | + 'height' => $data[2], |
|
443 | + 'generated' => $generated, |
|
444 | + ); |
|
445 | + } |
|
446 | + |
|
447 | + |
|
448 | + /** |
|
449 | + * Returns true if the array of data contains 'Event_CPT.ID'. False otherwise |
|
450 | + * |
|
451 | + * @param array $wpdb_row |
|
452 | + * @return bool |
|
453 | + */ |
|
454 | + protected function wpdbRowHasEventId($wpdb_row) |
|
455 | + { |
|
456 | + return (is_array($wpdb_row) && isset($wpdb_row['Event_CPT.ID']) && absint($wpdb_row['Event_CPT.ID'])); |
|
457 | + } |
|
458 | + |
|
459 | + |
|
460 | + /** |
|
461 | + * Provides an array for all the calculations possible that outlines a json schema for those calculations. |
|
462 | + * Array is indexed by calculation (snake case) and value is the schema for that calculation. |
|
463 | + * |
|
464 | + * @since 4.9.68.p |
|
465 | + * @return array |
|
466 | + */ |
|
467 | + public function schemaForCalculations() |
|
468 | + { |
|
469 | + $image_object_properties = array( |
|
470 | + 'url' => array( |
|
471 | + 'type' => 'string', |
|
472 | + ), |
|
473 | + 'width' => array( |
|
474 | + 'type' => 'number', |
|
475 | + ), |
|
476 | + 'height' => array( |
|
477 | + 'type' => 'number', |
|
478 | + ), |
|
479 | + 'generated' => array( |
|
480 | + 'type' => 'boolean', |
|
481 | + ), |
|
482 | + ); |
|
483 | + return array( |
|
484 | + 'optimum_sales_at_start' => array( |
|
485 | + 'description' => esc_html__( |
|
486 | + 'The total spaces on the event (not subtracting sales, but taking sales into account; so this is the optimum sales that CAN still be achieved.', |
|
487 | + 'event_espresso' |
|
488 | + ), |
|
489 | + 'type' => 'number', |
|
490 | + 'protected' => true, |
|
491 | + ), |
|
492 | + 'optimum_sales_now' => array( |
|
493 | + 'description' => esc_html__( |
|
494 | + 'The total spaces on the event (ignoring all sales; so this is the optimum sales that could have been achieved.', |
|
495 | + 'event_espresso' |
|
496 | + ), |
|
497 | + 'type' => 'number', |
|
498 | + 'protected' => true, |
|
499 | + ), |
|
500 | + 'spaces_remaining' => array( |
|
501 | + 'description' => esc_html__( |
|
502 | + 'The optimum_sales_number result, minus total sales so far.', |
|
503 | + 'event_espresso' |
|
504 | + ), |
|
505 | + 'type' => 'number', |
|
506 | + 'protected' => true, |
|
507 | + ), |
|
508 | + 'spots_taken' => array( |
|
509 | + 'description' => esc_html__( |
|
510 | + 'The number of approved registrations for this event (regardless of how many datetimes each registration\'s ticket purchase is for)', |
|
511 | + 'event_espresso' |
|
512 | + ), |
|
513 | + 'type' => 'number', |
|
514 | + 'protected' => true, |
|
515 | + ), |
|
516 | + 'spots_taken_pending_payment' => array( |
|
517 | + 'description' => esc_html__( |
|
518 | + 'The number of pending-payment registrations for this event (regardless of how many datetimes each registration\'s ticket purchase is for)', |
|
519 | + 'event_espresso' |
|
520 | + ), |
|
521 | + 'type' => 'number', |
|
522 | + 'protected' => true, |
|
523 | + ), |
|
524 | + 'registrations_checked_in_count' => array( |
|
525 | + 'description' => esc_html__( |
|
526 | + 'The count of all the registrations who have checked into one of this event\'s datetimes.', |
|
527 | + 'event_espresso' |
|
528 | + ), |
|
529 | + 'type' => 'number', |
|
530 | + 'protected' => true, |
|
531 | + ), |
|
532 | + 'registrations_checked_out_count' => array( |
|
533 | + 'description' => esc_html__( |
|
534 | + 'The count of all registrations who have checked out of one of this event\'s datetimes.', |
|
535 | + 'event_espresso' |
|
536 | + ), |
|
537 | + 'type' => 'number', |
|
538 | + 'protected' => true, |
|
539 | + ), |
|
540 | + 'image_thumbnail' => array( |
|
541 | + 'description' => esc_html__( |
|
542 | + 'The thumbnail image data.', |
|
543 | + 'event_espresso' |
|
544 | + ), |
|
545 | + 'type' => 'object', |
|
546 | + 'properties' => $image_object_properties, |
|
547 | + 'additionalProperties' => false, |
|
548 | + ), |
|
549 | + 'image_medium' => array( |
|
550 | + 'description' => esc_html__( |
|
551 | + 'The medium image data.', |
|
552 | + 'event_espresso' |
|
553 | + ), |
|
554 | + 'type' => 'object', |
|
555 | + 'properties' => $image_object_properties, |
|
556 | + 'additionalProperties' => false, |
|
557 | + ), |
|
558 | + 'image_medium_large' => array( |
|
559 | + 'description' => esc_html__( |
|
560 | + 'The medium-large image data.', |
|
561 | + 'event_espresso' |
|
562 | + ), |
|
563 | + 'type' => 'object', |
|
564 | + 'properties' => $image_object_properties, |
|
565 | + 'additionalProperties' => false, |
|
566 | + ), |
|
567 | + 'image_large' => array( |
|
568 | + 'description' => esc_html__( |
|
569 | + 'The large image data.', |
|
570 | + 'event_espresso' |
|
571 | + ), |
|
572 | + 'type' => 'object', |
|
573 | + 'properties' => $image_object_properties, |
|
574 | + 'additionalProperties' => false, |
|
575 | + ), |
|
576 | + 'image_post_thumbnail' => array( |
|
577 | + 'description' => esc_html__( |
|
578 | + 'The post-thumbnail image data.', |
|
579 | + 'event_espresso' |
|
580 | + ), |
|
581 | + 'type' => 'object', |
|
582 | + 'properties' => $image_object_properties, |
|
583 | + 'additionalProperties' => false, |
|
584 | + ), |
|
585 | + 'image_full' => array( |
|
586 | + 'description' => esc_html__( |
|
587 | + 'The full size image data', |
|
588 | + 'event_espresso' |
|
589 | + ), |
|
590 | + 'type' => 'object', |
|
591 | + 'properties' => $image_object_properties, |
|
592 | + 'additionalProperties' => false, |
|
593 | + ), |
|
594 | + ); |
|
595 | + } |
|
596 | 596 | } |
@@ -175,7 +175,7 @@ discard block |
||
175 | 175 | */ |
176 | 176 | public function spotsTaken($wpdb_row, $request, $controller) |
177 | 177 | { |
178 | - if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
178 | + if ( ! Event::wpdbRowHasEventId($wpdb_row)) { |
|
179 | 179 | throw new EE_Error( |
180 | 180 | sprintf( |
181 | 181 | esc_html__( |
@@ -217,7 +217,7 @@ discard block |
||
217 | 217 | */ |
218 | 218 | public function spotsTakenPendingPayment($wpdb_row, $request, $controller) |
219 | 219 | { |
220 | - if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
220 | + if ( ! Event::wpdbRowHasEventId($wpdb_row)) { |
|
221 | 221 | throw new EE_Error( |
222 | 222 | sprintf( |
223 | 223 | esc_html__( |
@@ -260,7 +260,7 @@ discard block |
||
260 | 260 | */ |
261 | 261 | public function registrationsCheckedInCount($wpdb_row, $request, $controller) |
262 | 262 | { |
263 | - if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
263 | + if ( ! Event::wpdbRowHasEventId($wpdb_row)) { |
|
264 | 264 | throw new EE_Error( |
265 | 265 | sprintf( |
266 | 266 | esc_html__( |
@@ -294,7 +294,7 @@ discard block |
||
294 | 294 | */ |
295 | 295 | public function registrationsCheckedOutCount($wpdb_row, $request, $controller) |
296 | 296 | { |
297 | - if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
297 | + if ( ! Event::wpdbRowHasEventId($wpdb_row)) { |
|
298 | 298 | throw new EE_Error( |
299 | 299 | sprintf( |
300 | 300 | esc_html__( |
@@ -413,7 +413,7 @@ discard block |
||
413 | 413 | */ |
414 | 414 | protected function calculateImageData($wpdb_row, $image_size) |
415 | 415 | { |
416 | - if (! Event::wpdbRowHasEventId($wpdb_row)) { |
|
416 | + if ( ! Event::wpdbRowHasEventId($wpdb_row)) { |
|
417 | 417 | throw new EE_Error( |
418 | 418 | sprintf( |
419 | 419 | esc_html__( |
@@ -429,7 +429,7 @@ discard block |
||
429 | 429 | $EVT_ID = $wpdb_row['Event_CPT.ID']; |
430 | 430 | $attachment_id = get_post_thumbnail_id($EVT_ID); |
431 | 431 | $data = wp_get_attachment_image_src($attachment_id, $image_size); |
432 | - if (! $data) { |
|
432 | + if ( ! $data) { |
|
433 | 433 | return null; |
434 | 434 | } |
435 | 435 | $generated = true; |
@@ -15,88 +15,88 @@ |
||
15 | 15 | * ------------------------------------------------------------------------ |
16 | 16 | */ |
17 | 17 | /** |
18 | - * |
|
19 | - * Class EE_Receipt_Line_Item_Display_Strategy |
|
20 | - * |
|
21 | - * Description |
|
22 | - * |
|
23 | - * @package Event Espresso |
|
24 | - * @subpackage core |
|
25 | - * @author Brent Christensen |
|
26 | - * |
|
27 | - * |
|
28 | - */ |
|
18 | + * |
|
19 | + * Class EE_Receipt_Line_Item_Display_Strategy |
|
20 | + * |
|
21 | + * Description |
|
22 | + * |
|
23 | + * @package Event Espresso |
|
24 | + * @subpackage core |
|
25 | + * @author Brent Christensen |
|
26 | + * |
|
27 | + * |
|
28 | + */ |
|
29 | 29 | |
30 | 30 | class EE_Receipt_Line_Item_Display_Strategy implements EEI_Line_Item_Display |
31 | 31 | { |
32 | 32 | |
33 | - /** |
|
34 | - * @param EE_Line_Item $line_item |
|
35 | - * @param array $options |
|
36 | - * @return mixed |
|
37 | - */ |
|
38 | - public function display_line_item(EE_Line_Item $line_item, $options = array()) |
|
39 | - { |
|
33 | + /** |
|
34 | + * @param EE_Line_Item $line_item |
|
35 | + * @param array $options |
|
36 | + * @return mixed |
|
37 | + */ |
|
38 | + public function display_line_item(EE_Line_Item $line_item, $options = array()) |
|
39 | + { |
|
40 | 40 | |
41 | - $html = ''; |
|
42 | - // set some default options and merge with incoming |
|
43 | - $default_options = array( |
|
44 | - 'show_desc' => true, |
|
45 | - 'odd' => false |
|
46 | - ); |
|
47 | - $options = array_merge($default_options, (array) $options); |
|
48 | - switch ($line_item->type()) { |
|
49 | - case EEM_Line_Item::type_total: |
|
50 | - // loop thru children |
|
51 | - foreach ($line_item->children() as $child_line_item) { |
|
52 | - // recursively feed children back into this method |
|
41 | + $html = ''; |
|
42 | + // set some default options and merge with incoming |
|
43 | + $default_options = array( |
|
44 | + 'show_desc' => true, |
|
45 | + 'odd' => false |
|
46 | + ); |
|
47 | + $options = array_merge($default_options, (array) $options); |
|
48 | + switch ($line_item->type()) { |
|
49 | + case EEM_Line_Item::type_total: |
|
50 | + // loop thru children |
|
51 | + foreach ($line_item->children() as $child_line_item) { |
|
52 | + // recursively feed children back into this method |
|
53 | 53 | // $html .= $this->display_line_item( $child_line_item, $options ); |
54 | - } |
|
54 | + } |
|
55 | 55 | // $html .= $this->_separator_row( $options ); |
56 | 56 | // $html .= $this->_total_row( $line_item, esc_html__('Total', 'event_espresso'), $options ); |
57 | - break; |
|
57 | + break; |
|
58 | 58 | |
59 | 59 | |
60 | - case EEM_Line_Item::type_sub_total: |
|
61 | - // loop thru children |
|
62 | - foreach ($line_item->children() as $child_line_item) { |
|
63 | - // recursively feed children back into this method |
|
60 | + case EEM_Line_Item::type_sub_total: |
|
61 | + // loop thru children |
|
62 | + foreach ($line_item->children() as $child_line_item) { |
|
63 | + // recursively feed children back into this method |
|
64 | 64 | // $html .= $this->display_line_item( $child_line_item, $options ); |
65 | - } |
|
65 | + } |
|
66 | 66 | // $html .= $this->_total_row( $line_item, esc_html__('Sub-Total', 'event_espresso'), $options ); |
67 | - break; |
|
67 | + break; |
|
68 | 68 | |
69 | 69 | |
70 | - case EEM_Line_Item::type_tax_sub_total: |
|
71 | - // loop thru children |
|
72 | - foreach ($line_item->children() as $child_line_item) { |
|
73 | - // recursively feed children back into this method |
|
70 | + case EEM_Line_Item::type_tax_sub_total: |
|
71 | + // loop thru children |
|
72 | + foreach ($line_item->children() as $child_line_item) { |
|
73 | + // recursively feed children back into this method |
|
74 | 74 | // $html .= $this->display_line_item( $child_line_item, $options ); |
75 | - } |
|
75 | + } |
|
76 | 76 | // $html .= $this->_total_row( $line_item, esc_html__('Tax Total', 'event_espresso'), $options ); |
77 | - break; |
|
77 | + break; |
|
78 | 78 | |
79 | 79 | |
80 | - case EEM_Line_Item::type_line_item: |
|
81 | - // item row |
|
80 | + case EEM_Line_Item::type_line_item: |
|
81 | + // item row |
|
82 | 82 | // $html .= $this->_item_row( $line_item, $options ); |
83 | - // got any kids? |
|
84 | - foreach ($line_item->children() as $child_line_item) { |
|
83 | + // got any kids? |
|
84 | + foreach ($line_item->children() as $child_line_item) { |
|
85 | 85 | // $this->display_line_item( $child_line_item, $options ); |
86 | - } |
|
87 | - break; |
|
86 | + } |
|
87 | + break; |
|
88 | 88 | |
89 | 89 | |
90 | - case EEM_Line_Item::type_sub_line_item: |
|
90 | + case EEM_Line_Item::type_sub_line_item: |
|
91 | 91 | // $html .= $this->_sub_item_row( $line_item, $options ); |
92 | - break; |
|
92 | + break; |
|
93 | 93 | |
94 | 94 | |
95 | - case EEM_Line_Item::type_tax: |
|
95 | + case EEM_Line_Item::type_tax: |
|
96 | 96 | // $html .= $this->_tax_row( $line_item, $options ); |
97 | - break; |
|
98 | - } |
|
97 | + break; |
|
98 | + } |
|
99 | 99 | |
100 | - return $html; |
|
101 | - } |
|
100 | + return $html; |
|
101 | + } |
|
102 | 102 | } |
@@ -15,332 +15,332 @@ |
||
15 | 15 | { |
16 | 16 | |
17 | 17 | |
18 | - /** |
|
19 | - * whether to display the taxes row or not |
|
20 | - * @type bool $_show_taxes |
|
21 | - */ |
|
22 | - protected $_show_taxes = false; |
|
23 | - |
|
24 | - /** |
|
25 | - * html for any tax rows |
|
26 | - * @type string $_show_taxes |
|
27 | - */ |
|
28 | - protected $_taxes_html = ''; |
|
29 | - |
|
30 | - |
|
31 | - /** |
|
32 | - * total amount including tax we can bill for at this time |
|
33 | - * @type float $_grand_total |
|
34 | - */ |
|
35 | - protected $_grand_total = 0.00; |
|
36 | - |
|
37 | - |
|
38 | - |
|
39 | - /** |
|
40 | - * @return float |
|
41 | - */ |
|
42 | - public function grand_total() |
|
43 | - { |
|
44 | - return $this->_grand_total; |
|
45 | - } |
|
46 | - |
|
47 | - |
|
48 | - |
|
49 | - /** |
|
50 | - * This is used to output a single |
|
51 | - * @param EE_Line_Item $line_item |
|
52 | - * @param array $options |
|
53 | - * @return mixed |
|
54 | - */ |
|
55 | - public function display_line_item(EE_Line_Item $line_item, $options = array()) |
|
56 | - { |
|
57 | - |
|
58 | - $html = ''; |
|
59 | - // set some default options and merge with incoming |
|
60 | - $default_options = array( |
|
61 | - 'odd' => true, |
|
62 | - 'use_table_wrapper' => true, |
|
63 | - 'table_css_class' => 'admin-primary-mbox-tbl', |
|
64 | - 'taxes_tr_css_class' => 'admin-primary-mbox-taxes-tr', |
|
65 | - 'total_tr_css_class' => 'admin-primary-mbox-total-tr' |
|
66 | - ); |
|
67 | - $options = array_merge($default_options, (array) $options); |
|
68 | - |
|
69 | - switch ($line_item->type()) { |
|
70 | - case EEM_Line_Item::type_line_item: |
|
71 | - // item row |
|
72 | - $html .= $this->_item_row($line_item, $options); |
|
73 | - break; |
|
74 | - |
|
75 | - case EEM_Line_Item::type_sub_line_item: |
|
76 | - $html .= $this->_sub_item_row($line_item, $options); |
|
77 | - break; |
|
78 | - |
|
79 | - case EEM_Line_Item::type_sub_total: |
|
80 | - if ($line_item->quantity() === 0) { |
|
81 | - return $html; |
|
82 | - } |
|
83 | - // loop through children |
|
84 | - $child_line_items = $line_item->children(); |
|
85 | - // loop through children |
|
86 | - foreach ($child_line_items as $child_line_item) { |
|
87 | - // recursively feed children back into this method |
|
88 | - $html .= $this->display_line_item($child_line_item, $options); |
|
89 | - } |
|
90 | - $html .= $this->_sub_total_row($line_item, $options); |
|
91 | - break; |
|
92 | - |
|
93 | - case EEM_Line_Item::type_tax: |
|
94 | - if ($this->_show_taxes) { |
|
95 | - $this->_taxes_html .= $this->_tax_row($line_item, $options); |
|
96 | - } |
|
97 | - break; |
|
98 | - |
|
99 | - case EEM_Line_Item::type_tax_sub_total: |
|
100 | - foreach ($line_item->children() as $child_line_item) { |
|
101 | - if ($child_line_item->type() == EEM_Line_Item::type_tax) { |
|
102 | - $this->display_line_item($child_line_item, $options); |
|
103 | - } |
|
104 | - } |
|
105 | - break; |
|
106 | - |
|
107 | - case EEM_Line_Item::type_total: |
|
108 | - // determine whether to display taxes or not |
|
109 | - $this->_show_taxes = $line_item->get_total_tax() > 0 ? true : false; |
|
110 | - // get all child line items |
|
111 | - $children = $line_item->children(); |
|
112 | - |
|
113 | - // loop thru all non-tax child line items |
|
114 | - foreach ($children as $child_line_item) { |
|
115 | - $html .= $this->display_line_item($child_line_item, $options); |
|
116 | - } |
|
117 | - |
|
118 | - $html .= $this->_taxes_html; |
|
119 | - $html .= $this->_total_row($line_item, $options); |
|
120 | - if ($options['use_table_wrapper']) { |
|
121 | - $html = $this->_table_header($options) . $html . $this->_table_footer($options); |
|
122 | - } |
|
123 | - break; |
|
124 | - } |
|
125 | - |
|
126 | - return $html; |
|
127 | - } |
|
128 | - |
|
129 | - |
|
130 | - |
|
131 | - /** |
|
132 | - * Table header for display. |
|
133 | - * @since 4.8 |
|
134 | - * @param array $options |
|
135 | - * @return string |
|
136 | - */ |
|
137 | - protected function _table_header($options) |
|
138 | - { |
|
139 | - $html = EEH_HTML::table('', '', $options['table_css_class']); |
|
140 | - $html .= EEH_HTML::thead(); |
|
141 | - $html .= EEH_HTML::tr(); |
|
142 | - $html .= EEH_HTML::th(esc_html__('Name', 'event_espresso'), '', 'jst-left'); |
|
143 | - $html .= EEH_HTML::th(esc_html__('Type', 'event_espresso'), '', 'jst-left'); |
|
144 | - $html .= EEH_HTML::th(esc_html__('Amount', 'event_espresso'), '', 'jst-cntr'); |
|
145 | - $html .= EEH_HTML::th(esc_html__('Qty', 'event_espresso'), '', 'jst-cntr'); |
|
146 | - $html .= EEH_HTML::th(esc_html__('Line Total', 'event_espresso'), '', 'jst-cntr'); |
|
147 | - $html .= EEH_HTML::tbody(); |
|
148 | - return $html; |
|
149 | - } |
|
150 | - |
|
151 | - |
|
152 | - /** |
|
153 | - * Table footer for display |
|
154 | - * @since 4.8 |
|
155 | - * @param array $options array of options for the table. |
|
156 | - * @return string |
|
157 | - */ |
|
158 | - protected function _table_footer($options) |
|
159 | - { |
|
160 | - return EEH_HTML::tbodyx() . EEH_HTML::tablex(); |
|
161 | - } |
|
162 | - |
|
163 | - |
|
164 | - |
|
165 | - /** |
|
166 | - * _item_row |
|
167 | - * |
|
168 | - * @param EE_Line_Item $line_item |
|
169 | - * @param array $options |
|
170 | - * @return mixed |
|
171 | - */ |
|
172 | - protected function _item_row(EE_Line_Item $line_item, $options = array()) |
|
173 | - { |
|
174 | - $line_item_related_object = $line_item->get_object(); |
|
175 | - $parent_line_item_related_object = $line_item->parent() instanceof EE_Line_Item ? $line_item->parent()->get_object() : null; |
|
176 | - // start of row |
|
177 | - $row_class = $options['odd'] ? 'item odd' : 'item'; |
|
178 | - $html = EEH_HTML::tr('', '', $row_class); |
|
179 | - |
|
180 | - |
|
181 | - // Name Column |
|
182 | - $name_link = $line_item_related_object instanceof EEI_Admin_Links ? $line_item_related_object->get_admin_details_link() : ''; |
|
183 | - |
|
184 | - // related object scope. |
|
185 | - $parent_related_object_name = $parent_line_item_related_object instanceof EEI_Line_Item_Object ? $parent_line_item_related_object->name() : ''; |
|
186 | - $parent_related_object_name = empty($parent_related_object_name) && $line_item->parent() instanceof EE_Line_Item ? $line_item->parent()->name() : $parent_related_object_name; |
|
187 | - $parent_related_object_link = $parent_line_item_related_object instanceof EEI_Admin_Links ? $parent_line_item_related_object->get_admin_details_link() : ''; |
|
188 | - |
|
189 | - |
|
190 | - $name_html = $line_item_related_object instanceof EEI_Line_Item_Object ? $line_item_related_object->name() : $line_item->name(); |
|
191 | - $name_html = $name_link ? '<a href="' . $name_link . '">' . $name_html . '</a>' : $name_html; |
|
192 | - $name_html .= $line_item->is_taxable() ? ' *' : ''; |
|
193 | - // maybe preface with icon? |
|
194 | - $name_html = $line_item_related_object instanceof EEI_Has_Icon ? $line_item_related_object->get_icon() . $name_html : $name_html; |
|
195 | - $name_html = '<span class="ee-line-item-name linked">' . $name_html . '</span><br>'; |
|
196 | - $name_html .= sprintf( |
|
197 | - _x('%1$sfor the %2$s: %3$s%4$s', 'eg. "for the Event: My Cool Event"', 'event_espresso'), |
|
198 | - '<span class="ee-line-item-related-parent-object">', |
|
199 | - $line_item->parent() instanceof EE_Line_Item ? $line_item->parent()->OBJ_type_i18n() : esc_html__('Item:', 'event_espresso'), |
|
200 | - $parent_related_object_link ? '<a href="' . $parent_related_object_link . '">' . $parent_related_object_name . '</a>' : $parent_related_object_name, |
|
201 | - '</span>' |
|
202 | - ); |
|
203 | - |
|
204 | - $name_html = apply_filters( |
|
205 | - 'FHEE__EE_Admin_Table_Line_Item_Display_Strategy___item_row__name_html', |
|
206 | - $name_html, |
|
207 | - $line_item, |
|
208 | - $options |
|
209 | - ); |
|
210 | - |
|
211 | - $html .= EEH_HTML::td($name_html, '', 'jst-left'); |
|
212 | - // Type Column |
|
213 | - $type_html = $line_item->OBJ_type() ? $line_item->OBJ_type_i18n() : ''; |
|
214 | - $type_html .= $this->_get_cancellations($line_item); |
|
215 | - $type_html .= $line_item->OBJ_type() ? '<br />' : ''; |
|
216 | - $code = $line_item_related_object instanceof EEI_Has_Code ? $line_item_related_object->code() : ''; |
|
217 | - $type_html .= ! empty($code) ? '<span class="ee-line-item-id">' . sprintf(esc_html__('Code: %s', 'event_espresso'), $code) . '</span>' : ''; |
|
218 | - $html .= EEH_HTML::td($type_html, '', 'jst-left'); |
|
219 | - |
|
220 | - |
|
221 | - // Amount Column |
|
222 | - if ($line_item->is_percent()) { |
|
223 | - $html .= EEH_HTML::td($line_item->percent() . '%', '', 'jst-rght'); |
|
224 | - } else { |
|
225 | - $html .= EEH_HTML::td($line_item->unit_price_no_code(), '', 'jst-rght'); |
|
226 | - } |
|
227 | - |
|
228 | - // QTY column |
|
229 | - $html .= EEH_HTML::td($line_item->quantity(), '', 'jst-rght'); |
|
230 | - |
|
231 | - // total column |
|
232 | - $html .= EEH_HTML::td(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
|
233 | - |
|
234 | - // finish things off and return |
|
235 | - $html .= EEH_HTML::trx(); |
|
236 | - return $html; |
|
237 | - } |
|
238 | - |
|
239 | - |
|
240 | - |
|
241 | - /** |
|
242 | - * _get_cancellations |
|
243 | - * |
|
244 | - * @param EE_Line_Item $line_item |
|
245 | - * @return string |
|
246 | - */ |
|
247 | - protected function _get_cancellations(EE_Line_Item $line_item) |
|
248 | - { |
|
249 | - $html = ''; |
|
250 | - $cancellations = $line_item->get_cancellations(); |
|
251 | - $cancellation = reset($cancellations); |
|
252 | - // \EEH_Debug_Tools::printr( $cancellation, '$cancellation', __FILE__, __LINE__ ); |
|
253 | - if ($cancellation instanceof EE_Line_Item) { |
|
254 | - $html .= ' <span class="ee-line-item-id">'; |
|
255 | - $html .= sprintf( |
|
256 | - _n( |
|
257 | - '(%1$s Cancellation)', |
|
258 | - '(%1$s Cancellations)', |
|
259 | - $cancellation->quantity(), |
|
260 | - 'event_espresso' |
|
261 | - ), |
|
262 | - $cancellation->quantity() |
|
263 | - ); |
|
264 | - $html .= '</span>'; |
|
265 | - } |
|
266 | - return $html; |
|
267 | - } |
|
268 | - |
|
269 | - |
|
270 | - |
|
271 | - /** |
|
272 | - * _sub_item_row |
|
273 | - * |
|
274 | - * @param EE_Line_Item $line_item |
|
275 | - * @param array $options |
|
276 | - * @return mixed |
|
277 | - */ |
|
278 | - protected function _sub_item_row(EE_Line_Item $line_item, $options = array()) |
|
279 | - { |
|
280 | - // for now we're not showing sub-items |
|
281 | - return ''; |
|
282 | - } |
|
283 | - |
|
284 | - |
|
285 | - |
|
286 | - /** |
|
287 | - * _tax_row |
|
288 | - * |
|
289 | - * @param EE_Line_Item $line_item |
|
290 | - * @param array $options |
|
291 | - * @return mixed |
|
292 | - */ |
|
293 | - protected function _tax_row(EE_Line_Item $line_item, $options = array()) |
|
294 | - { |
|
295 | - // start of row |
|
296 | - $html = EEH_HTML::tr('', 'admin-primary-mbox-taxes-tr'); |
|
297 | - // name th |
|
298 | - $html .= EEH_HTML::th($line_item->name() . '(' . $line_item->get_pretty('LIN_percent') . '%)', '', 'jst-rght', '', ' colspan="4"'); |
|
299 | - // total th |
|
300 | - $html .= EEH_HTML::th(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
|
301 | - // end of row |
|
302 | - $html .= EEH_HTML::trx(); |
|
303 | - return $html; |
|
304 | - } |
|
305 | - |
|
306 | - |
|
307 | - |
|
308 | - |
|
309 | - /** |
|
310 | - * _total_row |
|
311 | - * |
|
312 | - * @param EE_Line_Item $line_item |
|
313 | - * @param string $text |
|
314 | - * @param array $options |
|
315 | - * @return mixed |
|
316 | - */ |
|
317 | - protected function _sub_total_row(EE_Line_Item $line_item, $text = '', $options = array()) |
|
318 | - { |
|
319 | - // currently not showing subtotal row |
|
320 | - return ''; |
|
321 | - } |
|
322 | - |
|
323 | - |
|
324 | - |
|
325 | - /** |
|
326 | - * _total_row |
|
327 | - * |
|
328 | - * @param EE_Line_Item $line_item |
|
329 | - * @param array $options |
|
330 | - * @return mixed |
|
331 | - */ |
|
332 | - protected function _total_row(EE_Line_Item $line_item, $options = array()) |
|
333 | - { |
|
334 | - // start of row |
|
335 | - $html = EEH_HTML::tr('', '', 'admin-primary-mbox-total-tr'); |
|
336 | - // Total th label |
|
337 | - $total_label = sprintf(esc_html__('Transaction Total %s', 'event_espresso'), '(' . EE_Registry::instance()->CFG->currency->code . ')'); |
|
338 | - $html .= EEH_HTML::th($total_label, '', 'jst-rght', '', ' colspan="4"'); |
|
339 | - // total th |
|
340 | - |
|
341 | - $html .= EEH_HTML::th(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
|
342 | - // end of row |
|
343 | - $html .= EEH_HTML::trx(); |
|
344 | - return $html; |
|
345 | - } |
|
18 | + /** |
|
19 | + * whether to display the taxes row or not |
|
20 | + * @type bool $_show_taxes |
|
21 | + */ |
|
22 | + protected $_show_taxes = false; |
|
23 | + |
|
24 | + /** |
|
25 | + * html for any tax rows |
|
26 | + * @type string $_show_taxes |
|
27 | + */ |
|
28 | + protected $_taxes_html = ''; |
|
29 | + |
|
30 | + |
|
31 | + /** |
|
32 | + * total amount including tax we can bill for at this time |
|
33 | + * @type float $_grand_total |
|
34 | + */ |
|
35 | + protected $_grand_total = 0.00; |
|
36 | + |
|
37 | + |
|
38 | + |
|
39 | + /** |
|
40 | + * @return float |
|
41 | + */ |
|
42 | + public function grand_total() |
|
43 | + { |
|
44 | + return $this->_grand_total; |
|
45 | + } |
|
46 | + |
|
47 | + |
|
48 | + |
|
49 | + /** |
|
50 | + * This is used to output a single |
|
51 | + * @param EE_Line_Item $line_item |
|
52 | + * @param array $options |
|
53 | + * @return mixed |
|
54 | + */ |
|
55 | + public function display_line_item(EE_Line_Item $line_item, $options = array()) |
|
56 | + { |
|
57 | + |
|
58 | + $html = ''; |
|
59 | + // set some default options and merge with incoming |
|
60 | + $default_options = array( |
|
61 | + 'odd' => true, |
|
62 | + 'use_table_wrapper' => true, |
|
63 | + 'table_css_class' => 'admin-primary-mbox-tbl', |
|
64 | + 'taxes_tr_css_class' => 'admin-primary-mbox-taxes-tr', |
|
65 | + 'total_tr_css_class' => 'admin-primary-mbox-total-tr' |
|
66 | + ); |
|
67 | + $options = array_merge($default_options, (array) $options); |
|
68 | + |
|
69 | + switch ($line_item->type()) { |
|
70 | + case EEM_Line_Item::type_line_item: |
|
71 | + // item row |
|
72 | + $html .= $this->_item_row($line_item, $options); |
|
73 | + break; |
|
74 | + |
|
75 | + case EEM_Line_Item::type_sub_line_item: |
|
76 | + $html .= $this->_sub_item_row($line_item, $options); |
|
77 | + break; |
|
78 | + |
|
79 | + case EEM_Line_Item::type_sub_total: |
|
80 | + if ($line_item->quantity() === 0) { |
|
81 | + return $html; |
|
82 | + } |
|
83 | + // loop through children |
|
84 | + $child_line_items = $line_item->children(); |
|
85 | + // loop through children |
|
86 | + foreach ($child_line_items as $child_line_item) { |
|
87 | + // recursively feed children back into this method |
|
88 | + $html .= $this->display_line_item($child_line_item, $options); |
|
89 | + } |
|
90 | + $html .= $this->_sub_total_row($line_item, $options); |
|
91 | + break; |
|
92 | + |
|
93 | + case EEM_Line_Item::type_tax: |
|
94 | + if ($this->_show_taxes) { |
|
95 | + $this->_taxes_html .= $this->_tax_row($line_item, $options); |
|
96 | + } |
|
97 | + break; |
|
98 | + |
|
99 | + case EEM_Line_Item::type_tax_sub_total: |
|
100 | + foreach ($line_item->children() as $child_line_item) { |
|
101 | + if ($child_line_item->type() == EEM_Line_Item::type_tax) { |
|
102 | + $this->display_line_item($child_line_item, $options); |
|
103 | + } |
|
104 | + } |
|
105 | + break; |
|
106 | + |
|
107 | + case EEM_Line_Item::type_total: |
|
108 | + // determine whether to display taxes or not |
|
109 | + $this->_show_taxes = $line_item->get_total_tax() > 0 ? true : false; |
|
110 | + // get all child line items |
|
111 | + $children = $line_item->children(); |
|
112 | + |
|
113 | + // loop thru all non-tax child line items |
|
114 | + foreach ($children as $child_line_item) { |
|
115 | + $html .= $this->display_line_item($child_line_item, $options); |
|
116 | + } |
|
117 | + |
|
118 | + $html .= $this->_taxes_html; |
|
119 | + $html .= $this->_total_row($line_item, $options); |
|
120 | + if ($options['use_table_wrapper']) { |
|
121 | + $html = $this->_table_header($options) . $html . $this->_table_footer($options); |
|
122 | + } |
|
123 | + break; |
|
124 | + } |
|
125 | + |
|
126 | + return $html; |
|
127 | + } |
|
128 | + |
|
129 | + |
|
130 | + |
|
131 | + /** |
|
132 | + * Table header for display. |
|
133 | + * @since 4.8 |
|
134 | + * @param array $options |
|
135 | + * @return string |
|
136 | + */ |
|
137 | + protected function _table_header($options) |
|
138 | + { |
|
139 | + $html = EEH_HTML::table('', '', $options['table_css_class']); |
|
140 | + $html .= EEH_HTML::thead(); |
|
141 | + $html .= EEH_HTML::tr(); |
|
142 | + $html .= EEH_HTML::th(esc_html__('Name', 'event_espresso'), '', 'jst-left'); |
|
143 | + $html .= EEH_HTML::th(esc_html__('Type', 'event_espresso'), '', 'jst-left'); |
|
144 | + $html .= EEH_HTML::th(esc_html__('Amount', 'event_espresso'), '', 'jst-cntr'); |
|
145 | + $html .= EEH_HTML::th(esc_html__('Qty', 'event_espresso'), '', 'jst-cntr'); |
|
146 | + $html .= EEH_HTML::th(esc_html__('Line Total', 'event_espresso'), '', 'jst-cntr'); |
|
147 | + $html .= EEH_HTML::tbody(); |
|
148 | + return $html; |
|
149 | + } |
|
150 | + |
|
151 | + |
|
152 | + /** |
|
153 | + * Table footer for display |
|
154 | + * @since 4.8 |
|
155 | + * @param array $options array of options for the table. |
|
156 | + * @return string |
|
157 | + */ |
|
158 | + protected function _table_footer($options) |
|
159 | + { |
|
160 | + return EEH_HTML::tbodyx() . EEH_HTML::tablex(); |
|
161 | + } |
|
162 | + |
|
163 | + |
|
164 | + |
|
165 | + /** |
|
166 | + * _item_row |
|
167 | + * |
|
168 | + * @param EE_Line_Item $line_item |
|
169 | + * @param array $options |
|
170 | + * @return mixed |
|
171 | + */ |
|
172 | + protected function _item_row(EE_Line_Item $line_item, $options = array()) |
|
173 | + { |
|
174 | + $line_item_related_object = $line_item->get_object(); |
|
175 | + $parent_line_item_related_object = $line_item->parent() instanceof EE_Line_Item ? $line_item->parent()->get_object() : null; |
|
176 | + // start of row |
|
177 | + $row_class = $options['odd'] ? 'item odd' : 'item'; |
|
178 | + $html = EEH_HTML::tr('', '', $row_class); |
|
179 | + |
|
180 | + |
|
181 | + // Name Column |
|
182 | + $name_link = $line_item_related_object instanceof EEI_Admin_Links ? $line_item_related_object->get_admin_details_link() : ''; |
|
183 | + |
|
184 | + // related object scope. |
|
185 | + $parent_related_object_name = $parent_line_item_related_object instanceof EEI_Line_Item_Object ? $parent_line_item_related_object->name() : ''; |
|
186 | + $parent_related_object_name = empty($parent_related_object_name) && $line_item->parent() instanceof EE_Line_Item ? $line_item->parent()->name() : $parent_related_object_name; |
|
187 | + $parent_related_object_link = $parent_line_item_related_object instanceof EEI_Admin_Links ? $parent_line_item_related_object->get_admin_details_link() : ''; |
|
188 | + |
|
189 | + |
|
190 | + $name_html = $line_item_related_object instanceof EEI_Line_Item_Object ? $line_item_related_object->name() : $line_item->name(); |
|
191 | + $name_html = $name_link ? '<a href="' . $name_link . '">' . $name_html . '</a>' : $name_html; |
|
192 | + $name_html .= $line_item->is_taxable() ? ' *' : ''; |
|
193 | + // maybe preface with icon? |
|
194 | + $name_html = $line_item_related_object instanceof EEI_Has_Icon ? $line_item_related_object->get_icon() . $name_html : $name_html; |
|
195 | + $name_html = '<span class="ee-line-item-name linked">' . $name_html . '</span><br>'; |
|
196 | + $name_html .= sprintf( |
|
197 | + _x('%1$sfor the %2$s: %3$s%4$s', 'eg. "for the Event: My Cool Event"', 'event_espresso'), |
|
198 | + '<span class="ee-line-item-related-parent-object">', |
|
199 | + $line_item->parent() instanceof EE_Line_Item ? $line_item->parent()->OBJ_type_i18n() : esc_html__('Item:', 'event_espresso'), |
|
200 | + $parent_related_object_link ? '<a href="' . $parent_related_object_link . '">' . $parent_related_object_name . '</a>' : $parent_related_object_name, |
|
201 | + '</span>' |
|
202 | + ); |
|
203 | + |
|
204 | + $name_html = apply_filters( |
|
205 | + 'FHEE__EE_Admin_Table_Line_Item_Display_Strategy___item_row__name_html', |
|
206 | + $name_html, |
|
207 | + $line_item, |
|
208 | + $options |
|
209 | + ); |
|
210 | + |
|
211 | + $html .= EEH_HTML::td($name_html, '', 'jst-left'); |
|
212 | + // Type Column |
|
213 | + $type_html = $line_item->OBJ_type() ? $line_item->OBJ_type_i18n() : ''; |
|
214 | + $type_html .= $this->_get_cancellations($line_item); |
|
215 | + $type_html .= $line_item->OBJ_type() ? '<br />' : ''; |
|
216 | + $code = $line_item_related_object instanceof EEI_Has_Code ? $line_item_related_object->code() : ''; |
|
217 | + $type_html .= ! empty($code) ? '<span class="ee-line-item-id">' . sprintf(esc_html__('Code: %s', 'event_espresso'), $code) . '</span>' : ''; |
|
218 | + $html .= EEH_HTML::td($type_html, '', 'jst-left'); |
|
219 | + |
|
220 | + |
|
221 | + // Amount Column |
|
222 | + if ($line_item->is_percent()) { |
|
223 | + $html .= EEH_HTML::td($line_item->percent() . '%', '', 'jst-rght'); |
|
224 | + } else { |
|
225 | + $html .= EEH_HTML::td($line_item->unit_price_no_code(), '', 'jst-rght'); |
|
226 | + } |
|
227 | + |
|
228 | + // QTY column |
|
229 | + $html .= EEH_HTML::td($line_item->quantity(), '', 'jst-rght'); |
|
230 | + |
|
231 | + // total column |
|
232 | + $html .= EEH_HTML::td(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
|
233 | + |
|
234 | + // finish things off and return |
|
235 | + $html .= EEH_HTML::trx(); |
|
236 | + return $html; |
|
237 | + } |
|
238 | + |
|
239 | + |
|
240 | + |
|
241 | + /** |
|
242 | + * _get_cancellations |
|
243 | + * |
|
244 | + * @param EE_Line_Item $line_item |
|
245 | + * @return string |
|
246 | + */ |
|
247 | + protected function _get_cancellations(EE_Line_Item $line_item) |
|
248 | + { |
|
249 | + $html = ''; |
|
250 | + $cancellations = $line_item->get_cancellations(); |
|
251 | + $cancellation = reset($cancellations); |
|
252 | + // \EEH_Debug_Tools::printr( $cancellation, '$cancellation', __FILE__, __LINE__ ); |
|
253 | + if ($cancellation instanceof EE_Line_Item) { |
|
254 | + $html .= ' <span class="ee-line-item-id">'; |
|
255 | + $html .= sprintf( |
|
256 | + _n( |
|
257 | + '(%1$s Cancellation)', |
|
258 | + '(%1$s Cancellations)', |
|
259 | + $cancellation->quantity(), |
|
260 | + 'event_espresso' |
|
261 | + ), |
|
262 | + $cancellation->quantity() |
|
263 | + ); |
|
264 | + $html .= '</span>'; |
|
265 | + } |
|
266 | + return $html; |
|
267 | + } |
|
268 | + |
|
269 | + |
|
270 | + |
|
271 | + /** |
|
272 | + * _sub_item_row |
|
273 | + * |
|
274 | + * @param EE_Line_Item $line_item |
|
275 | + * @param array $options |
|
276 | + * @return mixed |
|
277 | + */ |
|
278 | + protected function _sub_item_row(EE_Line_Item $line_item, $options = array()) |
|
279 | + { |
|
280 | + // for now we're not showing sub-items |
|
281 | + return ''; |
|
282 | + } |
|
283 | + |
|
284 | + |
|
285 | + |
|
286 | + /** |
|
287 | + * _tax_row |
|
288 | + * |
|
289 | + * @param EE_Line_Item $line_item |
|
290 | + * @param array $options |
|
291 | + * @return mixed |
|
292 | + */ |
|
293 | + protected function _tax_row(EE_Line_Item $line_item, $options = array()) |
|
294 | + { |
|
295 | + // start of row |
|
296 | + $html = EEH_HTML::tr('', 'admin-primary-mbox-taxes-tr'); |
|
297 | + // name th |
|
298 | + $html .= EEH_HTML::th($line_item->name() . '(' . $line_item->get_pretty('LIN_percent') . '%)', '', 'jst-rght', '', ' colspan="4"'); |
|
299 | + // total th |
|
300 | + $html .= EEH_HTML::th(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
|
301 | + // end of row |
|
302 | + $html .= EEH_HTML::trx(); |
|
303 | + return $html; |
|
304 | + } |
|
305 | + |
|
306 | + |
|
307 | + |
|
308 | + |
|
309 | + /** |
|
310 | + * _total_row |
|
311 | + * |
|
312 | + * @param EE_Line_Item $line_item |
|
313 | + * @param string $text |
|
314 | + * @param array $options |
|
315 | + * @return mixed |
|
316 | + */ |
|
317 | + protected function _sub_total_row(EE_Line_Item $line_item, $text = '', $options = array()) |
|
318 | + { |
|
319 | + // currently not showing subtotal row |
|
320 | + return ''; |
|
321 | + } |
|
322 | + |
|
323 | + |
|
324 | + |
|
325 | + /** |
|
326 | + * _total_row |
|
327 | + * |
|
328 | + * @param EE_Line_Item $line_item |
|
329 | + * @param array $options |
|
330 | + * @return mixed |
|
331 | + */ |
|
332 | + protected function _total_row(EE_Line_Item $line_item, $options = array()) |
|
333 | + { |
|
334 | + // start of row |
|
335 | + $html = EEH_HTML::tr('', '', 'admin-primary-mbox-total-tr'); |
|
336 | + // Total th label |
|
337 | + $total_label = sprintf(esc_html__('Transaction Total %s', 'event_espresso'), '(' . EE_Registry::instance()->CFG->currency->code . ')'); |
|
338 | + $html .= EEH_HTML::th($total_label, '', 'jst-rght', '', ' colspan="4"'); |
|
339 | + // total th |
|
340 | + |
|
341 | + $html .= EEH_HTML::th(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
|
342 | + // end of row |
|
343 | + $html .= EEH_HTML::trx(); |
|
344 | + return $html; |
|
345 | + } |
|
346 | 346 | } |
@@ -118,7 +118,7 @@ discard block |
||
118 | 118 | $html .= $this->_taxes_html; |
119 | 119 | $html .= $this->_total_row($line_item, $options); |
120 | 120 | if ($options['use_table_wrapper']) { |
121 | - $html = $this->_table_header($options) . $html . $this->_table_footer($options); |
|
121 | + $html = $this->_table_header($options).$html.$this->_table_footer($options); |
|
122 | 122 | } |
123 | 123 | break; |
124 | 124 | } |
@@ -157,7 +157,7 @@ discard block |
||
157 | 157 | */ |
158 | 158 | protected function _table_footer($options) |
159 | 159 | { |
160 | - return EEH_HTML::tbodyx() . EEH_HTML::tablex(); |
|
160 | + return EEH_HTML::tbodyx().EEH_HTML::tablex(); |
|
161 | 161 | } |
162 | 162 | |
163 | 163 | |
@@ -188,16 +188,16 @@ discard block |
||
188 | 188 | |
189 | 189 | |
190 | 190 | $name_html = $line_item_related_object instanceof EEI_Line_Item_Object ? $line_item_related_object->name() : $line_item->name(); |
191 | - $name_html = $name_link ? '<a href="' . $name_link . '">' . $name_html . '</a>' : $name_html; |
|
191 | + $name_html = $name_link ? '<a href="'.$name_link.'">'.$name_html.'</a>' : $name_html; |
|
192 | 192 | $name_html .= $line_item->is_taxable() ? ' *' : ''; |
193 | 193 | // maybe preface with icon? |
194 | - $name_html = $line_item_related_object instanceof EEI_Has_Icon ? $line_item_related_object->get_icon() . $name_html : $name_html; |
|
195 | - $name_html = '<span class="ee-line-item-name linked">' . $name_html . '</span><br>'; |
|
196 | - $name_html .= sprintf( |
|
194 | + $name_html = $line_item_related_object instanceof EEI_Has_Icon ? $line_item_related_object->get_icon().$name_html : $name_html; |
|
195 | + $name_html = '<span class="ee-line-item-name linked">'.$name_html.'</span><br>'; |
|
196 | + $name_html .= sprintf( |
|
197 | 197 | _x('%1$sfor the %2$s: %3$s%4$s', 'eg. "for the Event: My Cool Event"', 'event_espresso'), |
198 | 198 | '<span class="ee-line-item-related-parent-object">', |
199 | 199 | $line_item->parent() instanceof EE_Line_Item ? $line_item->parent()->OBJ_type_i18n() : esc_html__('Item:', 'event_espresso'), |
200 | - $parent_related_object_link ? '<a href="' . $parent_related_object_link . '">' . $parent_related_object_name . '</a>' : $parent_related_object_name, |
|
200 | + $parent_related_object_link ? '<a href="'.$parent_related_object_link.'">'.$parent_related_object_name.'</a>' : $parent_related_object_name, |
|
201 | 201 | '</span>' |
202 | 202 | ); |
203 | 203 | |
@@ -214,13 +214,13 @@ discard block |
||
214 | 214 | $type_html .= $this->_get_cancellations($line_item); |
215 | 215 | $type_html .= $line_item->OBJ_type() ? '<br />' : ''; |
216 | 216 | $code = $line_item_related_object instanceof EEI_Has_Code ? $line_item_related_object->code() : ''; |
217 | - $type_html .= ! empty($code) ? '<span class="ee-line-item-id">' . sprintf(esc_html__('Code: %s', 'event_espresso'), $code) . '</span>' : ''; |
|
217 | + $type_html .= ! empty($code) ? '<span class="ee-line-item-id">'.sprintf(esc_html__('Code: %s', 'event_espresso'), $code).'</span>' : ''; |
|
218 | 218 | $html .= EEH_HTML::td($type_html, '', 'jst-left'); |
219 | 219 | |
220 | 220 | |
221 | 221 | // Amount Column |
222 | 222 | if ($line_item->is_percent()) { |
223 | - $html .= EEH_HTML::td($line_item->percent() . '%', '', 'jst-rght'); |
|
223 | + $html .= EEH_HTML::td($line_item->percent().'%', '', 'jst-rght'); |
|
224 | 224 | } else { |
225 | 225 | $html .= EEH_HTML::td($line_item->unit_price_no_code(), '', 'jst-rght'); |
226 | 226 | } |
@@ -295,7 +295,7 @@ discard block |
||
295 | 295 | // start of row |
296 | 296 | $html = EEH_HTML::tr('', 'admin-primary-mbox-taxes-tr'); |
297 | 297 | // name th |
298 | - $html .= EEH_HTML::th($line_item->name() . '(' . $line_item->get_pretty('LIN_percent') . '%)', '', 'jst-rght', '', ' colspan="4"'); |
|
298 | + $html .= EEH_HTML::th($line_item->name().'('.$line_item->get_pretty('LIN_percent').'%)', '', 'jst-rght', '', ' colspan="4"'); |
|
299 | 299 | // total th |
300 | 300 | $html .= EEH_HTML::th(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
301 | 301 | // end of row |
@@ -334,7 +334,7 @@ discard block |
||
334 | 334 | // start of row |
335 | 335 | $html = EEH_HTML::tr('', '', 'admin-primary-mbox-total-tr'); |
336 | 336 | // Total th label |
337 | - $total_label = sprintf(esc_html__('Transaction Total %s', 'event_espresso'), '(' . EE_Registry::instance()->CFG->currency->code . ')'); |
|
337 | + $total_label = sprintf(esc_html__('Transaction Total %s', 'event_espresso'), '('.EE_Registry::instance()->CFG->currency->code.')'); |
|
338 | 338 | $html .= EEH_HTML::th($total_label, '', 'jst-rght', '', ' colspan="4"'); |
339 | 339 | // total th |
340 | 340 |
@@ -14,191 +14,191 @@ |
||
14 | 14 | class EE_Admin_Table_Registration_Line_Item_Display_Strategy extends EE_Admin_Table_Line_Item_Display_Strategy |
15 | 15 | { |
16 | 16 | |
17 | - /** |
|
18 | - * Table header for display. |
|
19 | - * @since 4.8 |
|
20 | - * @param array $options |
|
21 | - * @return string |
|
22 | - */ |
|
23 | - protected function _table_header($options) |
|
24 | - { |
|
25 | - $html = EEH_HTML::table('', '', $options['table_css_class']); |
|
26 | - $html .= EEH_HTML::thead(); |
|
27 | - $html .= EEH_HTML::tr(); |
|
28 | - $html .= EEH_HTML::th(esc_html__('Name', 'event_espresso'), '', 'jst-left'); |
|
29 | - $html .= EEH_HTML::th(esc_html__('Type', 'event_espresso'), '', 'jst-left'); |
|
30 | - $html .= EEH_HTML::th(esc_html__('Date(s)', 'event_espresso'), '', 'jst-left'); |
|
31 | - $html .= EEH_HTML::th(esc_html__('Amount', 'event_espresso'), '', 'jst-cntr'); |
|
32 | - $html .= EEH_HTML::tbody(); |
|
33 | - return $html; |
|
34 | - } |
|
35 | - |
|
36 | - |
|
37 | - |
|
38 | - |
|
39 | - |
|
40 | - /** |
|
41 | - * _item_row |
|
42 | - * |
|
43 | - * @param EE_Line_Item $line_item |
|
44 | - * @param array $options |
|
45 | - * @return mixed |
|
46 | - */ |
|
47 | - protected function _item_row(EE_Line_Item $line_item, $options = array()) |
|
48 | - { |
|
49 | - $line_item_related_object = $line_item->get_object(); |
|
50 | - $parent_line_item_related_object = $line_item->parent() instanceof EE_Line_Item |
|
51 | - ? $line_item->parent()->get_object() |
|
52 | - : null; |
|
53 | - // start of row |
|
54 | - $row_class = $options['odd'] ? 'item odd' : 'item'; |
|
55 | - $html = EEH_HTML::tr('', '', $row_class); |
|
56 | - |
|
57 | - |
|
58 | - // Name Column |
|
59 | - $name_link = $line_item_related_object instanceof EEI_Admin_Links ? $line_item_related_object->get_admin_details_link() : ''; |
|
60 | - |
|
61 | - // related object scope. |
|
62 | - $parent_related_object_name = $parent_line_item_related_object instanceof EEI_Line_Item_Object |
|
63 | - ? $parent_line_item_related_object->name() |
|
64 | - : ''; |
|
65 | - $parent_related_object_name = empty($parent_related_object_name) && $line_item->parent() instanceof EE_Line_Item |
|
66 | - ? $line_item->parent()->name() |
|
67 | - : $parent_related_object_name; |
|
68 | - $parent_related_object_link = $parent_line_item_related_object instanceof EEI_Admin_Links |
|
69 | - ? $parent_line_item_related_object->get_admin_details_link() |
|
70 | - : ''; |
|
71 | - |
|
72 | - |
|
73 | - $name_html = $line_item_related_object instanceof EEI_Line_Item_Object |
|
74 | - ? $line_item_related_object->name() : $line_item->name(); |
|
75 | - $name_html = $name_link ? '<a href="' . $name_link . '">' . $name_html . '</a>' |
|
76 | - : $name_html; |
|
77 | - $name_html .= $line_item->is_taxable() ? ' *' : ''; |
|
78 | - // maybe preface with icon? |
|
79 | - $name_html = $line_item_related_object instanceof EEI_Has_Icon |
|
80 | - ? $line_item_related_object->get_icon() . $name_html |
|
81 | - : $name_html; |
|
82 | - $name_html = '<span class="ee-line-item-name linked">' . $name_html . '</span><br>'; |
|
83 | - $name_html .= sprintf( |
|
84 | - _x('%1$sfor the %2$s: %3$s%4$s', 'eg. "for the Event: My Cool Event"', 'event_espresso'), |
|
85 | - '<span class="ee-line-item-related-parent-object">', |
|
86 | - $line_item->parent() instanceof EE_Line_Item |
|
87 | - ? $line_item->parent()->OBJ_type_i18n() |
|
88 | - : esc_html__('Item:', 'event_espresso'), |
|
89 | - $parent_related_object_link |
|
90 | - ? '<a href="' . $parent_related_object_link . '">' . $parent_related_object_name . '</a>' |
|
91 | - : $parent_related_object_name, |
|
92 | - '</span>' |
|
93 | - ); |
|
94 | - |
|
95 | - $name_html = apply_filters( |
|
96 | - 'FHEE__EE_Admin_Table_Registration_Line_Item_Display_Strategy___item_row__name_html', |
|
97 | - $name_html, |
|
98 | - $line_item, |
|
99 | - $options |
|
100 | - ); |
|
101 | - |
|
102 | - $html .= EEH_HTML::td($name_html, '', 'jst-left'); |
|
103 | - // Type Column |
|
104 | - $type_html = $line_item->OBJ_type() ? $line_item->OBJ_type_i18n() : ''; |
|
105 | - $type_html .= $this->_get_cancellations($line_item); |
|
106 | - $type_html .= $line_item->OBJ_type() ? '<br />' : ''; |
|
107 | - $code = $line_item_related_object instanceof EEI_Has_Code ? $line_item_related_object->code() : ''; |
|
108 | - $type_html .= ! empty($code) ? '<span class="ee-line-item-id">' . sprintf(esc_html__('Code: %s', 'event_espresso'), $code) . '</span>' : ''; |
|
109 | - $html .= EEH_HTML::td($type_html, '', 'jst-left'); |
|
110 | - |
|
111 | - // Date column |
|
112 | - $datetime_content = ''; |
|
113 | - if ($line_item_related_object instanceof EE_Ticket) { |
|
114 | - $datetimes = $line_item_related_object->datetimes(); |
|
115 | - foreach ($datetimes as $datetime) { |
|
116 | - if ($datetime instanceof EE_Datetime) { |
|
117 | - $datetime_content .= $datetime->get_dtt_display_name() . '<br>'; |
|
118 | - } |
|
119 | - } |
|
120 | - } |
|
121 | - $html .= EEH_HTML::td($datetime_content, '', 'jst-left'); |
|
122 | - |
|
123 | - // Amount Column |
|
124 | - if ($line_item->is_percent()) { |
|
125 | - $html .= EEH_HTML::td($line_item->percent() . '%', '', 'jst-rght'); |
|
126 | - } else { |
|
127 | - $html .= EEH_HTML::td($line_item->unit_price_no_code(), '', 'jst-rght'); |
|
128 | - } |
|
129 | - |
|
130 | - |
|
131 | - // finish things off and return |
|
132 | - $html .= EEH_HTML::trx(); |
|
133 | - return $html; |
|
134 | - } |
|
135 | - |
|
136 | - |
|
137 | - |
|
138 | - /** |
|
139 | - * _tax_row |
|
140 | - * |
|
141 | - * @param EE_Line_Item $line_item |
|
142 | - * @param array $options |
|
143 | - * @return mixed |
|
144 | - */ |
|
145 | - protected function _tax_row(EE_Line_Item $line_item, $options = array()) |
|
146 | - { |
|
147 | - // start of row |
|
148 | - $html = EEH_HTML::tr('', 'admin-primary-mbox-taxes-tr'); |
|
149 | - // name th |
|
150 | - $html .= EEH_HTML::th($line_item->name() . '(' . $line_item->get_pretty('LIN_percent') . '%)', '', 'jst-rght', '', ' colspan="3"'); |
|
151 | - // total th |
|
152 | - $html .= EEH_HTML::th(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
|
153 | - // end of row |
|
154 | - $html .= EEH_HTML::trx(); |
|
155 | - return $html; |
|
156 | - } |
|
157 | - |
|
158 | - |
|
159 | - |
|
160 | - |
|
161 | - |
|
162 | - /** |
|
163 | - * _total_row |
|
164 | - * |
|
165 | - * @param EE_Line_Item $line_item |
|
166 | - * @param array $options |
|
167 | - * @return mixed |
|
168 | - */ |
|
169 | - protected function _total_row(EE_Line_Item $line_item, $options = array()) |
|
170 | - { |
|
171 | - |
|
172 | - $registration = isset($options['EE_Registration']) ? $options['EE_Registration'] : null; |
|
173 | - $registration_total = $registration instanceof EE_Registration ? $registration->pretty_final_price() : 0; |
|
174 | - // if no valid registration object then we're not going to show the approximate text. |
|
175 | - $total_match = $registration instanceof EE_Registration |
|
176 | - ? $registration->final_price() === $line_item->total() |
|
177 | - : true; |
|
178 | - |
|
179 | - // start of row |
|
180 | - $html = EEH_HTML::tr('', '', 'admin-primary-mbox-total-tr'); |
|
181 | - // Total th label |
|
182 | - if ($total_match) { |
|
183 | - $total_label = sprintf(esc_html__('This registration\'s total %s:', 'event_espresso'), '(' . EE_Registry::instance()->CFG->currency->code . ')'); |
|
184 | - } else { |
|
185 | - $total_label = sprintf(esc_html__('This registration\'s approximate total %s', 'event_espresso'), '(' . EE_Registry::instance()->CFG->currency->code . ')'); |
|
186 | - $total_label .= '<br>'; |
|
187 | - $total_label .= '<p class="ee-footnote-text">' |
|
188 | - . sprintf( |
|
189 | - esc_html__('The registrations\' share of the transaction total is approximate because it might not be possible to evenly divide the transaction total among each registration, and so some registrations may need to pay a penny more than others. This registration\'s final share is actually %1$s%2$s%3$s.', 'event_espresso'), |
|
190 | - '<strong>', |
|
191 | - $registration_total, |
|
192 | - '</strong>' |
|
193 | - ) |
|
194 | - . '</p>'; |
|
195 | - } |
|
196 | - $html .= EEH_HTML::th($total_label, '', 'jst-rght', '', ' colspan="3"'); |
|
197 | - // total th |
|
198 | - |
|
199 | - $html .= EEH_HTML::th(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
|
200 | - // end of row |
|
201 | - $html .= EEH_HTML::trx(); |
|
202 | - return $html; |
|
203 | - } |
|
17 | + /** |
|
18 | + * Table header for display. |
|
19 | + * @since 4.8 |
|
20 | + * @param array $options |
|
21 | + * @return string |
|
22 | + */ |
|
23 | + protected function _table_header($options) |
|
24 | + { |
|
25 | + $html = EEH_HTML::table('', '', $options['table_css_class']); |
|
26 | + $html .= EEH_HTML::thead(); |
|
27 | + $html .= EEH_HTML::tr(); |
|
28 | + $html .= EEH_HTML::th(esc_html__('Name', 'event_espresso'), '', 'jst-left'); |
|
29 | + $html .= EEH_HTML::th(esc_html__('Type', 'event_espresso'), '', 'jst-left'); |
|
30 | + $html .= EEH_HTML::th(esc_html__('Date(s)', 'event_espresso'), '', 'jst-left'); |
|
31 | + $html .= EEH_HTML::th(esc_html__('Amount', 'event_espresso'), '', 'jst-cntr'); |
|
32 | + $html .= EEH_HTML::tbody(); |
|
33 | + return $html; |
|
34 | + } |
|
35 | + |
|
36 | + |
|
37 | + |
|
38 | + |
|
39 | + |
|
40 | + /** |
|
41 | + * _item_row |
|
42 | + * |
|
43 | + * @param EE_Line_Item $line_item |
|
44 | + * @param array $options |
|
45 | + * @return mixed |
|
46 | + */ |
|
47 | + protected function _item_row(EE_Line_Item $line_item, $options = array()) |
|
48 | + { |
|
49 | + $line_item_related_object = $line_item->get_object(); |
|
50 | + $parent_line_item_related_object = $line_item->parent() instanceof EE_Line_Item |
|
51 | + ? $line_item->parent()->get_object() |
|
52 | + : null; |
|
53 | + // start of row |
|
54 | + $row_class = $options['odd'] ? 'item odd' : 'item'; |
|
55 | + $html = EEH_HTML::tr('', '', $row_class); |
|
56 | + |
|
57 | + |
|
58 | + // Name Column |
|
59 | + $name_link = $line_item_related_object instanceof EEI_Admin_Links ? $line_item_related_object->get_admin_details_link() : ''; |
|
60 | + |
|
61 | + // related object scope. |
|
62 | + $parent_related_object_name = $parent_line_item_related_object instanceof EEI_Line_Item_Object |
|
63 | + ? $parent_line_item_related_object->name() |
|
64 | + : ''; |
|
65 | + $parent_related_object_name = empty($parent_related_object_name) && $line_item->parent() instanceof EE_Line_Item |
|
66 | + ? $line_item->parent()->name() |
|
67 | + : $parent_related_object_name; |
|
68 | + $parent_related_object_link = $parent_line_item_related_object instanceof EEI_Admin_Links |
|
69 | + ? $parent_line_item_related_object->get_admin_details_link() |
|
70 | + : ''; |
|
71 | + |
|
72 | + |
|
73 | + $name_html = $line_item_related_object instanceof EEI_Line_Item_Object |
|
74 | + ? $line_item_related_object->name() : $line_item->name(); |
|
75 | + $name_html = $name_link ? '<a href="' . $name_link . '">' . $name_html . '</a>' |
|
76 | + : $name_html; |
|
77 | + $name_html .= $line_item->is_taxable() ? ' *' : ''; |
|
78 | + // maybe preface with icon? |
|
79 | + $name_html = $line_item_related_object instanceof EEI_Has_Icon |
|
80 | + ? $line_item_related_object->get_icon() . $name_html |
|
81 | + : $name_html; |
|
82 | + $name_html = '<span class="ee-line-item-name linked">' . $name_html . '</span><br>'; |
|
83 | + $name_html .= sprintf( |
|
84 | + _x('%1$sfor the %2$s: %3$s%4$s', 'eg. "for the Event: My Cool Event"', 'event_espresso'), |
|
85 | + '<span class="ee-line-item-related-parent-object">', |
|
86 | + $line_item->parent() instanceof EE_Line_Item |
|
87 | + ? $line_item->parent()->OBJ_type_i18n() |
|
88 | + : esc_html__('Item:', 'event_espresso'), |
|
89 | + $parent_related_object_link |
|
90 | + ? '<a href="' . $parent_related_object_link . '">' . $parent_related_object_name . '</a>' |
|
91 | + : $parent_related_object_name, |
|
92 | + '</span>' |
|
93 | + ); |
|
94 | + |
|
95 | + $name_html = apply_filters( |
|
96 | + 'FHEE__EE_Admin_Table_Registration_Line_Item_Display_Strategy___item_row__name_html', |
|
97 | + $name_html, |
|
98 | + $line_item, |
|
99 | + $options |
|
100 | + ); |
|
101 | + |
|
102 | + $html .= EEH_HTML::td($name_html, '', 'jst-left'); |
|
103 | + // Type Column |
|
104 | + $type_html = $line_item->OBJ_type() ? $line_item->OBJ_type_i18n() : ''; |
|
105 | + $type_html .= $this->_get_cancellations($line_item); |
|
106 | + $type_html .= $line_item->OBJ_type() ? '<br />' : ''; |
|
107 | + $code = $line_item_related_object instanceof EEI_Has_Code ? $line_item_related_object->code() : ''; |
|
108 | + $type_html .= ! empty($code) ? '<span class="ee-line-item-id">' . sprintf(esc_html__('Code: %s', 'event_espresso'), $code) . '</span>' : ''; |
|
109 | + $html .= EEH_HTML::td($type_html, '', 'jst-left'); |
|
110 | + |
|
111 | + // Date column |
|
112 | + $datetime_content = ''; |
|
113 | + if ($line_item_related_object instanceof EE_Ticket) { |
|
114 | + $datetimes = $line_item_related_object->datetimes(); |
|
115 | + foreach ($datetimes as $datetime) { |
|
116 | + if ($datetime instanceof EE_Datetime) { |
|
117 | + $datetime_content .= $datetime->get_dtt_display_name() . '<br>'; |
|
118 | + } |
|
119 | + } |
|
120 | + } |
|
121 | + $html .= EEH_HTML::td($datetime_content, '', 'jst-left'); |
|
122 | + |
|
123 | + // Amount Column |
|
124 | + if ($line_item->is_percent()) { |
|
125 | + $html .= EEH_HTML::td($line_item->percent() . '%', '', 'jst-rght'); |
|
126 | + } else { |
|
127 | + $html .= EEH_HTML::td($line_item->unit_price_no_code(), '', 'jst-rght'); |
|
128 | + } |
|
129 | + |
|
130 | + |
|
131 | + // finish things off and return |
|
132 | + $html .= EEH_HTML::trx(); |
|
133 | + return $html; |
|
134 | + } |
|
135 | + |
|
136 | + |
|
137 | + |
|
138 | + /** |
|
139 | + * _tax_row |
|
140 | + * |
|
141 | + * @param EE_Line_Item $line_item |
|
142 | + * @param array $options |
|
143 | + * @return mixed |
|
144 | + */ |
|
145 | + protected function _tax_row(EE_Line_Item $line_item, $options = array()) |
|
146 | + { |
|
147 | + // start of row |
|
148 | + $html = EEH_HTML::tr('', 'admin-primary-mbox-taxes-tr'); |
|
149 | + // name th |
|
150 | + $html .= EEH_HTML::th($line_item->name() . '(' . $line_item->get_pretty('LIN_percent') . '%)', '', 'jst-rght', '', ' colspan="3"'); |
|
151 | + // total th |
|
152 | + $html .= EEH_HTML::th(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
|
153 | + // end of row |
|
154 | + $html .= EEH_HTML::trx(); |
|
155 | + return $html; |
|
156 | + } |
|
157 | + |
|
158 | + |
|
159 | + |
|
160 | + |
|
161 | + |
|
162 | + /** |
|
163 | + * _total_row |
|
164 | + * |
|
165 | + * @param EE_Line_Item $line_item |
|
166 | + * @param array $options |
|
167 | + * @return mixed |
|
168 | + */ |
|
169 | + protected function _total_row(EE_Line_Item $line_item, $options = array()) |
|
170 | + { |
|
171 | + |
|
172 | + $registration = isset($options['EE_Registration']) ? $options['EE_Registration'] : null; |
|
173 | + $registration_total = $registration instanceof EE_Registration ? $registration->pretty_final_price() : 0; |
|
174 | + // if no valid registration object then we're not going to show the approximate text. |
|
175 | + $total_match = $registration instanceof EE_Registration |
|
176 | + ? $registration->final_price() === $line_item->total() |
|
177 | + : true; |
|
178 | + |
|
179 | + // start of row |
|
180 | + $html = EEH_HTML::tr('', '', 'admin-primary-mbox-total-tr'); |
|
181 | + // Total th label |
|
182 | + if ($total_match) { |
|
183 | + $total_label = sprintf(esc_html__('This registration\'s total %s:', 'event_espresso'), '(' . EE_Registry::instance()->CFG->currency->code . ')'); |
|
184 | + } else { |
|
185 | + $total_label = sprintf(esc_html__('This registration\'s approximate total %s', 'event_espresso'), '(' . EE_Registry::instance()->CFG->currency->code . ')'); |
|
186 | + $total_label .= '<br>'; |
|
187 | + $total_label .= '<p class="ee-footnote-text">' |
|
188 | + . sprintf( |
|
189 | + esc_html__('The registrations\' share of the transaction total is approximate because it might not be possible to evenly divide the transaction total among each registration, and so some registrations may need to pay a penny more than others. This registration\'s final share is actually %1$s%2$s%3$s.', 'event_espresso'), |
|
190 | + '<strong>', |
|
191 | + $registration_total, |
|
192 | + '</strong>' |
|
193 | + ) |
|
194 | + . '</p>'; |
|
195 | + } |
|
196 | + $html .= EEH_HTML::th($total_label, '', 'jst-rght', '', ' colspan="3"'); |
|
197 | + // total th |
|
198 | + |
|
199 | + $html .= EEH_HTML::th(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
|
200 | + // end of row |
|
201 | + $html .= EEH_HTML::trx(); |
|
202 | + return $html; |
|
203 | + } |
|
204 | 204 | } |
@@ -72,22 +72,22 @@ discard block |
||
72 | 72 | |
73 | 73 | $name_html = $line_item_related_object instanceof EEI_Line_Item_Object |
74 | 74 | ? $line_item_related_object->name() : $line_item->name(); |
75 | - $name_html = $name_link ? '<a href="' . $name_link . '">' . $name_html . '</a>' |
|
75 | + $name_html = $name_link ? '<a href="'.$name_link.'">'.$name_html.'</a>' |
|
76 | 76 | : $name_html; |
77 | 77 | $name_html .= $line_item->is_taxable() ? ' *' : ''; |
78 | 78 | // maybe preface with icon? |
79 | 79 | $name_html = $line_item_related_object instanceof EEI_Has_Icon |
80 | - ? $line_item_related_object->get_icon() . $name_html |
|
80 | + ? $line_item_related_object->get_icon().$name_html |
|
81 | 81 | : $name_html; |
82 | - $name_html = '<span class="ee-line-item-name linked">' . $name_html . '</span><br>'; |
|
83 | - $name_html .= sprintf( |
|
82 | + $name_html = '<span class="ee-line-item-name linked">'.$name_html.'</span><br>'; |
|
83 | + $name_html .= sprintf( |
|
84 | 84 | _x('%1$sfor the %2$s: %3$s%4$s', 'eg. "for the Event: My Cool Event"', 'event_espresso'), |
85 | 85 | '<span class="ee-line-item-related-parent-object">', |
86 | 86 | $line_item->parent() instanceof EE_Line_Item |
87 | 87 | ? $line_item->parent()->OBJ_type_i18n() |
88 | 88 | : esc_html__('Item:', 'event_espresso'), |
89 | 89 | $parent_related_object_link |
90 | - ? '<a href="' . $parent_related_object_link . '">' . $parent_related_object_name . '</a>' |
|
90 | + ? '<a href="'.$parent_related_object_link.'">'.$parent_related_object_name.'</a>' |
|
91 | 91 | : $parent_related_object_name, |
92 | 92 | '</span>' |
93 | 93 | ); |
@@ -105,7 +105,7 @@ discard block |
||
105 | 105 | $type_html .= $this->_get_cancellations($line_item); |
106 | 106 | $type_html .= $line_item->OBJ_type() ? '<br />' : ''; |
107 | 107 | $code = $line_item_related_object instanceof EEI_Has_Code ? $line_item_related_object->code() : ''; |
108 | - $type_html .= ! empty($code) ? '<span class="ee-line-item-id">' . sprintf(esc_html__('Code: %s', 'event_espresso'), $code) . '</span>' : ''; |
|
108 | + $type_html .= ! empty($code) ? '<span class="ee-line-item-id">'.sprintf(esc_html__('Code: %s', 'event_espresso'), $code).'</span>' : ''; |
|
109 | 109 | $html .= EEH_HTML::td($type_html, '', 'jst-left'); |
110 | 110 | |
111 | 111 | // Date column |
@@ -114,7 +114,7 @@ discard block |
||
114 | 114 | $datetimes = $line_item_related_object->datetimes(); |
115 | 115 | foreach ($datetimes as $datetime) { |
116 | 116 | if ($datetime instanceof EE_Datetime) { |
117 | - $datetime_content .= $datetime->get_dtt_display_name() . '<br>'; |
|
117 | + $datetime_content .= $datetime->get_dtt_display_name().'<br>'; |
|
118 | 118 | } |
119 | 119 | } |
120 | 120 | } |
@@ -122,7 +122,7 @@ discard block |
||
122 | 122 | |
123 | 123 | // Amount Column |
124 | 124 | if ($line_item->is_percent()) { |
125 | - $html .= EEH_HTML::td($line_item->percent() . '%', '', 'jst-rght'); |
|
125 | + $html .= EEH_HTML::td($line_item->percent().'%', '', 'jst-rght'); |
|
126 | 126 | } else { |
127 | 127 | $html .= EEH_HTML::td($line_item->unit_price_no_code(), '', 'jst-rght'); |
128 | 128 | } |
@@ -147,7 +147,7 @@ discard block |
||
147 | 147 | // start of row |
148 | 148 | $html = EEH_HTML::tr('', 'admin-primary-mbox-taxes-tr'); |
149 | 149 | // name th |
150 | - $html .= EEH_HTML::th($line_item->name() . '(' . $line_item->get_pretty('LIN_percent') . '%)', '', 'jst-rght', '', ' colspan="3"'); |
|
150 | + $html .= EEH_HTML::th($line_item->name().'('.$line_item->get_pretty('LIN_percent').'%)', '', 'jst-rght', '', ' colspan="3"'); |
|
151 | 151 | // total th |
152 | 152 | $html .= EEH_HTML::th(EEH_Template::format_currency($line_item->total(), false, false), '', 'jst-rght'); |
153 | 153 | // end of row |
@@ -180,9 +180,9 @@ discard block |
||
180 | 180 | $html = EEH_HTML::tr('', '', 'admin-primary-mbox-total-tr'); |
181 | 181 | // Total th label |
182 | 182 | if ($total_match) { |
183 | - $total_label = sprintf(esc_html__('This registration\'s total %s:', 'event_espresso'), '(' . EE_Registry::instance()->CFG->currency->code . ')'); |
|
183 | + $total_label = sprintf(esc_html__('This registration\'s total %s:', 'event_espresso'), '('.EE_Registry::instance()->CFG->currency->code.')'); |
|
184 | 184 | } else { |
185 | - $total_label = sprintf(esc_html__('This registration\'s approximate total %s', 'event_espresso'), '(' . EE_Registry::instance()->CFG->currency->code . ')'); |
|
185 | + $total_label = sprintf(esc_html__('This registration\'s approximate total %s', 'event_espresso'), '('.EE_Registry::instance()->CFG->currency->code.')'); |
|
186 | 186 | $total_label .= '<br>'; |
187 | 187 | $total_label .= '<p class="ee-footnote-text">' |
188 | 188 | . sprintf( |
@@ -13,25 +13,25 @@ |
||
13 | 13 | class InvalidFormHandlerException extends \UnexpectedValueException |
14 | 14 | { |
15 | 15 | |
16 | - /** |
|
17 | - * InvalidFormHandlerException constructor. |
|
18 | - * |
|
19 | - * @param string $actual the FormHandler object that was received |
|
20 | - * @param string $message |
|
21 | - * @param int $code |
|
22 | - * @param \Exception $previous |
|
23 | - */ |
|
24 | - public function __construct($actual, $message = '', $code = 0, \Exception $previous = null) |
|
25 | - { |
|
26 | - if (empty($message)) { |
|
27 | - $message = sprintf( |
|
28 | - esc_html__( |
|
29 | - 'A valid Form Handler was expected but instead "%1$s" was received.', |
|
30 | - 'event_espresso' |
|
31 | - ), |
|
32 | - $actual |
|
33 | - ); |
|
34 | - } |
|
35 | - parent::__construct($message, $code, $previous); |
|
36 | - } |
|
16 | + /** |
|
17 | + * InvalidFormHandlerException constructor. |
|
18 | + * |
|
19 | + * @param string $actual the FormHandler object that was received |
|
20 | + * @param string $message |
|
21 | + * @param int $code |
|
22 | + * @param \Exception $previous |
|
23 | + */ |
|
24 | + public function __construct($actual, $message = '', $code = 0, \Exception $previous = null) |
|
25 | + { |
|
26 | + if (empty($message)) { |
|
27 | + $message = sprintf( |
|
28 | + esc_html__( |
|
29 | + 'A valid Form Handler was expected but instead "%1$s" was received.', |
|
30 | + 'event_espresso' |
|
31 | + ), |
|
32 | + $actual |
|
33 | + ); |
|
34 | + } |
|
35 | + parent::__construct($message, $code, $previous); |
|
36 | + } |
|
37 | 37 | } |
@@ -15,486 +15,486 @@ |
||
15 | 15 | abstract class EE_Form_Section_Base |
16 | 16 | { |
17 | 17 | |
18 | - /** |
|
19 | - * the URL the form is submitted to |
|
20 | - * |
|
21 | - * @var string |
|
22 | - */ |
|
23 | - protected $_action; |
|
24 | - |
|
25 | - /** |
|
26 | - * POST (default) or GET |
|
27 | - * |
|
28 | - * @var string |
|
29 | - */ |
|
30 | - protected $_method; |
|
31 | - |
|
32 | - /** |
|
33 | - * html_id and html_name are derived from this by default |
|
34 | - * |
|
35 | - * @var string |
|
36 | - */ |
|
37 | - protected $_name; |
|
38 | - |
|
39 | - /** |
|
40 | - * $_html_id |
|
41 | - * @var string |
|
42 | - */ |
|
43 | - protected $_html_id; |
|
44 | - |
|
45 | - /** |
|
46 | - * $_html_class |
|
47 | - * @var string |
|
48 | - */ |
|
49 | - protected $_html_class; |
|
50 | - |
|
51 | - /** |
|
52 | - * $_html_style |
|
53 | - * @var string |
|
54 | - */ |
|
55 | - protected $_html_style; |
|
56 | - |
|
57 | - /** |
|
58 | - * $_other_html_attributes |
|
59 | - * @var string |
|
60 | - */ |
|
61 | - protected $_other_html_attributes; |
|
62 | - |
|
63 | - /** |
|
64 | - * The form section of which this form section is a part |
|
65 | - * |
|
66 | - * @var EE_Form_Section_Proper |
|
67 | - */ |
|
68 | - protected $_parent_section; |
|
69 | - |
|
70 | - /** |
|
71 | - * flag indicating that _construct_finalize has been called. |
|
72 | - * If it has not been called and we try to use functions which require it, we call it |
|
73 | - * with no parameters. But normally, _construct_finalize should be called by the instantiating class |
|
74 | - * |
|
75 | - * @var boolean |
|
76 | - */ |
|
77 | - protected $_construction_finalized; |
|
78 | - |
|
79 | - /** |
|
80 | - * Strategy for parsing the form HTML upon display |
|
81 | - * |
|
82 | - * @var FormHtmlFilter |
|
83 | - */ |
|
84 | - protected $_form_html_filter; |
|
85 | - |
|
86 | - |
|
87 | - /** |
|
88 | - * @param array $options_array { |
|
89 | - * @type $name string the name for this form section, if you want to explicitly define it |
|
90 | - * } |
|
91 | - * @throws InvalidDataTypeException |
|
92 | - */ |
|
93 | - public function __construct($options_array = array()) |
|
94 | - { |
|
95 | - // used by display strategies |
|
96 | - // assign incoming values to properties |
|
97 | - foreach ($options_array as $key => $value) { |
|
98 | - $key = '_' . $key; |
|
99 | - if (property_exists($this, $key) && empty($this->{$key})) { |
|
100 | - $this->{$key} = $value; |
|
101 | - if ($key === '_subsections' && ! is_array($value)) { |
|
102 | - throw new InvalidDataTypeException($key, $value, 'array'); |
|
103 | - } |
|
104 | - } |
|
105 | - } |
|
106 | - // set parser which allows the form section's rendered HTML to be filtered |
|
107 | - if (isset($options_array['form_html_filter']) && $options_array['form_html_filter'] instanceof FormHtmlFilter) { |
|
108 | - $this->_form_html_filter = $options_array['form_html_filter']; |
|
109 | - } |
|
110 | - } |
|
111 | - |
|
112 | - |
|
113 | - |
|
114 | - /** |
|
115 | - * @param $parent_form_section |
|
116 | - * @param $name |
|
117 | - * @throws \EE_Error |
|
118 | - */ |
|
119 | - protected function _construct_finalize($parent_form_section, $name) |
|
120 | - { |
|
121 | - $this->_construction_finalized = true; |
|
122 | - $this->_parent_section = $parent_form_section; |
|
123 | - if ($name !== null) { |
|
124 | - $this->_name = $name; |
|
125 | - } |
|
126 | - } |
|
127 | - |
|
128 | - |
|
129 | - |
|
130 | - /** |
|
131 | - * make sure construction finalized was called, otherwise children might not be ready |
|
132 | - * |
|
133 | - * @return void |
|
134 | - * @throws \EE_Error |
|
135 | - */ |
|
136 | - public function ensure_construct_finalized_called() |
|
137 | - { |
|
138 | - if (! $this->_construction_finalized) { |
|
139 | - $this->_construct_finalize($this->_parent_section, $this->_name); |
|
140 | - } |
|
141 | - } |
|
142 | - |
|
143 | - |
|
144 | - |
|
145 | - /** |
|
146 | - * @return string |
|
147 | - */ |
|
148 | - public function action() |
|
149 | - { |
|
150 | - return $this->_action; |
|
151 | - } |
|
152 | - |
|
153 | - |
|
154 | - |
|
155 | - /** |
|
156 | - * @param string $action |
|
157 | - */ |
|
158 | - public function set_action($action) |
|
159 | - { |
|
160 | - $this->_action = $action; |
|
161 | - } |
|
162 | - |
|
163 | - |
|
164 | - |
|
165 | - /** |
|
166 | - * @return string |
|
167 | - */ |
|
168 | - public function method() |
|
169 | - { |
|
170 | - return ! empty($this->_method) ? $this->_method : 'POST'; |
|
171 | - } |
|
172 | - |
|
173 | - |
|
174 | - |
|
175 | - /** |
|
176 | - * @param string $method |
|
177 | - */ |
|
178 | - public function set_method($method) |
|
179 | - { |
|
180 | - switch ($method) { |
|
181 | - case 'get': |
|
182 | - case 'GET': |
|
183 | - $this->_method = 'GET'; |
|
184 | - break; |
|
185 | - default: |
|
186 | - $this->_method = 'POST'; |
|
187 | - } |
|
188 | - } |
|
189 | - |
|
190 | - |
|
191 | - |
|
192 | - /** |
|
193 | - * Sets the html_id to its default value, if none was specified in the constructor. |
|
194 | - * Calculation involves using the name and the parent's html id |
|
195 | - * return void |
|
196 | - * |
|
197 | - * @throws \EE_Error |
|
198 | - */ |
|
199 | - protected function _set_default_html_id_if_empty() |
|
200 | - { |
|
201 | - if (! $this->_html_id) { |
|
202 | - if ($this->_parent_section && $this->_parent_section instanceof EE_Form_Section_Proper) { |
|
203 | - $this->_html_id = $this->_parent_section->html_id() |
|
204 | - . '-' |
|
205 | - . $this->_prep_name_for_html_id($this->name()); |
|
206 | - } else { |
|
207 | - $this->_html_id = $this->_prep_name_for_html_id($this->name()); |
|
208 | - } |
|
209 | - } |
|
210 | - } |
|
211 | - |
|
212 | - |
|
213 | - |
|
214 | - /** |
|
215 | - * _prep_name_for_html_id |
|
216 | - * |
|
217 | - * @param $name |
|
218 | - * @return string |
|
219 | - */ |
|
220 | - private function _prep_name_for_html_id($name) |
|
221 | - { |
|
222 | - return sanitize_key(str_replace(array(' ', ' ', '_'), '-', $name)); |
|
223 | - } |
|
18 | + /** |
|
19 | + * the URL the form is submitted to |
|
20 | + * |
|
21 | + * @var string |
|
22 | + */ |
|
23 | + protected $_action; |
|
24 | + |
|
25 | + /** |
|
26 | + * POST (default) or GET |
|
27 | + * |
|
28 | + * @var string |
|
29 | + */ |
|
30 | + protected $_method; |
|
31 | + |
|
32 | + /** |
|
33 | + * html_id and html_name are derived from this by default |
|
34 | + * |
|
35 | + * @var string |
|
36 | + */ |
|
37 | + protected $_name; |
|
38 | + |
|
39 | + /** |
|
40 | + * $_html_id |
|
41 | + * @var string |
|
42 | + */ |
|
43 | + protected $_html_id; |
|
44 | + |
|
45 | + /** |
|
46 | + * $_html_class |
|
47 | + * @var string |
|
48 | + */ |
|
49 | + protected $_html_class; |
|
50 | + |
|
51 | + /** |
|
52 | + * $_html_style |
|
53 | + * @var string |
|
54 | + */ |
|
55 | + protected $_html_style; |
|
56 | + |
|
57 | + /** |
|
58 | + * $_other_html_attributes |
|
59 | + * @var string |
|
60 | + */ |
|
61 | + protected $_other_html_attributes; |
|
62 | + |
|
63 | + /** |
|
64 | + * The form section of which this form section is a part |
|
65 | + * |
|
66 | + * @var EE_Form_Section_Proper |
|
67 | + */ |
|
68 | + protected $_parent_section; |
|
69 | + |
|
70 | + /** |
|
71 | + * flag indicating that _construct_finalize has been called. |
|
72 | + * If it has not been called and we try to use functions which require it, we call it |
|
73 | + * with no parameters. But normally, _construct_finalize should be called by the instantiating class |
|
74 | + * |
|
75 | + * @var boolean |
|
76 | + */ |
|
77 | + protected $_construction_finalized; |
|
78 | + |
|
79 | + /** |
|
80 | + * Strategy for parsing the form HTML upon display |
|
81 | + * |
|
82 | + * @var FormHtmlFilter |
|
83 | + */ |
|
84 | + protected $_form_html_filter; |
|
85 | + |
|
86 | + |
|
87 | + /** |
|
88 | + * @param array $options_array { |
|
89 | + * @type $name string the name for this form section, if you want to explicitly define it |
|
90 | + * } |
|
91 | + * @throws InvalidDataTypeException |
|
92 | + */ |
|
93 | + public function __construct($options_array = array()) |
|
94 | + { |
|
95 | + // used by display strategies |
|
96 | + // assign incoming values to properties |
|
97 | + foreach ($options_array as $key => $value) { |
|
98 | + $key = '_' . $key; |
|
99 | + if (property_exists($this, $key) && empty($this->{$key})) { |
|
100 | + $this->{$key} = $value; |
|
101 | + if ($key === '_subsections' && ! is_array($value)) { |
|
102 | + throw new InvalidDataTypeException($key, $value, 'array'); |
|
103 | + } |
|
104 | + } |
|
105 | + } |
|
106 | + // set parser which allows the form section's rendered HTML to be filtered |
|
107 | + if (isset($options_array['form_html_filter']) && $options_array['form_html_filter'] instanceof FormHtmlFilter) { |
|
108 | + $this->_form_html_filter = $options_array['form_html_filter']; |
|
109 | + } |
|
110 | + } |
|
111 | + |
|
112 | + |
|
113 | + |
|
114 | + /** |
|
115 | + * @param $parent_form_section |
|
116 | + * @param $name |
|
117 | + * @throws \EE_Error |
|
118 | + */ |
|
119 | + protected function _construct_finalize($parent_form_section, $name) |
|
120 | + { |
|
121 | + $this->_construction_finalized = true; |
|
122 | + $this->_parent_section = $parent_form_section; |
|
123 | + if ($name !== null) { |
|
124 | + $this->_name = $name; |
|
125 | + } |
|
126 | + } |
|
127 | + |
|
128 | + |
|
129 | + |
|
130 | + /** |
|
131 | + * make sure construction finalized was called, otherwise children might not be ready |
|
132 | + * |
|
133 | + * @return void |
|
134 | + * @throws \EE_Error |
|
135 | + */ |
|
136 | + public function ensure_construct_finalized_called() |
|
137 | + { |
|
138 | + if (! $this->_construction_finalized) { |
|
139 | + $this->_construct_finalize($this->_parent_section, $this->_name); |
|
140 | + } |
|
141 | + } |
|
142 | + |
|
143 | + |
|
144 | + |
|
145 | + /** |
|
146 | + * @return string |
|
147 | + */ |
|
148 | + public function action() |
|
149 | + { |
|
150 | + return $this->_action; |
|
151 | + } |
|
152 | + |
|
153 | + |
|
154 | + |
|
155 | + /** |
|
156 | + * @param string $action |
|
157 | + */ |
|
158 | + public function set_action($action) |
|
159 | + { |
|
160 | + $this->_action = $action; |
|
161 | + } |
|
162 | + |
|
163 | + |
|
164 | + |
|
165 | + /** |
|
166 | + * @return string |
|
167 | + */ |
|
168 | + public function method() |
|
169 | + { |
|
170 | + return ! empty($this->_method) ? $this->_method : 'POST'; |
|
171 | + } |
|
172 | + |
|
173 | + |
|
174 | + |
|
175 | + /** |
|
176 | + * @param string $method |
|
177 | + */ |
|
178 | + public function set_method($method) |
|
179 | + { |
|
180 | + switch ($method) { |
|
181 | + case 'get': |
|
182 | + case 'GET': |
|
183 | + $this->_method = 'GET'; |
|
184 | + break; |
|
185 | + default: |
|
186 | + $this->_method = 'POST'; |
|
187 | + } |
|
188 | + } |
|
189 | + |
|
190 | + |
|
191 | + |
|
192 | + /** |
|
193 | + * Sets the html_id to its default value, if none was specified in the constructor. |
|
194 | + * Calculation involves using the name and the parent's html id |
|
195 | + * return void |
|
196 | + * |
|
197 | + * @throws \EE_Error |
|
198 | + */ |
|
199 | + protected function _set_default_html_id_if_empty() |
|
200 | + { |
|
201 | + if (! $this->_html_id) { |
|
202 | + if ($this->_parent_section && $this->_parent_section instanceof EE_Form_Section_Proper) { |
|
203 | + $this->_html_id = $this->_parent_section->html_id() |
|
204 | + . '-' |
|
205 | + . $this->_prep_name_for_html_id($this->name()); |
|
206 | + } else { |
|
207 | + $this->_html_id = $this->_prep_name_for_html_id($this->name()); |
|
208 | + } |
|
209 | + } |
|
210 | + } |
|
211 | + |
|
212 | + |
|
213 | + |
|
214 | + /** |
|
215 | + * _prep_name_for_html_id |
|
216 | + * |
|
217 | + * @param $name |
|
218 | + * @return string |
|
219 | + */ |
|
220 | + private function _prep_name_for_html_id($name) |
|
221 | + { |
|
222 | + return sanitize_key(str_replace(array(' ', ' ', '_'), '-', $name)); |
|
223 | + } |
|
224 | 224 | |
225 | 225 | |
226 | 226 | |
227 | - /** |
|
228 | - * Returns the HTML, JS, and CSS necessary to display this form section on a page. |
|
229 | - * Note however, it's recommended that you instead call enqueue_js on the "wp_enqueue_scripts" action, |
|
230 | - * and call get_html when you want to output the html. Calling get_html_and_js after |
|
231 | - * "wp_enqueue_scripts" has already fired seems to work for now, but is contrary |
|
232 | - * to the instructions on https://developer.wordpress.org/reference/functions/wp_enqueue_script/ |
|
233 | - * and so might stop working anytime. |
|
234 | - * |
|
235 | - * @return string |
|
236 | - */ |
|
237 | - public function get_html_and_js() |
|
238 | - { |
|
239 | - return $this->get_html(); |
|
240 | - } |
|
227 | + /** |
|
228 | + * Returns the HTML, JS, and CSS necessary to display this form section on a page. |
|
229 | + * Note however, it's recommended that you instead call enqueue_js on the "wp_enqueue_scripts" action, |
|
230 | + * and call get_html when you want to output the html. Calling get_html_and_js after |
|
231 | + * "wp_enqueue_scripts" has already fired seems to work for now, but is contrary |
|
232 | + * to the instructions on https://developer.wordpress.org/reference/functions/wp_enqueue_script/ |
|
233 | + * and so might stop working anytime. |
|
234 | + * |
|
235 | + * @return string |
|
236 | + */ |
|
237 | + public function get_html_and_js() |
|
238 | + { |
|
239 | + return $this->get_html(); |
|
240 | + } |
|
241 | 241 | |
242 | 242 | |
243 | - |
|
244 | - /** |
|
245 | - * Gets the HTML for displaying this form section |
|
246 | - * |
|
247 | - * @return string |
|
248 | - */ |
|
249 | - abstract public function get_html(); |
|
250 | - |
|
251 | - |
|
252 | - /** |
|
253 | - * @param bool $add_pound_sign |
|
254 | - * @return string |
|
255 | - * @throws EE_Error |
|
256 | - */ |
|
257 | - public function html_id($add_pound_sign = false) |
|
258 | - { |
|
259 | - $this->_set_default_html_id_if_empty(); |
|
260 | - return $add_pound_sign ? '#' . $this->_html_id : $this->_html_id; |
|
261 | - } |
|
262 | - |
|
263 | - |
|
264 | - |
|
265 | - /** |
|
266 | - * @return string |
|
267 | - */ |
|
268 | - public function html_class() |
|
269 | - { |
|
270 | - return $this->_html_class; |
|
271 | - } |
|
272 | - |
|
273 | - |
|
274 | - |
|
275 | - /** |
|
276 | - * @return string |
|
277 | - */ |
|
278 | - public function html_style() |
|
279 | - { |
|
280 | - return $this->_html_style; |
|
281 | - } |
|
282 | - |
|
283 | - |
|
284 | - |
|
285 | - /** |
|
286 | - * @param mixed $html_class |
|
287 | - */ |
|
288 | - public function set_html_class($html_class) |
|
289 | - { |
|
290 | - $this->_html_class = $html_class; |
|
291 | - } |
|
292 | - |
|
293 | - |
|
294 | - |
|
295 | - /** |
|
296 | - * @param mixed $html_id |
|
297 | - */ |
|
298 | - public function set_html_id($html_id) |
|
299 | - { |
|
300 | - $this->_html_id = $html_id; |
|
301 | - } |
|
302 | - |
|
303 | - |
|
304 | - |
|
305 | - /** |
|
306 | - * @param mixed $html_style |
|
307 | - */ |
|
308 | - public function set_html_style($html_style) |
|
309 | - { |
|
310 | - $this->_html_style = $html_style; |
|
311 | - } |
|
312 | - |
|
313 | - |
|
314 | - |
|
315 | - /** |
|
316 | - * @param string $other_html_attributes |
|
317 | - */ |
|
318 | - public function set_other_html_attributes($other_html_attributes) |
|
319 | - { |
|
320 | - $this->_other_html_attributes = $other_html_attributes; |
|
321 | - } |
|
322 | - |
|
323 | - |
|
324 | - |
|
325 | - /** |
|
326 | - * @return string |
|
327 | - */ |
|
328 | - public function other_html_attributes() |
|
329 | - { |
|
330 | - return ! empty($this->_other_html_attributes) ? ' ' . $this->_other_html_attributes : ''; |
|
331 | - } |
|
332 | - |
|
333 | - |
|
334 | - |
|
335 | - /** |
|
336 | - * Gets the name of the form section. This is not the same as the HTML name. |
|
337 | - * |
|
338 | - * @throws EE_Error |
|
339 | - * @return string |
|
340 | - */ |
|
341 | - public function name() |
|
342 | - { |
|
343 | - if (! $this->_construction_finalized) { |
|
344 | - throw new EE_Error(sprintf(esc_html__( |
|
345 | - 'You cannot use the form section\s name until _construct_finalize has been called on it (when we set the name). It was called on a form section of type \'s\'', |
|
346 | - 'event_espresso' |
|
347 | - ), get_class($this))); |
|
348 | - } |
|
349 | - return $this->_name; |
|
350 | - } |
|
351 | - |
|
352 | - |
|
353 | - |
|
354 | - /** |
|
355 | - * Gets the parent section |
|
356 | - * |
|
357 | - * @return EE_Form_Section_Proper |
|
358 | - */ |
|
359 | - public function parent_section() |
|
360 | - { |
|
361 | - return $this->_parent_section; |
|
362 | - } |
|
363 | - |
|
364 | - |
|
365 | - /** |
|
366 | - * returns HTML for generating the opening form HTML tag (<form>) |
|
367 | - * |
|
368 | - * @param string $action the URL the form is submitted to |
|
369 | - * @param string $method POST (default) or GET |
|
370 | - * @param string $other_attributes anything else added to the form open tag, MUST BE VALID HTML |
|
371 | - * @return string |
|
372 | - * @throws EE_Error |
|
373 | - */ |
|
374 | - public function form_open($action = '', $method = '', $other_attributes = '') |
|
375 | - { |
|
376 | - if (! empty($action)) { |
|
377 | - $this->set_action($action); |
|
378 | - } |
|
379 | - if (! empty($method)) { |
|
380 | - $this->set_method($method); |
|
381 | - } |
|
382 | - $html = EEH_HTML::nl(1, 'form') . '<form'; |
|
383 | - $html .= $this->html_id() !== '' ? ' id="' . $this->get_html_id_for_form($this->html_id()) . '"' : ''; |
|
384 | - $html .= ' action="' . $this->action() . '"'; |
|
385 | - $html .= ' method="' . $this->method() . '"'; |
|
386 | - $html .= ' name="' . $this->name() . '"'; |
|
387 | - $html .= $other_attributes . '>'; |
|
388 | - return $html; |
|
389 | - } |
|
390 | - |
|
391 | - |
|
392 | - |
|
393 | - /** |
|
394 | - * ensures that html id for form either ends in "-form" or "-frm" |
|
395 | - * so that id doesn't conflict/collide with other elements |
|
396 | - * |
|
397 | - * @param string $html_id |
|
398 | - * @return string |
|
399 | - */ |
|
400 | - protected function get_html_id_for_form($html_id) |
|
401 | - { |
|
402 | - $strlen = strlen($html_id); |
|
403 | - $html_id = strpos($html_id, '-form') === $strlen - 5 || strpos($html_id, '-frm') === $strlen - 4 |
|
404 | - ? $html_id |
|
405 | - : $html_id . '-frm'; |
|
406 | - return $html_id; |
|
407 | - } |
|
408 | - |
|
409 | - |
|
410 | - /** |
|
411 | - * returns HTML for generating the closing form HTML tag (</form>) |
|
412 | - * |
|
413 | - * @return string |
|
414 | - * @throws EE_Error |
|
415 | - */ |
|
416 | - public function form_close() |
|
417 | - { |
|
418 | - return EEH_HTML::nl(-1, 'form') |
|
419 | - . '</form>' |
|
420 | - . EEH_HTML::nl() |
|
421 | - . '<!-- end of ee-' |
|
422 | - . $this->html_id() |
|
423 | - . '-form -->' |
|
424 | - . EEH_HTML::nl(); |
|
425 | - } |
|
426 | - |
|
427 | - |
|
428 | - |
|
429 | - /** |
|
430 | - * enqueues JS (and CSS) for the form (ie immediately call wp_enqueue_script and |
|
431 | - * wp_enqueue_style; the scripts could have optionally been registered earlier) |
|
432 | - * Default does nothing, but child classes can override |
|
433 | - * |
|
434 | - * @return void |
|
435 | - */ |
|
436 | - public function enqueue_js() |
|
437 | - { |
|
438 | - // defaults to enqueue NO js or css |
|
439 | - } |
|
440 | - |
|
441 | - |
|
442 | - |
|
443 | - /** |
|
444 | - * Adds any extra data needed by js. Eventually we'll call wp_localize_script |
|
445 | - * with it, and it will be on each form section's 'other_data' property. |
|
446 | - * By default nothing is added, but child classes can extend this method to add something. |
|
447 | - * Eg, if you have an input that will cause a modal dialog to appear, |
|
448 | - * here you could add an entry like 'modal_dialog_inputs' to this array |
|
449 | - * to map between the input's html ID and the modal dialogue's ID, so that |
|
450 | - * your JS code will know where to find the modal dialog when the input is pressed. |
|
451 | - * Eg $form_other_js_data['modal_dialog_inputs']['some-input-id']='modal-dialog-id'; |
|
452 | - * |
|
453 | - * @param array $form_other_js_data |
|
454 | - * @return array |
|
455 | - */ |
|
456 | - public function get_other_js_data($form_other_js_data = array()) |
|
457 | - { |
|
458 | - return $form_other_js_data; |
|
459 | - } |
|
460 | - |
|
461 | - |
|
462 | - |
|
463 | - /** |
|
464 | - * This isn't just the name of an input, it's a path pointing to an input. The |
|
465 | - * path is similar to a folder path: slash (/) means to descend into a subsection, |
|
466 | - * dot-dot-slash (../) means to ascend into the parent section. |
|
467 | - * After a series of slashes and dot-dot-slashes, there should be the name of an input, |
|
468 | - * which will be returned. |
|
469 | - * Eg, if you want the related input to be conditional on a sibling input name 'foobar' |
|
470 | - * just use 'foobar'. If you want it to be conditional on an aunt/uncle input name |
|
471 | - * 'baz', use '../baz'. If you want it to be conditional on a cousin input, |
|
472 | - * the child of 'baz_section' named 'baz_child', use '../baz_section/baz_child'. |
|
473 | - * Etc |
|
474 | - * |
|
475 | - * @param string|false $form_section_path we accept false also because substr( '../', '../' ) = false |
|
476 | - * @return EE_Form_Section_Base |
|
477 | - */ |
|
478 | - public function find_section_from_path($form_section_path) |
|
479 | - { |
|
480 | - if (strpos($form_section_path, '/') === 0) { |
|
481 | - $form_section_path = substr($form_section_path, strlen('/')); |
|
482 | - } |
|
483 | - if (empty($form_section_path)) { |
|
484 | - return $this; |
|
485 | - } |
|
486 | - if (strpos($form_section_path, '../') === 0) { |
|
487 | - $parent = $this->parent_section(); |
|
488 | - $form_section_path = substr($form_section_path, strlen('../')); |
|
489 | - if ($parent instanceof EE_Form_Section_Base) { |
|
490 | - return $parent->find_section_from_path($form_section_path); |
|
491 | - } |
|
492 | - if (empty($form_section_path)) { |
|
493 | - return $this; |
|
494 | - } |
|
495 | - } |
|
496 | - // couldn't find it using simple parent following |
|
497 | - return null; |
|
498 | - } |
|
243 | + |
|
244 | + /** |
|
245 | + * Gets the HTML for displaying this form section |
|
246 | + * |
|
247 | + * @return string |
|
248 | + */ |
|
249 | + abstract public function get_html(); |
|
250 | + |
|
251 | + |
|
252 | + /** |
|
253 | + * @param bool $add_pound_sign |
|
254 | + * @return string |
|
255 | + * @throws EE_Error |
|
256 | + */ |
|
257 | + public function html_id($add_pound_sign = false) |
|
258 | + { |
|
259 | + $this->_set_default_html_id_if_empty(); |
|
260 | + return $add_pound_sign ? '#' . $this->_html_id : $this->_html_id; |
|
261 | + } |
|
262 | + |
|
263 | + |
|
264 | + |
|
265 | + /** |
|
266 | + * @return string |
|
267 | + */ |
|
268 | + public function html_class() |
|
269 | + { |
|
270 | + return $this->_html_class; |
|
271 | + } |
|
272 | + |
|
273 | + |
|
274 | + |
|
275 | + /** |
|
276 | + * @return string |
|
277 | + */ |
|
278 | + public function html_style() |
|
279 | + { |
|
280 | + return $this->_html_style; |
|
281 | + } |
|
282 | + |
|
283 | + |
|
284 | + |
|
285 | + /** |
|
286 | + * @param mixed $html_class |
|
287 | + */ |
|
288 | + public function set_html_class($html_class) |
|
289 | + { |
|
290 | + $this->_html_class = $html_class; |
|
291 | + } |
|
292 | + |
|
293 | + |
|
294 | + |
|
295 | + /** |
|
296 | + * @param mixed $html_id |
|
297 | + */ |
|
298 | + public function set_html_id($html_id) |
|
299 | + { |
|
300 | + $this->_html_id = $html_id; |
|
301 | + } |
|
302 | + |
|
303 | + |
|
304 | + |
|
305 | + /** |
|
306 | + * @param mixed $html_style |
|
307 | + */ |
|
308 | + public function set_html_style($html_style) |
|
309 | + { |
|
310 | + $this->_html_style = $html_style; |
|
311 | + } |
|
312 | + |
|
313 | + |
|
314 | + |
|
315 | + /** |
|
316 | + * @param string $other_html_attributes |
|
317 | + */ |
|
318 | + public function set_other_html_attributes($other_html_attributes) |
|
319 | + { |
|
320 | + $this->_other_html_attributes = $other_html_attributes; |
|
321 | + } |
|
322 | + |
|
323 | + |
|
324 | + |
|
325 | + /** |
|
326 | + * @return string |
|
327 | + */ |
|
328 | + public function other_html_attributes() |
|
329 | + { |
|
330 | + return ! empty($this->_other_html_attributes) ? ' ' . $this->_other_html_attributes : ''; |
|
331 | + } |
|
332 | + |
|
333 | + |
|
334 | + |
|
335 | + /** |
|
336 | + * Gets the name of the form section. This is not the same as the HTML name. |
|
337 | + * |
|
338 | + * @throws EE_Error |
|
339 | + * @return string |
|
340 | + */ |
|
341 | + public function name() |
|
342 | + { |
|
343 | + if (! $this->_construction_finalized) { |
|
344 | + throw new EE_Error(sprintf(esc_html__( |
|
345 | + 'You cannot use the form section\s name until _construct_finalize has been called on it (when we set the name). It was called on a form section of type \'s\'', |
|
346 | + 'event_espresso' |
|
347 | + ), get_class($this))); |
|
348 | + } |
|
349 | + return $this->_name; |
|
350 | + } |
|
351 | + |
|
352 | + |
|
353 | + |
|
354 | + /** |
|
355 | + * Gets the parent section |
|
356 | + * |
|
357 | + * @return EE_Form_Section_Proper |
|
358 | + */ |
|
359 | + public function parent_section() |
|
360 | + { |
|
361 | + return $this->_parent_section; |
|
362 | + } |
|
363 | + |
|
364 | + |
|
365 | + /** |
|
366 | + * returns HTML for generating the opening form HTML tag (<form>) |
|
367 | + * |
|
368 | + * @param string $action the URL the form is submitted to |
|
369 | + * @param string $method POST (default) or GET |
|
370 | + * @param string $other_attributes anything else added to the form open tag, MUST BE VALID HTML |
|
371 | + * @return string |
|
372 | + * @throws EE_Error |
|
373 | + */ |
|
374 | + public function form_open($action = '', $method = '', $other_attributes = '') |
|
375 | + { |
|
376 | + if (! empty($action)) { |
|
377 | + $this->set_action($action); |
|
378 | + } |
|
379 | + if (! empty($method)) { |
|
380 | + $this->set_method($method); |
|
381 | + } |
|
382 | + $html = EEH_HTML::nl(1, 'form') . '<form'; |
|
383 | + $html .= $this->html_id() !== '' ? ' id="' . $this->get_html_id_for_form($this->html_id()) . '"' : ''; |
|
384 | + $html .= ' action="' . $this->action() . '"'; |
|
385 | + $html .= ' method="' . $this->method() . '"'; |
|
386 | + $html .= ' name="' . $this->name() . '"'; |
|
387 | + $html .= $other_attributes . '>'; |
|
388 | + return $html; |
|
389 | + } |
|
390 | + |
|
391 | + |
|
392 | + |
|
393 | + /** |
|
394 | + * ensures that html id for form either ends in "-form" or "-frm" |
|
395 | + * so that id doesn't conflict/collide with other elements |
|
396 | + * |
|
397 | + * @param string $html_id |
|
398 | + * @return string |
|
399 | + */ |
|
400 | + protected function get_html_id_for_form($html_id) |
|
401 | + { |
|
402 | + $strlen = strlen($html_id); |
|
403 | + $html_id = strpos($html_id, '-form') === $strlen - 5 || strpos($html_id, '-frm') === $strlen - 4 |
|
404 | + ? $html_id |
|
405 | + : $html_id . '-frm'; |
|
406 | + return $html_id; |
|
407 | + } |
|
408 | + |
|
409 | + |
|
410 | + /** |
|
411 | + * returns HTML for generating the closing form HTML tag (</form>) |
|
412 | + * |
|
413 | + * @return string |
|
414 | + * @throws EE_Error |
|
415 | + */ |
|
416 | + public function form_close() |
|
417 | + { |
|
418 | + return EEH_HTML::nl(-1, 'form') |
|
419 | + . '</form>' |
|
420 | + . EEH_HTML::nl() |
|
421 | + . '<!-- end of ee-' |
|
422 | + . $this->html_id() |
|
423 | + . '-form -->' |
|
424 | + . EEH_HTML::nl(); |
|
425 | + } |
|
426 | + |
|
427 | + |
|
428 | + |
|
429 | + /** |
|
430 | + * enqueues JS (and CSS) for the form (ie immediately call wp_enqueue_script and |
|
431 | + * wp_enqueue_style; the scripts could have optionally been registered earlier) |
|
432 | + * Default does nothing, but child classes can override |
|
433 | + * |
|
434 | + * @return void |
|
435 | + */ |
|
436 | + public function enqueue_js() |
|
437 | + { |
|
438 | + // defaults to enqueue NO js or css |
|
439 | + } |
|
440 | + |
|
441 | + |
|
442 | + |
|
443 | + /** |
|
444 | + * Adds any extra data needed by js. Eventually we'll call wp_localize_script |
|
445 | + * with it, and it will be on each form section's 'other_data' property. |
|
446 | + * By default nothing is added, but child classes can extend this method to add something. |
|
447 | + * Eg, if you have an input that will cause a modal dialog to appear, |
|
448 | + * here you could add an entry like 'modal_dialog_inputs' to this array |
|
449 | + * to map between the input's html ID and the modal dialogue's ID, so that |
|
450 | + * your JS code will know where to find the modal dialog when the input is pressed. |
|
451 | + * Eg $form_other_js_data['modal_dialog_inputs']['some-input-id']='modal-dialog-id'; |
|
452 | + * |
|
453 | + * @param array $form_other_js_data |
|
454 | + * @return array |
|
455 | + */ |
|
456 | + public function get_other_js_data($form_other_js_data = array()) |
|
457 | + { |
|
458 | + return $form_other_js_data; |
|
459 | + } |
|
460 | + |
|
461 | + |
|
462 | + |
|
463 | + /** |
|
464 | + * This isn't just the name of an input, it's a path pointing to an input. The |
|
465 | + * path is similar to a folder path: slash (/) means to descend into a subsection, |
|
466 | + * dot-dot-slash (../) means to ascend into the parent section. |
|
467 | + * After a series of slashes and dot-dot-slashes, there should be the name of an input, |
|
468 | + * which will be returned. |
|
469 | + * Eg, if you want the related input to be conditional on a sibling input name 'foobar' |
|
470 | + * just use 'foobar'. If you want it to be conditional on an aunt/uncle input name |
|
471 | + * 'baz', use '../baz'. If you want it to be conditional on a cousin input, |
|
472 | + * the child of 'baz_section' named 'baz_child', use '../baz_section/baz_child'. |
|
473 | + * Etc |
|
474 | + * |
|
475 | + * @param string|false $form_section_path we accept false also because substr( '../', '../' ) = false |
|
476 | + * @return EE_Form_Section_Base |
|
477 | + */ |
|
478 | + public function find_section_from_path($form_section_path) |
|
479 | + { |
|
480 | + if (strpos($form_section_path, '/') === 0) { |
|
481 | + $form_section_path = substr($form_section_path, strlen('/')); |
|
482 | + } |
|
483 | + if (empty($form_section_path)) { |
|
484 | + return $this; |
|
485 | + } |
|
486 | + if (strpos($form_section_path, '../') === 0) { |
|
487 | + $parent = $this->parent_section(); |
|
488 | + $form_section_path = substr($form_section_path, strlen('../')); |
|
489 | + if ($parent instanceof EE_Form_Section_Base) { |
|
490 | + return $parent->find_section_from_path($form_section_path); |
|
491 | + } |
|
492 | + if (empty($form_section_path)) { |
|
493 | + return $this; |
|
494 | + } |
|
495 | + } |
|
496 | + // couldn't find it using simple parent following |
|
497 | + return null; |
|
498 | + } |
|
499 | 499 | } |
500 | 500 | // End of file EE_Form_Section_Base.form.php |
@@ -95,7 +95,7 @@ discard block |
||
95 | 95 | // used by display strategies |
96 | 96 | // assign incoming values to properties |
97 | 97 | foreach ($options_array as $key => $value) { |
98 | - $key = '_' . $key; |
|
98 | + $key = '_'.$key; |
|
99 | 99 | if (property_exists($this, $key) && empty($this->{$key})) { |
100 | 100 | $this->{$key} = $value; |
101 | 101 | if ($key === '_subsections' && ! is_array($value)) { |
@@ -135,7 +135,7 @@ discard block |
||
135 | 135 | */ |
136 | 136 | public function ensure_construct_finalized_called() |
137 | 137 | { |
138 | - if (! $this->_construction_finalized) { |
|
138 | + if ( ! $this->_construction_finalized) { |
|
139 | 139 | $this->_construct_finalize($this->_parent_section, $this->_name); |
140 | 140 | } |
141 | 141 | } |
@@ -198,7 +198,7 @@ discard block |
||
198 | 198 | */ |
199 | 199 | protected function _set_default_html_id_if_empty() |
200 | 200 | { |
201 | - if (! $this->_html_id) { |
|
201 | + if ( ! $this->_html_id) { |
|
202 | 202 | if ($this->_parent_section && $this->_parent_section instanceof EE_Form_Section_Proper) { |
203 | 203 | $this->_html_id = $this->_parent_section->html_id() |
204 | 204 | . '-' |
@@ -257,7 +257,7 @@ discard block |
||
257 | 257 | public function html_id($add_pound_sign = false) |
258 | 258 | { |
259 | 259 | $this->_set_default_html_id_if_empty(); |
260 | - return $add_pound_sign ? '#' . $this->_html_id : $this->_html_id; |
|
260 | + return $add_pound_sign ? '#'.$this->_html_id : $this->_html_id; |
|
261 | 261 | } |
262 | 262 | |
263 | 263 | |
@@ -327,7 +327,7 @@ discard block |
||
327 | 327 | */ |
328 | 328 | public function other_html_attributes() |
329 | 329 | { |
330 | - return ! empty($this->_other_html_attributes) ? ' ' . $this->_other_html_attributes : ''; |
|
330 | + return ! empty($this->_other_html_attributes) ? ' '.$this->_other_html_attributes : ''; |
|
331 | 331 | } |
332 | 332 | |
333 | 333 | |
@@ -340,7 +340,7 @@ discard block |
||
340 | 340 | */ |
341 | 341 | public function name() |
342 | 342 | { |
343 | - if (! $this->_construction_finalized) { |
|
343 | + if ( ! $this->_construction_finalized) { |
|
344 | 344 | throw new EE_Error(sprintf(esc_html__( |
345 | 345 | 'You cannot use the form section\s name until _construct_finalize has been called on it (when we set the name). It was called on a form section of type \'s\'', |
346 | 346 | 'event_espresso' |
@@ -373,18 +373,18 @@ discard block |
||
373 | 373 | */ |
374 | 374 | public function form_open($action = '', $method = '', $other_attributes = '') |
375 | 375 | { |
376 | - if (! empty($action)) { |
|
376 | + if ( ! empty($action)) { |
|
377 | 377 | $this->set_action($action); |
378 | 378 | } |
379 | - if (! empty($method)) { |
|
379 | + if ( ! empty($method)) { |
|
380 | 380 | $this->set_method($method); |
381 | 381 | } |
382 | - $html = EEH_HTML::nl(1, 'form') . '<form'; |
|
383 | - $html .= $this->html_id() !== '' ? ' id="' . $this->get_html_id_for_form($this->html_id()) . '"' : ''; |
|
384 | - $html .= ' action="' . $this->action() . '"'; |
|
385 | - $html .= ' method="' . $this->method() . '"'; |
|
386 | - $html .= ' name="' . $this->name() . '"'; |
|
387 | - $html .= $other_attributes . '>'; |
|
382 | + $html = EEH_HTML::nl(1, 'form').'<form'; |
|
383 | + $html .= $this->html_id() !== '' ? ' id="'.$this->get_html_id_for_form($this->html_id()).'"' : ''; |
|
384 | + $html .= ' action="'.$this->action().'"'; |
|
385 | + $html .= ' method="'.$this->method().'"'; |
|
386 | + $html .= ' name="'.$this->name().'"'; |
|
387 | + $html .= $other_attributes.'>'; |
|
388 | 388 | return $html; |
389 | 389 | } |
390 | 390 | |
@@ -402,7 +402,7 @@ discard block |
||
402 | 402 | $strlen = strlen($html_id); |
403 | 403 | $html_id = strpos($html_id, '-form') === $strlen - 5 || strpos($html_id, '-frm') === $strlen - 4 |
404 | 404 | ? $html_id |
405 | - : $html_id . '-frm'; |
|
405 | + : $html_id.'-frm'; |
|
406 | 406 | return $html_id; |
407 | 407 | } |
408 | 408 |
@@ -12,460 +12,460 @@ |
||
12 | 12 | class EE_Model_Form_Section extends EE_Form_Section_Proper |
13 | 13 | { |
14 | 14 | |
15 | - /** |
|
16 | - * @var EEM_Base |
|
17 | - */ |
|
18 | - protected $_model = null; |
|
19 | - |
|
20 | - /** |
|
21 | - * @var EE_Base_Class |
|
22 | - */ |
|
23 | - protected $_model_object = null; |
|
24 | - |
|
25 | - |
|
26 | - |
|
27 | - /** |
|
28 | - * @param array $options_array keys: { |
|
29 | - * @type EEM_Base $model |
|
30 | - * @type EE_Base_Class $model_object |
|
31 | - * @type array $subsection_args array keys should be subsection names (that either do or will exist), and |
|
32 | - * values are the arrays as you would pass them to that subsection |
|
33 | - * } |
|
34 | - * @throws EE_Error |
|
35 | - */ |
|
36 | - public function __construct($options_array = array()) |
|
37 | - { |
|
38 | - if (isset($options_array['model']) && $options_array['model'] instanceof EEM_Base) { |
|
39 | - $this->_model = $options_array['model']; |
|
40 | - } |
|
41 | - if (! $this->_model || ! $this->_model instanceof EEM_Base) { |
|
42 | - throw new EE_Error(sprintf(esc_html__( |
|
43 | - "Model Form Sections must first specify the _model property to be a subclass of EEM_Base", |
|
44 | - "event_espresso" |
|
45 | - ))); |
|
46 | - } |
|
47 | - if (isset($options_array['subsection_args'])) { |
|
48 | - $subsection_args = $options_array['subsection_args']; |
|
49 | - } else { |
|
50 | - $subsection_args = array(); |
|
51 | - } |
|
52 | - // gather fields and relations to convert to inputs |
|
53 | - // but if they're just going to exclude a field anyways, don't bother converting it to an input |
|
54 | - $exclude = $this->_subsections; |
|
55 | - if (isset($options_array['exclude'])) { |
|
56 | - $exclude = array_merge($exclude, array_flip($options_array['exclude'])); |
|
57 | - } |
|
58 | - $model_fields = array_diff_key($this->_model->field_settings(), $exclude); |
|
59 | - $model_relations = array_diff_key($this->_model->relation_settings(), $exclude); |
|
60 | - // convert fields and relations to inputs |
|
61 | - $this->_subsections = array_merge( |
|
62 | - $this->_convert_model_fields_to_inputs($model_fields), |
|
63 | - $this->_convert_model_relations_to_inputs($model_relations, $subsection_args), |
|
64 | - $this->_subsections |
|
65 | - ); |
|
66 | - parent::__construct($options_array); |
|
67 | - if (isset($options_array['model_object']) && $options_array['model_object'] instanceof EE_Base_Class) { |
|
68 | - $this->populate_model_obj($options_array['model_object']); |
|
69 | - } |
|
70 | - } |
|
71 | - |
|
72 | - |
|
73 | - |
|
74 | - /** |
|
75 | - * For now, just makes inputs for only HABTM relations |
|
76 | - * |
|
77 | - * @param EE_Model_Relation_Base[] $relations |
|
78 | - * @param array $subsection_args keys should be existing or soon-to-be-existing input names, and |
|
79 | - * their values are { |
|
80 | - * @type array { |
|
81 | - * @type EE_Base_Class[] $model_objects if the subsection is an EE_Select_Multi_Model_Input |
|
82 | - * } |
|
83 | - * } |
|
84 | - * @return array |
|
85 | - */ |
|
86 | - protected function _convert_model_relations_to_inputs($relations, $subsection_args = array()) |
|
87 | - { |
|
88 | - $inputs = array(); |
|
89 | - foreach ($relations as $relation_name => $relation_obj) { |
|
90 | - $input_constructor_args = array( |
|
91 | - array_merge( |
|
92 | - array( |
|
93 | - 'required' => $relation_obj instanceof EE_Belongs_To_Relation, |
|
94 | - 'html_label_text' => $relation_obj instanceof EE_Belongs_To_Relation |
|
95 | - ? $relation_obj->get_other_model()->item_name(1) |
|
96 | - : $relation_obj->get_other_model() |
|
97 | - ->item_name(2), |
|
98 | - ), |
|
99 | - $subsection_args |
|
100 | - ), |
|
101 | - ); |
|
102 | - $input = null; |
|
103 | - switch (get_class($relation_obj)) { |
|
104 | - case 'EE_HABTM_Relation': |
|
105 | - if ( |
|
106 | - isset($subsection_args[ $relation_name ]) |
|
107 | - && isset($subsection_args[ $relation_name ]['model_objects']) |
|
108 | - ) { |
|
109 | - $model_objects = $subsection_args[ $relation_name ]['model_objects']; |
|
110 | - } else { |
|
111 | - $model_objects = $relation_obj->get_other_model()->get_all(); |
|
112 | - } |
|
113 | - $input = new EE_Select_Multi_Model_Input($model_objects, $input_constructor_args); |
|
114 | - break; |
|
115 | - default: |
|
116 | - } |
|
117 | - if ($input) { |
|
118 | - $inputs[ $relation_name ] = $input; |
|
119 | - } |
|
120 | - } |
|
121 | - return $inputs; |
|
122 | - } |
|
123 | - |
|
124 | - |
|
125 | - |
|
126 | - /** |
|
127 | - * Changes model fields into form section inputs |
|
128 | - * |
|
129 | - * @param EE_Model_Field_Base[] $model_fields keys are the model's name |
|
130 | - * @throws EE_Error |
|
131 | - * @return EE_Form_Input_Base[] |
|
132 | - */ |
|
133 | - protected function _convert_model_fields_to_inputs($model_fields = array()) |
|
134 | - { |
|
135 | - $inputs = array(); |
|
136 | - foreach ($model_fields as $field_name => $model_field) { |
|
137 | - if ($model_field instanceof EE_Model_Field_Base) { |
|
138 | - $input_constructor_args = array( |
|
139 | - array( |
|
140 | - 'required' => ! $model_field->is_nullable() |
|
141 | - && $model_field->get_default_value() |
|
142 | - === null, |
|
143 | - 'html_label_text' => $model_field->get_nicename(), |
|
144 | - 'default' => $model_field->get_default_value(), |
|
145 | - ), |
|
146 | - ); |
|
147 | - switch (get_class($model_field)) { |
|
148 | - case 'EE_All_Caps_Text_Field': |
|
149 | - case 'EE_Any_Foreign_Model_Name_Field': |
|
150 | - $input_class = 'EE_Text_Input'; |
|
151 | - break; |
|
152 | - case 'EE_Boolean_Field': |
|
153 | - $input_class = 'EE_Yes_No_Input'; |
|
154 | - break; |
|
155 | - case 'EE_Datetime_Field': |
|
156 | - throw new EE_Error(sprintf(esc_html__( |
|
157 | - "Model field '%s' does not yet have a known conversion to form input", |
|
158 | - "event_espresso" |
|
159 | - ), get_class($model_field))); |
|
160 | - break; |
|
161 | - case 'EE_Email_Field': |
|
162 | - $input_class = 'EE_Email_Input'; |
|
163 | - break; |
|
164 | - case 'EE_Enum_Integer_Field': |
|
165 | - throw new EE_Error(sprintf(esc_html__( |
|
166 | - "Model field '%s' does not yet have a known conversion to form input", |
|
167 | - "event_espresso" |
|
168 | - ), get_class($model_field))); |
|
169 | - break; |
|
170 | - case 'EE_Enum_Text_Field': |
|
171 | - throw new EE_Error(sprintf(esc_html__( |
|
172 | - "Model field '%s' does not yet have a known conversion to form input", |
|
173 | - "event_espresso" |
|
174 | - ), get_class($model_field))); |
|
175 | - break; |
|
176 | - case 'EE_Float_Field': |
|
177 | - $input_class = 'EE_Float_Input'; |
|
178 | - break; |
|
179 | - case 'EE_Foreign_Key_Int_Field': |
|
180 | - case 'EE_Foreign_Key_String_Field': |
|
181 | - case 'EE_WP_User_Field': |
|
182 | - $models_pointed_to = $model_field instanceof EE_Field_With_Model_Name |
|
183 | - ? $model_field->get_model_class_names_pointed_to() : array(); |
|
184 | - if (true || is_array($models_pointed_to) && count($models_pointed_to) > 1) { |
|
185 | - $input_class = 'EE_Text_Input'; |
|
186 | - } else { |
|
187 | - // so its just one model |
|
188 | - $model_name = is_array($models_pointed_to) ? reset($models_pointed_to) : $models_pointed_to; |
|
189 | - $model = EE_Registry::instance()->load_model($model_name); |
|
190 | - $model_names = $model->get_all_names(array('limit' => 10)); |
|
191 | - if ($model_field->is_nullable()) { |
|
192 | - array_unshift($model_names, esc_html__("Please Select", 'event_espresso')); |
|
193 | - } |
|
194 | - $input_constructor_args[1] = $input_constructor_args[0]; |
|
195 | - $input_constructor_args[0] = $model_names; |
|
196 | - $input_class = 'EE_Select_Input'; |
|
197 | - } |
|
198 | - break; |
|
199 | - case 'EE_Full_HTML_Field': |
|
200 | - $input_class = 'EE_Text_Area_Input'; |
|
201 | - $input_constructor_args[0]['validation_strategies'] = array(new EE_Full_HTML_Validation_Strategy()); |
|
202 | - break; |
|
203 | - case 'EE_Infinite_Integer': |
|
204 | - throw new EE_Error(sprintf(esc_html__( |
|
205 | - "Model field '%s' does not yet have a known conversion to form input", |
|
206 | - "event_espresso" |
|
207 | - ), get_class($model_field))); |
|
208 | - break; |
|
209 | - case 'EE_Integer_Field': |
|
210 | - $input_class = 'EE_Text_Input'; |
|
211 | - break; |
|
212 | - case 'EE_Maybe_Serialized_Text_Field': |
|
213 | - $input_class = 'EE_Text_Area_Input'; |
|
214 | - break; |
|
215 | - case 'EE_Money_Field': |
|
216 | - throw new EE_Error(sprintf(esc_html__( |
|
217 | - "Model field '%s' does not yet have a known conversion to form input", |
|
218 | - "event_espresso" |
|
219 | - ), get_class($model_field))); |
|
220 | - break; |
|
221 | - case 'EE_Post_Content_Field': |
|
222 | - $input_class = 'EE_Text_Area_Input'; |
|
223 | - $input_constructor_args[0]['validation_strategies'] = array(new EE_Full_HTML_Validation_Strategy()); |
|
224 | - break; |
|
225 | - case 'EE_Plain_Text_Field': |
|
226 | - $input_class = 'EE_Text_Input'; |
|
227 | - break; |
|
228 | - case 'EE_Primary_Key_Int_Field': |
|
229 | - $input_class = 'EE_Hidden_Input'; |
|
230 | - $input_constructor_args[0]['normalization_strategy'] = new EE_Int_Normalization(); |
|
231 | - break; |
|
232 | - case 'EE_Primary_Key_String_Field': |
|
233 | - $input_class = 'EE_Hidden_Input'; |
|
234 | - break; |
|
235 | - case 'EE_Serialized_Text_Field': |
|
236 | - $input_class = 'EE_Text_Area_Input'; |
|
237 | - break; |
|
238 | - case 'EE_Simple_HTML_Field': |
|
239 | - $input_class = 'EE_Text_Area_Input'; |
|
240 | - $input_constructor_args[0]['validation_strategies'] = array(new EE_Simple_HTML_Validation_Strategy()); |
|
241 | - break; |
|
242 | - case 'EE_Slug_Field': |
|
243 | - $input_class = 'EE_Text_Input'; |
|
244 | - break; |
|
245 | - case 'EE_Trashed_Flag_Field': |
|
246 | - $input_class = 'EE_Yes_No_Input'; |
|
247 | - break; |
|
248 | - case 'EE_WP_Post_Status_Field': |
|
249 | - throw new EE_Error(sprintf(esc_html__( |
|
250 | - "Model field '%s' does not yet have a known conversion to form input", |
|
251 | - "event_espresso" |
|
252 | - ), get_class($model_field))); |
|
253 | - break; |
|
254 | - case 'EE_WP_Post_Type_Field': |
|
255 | - throw new EE_Error(sprintf(esc_html__( |
|
256 | - "Model field '%s' does not yet have a known conversion to form input", |
|
257 | - "event_espresso" |
|
258 | - ), get_class($model_field))); |
|
259 | - break; |
|
260 | - default: |
|
261 | - throw new EE_Error(sprintf(esc_html__( |
|
262 | - "Model field of type '%s' does not convert to any known Form Input. Please add a case to EE_Model_Form_section's _convert_model_fields_to_inputs switch statement", |
|
263 | - "event_espresso" |
|
264 | - ), get_class($model_field))); |
|
265 | - } |
|
266 | - $reflection = new ReflectionClass($input_class); |
|
267 | - $input = $reflection->newInstanceArgs($input_constructor_args); |
|
268 | - $inputs[ $field_name ] = $input; |
|
269 | - } |
|
270 | - } |
|
271 | - return $inputs; |
|
272 | - } |
|
273 | - |
|
274 | - |
|
275 | - |
|
276 | - /** |
|
277 | - * Mostly the same as populate_defaults , except takes a model object as input, not an array, |
|
278 | - * and also sets the form's _model_object |
|
279 | - * |
|
280 | - * @param EE_Base_Class $model_obj |
|
281 | - * @return void |
|
282 | - */ |
|
283 | - public function populate_model_obj($model_obj) |
|
284 | - { |
|
285 | - $model_obj = $this->_model->ensure_is_obj($model_obj); |
|
286 | - $this->_model_object = $model_obj; |
|
287 | - $defaults = $model_obj->model_field_array(); |
|
288 | - foreach ($this->_model->relation_settings() as $relation_name => $relation_obj) { |
|
289 | - $subsection = $this->get_subsection($relation_name, false); |
|
290 | - if ($subsection instanceof EE_Form_Input_Base) { |
|
291 | - if ($relation_obj instanceof EE_Belongs_To_Relation) { |
|
292 | - // then we only expect there to be one |
|
293 | - $related_item = $this->_model_object->get_first_related($relation_name); |
|
294 | - $defaults[ $relation_name ] = $related_item->ID(); |
|
295 | - } else { |
|
296 | - $related_items = $this->_model_object->get_many_related($relation_name); |
|
297 | - $ids = array(); |
|
298 | - foreach ($related_items as $related_item) { |
|
299 | - $ids[] = $related_item->ID(); |
|
300 | - } |
|
301 | - $defaults[ $relation_name ] = $ids; |
|
302 | - } |
|
303 | - } |
|
304 | - } |
|
305 | - $defaults = apply_filters( |
|
306 | - 'FHEE__EE_Model_Form_Section__populate_model_obj', |
|
307 | - $defaults, |
|
308 | - $this |
|
309 | - ); |
|
310 | - $this->populate_defaults($defaults); |
|
311 | - } |
|
312 | - |
|
313 | - |
|
314 | - |
|
315 | - /** |
|
316 | - * Gets all the input values that correspond to model fields. Keys are the input/field names, |
|
317 | - * values are their normalized values |
|
318 | - * |
|
319 | - * @return array |
|
320 | - */ |
|
321 | - public function inputs_values_corresponding_to_model_fields() |
|
322 | - { |
|
323 | - return array_intersect_key($this->input_values(), $this->_model->field_settings()); |
|
324 | - } |
|
325 | - |
|
326 | - |
|
327 | - |
|
328 | - /** |
|
329 | - * After we've normalized the data as normal, set the corresponding model object |
|
330 | - * on the form. |
|
331 | - * |
|
332 | - * @param array $req_data should usually be the form post/request data (the default). |
|
333 | - * @return void |
|
334 | - */ |
|
335 | - public function _normalize($req_data) |
|
336 | - { |
|
337 | - parent::_normalize($req_data); |
|
338 | - // create or set the model object, if it isn't already |
|
339 | - if (! $this->_model_object) { |
|
340 | - // check to see if the form indicates a PK, in which case we want to only retrieve it and update it |
|
341 | - $pk_name = $this->_model->primary_key_name(); |
|
342 | - $model_obj = $this->_model->get_one_by_ID($this->get_input_value($pk_name)); |
|
343 | - if ($model_obj) { |
|
344 | - $this->_model_object = $model_obj; |
|
345 | - } else { |
|
346 | - $this->_model_object = EE_Registry::instance()->load_class($this->_model->get_this_model_name()); |
|
347 | - } |
|
348 | - } |
|
349 | - } |
|
350 | - |
|
351 | - |
|
352 | - |
|
353 | - /** |
|
354 | - * After this form has been initialized and is verified to be valid, |
|
355 | - * either creates a model object from its data and saves it, or updates |
|
356 | - * the model object its data represents |
|
357 | - * |
|
358 | - * @throws EE_Error |
|
359 | - * @return int, 1 on a successful update, the ID of |
|
360 | - * the new entry on insert; 0 on failure |
|
361 | - */ |
|
362 | - public function save() |
|
363 | - { |
|
364 | - if (! $this->_model_object) { |
|
365 | - throw new EE_Error(sprintf(esc_html__( |
|
366 | - "Cannot save the model form's model object (model is '%s') because there is no model object set. You must either set it, or call receive_form_submission where it is set automatically", |
|
367 | - "event_espresso" |
|
368 | - ), get_class($this->_model))); |
|
369 | - } |
|
370 | - // ok so the model object is set. Just set it with the submitted form data |
|
371 | - foreach ($this->inputs_values_corresponding_to_model_fields() as $field_name => $field_value) { |
|
372 | - // only set the non-primary key |
|
373 | - if ($field_name != $this->_model->primary_key_name()) { |
|
374 | - $this->_model_object->set($field_name, $field_value); |
|
375 | - } |
|
376 | - } |
|
377 | - $success = $this->_model_object->save(); |
|
378 | - foreach ($this->_model->relation_settings() as $relation_name => $relation_obj) { |
|
379 | - if (isset($this->_subsections[ $relation_name ])) { |
|
380 | - $success = $this->_save_related_info($relation_name); |
|
381 | - } |
|
382 | - } |
|
383 | - do_action('AHEE__EE_Model_Form_Section__save__done', $this, $success); |
|
384 | - return $success; |
|
385 | - } |
|
386 | - |
|
387 | - |
|
388 | - |
|
389 | - /** |
|
390 | - * Automatically finds the related model info from the form, if present, and |
|
391 | - * save the relations indicated |
|
392 | - * |
|
393 | - * @type string $relation_name |
|
394 | - * @return bool |
|
395 | - * @throws EE_Error |
|
396 | - */ |
|
397 | - protected function _save_related_info($relation_name) |
|
398 | - { |
|
399 | - $relation_obj = $this->_model->related_settings_for($relation_name); |
|
400 | - if ($relation_obj instanceof EE_Belongs_To_Relation) { |
|
401 | - // there is just a foreign key on this model pointing to that one |
|
402 | - $this->_model_object->_add_relation_to($this->get_input_value($relation_name), $relation_name); |
|
403 | - } elseif ($relation_obj instanceof EE_Has_Many_Relation) { |
|
404 | - // then we want to consider all of its currently-related things. |
|
405 | - // if they're in this list, keep them |
|
406 | - // if they're not in this list, remove them |
|
407 | - // and lastly add all the new items |
|
408 | - throw new EE_Error(sprintf(esc_html__( |
|
409 | - 'Automatic saving of related info across a "has many" relation is not yet supported', |
|
410 | - "event_espresso" |
|
411 | - ))); |
|
412 | - } elseif ($relation_obj instanceof EE_HABTM_Relation) { |
|
413 | - // delete everything NOT in this list |
|
414 | - $normalized_input_value = $this->get_input_value($relation_name); |
|
415 | - if ($normalized_input_value && is_array($normalized_input_value)) { |
|
416 | - $where_query_params = array( |
|
417 | - $relation_obj->get_other_model()->primary_key_name() => array('NOT_IN', $normalized_input_value), |
|
418 | - ); |
|
419 | - } else { |
|
420 | - $where_query_params = array(); |
|
421 | - } |
|
422 | - $this->_model_object->_remove_relations($relation_name, $where_query_params); |
|
423 | - foreach ($normalized_input_value as $id) { |
|
424 | - $this->_model_object->_add_relation_to($id, $relation_name); |
|
425 | - } |
|
426 | - } |
|
427 | - return true; |
|
428 | - } |
|
429 | - |
|
430 | - |
|
431 | - |
|
432 | - /** |
|
433 | - * Gets the model of this model form |
|
434 | - * |
|
435 | - * @return EEM_Base |
|
436 | - */ |
|
437 | - public function get_model() |
|
438 | - { |
|
439 | - return $this->_model; |
|
440 | - } |
|
441 | - |
|
442 | - |
|
443 | - |
|
444 | - /** |
|
445 | - * Gets the model object for this model form, which was either set |
|
446 | - * upon construction (using the $options_array arg 'model_object'), by using |
|
447 | - * set_model_object($model_obj), or implicitly |
|
448 | - * when receive_form_submission($req_data) was called. |
|
449 | - * |
|
450 | - * @return EE_Base_Class |
|
451 | - */ |
|
452 | - public function get_model_object() |
|
453 | - { |
|
454 | - return $this->_model_object; |
|
455 | - } |
|
456 | - |
|
457 | - |
|
458 | - |
|
459 | - /** |
|
460 | - * gets teh default name of this form section if none is specified |
|
461 | - * |
|
462 | - * @return string |
|
463 | - */ |
|
464 | - protected function _set_default_name_if_empty() |
|
465 | - { |
|
466 | - if (! $this->_name) { |
|
467 | - $default_name = str_replace("EEM_", "", get_class($this->_model)) . "_Model_Form"; |
|
468 | - $this->_name = $default_name; |
|
469 | - } |
|
470 | - } |
|
15 | + /** |
|
16 | + * @var EEM_Base |
|
17 | + */ |
|
18 | + protected $_model = null; |
|
19 | + |
|
20 | + /** |
|
21 | + * @var EE_Base_Class |
|
22 | + */ |
|
23 | + protected $_model_object = null; |
|
24 | + |
|
25 | + |
|
26 | + |
|
27 | + /** |
|
28 | + * @param array $options_array keys: { |
|
29 | + * @type EEM_Base $model |
|
30 | + * @type EE_Base_Class $model_object |
|
31 | + * @type array $subsection_args array keys should be subsection names (that either do or will exist), and |
|
32 | + * values are the arrays as you would pass them to that subsection |
|
33 | + * } |
|
34 | + * @throws EE_Error |
|
35 | + */ |
|
36 | + public function __construct($options_array = array()) |
|
37 | + { |
|
38 | + if (isset($options_array['model']) && $options_array['model'] instanceof EEM_Base) { |
|
39 | + $this->_model = $options_array['model']; |
|
40 | + } |
|
41 | + if (! $this->_model || ! $this->_model instanceof EEM_Base) { |
|
42 | + throw new EE_Error(sprintf(esc_html__( |
|
43 | + "Model Form Sections must first specify the _model property to be a subclass of EEM_Base", |
|
44 | + "event_espresso" |
|
45 | + ))); |
|
46 | + } |
|
47 | + if (isset($options_array['subsection_args'])) { |
|
48 | + $subsection_args = $options_array['subsection_args']; |
|
49 | + } else { |
|
50 | + $subsection_args = array(); |
|
51 | + } |
|
52 | + // gather fields and relations to convert to inputs |
|
53 | + // but if they're just going to exclude a field anyways, don't bother converting it to an input |
|
54 | + $exclude = $this->_subsections; |
|
55 | + if (isset($options_array['exclude'])) { |
|
56 | + $exclude = array_merge($exclude, array_flip($options_array['exclude'])); |
|
57 | + } |
|
58 | + $model_fields = array_diff_key($this->_model->field_settings(), $exclude); |
|
59 | + $model_relations = array_diff_key($this->_model->relation_settings(), $exclude); |
|
60 | + // convert fields and relations to inputs |
|
61 | + $this->_subsections = array_merge( |
|
62 | + $this->_convert_model_fields_to_inputs($model_fields), |
|
63 | + $this->_convert_model_relations_to_inputs($model_relations, $subsection_args), |
|
64 | + $this->_subsections |
|
65 | + ); |
|
66 | + parent::__construct($options_array); |
|
67 | + if (isset($options_array['model_object']) && $options_array['model_object'] instanceof EE_Base_Class) { |
|
68 | + $this->populate_model_obj($options_array['model_object']); |
|
69 | + } |
|
70 | + } |
|
71 | + |
|
72 | + |
|
73 | + |
|
74 | + /** |
|
75 | + * For now, just makes inputs for only HABTM relations |
|
76 | + * |
|
77 | + * @param EE_Model_Relation_Base[] $relations |
|
78 | + * @param array $subsection_args keys should be existing or soon-to-be-existing input names, and |
|
79 | + * their values are { |
|
80 | + * @type array { |
|
81 | + * @type EE_Base_Class[] $model_objects if the subsection is an EE_Select_Multi_Model_Input |
|
82 | + * } |
|
83 | + * } |
|
84 | + * @return array |
|
85 | + */ |
|
86 | + protected function _convert_model_relations_to_inputs($relations, $subsection_args = array()) |
|
87 | + { |
|
88 | + $inputs = array(); |
|
89 | + foreach ($relations as $relation_name => $relation_obj) { |
|
90 | + $input_constructor_args = array( |
|
91 | + array_merge( |
|
92 | + array( |
|
93 | + 'required' => $relation_obj instanceof EE_Belongs_To_Relation, |
|
94 | + 'html_label_text' => $relation_obj instanceof EE_Belongs_To_Relation |
|
95 | + ? $relation_obj->get_other_model()->item_name(1) |
|
96 | + : $relation_obj->get_other_model() |
|
97 | + ->item_name(2), |
|
98 | + ), |
|
99 | + $subsection_args |
|
100 | + ), |
|
101 | + ); |
|
102 | + $input = null; |
|
103 | + switch (get_class($relation_obj)) { |
|
104 | + case 'EE_HABTM_Relation': |
|
105 | + if ( |
|
106 | + isset($subsection_args[ $relation_name ]) |
|
107 | + && isset($subsection_args[ $relation_name ]['model_objects']) |
|
108 | + ) { |
|
109 | + $model_objects = $subsection_args[ $relation_name ]['model_objects']; |
|
110 | + } else { |
|
111 | + $model_objects = $relation_obj->get_other_model()->get_all(); |
|
112 | + } |
|
113 | + $input = new EE_Select_Multi_Model_Input($model_objects, $input_constructor_args); |
|
114 | + break; |
|
115 | + default: |
|
116 | + } |
|
117 | + if ($input) { |
|
118 | + $inputs[ $relation_name ] = $input; |
|
119 | + } |
|
120 | + } |
|
121 | + return $inputs; |
|
122 | + } |
|
123 | + |
|
124 | + |
|
125 | + |
|
126 | + /** |
|
127 | + * Changes model fields into form section inputs |
|
128 | + * |
|
129 | + * @param EE_Model_Field_Base[] $model_fields keys are the model's name |
|
130 | + * @throws EE_Error |
|
131 | + * @return EE_Form_Input_Base[] |
|
132 | + */ |
|
133 | + protected function _convert_model_fields_to_inputs($model_fields = array()) |
|
134 | + { |
|
135 | + $inputs = array(); |
|
136 | + foreach ($model_fields as $field_name => $model_field) { |
|
137 | + if ($model_field instanceof EE_Model_Field_Base) { |
|
138 | + $input_constructor_args = array( |
|
139 | + array( |
|
140 | + 'required' => ! $model_field->is_nullable() |
|
141 | + && $model_field->get_default_value() |
|
142 | + === null, |
|
143 | + 'html_label_text' => $model_field->get_nicename(), |
|
144 | + 'default' => $model_field->get_default_value(), |
|
145 | + ), |
|
146 | + ); |
|
147 | + switch (get_class($model_field)) { |
|
148 | + case 'EE_All_Caps_Text_Field': |
|
149 | + case 'EE_Any_Foreign_Model_Name_Field': |
|
150 | + $input_class = 'EE_Text_Input'; |
|
151 | + break; |
|
152 | + case 'EE_Boolean_Field': |
|
153 | + $input_class = 'EE_Yes_No_Input'; |
|
154 | + break; |
|
155 | + case 'EE_Datetime_Field': |
|
156 | + throw new EE_Error(sprintf(esc_html__( |
|
157 | + "Model field '%s' does not yet have a known conversion to form input", |
|
158 | + "event_espresso" |
|
159 | + ), get_class($model_field))); |
|
160 | + break; |
|
161 | + case 'EE_Email_Field': |
|
162 | + $input_class = 'EE_Email_Input'; |
|
163 | + break; |
|
164 | + case 'EE_Enum_Integer_Field': |
|
165 | + throw new EE_Error(sprintf(esc_html__( |
|
166 | + "Model field '%s' does not yet have a known conversion to form input", |
|
167 | + "event_espresso" |
|
168 | + ), get_class($model_field))); |
|
169 | + break; |
|
170 | + case 'EE_Enum_Text_Field': |
|
171 | + throw new EE_Error(sprintf(esc_html__( |
|
172 | + "Model field '%s' does not yet have a known conversion to form input", |
|
173 | + "event_espresso" |
|
174 | + ), get_class($model_field))); |
|
175 | + break; |
|
176 | + case 'EE_Float_Field': |
|
177 | + $input_class = 'EE_Float_Input'; |
|
178 | + break; |
|
179 | + case 'EE_Foreign_Key_Int_Field': |
|
180 | + case 'EE_Foreign_Key_String_Field': |
|
181 | + case 'EE_WP_User_Field': |
|
182 | + $models_pointed_to = $model_field instanceof EE_Field_With_Model_Name |
|
183 | + ? $model_field->get_model_class_names_pointed_to() : array(); |
|
184 | + if (true || is_array($models_pointed_to) && count($models_pointed_to) > 1) { |
|
185 | + $input_class = 'EE_Text_Input'; |
|
186 | + } else { |
|
187 | + // so its just one model |
|
188 | + $model_name = is_array($models_pointed_to) ? reset($models_pointed_to) : $models_pointed_to; |
|
189 | + $model = EE_Registry::instance()->load_model($model_name); |
|
190 | + $model_names = $model->get_all_names(array('limit' => 10)); |
|
191 | + if ($model_field->is_nullable()) { |
|
192 | + array_unshift($model_names, esc_html__("Please Select", 'event_espresso')); |
|
193 | + } |
|
194 | + $input_constructor_args[1] = $input_constructor_args[0]; |
|
195 | + $input_constructor_args[0] = $model_names; |
|
196 | + $input_class = 'EE_Select_Input'; |
|
197 | + } |
|
198 | + break; |
|
199 | + case 'EE_Full_HTML_Field': |
|
200 | + $input_class = 'EE_Text_Area_Input'; |
|
201 | + $input_constructor_args[0]['validation_strategies'] = array(new EE_Full_HTML_Validation_Strategy()); |
|
202 | + break; |
|
203 | + case 'EE_Infinite_Integer': |
|
204 | + throw new EE_Error(sprintf(esc_html__( |
|
205 | + "Model field '%s' does not yet have a known conversion to form input", |
|
206 | + "event_espresso" |
|
207 | + ), get_class($model_field))); |
|
208 | + break; |
|
209 | + case 'EE_Integer_Field': |
|
210 | + $input_class = 'EE_Text_Input'; |
|
211 | + break; |
|
212 | + case 'EE_Maybe_Serialized_Text_Field': |
|
213 | + $input_class = 'EE_Text_Area_Input'; |
|
214 | + break; |
|
215 | + case 'EE_Money_Field': |
|
216 | + throw new EE_Error(sprintf(esc_html__( |
|
217 | + "Model field '%s' does not yet have a known conversion to form input", |
|
218 | + "event_espresso" |
|
219 | + ), get_class($model_field))); |
|
220 | + break; |
|
221 | + case 'EE_Post_Content_Field': |
|
222 | + $input_class = 'EE_Text_Area_Input'; |
|
223 | + $input_constructor_args[0]['validation_strategies'] = array(new EE_Full_HTML_Validation_Strategy()); |
|
224 | + break; |
|
225 | + case 'EE_Plain_Text_Field': |
|
226 | + $input_class = 'EE_Text_Input'; |
|
227 | + break; |
|
228 | + case 'EE_Primary_Key_Int_Field': |
|
229 | + $input_class = 'EE_Hidden_Input'; |
|
230 | + $input_constructor_args[0]['normalization_strategy'] = new EE_Int_Normalization(); |
|
231 | + break; |
|
232 | + case 'EE_Primary_Key_String_Field': |
|
233 | + $input_class = 'EE_Hidden_Input'; |
|
234 | + break; |
|
235 | + case 'EE_Serialized_Text_Field': |
|
236 | + $input_class = 'EE_Text_Area_Input'; |
|
237 | + break; |
|
238 | + case 'EE_Simple_HTML_Field': |
|
239 | + $input_class = 'EE_Text_Area_Input'; |
|
240 | + $input_constructor_args[0]['validation_strategies'] = array(new EE_Simple_HTML_Validation_Strategy()); |
|
241 | + break; |
|
242 | + case 'EE_Slug_Field': |
|
243 | + $input_class = 'EE_Text_Input'; |
|
244 | + break; |
|
245 | + case 'EE_Trashed_Flag_Field': |
|
246 | + $input_class = 'EE_Yes_No_Input'; |
|
247 | + break; |
|
248 | + case 'EE_WP_Post_Status_Field': |
|
249 | + throw new EE_Error(sprintf(esc_html__( |
|
250 | + "Model field '%s' does not yet have a known conversion to form input", |
|
251 | + "event_espresso" |
|
252 | + ), get_class($model_field))); |
|
253 | + break; |
|
254 | + case 'EE_WP_Post_Type_Field': |
|
255 | + throw new EE_Error(sprintf(esc_html__( |
|
256 | + "Model field '%s' does not yet have a known conversion to form input", |
|
257 | + "event_espresso" |
|
258 | + ), get_class($model_field))); |
|
259 | + break; |
|
260 | + default: |
|
261 | + throw new EE_Error(sprintf(esc_html__( |
|
262 | + "Model field of type '%s' does not convert to any known Form Input. Please add a case to EE_Model_Form_section's _convert_model_fields_to_inputs switch statement", |
|
263 | + "event_espresso" |
|
264 | + ), get_class($model_field))); |
|
265 | + } |
|
266 | + $reflection = new ReflectionClass($input_class); |
|
267 | + $input = $reflection->newInstanceArgs($input_constructor_args); |
|
268 | + $inputs[ $field_name ] = $input; |
|
269 | + } |
|
270 | + } |
|
271 | + return $inputs; |
|
272 | + } |
|
273 | + |
|
274 | + |
|
275 | + |
|
276 | + /** |
|
277 | + * Mostly the same as populate_defaults , except takes a model object as input, not an array, |
|
278 | + * and also sets the form's _model_object |
|
279 | + * |
|
280 | + * @param EE_Base_Class $model_obj |
|
281 | + * @return void |
|
282 | + */ |
|
283 | + public function populate_model_obj($model_obj) |
|
284 | + { |
|
285 | + $model_obj = $this->_model->ensure_is_obj($model_obj); |
|
286 | + $this->_model_object = $model_obj; |
|
287 | + $defaults = $model_obj->model_field_array(); |
|
288 | + foreach ($this->_model->relation_settings() as $relation_name => $relation_obj) { |
|
289 | + $subsection = $this->get_subsection($relation_name, false); |
|
290 | + if ($subsection instanceof EE_Form_Input_Base) { |
|
291 | + if ($relation_obj instanceof EE_Belongs_To_Relation) { |
|
292 | + // then we only expect there to be one |
|
293 | + $related_item = $this->_model_object->get_first_related($relation_name); |
|
294 | + $defaults[ $relation_name ] = $related_item->ID(); |
|
295 | + } else { |
|
296 | + $related_items = $this->_model_object->get_many_related($relation_name); |
|
297 | + $ids = array(); |
|
298 | + foreach ($related_items as $related_item) { |
|
299 | + $ids[] = $related_item->ID(); |
|
300 | + } |
|
301 | + $defaults[ $relation_name ] = $ids; |
|
302 | + } |
|
303 | + } |
|
304 | + } |
|
305 | + $defaults = apply_filters( |
|
306 | + 'FHEE__EE_Model_Form_Section__populate_model_obj', |
|
307 | + $defaults, |
|
308 | + $this |
|
309 | + ); |
|
310 | + $this->populate_defaults($defaults); |
|
311 | + } |
|
312 | + |
|
313 | + |
|
314 | + |
|
315 | + /** |
|
316 | + * Gets all the input values that correspond to model fields. Keys are the input/field names, |
|
317 | + * values are their normalized values |
|
318 | + * |
|
319 | + * @return array |
|
320 | + */ |
|
321 | + public function inputs_values_corresponding_to_model_fields() |
|
322 | + { |
|
323 | + return array_intersect_key($this->input_values(), $this->_model->field_settings()); |
|
324 | + } |
|
325 | + |
|
326 | + |
|
327 | + |
|
328 | + /** |
|
329 | + * After we've normalized the data as normal, set the corresponding model object |
|
330 | + * on the form. |
|
331 | + * |
|
332 | + * @param array $req_data should usually be the form post/request data (the default). |
|
333 | + * @return void |
|
334 | + */ |
|
335 | + public function _normalize($req_data) |
|
336 | + { |
|
337 | + parent::_normalize($req_data); |
|
338 | + // create or set the model object, if it isn't already |
|
339 | + if (! $this->_model_object) { |
|
340 | + // check to see if the form indicates a PK, in which case we want to only retrieve it and update it |
|
341 | + $pk_name = $this->_model->primary_key_name(); |
|
342 | + $model_obj = $this->_model->get_one_by_ID($this->get_input_value($pk_name)); |
|
343 | + if ($model_obj) { |
|
344 | + $this->_model_object = $model_obj; |
|
345 | + } else { |
|
346 | + $this->_model_object = EE_Registry::instance()->load_class($this->_model->get_this_model_name()); |
|
347 | + } |
|
348 | + } |
|
349 | + } |
|
350 | + |
|
351 | + |
|
352 | + |
|
353 | + /** |
|
354 | + * After this form has been initialized and is verified to be valid, |
|
355 | + * either creates a model object from its data and saves it, or updates |
|
356 | + * the model object its data represents |
|
357 | + * |
|
358 | + * @throws EE_Error |
|
359 | + * @return int, 1 on a successful update, the ID of |
|
360 | + * the new entry on insert; 0 on failure |
|
361 | + */ |
|
362 | + public function save() |
|
363 | + { |
|
364 | + if (! $this->_model_object) { |
|
365 | + throw new EE_Error(sprintf(esc_html__( |
|
366 | + "Cannot save the model form's model object (model is '%s') because there is no model object set. You must either set it, or call receive_form_submission where it is set automatically", |
|
367 | + "event_espresso" |
|
368 | + ), get_class($this->_model))); |
|
369 | + } |
|
370 | + // ok so the model object is set. Just set it with the submitted form data |
|
371 | + foreach ($this->inputs_values_corresponding_to_model_fields() as $field_name => $field_value) { |
|
372 | + // only set the non-primary key |
|
373 | + if ($field_name != $this->_model->primary_key_name()) { |
|
374 | + $this->_model_object->set($field_name, $field_value); |
|
375 | + } |
|
376 | + } |
|
377 | + $success = $this->_model_object->save(); |
|
378 | + foreach ($this->_model->relation_settings() as $relation_name => $relation_obj) { |
|
379 | + if (isset($this->_subsections[ $relation_name ])) { |
|
380 | + $success = $this->_save_related_info($relation_name); |
|
381 | + } |
|
382 | + } |
|
383 | + do_action('AHEE__EE_Model_Form_Section__save__done', $this, $success); |
|
384 | + return $success; |
|
385 | + } |
|
386 | + |
|
387 | + |
|
388 | + |
|
389 | + /** |
|
390 | + * Automatically finds the related model info from the form, if present, and |
|
391 | + * save the relations indicated |
|
392 | + * |
|
393 | + * @type string $relation_name |
|
394 | + * @return bool |
|
395 | + * @throws EE_Error |
|
396 | + */ |
|
397 | + protected function _save_related_info($relation_name) |
|
398 | + { |
|
399 | + $relation_obj = $this->_model->related_settings_for($relation_name); |
|
400 | + if ($relation_obj instanceof EE_Belongs_To_Relation) { |
|
401 | + // there is just a foreign key on this model pointing to that one |
|
402 | + $this->_model_object->_add_relation_to($this->get_input_value($relation_name), $relation_name); |
|
403 | + } elseif ($relation_obj instanceof EE_Has_Many_Relation) { |
|
404 | + // then we want to consider all of its currently-related things. |
|
405 | + // if they're in this list, keep them |
|
406 | + // if they're not in this list, remove them |
|
407 | + // and lastly add all the new items |
|
408 | + throw new EE_Error(sprintf(esc_html__( |
|
409 | + 'Automatic saving of related info across a "has many" relation is not yet supported', |
|
410 | + "event_espresso" |
|
411 | + ))); |
|
412 | + } elseif ($relation_obj instanceof EE_HABTM_Relation) { |
|
413 | + // delete everything NOT in this list |
|
414 | + $normalized_input_value = $this->get_input_value($relation_name); |
|
415 | + if ($normalized_input_value && is_array($normalized_input_value)) { |
|
416 | + $where_query_params = array( |
|
417 | + $relation_obj->get_other_model()->primary_key_name() => array('NOT_IN', $normalized_input_value), |
|
418 | + ); |
|
419 | + } else { |
|
420 | + $where_query_params = array(); |
|
421 | + } |
|
422 | + $this->_model_object->_remove_relations($relation_name, $where_query_params); |
|
423 | + foreach ($normalized_input_value as $id) { |
|
424 | + $this->_model_object->_add_relation_to($id, $relation_name); |
|
425 | + } |
|
426 | + } |
|
427 | + return true; |
|
428 | + } |
|
429 | + |
|
430 | + |
|
431 | + |
|
432 | + /** |
|
433 | + * Gets the model of this model form |
|
434 | + * |
|
435 | + * @return EEM_Base |
|
436 | + */ |
|
437 | + public function get_model() |
|
438 | + { |
|
439 | + return $this->_model; |
|
440 | + } |
|
441 | + |
|
442 | + |
|
443 | + |
|
444 | + /** |
|
445 | + * Gets the model object for this model form, which was either set |
|
446 | + * upon construction (using the $options_array arg 'model_object'), by using |
|
447 | + * set_model_object($model_obj), or implicitly |
|
448 | + * when receive_form_submission($req_data) was called. |
|
449 | + * |
|
450 | + * @return EE_Base_Class |
|
451 | + */ |
|
452 | + public function get_model_object() |
|
453 | + { |
|
454 | + return $this->_model_object; |
|
455 | + } |
|
456 | + |
|
457 | + |
|
458 | + |
|
459 | + /** |
|
460 | + * gets teh default name of this form section if none is specified |
|
461 | + * |
|
462 | + * @return string |
|
463 | + */ |
|
464 | + protected function _set_default_name_if_empty() |
|
465 | + { |
|
466 | + if (! $this->_name) { |
|
467 | + $default_name = str_replace("EEM_", "", get_class($this->_model)) . "_Model_Form"; |
|
468 | + $this->_name = $default_name; |
|
469 | + } |
|
470 | + } |
|
471 | 471 | } |
@@ -38,7 +38,7 @@ discard block |
||
38 | 38 | if (isset($options_array['model']) && $options_array['model'] instanceof EEM_Base) { |
39 | 39 | $this->_model = $options_array['model']; |
40 | 40 | } |
41 | - if (! $this->_model || ! $this->_model instanceof EEM_Base) { |
|
41 | + if ( ! $this->_model || ! $this->_model instanceof EEM_Base) { |
|
42 | 42 | throw new EE_Error(sprintf(esc_html__( |
43 | 43 | "Model Form Sections must first specify the _model property to be a subclass of EEM_Base", |
44 | 44 | "event_espresso" |
@@ -103,10 +103,10 @@ discard block |
||
103 | 103 | switch (get_class($relation_obj)) { |
104 | 104 | case 'EE_HABTM_Relation': |
105 | 105 | if ( |
106 | - isset($subsection_args[ $relation_name ]) |
|
107 | - && isset($subsection_args[ $relation_name ]['model_objects']) |
|
106 | + isset($subsection_args[$relation_name]) |
|
107 | + && isset($subsection_args[$relation_name]['model_objects']) |
|
108 | 108 | ) { |
109 | - $model_objects = $subsection_args[ $relation_name ]['model_objects']; |
|
109 | + $model_objects = $subsection_args[$relation_name]['model_objects']; |
|
110 | 110 | } else { |
111 | 111 | $model_objects = $relation_obj->get_other_model()->get_all(); |
112 | 112 | } |
@@ -115,7 +115,7 @@ discard block |
||
115 | 115 | default: |
116 | 116 | } |
117 | 117 | if ($input) { |
118 | - $inputs[ $relation_name ] = $input; |
|
118 | + $inputs[$relation_name] = $input; |
|
119 | 119 | } |
120 | 120 | } |
121 | 121 | return $inputs; |
@@ -265,7 +265,7 @@ discard block |
||
265 | 265 | } |
266 | 266 | $reflection = new ReflectionClass($input_class); |
267 | 267 | $input = $reflection->newInstanceArgs($input_constructor_args); |
268 | - $inputs[ $field_name ] = $input; |
|
268 | + $inputs[$field_name] = $input; |
|
269 | 269 | } |
270 | 270 | } |
271 | 271 | return $inputs; |
@@ -291,14 +291,14 @@ discard block |
||
291 | 291 | if ($relation_obj instanceof EE_Belongs_To_Relation) { |
292 | 292 | // then we only expect there to be one |
293 | 293 | $related_item = $this->_model_object->get_first_related($relation_name); |
294 | - $defaults[ $relation_name ] = $related_item->ID(); |
|
294 | + $defaults[$relation_name] = $related_item->ID(); |
|
295 | 295 | } else { |
296 | 296 | $related_items = $this->_model_object->get_many_related($relation_name); |
297 | 297 | $ids = array(); |
298 | 298 | foreach ($related_items as $related_item) { |
299 | 299 | $ids[] = $related_item->ID(); |
300 | 300 | } |
301 | - $defaults[ $relation_name ] = $ids; |
|
301 | + $defaults[$relation_name] = $ids; |
|
302 | 302 | } |
303 | 303 | } |
304 | 304 | } |
@@ -336,7 +336,7 @@ discard block |
||
336 | 336 | { |
337 | 337 | parent::_normalize($req_data); |
338 | 338 | // create or set the model object, if it isn't already |
339 | - if (! $this->_model_object) { |
|
339 | + if ( ! $this->_model_object) { |
|
340 | 340 | // check to see if the form indicates a PK, in which case we want to only retrieve it and update it |
341 | 341 | $pk_name = $this->_model->primary_key_name(); |
342 | 342 | $model_obj = $this->_model->get_one_by_ID($this->get_input_value($pk_name)); |
@@ -361,7 +361,7 @@ discard block |
||
361 | 361 | */ |
362 | 362 | public function save() |
363 | 363 | { |
364 | - if (! $this->_model_object) { |
|
364 | + if ( ! $this->_model_object) { |
|
365 | 365 | throw new EE_Error(sprintf(esc_html__( |
366 | 366 | "Cannot save the model form's model object (model is '%s') because there is no model object set. You must either set it, or call receive_form_submission where it is set automatically", |
367 | 367 | "event_espresso" |
@@ -376,7 +376,7 @@ discard block |
||
376 | 376 | } |
377 | 377 | $success = $this->_model_object->save(); |
378 | 378 | foreach ($this->_model->relation_settings() as $relation_name => $relation_obj) { |
379 | - if (isset($this->_subsections[ $relation_name ])) { |
|
379 | + if (isset($this->_subsections[$relation_name])) { |
|
380 | 380 | $success = $this->_save_related_info($relation_name); |
381 | 381 | } |
382 | 382 | } |
@@ -463,8 +463,8 @@ discard block |
||
463 | 463 | */ |
464 | 464 | protected function _set_default_name_if_empty() |
465 | 465 | { |
466 | - if (! $this->_name) { |
|
467 | - $default_name = str_replace("EEM_", "", get_class($this->_model)) . "_Model_Form"; |
|
466 | + if ( ! $this->_name) { |
|
467 | + $default_name = str_replace("EEM_", "", get_class($this->_model))."_Model_Form"; |
|
468 | 468 | $this->_name = $default_name; |
469 | 469 | } |
470 | 470 | } |
@@ -2,62 +2,62 @@ |
||
2 | 2 | |
3 | 3 | class EE_Sample_Form extends EE_Form_Section_Proper |
4 | 4 | { |
5 | - public function __construct() |
|
6 | - { |
|
7 | - $this->_subsections = array( |
|
8 | - 'h1' => new EE_Form_Section_HTML('hello wordl'), |
|
9 | - 'name' => new EE_Text_Input(array('required' => true,'default' => 'your name here')), |
|
10 | - 'email' => new EE_Email_Input(array('required' => false)), |
|
11 | - 'shirt_size' => new EE_Select_Input(array('' => 'Please select...', 's' => esc_html__("Small", "event_espresso"),'m' => esc_html__("Medium", "event_espresso"),'l' => esc_html__("Large", "event_espresso")), array('required' => true,'default' => 's')), |
|
12 | - 'month_normal' => new EE_Month_Input(), |
|
13 | - 'month_leading_zero' => new EE_Month_Input(true), |
|
14 | - 'year_2' => new EE_Year_Input(false, 1, 1), |
|
15 | - 'year_4' => new EE_Year_Input(true, 0, 10, array('default' => '2017')), |
|
16 | - 'yes_no' => new EE_Yes_No_Input(array('html_label_text' => esc_html__("Yes or No", "event_espresso"))), |
|
17 | - 'credit_card' => new EE_Credit_Card_Input(), |
|
18 | - 'image_1' => new EE_Admin_File_Uploader_Input(), |
|
19 | - 'image_2' => new EE_Admin_File_Uploader_Input(), |
|
20 | - 'skillz' => new EE_Checkbox_Multi_Input(array('php' => 'PHP','mysql' => 'MYSQL'), array('default' => array('php'))), |
|
21 | - 'float' => new EE_Float_Input(), |
|
22 | - 'essay' => new EE_Text_Area_Input(), |
|
23 | - 'amenities' => new EE_Select_Multiple_Input( |
|
24 | - array( |
|
25 | - 'hottub' => 'Hot Tub', |
|
26 | - 'balcony' => "Balcony", |
|
27 | - 'skylight' => 'SkyLight', |
|
28 | - 'no_axe' => 'No Axe Murderers' |
|
29 | - ), |
|
30 | - array( |
|
31 | - 'default' => array( |
|
32 | - 'hottub', |
|
33 | - 'no_axe' ), |
|
34 | - ) |
|
35 | - ), |
|
36 | - 'payment_methods' => new EE_Select_Multi_Model_Input(EEM_Payment_Method::instance()->get_all()), |
|
37 | - ); |
|
38 | - $this->_layout_strategy = new EE_Div_Per_Section_Layout(); |
|
39 | - parent::__construct(); |
|
40 | - } |
|
5 | + public function __construct() |
|
6 | + { |
|
7 | + $this->_subsections = array( |
|
8 | + 'h1' => new EE_Form_Section_HTML('hello wordl'), |
|
9 | + 'name' => new EE_Text_Input(array('required' => true,'default' => 'your name here')), |
|
10 | + 'email' => new EE_Email_Input(array('required' => false)), |
|
11 | + 'shirt_size' => new EE_Select_Input(array('' => 'Please select...', 's' => esc_html__("Small", "event_espresso"),'m' => esc_html__("Medium", "event_espresso"),'l' => esc_html__("Large", "event_espresso")), array('required' => true,'default' => 's')), |
|
12 | + 'month_normal' => new EE_Month_Input(), |
|
13 | + 'month_leading_zero' => new EE_Month_Input(true), |
|
14 | + 'year_2' => new EE_Year_Input(false, 1, 1), |
|
15 | + 'year_4' => new EE_Year_Input(true, 0, 10, array('default' => '2017')), |
|
16 | + 'yes_no' => new EE_Yes_No_Input(array('html_label_text' => esc_html__("Yes or No", "event_espresso"))), |
|
17 | + 'credit_card' => new EE_Credit_Card_Input(), |
|
18 | + 'image_1' => new EE_Admin_File_Uploader_Input(), |
|
19 | + 'image_2' => new EE_Admin_File_Uploader_Input(), |
|
20 | + 'skillz' => new EE_Checkbox_Multi_Input(array('php' => 'PHP','mysql' => 'MYSQL'), array('default' => array('php'))), |
|
21 | + 'float' => new EE_Float_Input(), |
|
22 | + 'essay' => new EE_Text_Area_Input(), |
|
23 | + 'amenities' => new EE_Select_Multiple_Input( |
|
24 | + array( |
|
25 | + 'hottub' => 'Hot Tub', |
|
26 | + 'balcony' => "Balcony", |
|
27 | + 'skylight' => 'SkyLight', |
|
28 | + 'no_axe' => 'No Axe Murderers' |
|
29 | + ), |
|
30 | + array( |
|
31 | + 'default' => array( |
|
32 | + 'hottub', |
|
33 | + 'no_axe' ), |
|
34 | + ) |
|
35 | + ), |
|
36 | + 'payment_methods' => new EE_Select_Multi_Model_Input(EEM_Payment_Method::instance()->get_all()), |
|
37 | + ); |
|
38 | + $this->_layout_strategy = new EE_Div_Per_Section_Layout(); |
|
39 | + parent::__construct(); |
|
40 | + } |
|
41 | 41 | |
42 | - /** |
|
43 | - * Extra validation for the 'name' input. |
|
44 | - * @param EE_Text_Input $form_input |
|
45 | - */ |
|
46 | - public function _validate_name($form_input) |
|
47 | - { |
|
48 | - if ($form_input->raw_value() != 'Mike') { |
|
49 | - $form_input->add_validation_error(esc_html__("You are not mike. You must be brent or darren. Thats ok, I guess", 'event_espresso'), 'not-mike'); |
|
50 | - } |
|
51 | - } |
|
42 | + /** |
|
43 | + * Extra validation for the 'name' input. |
|
44 | + * @param EE_Text_Input $form_input |
|
45 | + */ |
|
46 | + public function _validate_name($form_input) |
|
47 | + { |
|
48 | + if ($form_input->raw_value() != 'Mike') { |
|
49 | + $form_input->add_validation_error(esc_html__("You are not mike. You must be brent or darren. Thats ok, I guess", 'event_espresso'), 'not-mike'); |
|
50 | + } |
|
51 | + } |
|
52 | 52 | |
53 | - public function _validate() |
|
54 | - { |
|
55 | - parent::_validate(); |
|
56 | - if ( |
|
57 | - $this->_subsections['shirt_size']->normalized_value() == 's' |
|
58 | - && $this->_subsections['year_4']->normalized_value() < 2010 |
|
59 | - ) { |
|
60 | - $this->add_validation_error(esc_html__("If you want a small shirt, you should be born after 2010. Otherwise theyre just too big", 'event_espresso'), 'too-old'); |
|
61 | - } |
|
62 | - } |
|
53 | + public function _validate() |
|
54 | + { |
|
55 | + parent::_validate(); |
|
56 | + if ( |
|
57 | + $this->_subsections['shirt_size']->normalized_value() == 's' |
|
58 | + && $this->_subsections['year_4']->normalized_value() < 2010 |
|
59 | + ) { |
|
60 | + $this->add_validation_error(esc_html__("If you want a small shirt, you should be born after 2010. Otherwise theyre just too big", 'event_espresso'), 'too-old'); |
|
61 | + } |
|
62 | + } |
|
63 | 63 | } |
@@ -6,9 +6,9 @@ discard block |
||
6 | 6 | { |
7 | 7 | $this->_subsections = array( |
8 | 8 | 'h1' => new EE_Form_Section_HTML('hello wordl'), |
9 | - 'name' => new EE_Text_Input(array('required' => true,'default' => 'your name here')), |
|
9 | + 'name' => new EE_Text_Input(array('required' => true, 'default' => 'your name here')), |
|
10 | 10 | 'email' => new EE_Email_Input(array('required' => false)), |
11 | - 'shirt_size' => new EE_Select_Input(array('' => 'Please select...', 's' => esc_html__("Small", "event_espresso"),'m' => esc_html__("Medium", "event_espresso"),'l' => esc_html__("Large", "event_espresso")), array('required' => true,'default' => 's')), |
|
11 | + 'shirt_size' => new EE_Select_Input(array('' => 'Please select...', 's' => esc_html__("Small", "event_espresso"), 'm' => esc_html__("Medium", "event_espresso"), 'l' => esc_html__("Large", "event_espresso")), array('required' => true, 'default' => 's')), |
|
12 | 12 | 'month_normal' => new EE_Month_Input(), |
13 | 13 | 'month_leading_zero' => new EE_Month_Input(true), |
14 | 14 | 'year_2' => new EE_Year_Input(false, 1, 1), |
@@ -17,7 +17,7 @@ discard block |
||
17 | 17 | 'credit_card' => new EE_Credit_Card_Input(), |
18 | 18 | 'image_1' => new EE_Admin_File_Uploader_Input(), |
19 | 19 | 'image_2' => new EE_Admin_File_Uploader_Input(), |
20 | - 'skillz' => new EE_Checkbox_Multi_Input(array('php' => 'PHP','mysql' => 'MYSQL'), array('default' => array('php'))), |
|
20 | + 'skillz' => new EE_Checkbox_Multi_Input(array('php' => 'PHP', 'mysql' => 'MYSQL'), array('default' => array('php'))), |
|
21 | 21 | 'float' => new EE_Float_Input(), |
22 | 22 | 'essay' => new EE_Text_Area_Input(), |
23 | 23 | 'amenities' => new EE_Select_Multiple_Input( |
@@ -14,172 +14,172 @@ |
||
14 | 14 | class EE_Billing_Attendee_Info_Form extends EE_Billing_Info_Form |
15 | 15 | { |
16 | 16 | |
17 | - /** |
|
18 | - * |
|
19 | - * @param EE_Payment_Method $payment_method |
|
20 | - * @param array $options_array @see EE_Form_Section_Proper::__construct() |
|
21 | - */ |
|
22 | - public function __construct(EE_Payment_Method $payment_method, $options_array = array()) |
|
23 | - { |
|
24 | - $options_array['subsections'] = array_merge( |
|
25 | - array( |
|
26 | - 'first_name' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-fname', 'html_label_text' => esc_html__('First Name', 'event_espresso') )), |
|
27 | - 'last_name' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-lname', 'html_label_text' => esc_html__('Last Name', 'event_espresso') )), |
|
28 | - 'email' => new EE_Email_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-email', 'html_label_text' => esc_html__('Email', 'event_espresso') )), |
|
29 | - 'address' => new EE_Text_Input(array( 'html_label_text' => esc_html__('Address', 'event_espresso'), 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-address' )), |
|
30 | - 'address2' => new EE_Text_Input(array( 'html_label_text' => esc_html__('Address 2', 'event_espresso'), 'html_class' => 'ee-billing-qstn ee-billing-qstn-address2' )), |
|
31 | - 'city' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-city', 'html_label_text' => esc_html__('City', 'event_espresso') )), |
|
32 | - 'state' => apply_filters('FHEE__EE_Billing_Attendee_Info_Form__state_field', new EE_State_Select_Input(null, array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-state', 'html_label_text' => esc_html__('State', 'event_espresso') ))), |
|
33 | - 'country' => apply_filters('FHEE__EE_Billing_Attendee_Info_Form__country_field', new EE_Country_Select_Input(null, array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-country', 'html_label_text' => esc_html__('Country', 'event_espresso') ))), |
|
34 | - 'zip' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-zip', 'html_label_text' => esc_html__('Zip', 'event_espresso') )), |
|
35 | - 'phone' => new EE_Text_Input(array( 'html_class' => 'ee-billing-qstn ee-billing-qstn-phone', 'html_label_text' => esc_html__('Phone', 'event_espresso') )), |
|
36 | - ), |
|
37 | - isset($options_array['subsections']) ? $options_array['subsections'] : array() |
|
38 | - ); |
|
17 | + /** |
|
18 | + * |
|
19 | + * @param EE_Payment_Method $payment_method |
|
20 | + * @param array $options_array @see EE_Form_Section_Proper::__construct() |
|
21 | + */ |
|
22 | + public function __construct(EE_Payment_Method $payment_method, $options_array = array()) |
|
23 | + { |
|
24 | + $options_array['subsections'] = array_merge( |
|
25 | + array( |
|
26 | + 'first_name' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-fname', 'html_label_text' => esc_html__('First Name', 'event_espresso') )), |
|
27 | + 'last_name' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-lname', 'html_label_text' => esc_html__('Last Name', 'event_espresso') )), |
|
28 | + 'email' => new EE_Email_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-email', 'html_label_text' => esc_html__('Email', 'event_espresso') )), |
|
29 | + 'address' => new EE_Text_Input(array( 'html_label_text' => esc_html__('Address', 'event_espresso'), 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-address' )), |
|
30 | + 'address2' => new EE_Text_Input(array( 'html_label_text' => esc_html__('Address 2', 'event_espresso'), 'html_class' => 'ee-billing-qstn ee-billing-qstn-address2' )), |
|
31 | + 'city' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-city', 'html_label_text' => esc_html__('City', 'event_espresso') )), |
|
32 | + 'state' => apply_filters('FHEE__EE_Billing_Attendee_Info_Form__state_field', new EE_State_Select_Input(null, array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-state', 'html_label_text' => esc_html__('State', 'event_espresso') ))), |
|
33 | + 'country' => apply_filters('FHEE__EE_Billing_Attendee_Info_Form__country_field', new EE_Country_Select_Input(null, array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-country', 'html_label_text' => esc_html__('Country', 'event_espresso') ))), |
|
34 | + 'zip' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-zip', 'html_label_text' => esc_html__('Zip', 'event_espresso') )), |
|
35 | + 'phone' => new EE_Text_Input(array( 'html_class' => 'ee-billing-qstn ee-billing-qstn-phone', 'html_label_text' => esc_html__('Phone', 'event_espresso') )), |
|
36 | + ), |
|
37 | + isset($options_array['subsections']) ? $options_array['subsections'] : array() |
|
38 | + ); |
|
39 | 39 | |
40 | - parent::__construct($payment_method, $options_array); |
|
41 | - } |
|
40 | + parent::__construct($payment_method, $options_array); |
|
41 | + } |
|
42 | 42 | |
43 | - /** |
|
44 | - * Sets the defaults for the billing form according to the attendee's details |
|
45 | - * @param EE_Attendee $attendee |
|
46 | - */ |
|
47 | - public function populate_from_attendee($attendee) |
|
48 | - { |
|
49 | - $attendee = EEM_Attendee::instance()->ensure_is_obj($attendee); |
|
43 | + /** |
|
44 | + * Sets the defaults for the billing form according to the attendee's details |
|
45 | + * @param EE_Attendee $attendee |
|
46 | + */ |
|
47 | + public function populate_from_attendee($attendee) |
|
48 | + { |
|
49 | + $attendee = EEM_Attendee::instance()->ensure_is_obj($attendee); |
|
50 | 50 | |
51 | - /** @var $attendee EE_Attendee */ |
|
52 | - $this->populate_defaults( |
|
53 | - apply_filters( |
|
54 | - 'FHEE__EE_Billing_Attendee_Info_Form__populate_from_attendee', |
|
55 | - array( |
|
56 | - 'first_name' => $attendee->fname(), |
|
57 | - 'last_name' => $attendee->lname(), |
|
58 | - 'email' => $attendee->email(), |
|
59 | - 'address' => $attendee->address(), |
|
60 | - 'address2' => $attendee->address2(), |
|
61 | - 'city' => $attendee->city(), |
|
62 | - 'state' => $this->getAttendeeStateValueForForm($attendee), |
|
63 | - 'country' => $attendee->country_ID(), |
|
64 | - 'zip' => $attendee->zip(), |
|
65 | - 'phone' => $attendee->phone(), |
|
66 | - ), |
|
67 | - $attendee, |
|
68 | - $this |
|
69 | - ) |
|
70 | - ); |
|
71 | - } |
|
51 | + /** @var $attendee EE_Attendee */ |
|
52 | + $this->populate_defaults( |
|
53 | + apply_filters( |
|
54 | + 'FHEE__EE_Billing_Attendee_Info_Form__populate_from_attendee', |
|
55 | + array( |
|
56 | + 'first_name' => $attendee->fname(), |
|
57 | + 'last_name' => $attendee->lname(), |
|
58 | + 'email' => $attendee->email(), |
|
59 | + 'address' => $attendee->address(), |
|
60 | + 'address2' => $attendee->address2(), |
|
61 | + 'city' => $attendee->city(), |
|
62 | + 'state' => $this->getAttendeeStateValueForForm($attendee), |
|
63 | + 'country' => $attendee->country_ID(), |
|
64 | + 'zip' => $attendee->zip(), |
|
65 | + 'phone' => $attendee->phone(), |
|
66 | + ), |
|
67 | + $attendee, |
|
68 | + $this |
|
69 | + ) |
|
70 | + ); |
|
71 | + } |
|
72 | 72 | |
73 | - /** |
|
74 | - * Gets the default value to use for the billing form's state value. |
|
75 | - * @since 4.10.0.p |
|
76 | - * @param EE_Attendee $attendee |
|
77 | - * @return string |
|
78 | - * @throws EE_Error2 |
|
79 | - */ |
|
80 | - protected function getAttendeeStateValueForForm(EE_Attendee $attendee) |
|
81 | - { |
|
82 | - // If the state input was removed, just return a blank string. |
|
83 | - if (! $this->has_subsection('state')) { |
|
84 | - return ''; |
|
85 | - } |
|
86 | - $state_input = $this->get_input('state', false); |
|
87 | - if ($state_input instanceof EE_State_Select_Input) { |
|
88 | - $state_field_to_use = $state_input->valueFieldName(); |
|
89 | - } else { |
|
90 | - $state_field_to_use = 'STA_ID'; |
|
91 | - } |
|
92 | - switch ($state_field_to_use) { |
|
93 | - case 'STA_abbrev': |
|
94 | - $state_value = $attendee->state_abbrev(); |
|
95 | - break; |
|
96 | - case 'STA_name': |
|
97 | - $state_value = $attendee->state_name(); |
|
98 | - break; |
|
99 | - default: |
|
100 | - $state_value = $attendee->state_ID(); |
|
101 | - } |
|
102 | - return $state_value; |
|
103 | - } |
|
73 | + /** |
|
74 | + * Gets the default value to use for the billing form's state value. |
|
75 | + * @since 4.10.0.p |
|
76 | + * @param EE_Attendee $attendee |
|
77 | + * @return string |
|
78 | + * @throws EE_Error2 |
|
79 | + */ |
|
80 | + protected function getAttendeeStateValueForForm(EE_Attendee $attendee) |
|
81 | + { |
|
82 | + // If the state input was removed, just return a blank string. |
|
83 | + if (! $this->has_subsection('state')) { |
|
84 | + return ''; |
|
85 | + } |
|
86 | + $state_input = $this->get_input('state', false); |
|
87 | + if ($state_input instanceof EE_State_Select_Input) { |
|
88 | + $state_field_to_use = $state_input->valueFieldName(); |
|
89 | + } else { |
|
90 | + $state_field_to_use = 'STA_ID'; |
|
91 | + } |
|
92 | + switch ($state_field_to_use) { |
|
93 | + case 'STA_abbrev': |
|
94 | + $state_value = $attendee->state_abbrev(); |
|
95 | + break; |
|
96 | + case 'STA_name': |
|
97 | + $state_value = $attendee->state_name(); |
|
98 | + break; |
|
99 | + default: |
|
100 | + $state_value = $attendee->state_ID(); |
|
101 | + } |
|
102 | + return $state_value; |
|
103 | + } |
|
104 | 104 | |
105 | 105 | |
106 | 106 | |
107 | - /** |
|
108 | - * copy_billing_form_data_to_attendee |
|
109 | - * copies info from the billing form to the attendee's details |
|
110 | - * @param \EE_Attendee $attendee - the attendee object to copy details to |
|
111 | - * @return \EE_Attendee |
|
112 | - */ |
|
113 | - public function copy_billing_form_data_to_attendee(EE_Attendee $attendee) |
|
114 | - { |
|
115 | - // grab billing form data |
|
116 | - $data = $this->valid_data(); |
|
117 | - // copy first_name |
|
118 | - if (! empty($data['first_name'])) { |
|
119 | - $attendee->set_fname($data['first_name']); |
|
120 | - } |
|
121 | - // copy last_name |
|
122 | - if (! empty($data['last_name'])) { |
|
123 | - $attendee->set_lname($data['last_name']); |
|
124 | - } |
|
125 | - // copy email |
|
126 | - if (! empty($data['email'])) { |
|
127 | - $attendee->set_email($data['email']); |
|
128 | - } |
|
129 | - // copy address |
|
130 | - if (! empty($data['address'])) { |
|
131 | - $attendee->set_address($data['address']); |
|
132 | - } |
|
133 | - // copy address2 |
|
134 | - if (! empty($data['address2'])) { |
|
135 | - $attendee->set_address2($data['address2']); |
|
136 | - } |
|
137 | - // copy city |
|
138 | - if (! empty($data['city'])) { |
|
139 | - $attendee->set_city($data['city']); |
|
140 | - } |
|
141 | - // copy state |
|
142 | - if (! empty($data['state'])) { |
|
143 | - $attendee->set_state($data['state']); |
|
144 | - } |
|
145 | - // copy country |
|
146 | - if (! empty($data['country'])) { |
|
147 | - $attendee->set_country($data['country']); |
|
148 | - } |
|
149 | - // copy zip |
|
150 | - if (! empty($data['zip'])) { |
|
151 | - $attendee->set_zip($data['zip']); |
|
152 | - } |
|
153 | - // copy phone |
|
154 | - if (! empty($data['phone'])) { |
|
155 | - $attendee->set_phone($data['phone']); |
|
156 | - } |
|
157 | - return $attendee; |
|
158 | - } |
|
107 | + /** |
|
108 | + * copy_billing_form_data_to_attendee |
|
109 | + * copies info from the billing form to the attendee's details |
|
110 | + * @param \EE_Attendee $attendee - the attendee object to copy details to |
|
111 | + * @return \EE_Attendee |
|
112 | + */ |
|
113 | + public function copy_billing_form_data_to_attendee(EE_Attendee $attendee) |
|
114 | + { |
|
115 | + // grab billing form data |
|
116 | + $data = $this->valid_data(); |
|
117 | + // copy first_name |
|
118 | + if (! empty($data['first_name'])) { |
|
119 | + $attendee->set_fname($data['first_name']); |
|
120 | + } |
|
121 | + // copy last_name |
|
122 | + if (! empty($data['last_name'])) { |
|
123 | + $attendee->set_lname($data['last_name']); |
|
124 | + } |
|
125 | + // copy email |
|
126 | + if (! empty($data['email'])) { |
|
127 | + $attendee->set_email($data['email']); |
|
128 | + } |
|
129 | + // copy address |
|
130 | + if (! empty($data['address'])) { |
|
131 | + $attendee->set_address($data['address']); |
|
132 | + } |
|
133 | + // copy address2 |
|
134 | + if (! empty($data['address2'])) { |
|
135 | + $attendee->set_address2($data['address2']); |
|
136 | + } |
|
137 | + // copy city |
|
138 | + if (! empty($data['city'])) { |
|
139 | + $attendee->set_city($data['city']); |
|
140 | + } |
|
141 | + // copy state |
|
142 | + if (! empty($data['state'])) { |
|
143 | + $attendee->set_state($data['state']); |
|
144 | + } |
|
145 | + // copy country |
|
146 | + if (! empty($data['country'])) { |
|
147 | + $attendee->set_country($data['country']); |
|
148 | + } |
|
149 | + // copy zip |
|
150 | + if (! empty($data['zip'])) { |
|
151 | + $attendee->set_zip($data['zip']); |
|
152 | + } |
|
153 | + // copy phone |
|
154 | + if (! empty($data['phone'])) { |
|
155 | + $attendee->set_phone($data['phone']); |
|
156 | + } |
|
157 | + return $attendee; |
|
158 | + } |
|
159 | 159 | |
160 | 160 | |
161 | - /** |
|
162 | - * create_attendee_from_billing_form_data |
|
163 | - * uses info from the billing form to create a new attendee |
|
164 | - * @return \EE_Attendee |
|
165 | - */ |
|
166 | - public function create_attendee_from_billing_form_data() |
|
167 | - { |
|
168 | - // grab billing form data |
|
169 | - $data = $this->valid_data(); |
|
170 | - return EE_Attendee::new_instance(array( |
|
171 | - 'ATT_fname' => ! empty($data['first_name']) ? $data['first_name'] : '', |
|
172 | - 'ATT_lname' => ! empty($data['last_name']) ? $data['last_name'] : '', |
|
173 | - 'ATT_email' => ! empty($data['email']) ? $data['email'] : '', |
|
174 | - 'ATT_address' => ! empty($data['address']) ? $data['address'] : '', |
|
175 | - 'ATT_address2' => ! empty($data['address2']) ? $data['address2'] : '', |
|
176 | - 'ATT_city' => ! empty($data['city']) ? $data['city'] : '', |
|
177 | - 'STA_ID' => ! empty($data['state']) ? $data['state'] : '', |
|
178 | - 'CNT_ISO' => ! empty($data['country']) ? $data['country'] : '', |
|
179 | - 'ATT_zip' => ! empty($data['zip']) ? $data['zip'] : '', |
|
180 | - 'ATT_phone' => ! empty($data['phone']) ? $data['phone'] : '', |
|
181 | - )); |
|
182 | - } |
|
161 | + /** |
|
162 | + * create_attendee_from_billing_form_data |
|
163 | + * uses info from the billing form to create a new attendee |
|
164 | + * @return \EE_Attendee |
|
165 | + */ |
|
166 | + public function create_attendee_from_billing_form_data() |
|
167 | + { |
|
168 | + // grab billing form data |
|
169 | + $data = $this->valid_data(); |
|
170 | + return EE_Attendee::new_instance(array( |
|
171 | + 'ATT_fname' => ! empty($data['first_name']) ? $data['first_name'] : '', |
|
172 | + 'ATT_lname' => ! empty($data['last_name']) ? $data['last_name'] : '', |
|
173 | + 'ATT_email' => ! empty($data['email']) ? $data['email'] : '', |
|
174 | + 'ATT_address' => ! empty($data['address']) ? $data['address'] : '', |
|
175 | + 'ATT_address2' => ! empty($data['address2']) ? $data['address2'] : '', |
|
176 | + 'ATT_city' => ! empty($data['city']) ? $data['city'] : '', |
|
177 | + 'STA_ID' => ! empty($data['state']) ? $data['state'] : '', |
|
178 | + 'CNT_ISO' => ! empty($data['country']) ? $data['country'] : '', |
|
179 | + 'ATT_zip' => ! empty($data['zip']) ? $data['zip'] : '', |
|
180 | + 'ATT_phone' => ! empty($data['phone']) ? $data['phone'] : '', |
|
181 | + )); |
|
182 | + } |
|
183 | 183 | } |
184 | 184 | |
185 | 185 | // End of file EE_Billing_Attendee_Info_Form.form.php |
@@ -23,16 +23,16 @@ discard block |
||
23 | 23 | { |
24 | 24 | $options_array['subsections'] = array_merge( |
25 | 25 | array( |
26 | - 'first_name' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-fname', 'html_label_text' => esc_html__('First Name', 'event_espresso') )), |
|
27 | - 'last_name' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-lname', 'html_label_text' => esc_html__('Last Name', 'event_espresso') )), |
|
28 | - 'email' => new EE_Email_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-email', 'html_label_text' => esc_html__('Email', 'event_espresso') )), |
|
29 | - 'address' => new EE_Text_Input(array( 'html_label_text' => esc_html__('Address', 'event_espresso'), 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-address' )), |
|
30 | - 'address2' => new EE_Text_Input(array( 'html_label_text' => esc_html__('Address 2', 'event_espresso'), 'html_class' => 'ee-billing-qstn ee-billing-qstn-address2' )), |
|
31 | - 'city' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-city', 'html_label_text' => esc_html__('City', 'event_espresso') )), |
|
32 | - 'state' => apply_filters('FHEE__EE_Billing_Attendee_Info_Form__state_field', new EE_State_Select_Input(null, array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-state', 'html_label_text' => esc_html__('State', 'event_espresso') ))), |
|
33 | - 'country' => apply_filters('FHEE__EE_Billing_Attendee_Info_Form__country_field', new EE_Country_Select_Input(null, array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-country', 'html_label_text' => esc_html__('Country', 'event_espresso') ))), |
|
34 | - 'zip' => new EE_Text_Input(array( 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-zip', 'html_label_text' => esc_html__('Zip', 'event_espresso') )), |
|
35 | - 'phone' => new EE_Text_Input(array( 'html_class' => 'ee-billing-qstn ee-billing-qstn-phone', 'html_label_text' => esc_html__('Phone', 'event_espresso') )), |
|
26 | + 'first_name' => new EE_Text_Input(array('required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-fname', 'html_label_text' => esc_html__('First Name', 'event_espresso'))), |
|
27 | + 'last_name' => new EE_Text_Input(array('required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-lname', 'html_label_text' => esc_html__('Last Name', 'event_espresso'))), |
|
28 | + 'email' => new EE_Email_Input(array('required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-email', 'html_label_text' => esc_html__('Email', 'event_espresso'))), |
|
29 | + 'address' => new EE_Text_Input(array('html_label_text' => esc_html__('Address', 'event_espresso'), 'required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-address')), |
|
30 | + 'address2' => new EE_Text_Input(array('html_label_text' => esc_html__('Address 2', 'event_espresso'), 'html_class' => 'ee-billing-qstn ee-billing-qstn-address2')), |
|
31 | + 'city' => new EE_Text_Input(array('required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-city', 'html_label_text' => esc_html__('City', 'event_espresso'))), |
|
32 | + 'state' => apply_filters('FHEE__EE_Billing_Attendee_Info_Form__state_field', new EE_State_Select_Input(null, array('required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-state', 'html_label_text' => esc_html__('State', 'event_espresso')))), |
|
33 | + 'country' => apply_filters('FHEE__EE_Billing_Attendee_Info_Form__country_field', new EE_Country_Select_Input(null, array('required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-country', 'html_label_text' => esc_html__('Country', 'event_espresso')))), |
|
34 | + 'zip' => new EE_Text_Input(array('required' => true, 'html_class' => 'ee-billing-qstn ee-billing-qstn-zip', 'html_label_text' => esc_html__('Zip', 'event_espresso'))), |
|
35 | + 'phone' => new EE_Text_Input(array('html_class' => 'ee-billing-qstn ee-billing-qstn-phone', 'html_label_text' => esc_html__('Phone', 'event_espresso'))), |
|
36 | 36 | ), |
37 | 37 | isset($options_array['subsections']) ? $options_array['subsections'] : array() |
38 | 38 | ); |
@@ -80,12 +80,12 @@ discard block |
||
80 | 80 | protected function getAttendeeStateValueForForm(EE_Attendee $attendee) |
81 | 81 | { |
82 | 82 | // If the state input was removed, just return a blank string. |
83 | - if (! $this->has_subsection('state')) { |
|
83 | + if ( ! $this->has_subsection('state')) { |
|
84 | 84 | return ''; |
85 | 85 | } |
86 | - $state_input = $this->get_input('state', false); |
|
86 | + $state_input = $this->get_input('state', false); |
|
87 | 87 | if ($state_input instanceof EE_State_Select_Input) { |
88 | - $state_field_to_use = $state_input->valueFieldName(); |
|
88 | + $state_field_to_use = $state_input->valueFieldName(); |
|
89 | 89 | } else { |
90 | 90 | $state_field_to_use = 'STA_ID'; |
91 | 91 | } |
@@ -115,43 +115,43 @@ discard block |
||
115 | 115 | // grab billing form data |
116 | 116 | $data = $this->valid_data(); |
117 | 117 | // copy first_name |
118 | - if (! empty($data['first_name'])) { |
|
118 | + if ( ! empty($data['first_name'])) { |
|
119 | 119 | $attendee->set_fname($data['first_name']); |
120 | 120 | } |
121 | 121 | // copy last_name |
122 | - if (! empty($data['last_name'])) { |
|
122 | + if ( ! empty($data['last_name'])) { |
|
123 | 123 | $attendee->set_lname($data['last_name']); |
124 | 124 | } |
125 | 125 | // copy email |
126 | - if (! empty($data['email'])) { |
|
126 | + if ( ! empty($data['email'])) { |
|
127 | 127 | $attendee->set_email($data['email']); |
128 | 128 | } |
129 | 129 | // copy address |
130 | - if (! empty($data['address'])) { |
|
130 | + if ( ! empty($data['address'])) { |
|
131 | 131 | $attendee->set_address($data['address']); |
132 | 132 | } |
133 | 133 | // copy address2 |
134 | - if (! empty($data['address2'])) { |
|
134 | + if ( ! empty($data['address2'])) { |
|
135 | 135 | $attendee->set_address2($data['address2']); |
136 | 136 | } |
137 | 137 | // copy city |
138 | - if (! empty($data['city'])) { |
|
138 | + if ( ! empty($data['city'])) { |
|
139 | 139 | $attendee->set_city($data['city']); |
140 | 140 | } |
141 | 141 | // copy state |
142 | - if (! empty($data['state'])) { |
|
142 | + if ( ! empty($data['state'])) { |
|
143 | 143 | $attendee->set_state($data['state']); |
144 | 144 | } |
145 | 145 | // copy country |
146 | - if (! empty($data['country'])) { |
|
146 | + if ( ! empty($data['country'])) { |
|
147 | 147 | $attendee->set_country($data['country']); |
148 | 148 | } |
149 | 149 | // copy zip |
150 | - if (! empty($data['zip'])) { |
|
150 | + if ( ! empty($data['zip'])) { |
|
151 | 151 | $attendee->set_zip($data['zip']); |
152 | 152 | } |
153 | 153 | // copy phone |
154 | - if (! empty($data['phone'])) { |
|
154 | + if ( ! empty($data['phone'])) { |
|
155 | 155 | $attendee->set_phone($data['phone']); |
156 | 156 | } |
157 | 157 | return $attendee; |