PluginProbe ʕ •ᴥ•ʔ
Booking for Appointments and Events Calendar – Amelia / trunk
Booking for Appointments and Events Calendar – Amelia vtrunk
2.4.3 2.4.2 2.4.1 2.4 trunk 1.2.1 1.2.10 1.2.11 1.2.12 1.2.13 1.2.14 1.2.15 1.2.16 1.2.17 1.2.18 1.2.19 1.2.2 1.2.20 1.2.21 1.2.22 1.2.23 1.2.24 1.2.25 1.2.26 1.2.27 1.2.28 1.2.29 1.2.3 1.2.30 1.2.31 1.2.32 1.2.33 1.2.34 1.2.35 1.2.36 1.2.37 1.2.38 1.2.4 1.2.5 1.2.6 1.2.7 1.2.8 1.2.9 2.0 2.0.1 2.0.2 2.1 2.1.1 2.1.2 2.1.3 2.2 2.2.1 2.3
ameliabooking / src / Infrastructure / WP / InstallActions / DB / Booking / AppointmentsTable.php
ameliabooking / src / Infrastructure / WP / InstallActions / DB / Booking Last commit date
AppointmentsTable.php 2 months ago CustomerBookingToEventsTicketsTable.php 2 months ago CustomerBookingsTable.php 2 weeks ago CustomerBookingsToEventsPeriodsTable.php 2 months ago CustomerBookingsToExtrasTable.php 2 months ago EventsPeriodsTable.php 2 months ago EventsProvidersTable.php 2 months ago EventsTable.php 2 months ago EventsTagsTable.php 2 months ago EventsTicketsTable.php 2 months ago
AppointmentsTable.php
55 lines
1 <?php
2
3 namespace AmeliaBooking\Infrastructure\WP\InstallActions\DB\Booking;
4
5 use AmeliaBooking\Domain\Common\Exceptions\InvalidArgumentException;
6 use AmeliaBooking\Domain\ValueObjects\String\Description;
7 use AmeliaBooking\Infrastructure\WP\InstallActions\DB\AbstractDatabaseTable;
8
9 /**
10 * Class AppointmentsTable
11 *
12 * @package AmeliaBooking\Infrastructure\WP\InstallActions\DB\Booking
13 */
14 class AppointmentsTable extends AbstractDatabaseTable
15 {
16 public const TABLE = 'appointments';
17
18 /**
19 * @return string
20 * @throws InvalidArgumentException
21 */
22 public static function buildTable()
23 {
24 $table = self::getTableName();
25
26 $charsetCollate = self::getCharsetCollate();
27
28 $description = Description::MAX_LENGTH;
29
30 return "CREATE TABLE {$table} (
31 `id` INT(11) NOT NULL AUTO_INCREMENT,
32 `status` ENUM('approved', 'pending', 'canceled', 'rejected', 'no-show') NULL,
33 `bookingStart` DATETIME NOT NULL,
34 `bookingEnd` DATETIME NOT NULL,
35 `notifyParticipants` TINYINT(1) NOT NULL,
36 `createPaymentLinks` TINYINT(1) DEFAULT 1,
37 `serviceId` INT(11) NOT NULL,
38 `packageId` INT(11) DEFAULT NULL,
39 `providerId` INT(11) NOT NULL,
40 `locationId` INT(11) NULL,
41 `internalNotes` TEXT({$description}) NULL,
42 `googleCalendarEventId` VARCHAR(255) NULL,
43 `googleMeetUrl` VARCHAR(255) NULL,
44 `outlookCalendarEventId` VARCHAR(255) NULL,
45 `microsoftTeamsUrl` VARCHAR(255) NULL,
46 `appleCalendarEventId` VARCHAR(255) NULL,
47 `zoomMeeting` TEXT({$description}) NULL,
48 `lessonSpace` TEXT({$description}) NULL,
49 `parentId` INT(11) NULL,
50 `error` TEXT({$description}) DEFAULT NULL,
51 PRIMARY KEY (`id`)
52 ) {$charsetCollate};";
53 }
54 }
55