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 / Bookable / PackagesTable.php
ameliabooking / src / Infrastructure / WP / InstallActions / DB / Bookable Last commit date
CategoriesTable.php 2 months ago CategoriesTableInsertRows.php 6 months ago ExtrasTable.php 2 months ago PackagesCustomersServicesTable.php 2 months ago PackagesCustomersTable.php 2 weeks ago PackagesServicesLocationsTable.php 2 months ago PackagesServicesProvidersTable.php 2 months ago PackagesServicesTable.php 2 months ago PackagesTable.php 2 months ago ResourcesTable.php 2 months ago ResourcesToEntitiesTable.php 2 months ago ServicesTable.php 2 months ago ServicesViewsTable.php 2 months ago
PackagesTable.php
63 lines
1 <?php
2
3 namespace AmeliaBooking\Infrastructure\WP\InstallActions\DB\Bookable;
4
5 use AmeliaBooking\Domain\Common\Exceptions\InvalidArgumentException;
6 use AmeliaBooking\Domain\ValueObjects\Picture;
7 use AmeliaBooking\Domain\ValueObjects\String\Color;
8 use AmeliaBooking\Domain\ValueObjects\String\Description;
9 use AmeliaBooking\Domain\ValueObjects\String\Name;
10 use AmeliaBooking\Infrastructure\WP\InstallActions\DB\AbstractDatabaseTable;
11
12 /**
13 * Class PackagesTable
14 *
15 * @package AmeliaBooking\Infrastructure\WP\InstallActions\DB\Bookable
16 */
17 class PackagesTable extends AbstractDatabaseTable
18 {
19 public const TABLE = 'packages';
20
21 /**
22 * @return string
23 * @throws InvalidArgumentException
24 */
25 public static function buildTable()
26 {
27 $table = self::getTableName();
28
29 $charsetCollate = self::getCharsetCollate();
30
31 $name = Name::MAX_LENGTH;
32 $description = Description::MAX_LENGTH;
33 $color = Color::MAX_LENGTH;
34 $picture = Picture::MAX_LENGTH;
35
36 return "CREATE TABLE {$table} (
37 `id` INT(11) NOT NULL AUTO_INCREMENT,
38 `name` VARCHAR({$name}) NOT NULL DEFAULT '',
39 `description` TEXT({$description}) NULL,
40 `color` VARCHAR({$color}) NOT NULL DEFAULT '',
41 `price` DOUBLE NOT NULL,
42 `status` ENUM('hidden', 'visible', 'disabled') NOT NULL DEFAULT 'visible',
43 `pictureFullPath` VARCHAR ({$picture}) NULL,
44 `pictureThumbPath` VARCHAR ({$picture}) NULL,
45 `position` INT(11) DEFAULT 0,
46 `calculatedPrice` TINYINT(1) DEFAULT 1,
47 `discount` DOUBLE NOT NULL,
48 `endDate` DATETIME NULL,
49 `durationType` ENUM('day', 'week', 'month') DEFAULT NULL,
50 `durationCount` INT(4) DEFAULT NULL,
51 `settings` TEXT({$description}) NULL DEFAULT NULL,
52 `translations` TEXT NULL DEFAULT NULL,
53 `depositPayment` ENUM('disabled' , 'fixed', 'percentage') DEFAULT 'disabled',
54 `deposit` DOUBLE DEFAULT 0,
55 `fullPayment` TINYINT(1) DEFAULT 0,
56 `sharedCapacity` TINYINT(1) DEFAULT 0,
57 `quantity` INT(11) DEFAULT 1,
58 `limitPerCustomer` TEXT NULL DEFAULT NULL,
59 PRIMARY KEY (`id`)
60 ) {$charsetCollate};";
61 }
62 }
63