PluginProbe ʕ •ᴥ•ʔ
LatePoint – Calendar Booking Plugin for Appointments and Events / 5.4.2
LatePoint – Calendar Booking Plugin for Appointments and Events v5.4.2
5.6.5 5.6.4 5.6.3 5.6.2 5.6.1 5.6.0 5.5.2 5.5.1 5.5.0 5.4.2 trunk 5.1.0 5.1.1 5.1.2 5.1.3 5.1.4 5.1.5 5.1.6 5.1.7 5.1.8 5.1.9 5.1.91 5.1.92 5.1.93 5.1.94 5.2.0 5.2.1 5.2.10 5.2.11 5.2.2 5.2.3 5.2.4 5.2.5 5.2.6 5.2.7 5.2.8 5.2.9 5.3.0 5.3.1 5.3.2 5.4.0 5.4.1
latepoint / lib / abilities / orders / list-orders.php
latepoint / lib / abilities / orders Last commit date
abstract-order-ability.php 3 months ago change-invoice-status.php 3 months ago change-order-status.php 3 months ago create-invoice.php 3 months ago create-order.php 3 months ago delete-order.php 3 months ago get-invoice.php 3 months ago get-order-price-breakdown.php 3 months ago get-order.php 3 months ago get-transaction.php 3 months ago list-invoices.php 3 months ago list-orders.php 3 months ago list-transactions.php 3 months ago refund-transaction.php 3 months ago update-order.php 3 months ago
list-orders.php
94 lines
1 <?php
2 if ( ! defined( 'ABSPATH' ) ) {
3 exit;
4 }
5
6 class LatePointAbilityListOrders extends LatePointAbstractOrderAbility {
7
8 protected function configure(): void {
9 $this->id = 'latepoint/list-orders';
10 $this->label = __( 'List orders', 'latepoint' );
11 $this->description = __( 'Returns a paginated, filtered list of orders.', 'latepoint' );
12 $this->permission = 'booking__view';
13 $this->read_only = true;
14 }
15
16 public function get_input_schema(): array {
17 return [
18 'type' => 'object',
19 'properties' => array_merge(
20 [
21 'status' => [
22 'type' => 'string',
23 'enum' => [ 'open', 'cancelled', 'completed' ],
24 ],
25 'customer_id' => [ 'type' => 'integer' ],
26 'payment_status' => [ 'type' => 'string' ],
27 'date_from' => [
28 'type' => 'string',
29 'format' => 'date',
30 ],
31 'date_to' => [
32 'type' => 'string',
33 'format' => 'date',
34 ],
35 ],
36 self::pagination()
37 ),
38 ];
39 }
40
41 public function get_output_schema(): array {
42 return [
43 'type' => 'object',
44 'properties' => [
45 'orders' => [
46 'type' => 'array',
47 'items' => $this->order_output_schema(),
48 ],
49 'total' => [ 'type' => 'integer' ],
50 'page' => [ 'type' => 'integer' ],
51 'per_page' => [ 'type' => 'integer' ],
52 ],
53 ];
54 }
55
56 public function execute( array $args ) {
57 $page = max( 1, (int) ( $args['page'] ?? 1 ) );
58 $per_page = min( 100, max( 1, (int) ( $args['per_page'] ?? 20 ) ) );
59 $offset = ( $page - 1 ) * $per_page;
60
61 $query = new OsOrderModel();
62
63 if ( ! empty( $args['status'] ) ) {
64 $query->where( [ 'status' => sanitize_text_field( $args['status'] ) ] );
65 }
66 if ( ! empty( $args['customer_id'] ) ) {
67 $query->where( [ 'customer_id' => (int) $args['customer_id'] ] );
68 }
69 if ( ! empty( $args['payment_status'] ) ) {
70 $query->where( [ 'payment_status' => sanitize_text_field( $args['payment_status'] ) ] );
71 }
72 if ( ! empty( $args['date_from'] ) ) {
73 $query->where( [ 'created_at >=' => sanitize_text_field( $args['date_from'] ) ] );
74 }
75 if ( ! empty( $args['date_to'] ) ) {
76 $query->where( [ 'created_at <=' => sanitize_text_field( $args['date_to'] ) ] );
77 }
78
79 $total = ( clone $query )->count();
80 $orders = $query
81 ->order_by( 'created_at DESC' )
82 ->set_limit( $per_page )
83 ->set_offset( $offset )
84 ->get_results_as_models();
85
86 return [
87 'orders' => array_map( [ $this, 'serialize_order' ], $orders ),
88 'total' => (int) $total,
89 'page' => $page,
90 'per_page' => $per_page,
91 ];
92 }
93 }
94