From e9f17de35bb14122205d84cfde60c1ddb9a4c215 Mon Sep 17 00:00:00 2001 From: LasseStaus Date: Wed, 3 Apr 2024 20:33:11 +0200 Subject: [PATCH 1/6] Create paragraph for openingHours. DDFFORM-417 --- ...view_display.paragraph.opening_hours.default.yml | 13 +++++++++++++ .../paragraphs.paragraphs_type.opening_hours.yml | 12 ++++++++++++ 2 files changed, 25 insertions(+) create mode 100644 config/sync/core.entity_view_display.paragraph.opening_hours.default.yml create mode 100644 config/sync/paragraphs.paragraphs_type.opening_hours.yml diff --git a/config/sync/core.entity_view_display.paragraph.opening_hours.default.yml b/config/sync/core.entity_view_display.paragraph.opening_hours.default.yml new file mode 100644 index 000000000..f3da15e1a --- /dev/null +++ b/config/sync/core.entity_view_display.paragraph.opening_hours.default.yml @@ -0,0 +1,13 @@ +uuid: 20cff0b7-b0d1-406c-8d70-960e540aa306 +langcode: en +status: true +dependencies: + config: + - paragraphs.paragraphs_type.opening_hours +id: paragraph.opening_hours.default +targetEntityType: paragraph +bundle: opening_hours +mode: default +content: { } +hidden: + search_api_excerpt: true diff --git a/config/sync/paragraphs.paragraphs_type.opening_hours.yml b/config/sync/paragraphs.paragraphs_type.opening_hours.yml new file mode 100644 index 000000000..8d369dce0 --- /dev/null +++ b/config/sync/paragraphs.paragraphs_type.opening_hours.yml @@ -0,0 +1,12 @@ +uuid: 17027187-09ac-4092-bbf0-72e49902f7fb +langcode: en +status: true +dependencies: + content: + - 'file:file:e7152b57-d23b-4566-94a7-37767535721a' +id: opening_hours +label: 'Opening Hours' +icon_uuid: e7152b57-d23b-4566-94a7-37767535721a +icon_default: '' +description: "This is a paragraph for displaying the opening hours for the branch it is applied to. \r\n\r\nOpening hours are created under the settings of a branch. \r\n" +behavior_plugins: { } From 352efec269b535f2fcccd2d6c846d5a270a2e635 Mon Sep 17 00:00:00 2001 From: LasseStaus Date: Wed, 3 Apr 2024 20:34:42 +0200 Subject: [PATCH 2/6] Exclude openingHours paragraph from page/article This ensures that the paragraph cannot be selected for the content types Artciel and Page, as it should only be used on the content-type Branch DDFFORM-417 --- ...ld.field.node.article.field_paragraphs.yml | 50 +++++++++++++++++++ ...field.field.node.page.field_paragraphs.yml | 35 +++++++++++++ 2 files changed, 85 insertions(+) diff --git a/config/sync/field.field.node.article.field_paragraphs.yml b/config/sync/field.field.node.article.field_paragraphs.yml index b142438aa..bc29124d0 100644 --- a/config/sync/field.field.node.article.field_paragraphs.yml +++ b/config/sync/field.field.node.article.field_paragraphs.yml @@ -7,6 +7,7 @@ dependencies: - node.type.article - paragraphs.paragraphs_type.campaign_rule - paragraphs.paragraphs_type.event_ticket_category + - paragraphs.paragraphs_type.opening_hours module: - entity_reference_revisions id: node.article.field_paragraphs @@ -25,21 +26,70 @@ settings: target_bundles: campaign_rule: campaign_rule event_ticket_category: event_ticket_category + opening_hours: opening_hours negate: 1 target_bundles_drag_drop: + accordion: + weight: 22 + enabled: false campaign_rule: weight: 2 enabled: true + card_grid_automatic: + weight: 24 + enabled: false + card_grid_manual: + weight: 25 + enabled: false + content_slider: + weight: 26 + enabled: false event_ticket_category: weight: 7 enabled: true + files: + weight: 28 + enabled: false + hero: + weight: 29 + enabled: false + language_selector: + weight: 30 + enabled: false links: weight: 8 enabled: false + material_grid_automatic: + weight: 32 + enabled: false + material_grid_manual: + weight: 33 + enabled: false medias: weight: 9 enabled: false + nav_grid_manual: + weight: 35 + enabled: false + nav_spots_manual: + weight: 36 + enabled: false + opening_hours: + weight: 37 + enabled: true + recommendation: + weight: 38 + enabled: false text_body: weight: 4 enabled: false + user_registration_item: + weight: 40 + enabled: false + user_registration_section: + weight: 41 + enabled: false + video: + weight: 42 + enabled: false field_type: entity_reference_revisions diff --git a/config/sync/field.field.node.page.field_paragraphs.yml b/config/sync/field.field.node.page.field_paragraphs.yml index 0978c80af..f56101569 100644 --- a/config/sync/field.field.node.page.field_paragraphs.yml +++ b/config/sync/field.field.node.page.field_paragraphs.yml @@ -7,6 +7,7 @@ dependencies: - node.type.page - paragraphs.paragraphs_type.campaign_rule - paragraphs.paragraphs_type.event_ticket_category + - paragraphs.paragraphs_type.opening_hours module: - entity_reference_revisions id: node.page.field_paragraphs @@ -25,8 +26,12 @@ settings: target_bundles: campaign_rule: campaign_rule event_ticket_category: event_ticket_category + opening_hours: opening_hours negate: 1 target_bundles_drag_drop: + accordion: + weight: 22 + enabled: false campaign_rule: weight: 2 enabled: true @@ -45,15 +50,45 @@ settings: files: weight: 16 enabled: false + hero: + weight: 29 + enabled: false + language_selector: + weight: 30 + enabled: false links: weight: 8 enabled: false + material_grid_automatic: + weight: 32 + enabled: false + material_grid_manual: + weight: 33 + enabled: false medias: weight: 9 enabled: false + nav_grid_manual: + weight: 35 + enabled: false + nav_spots_manual: + weight: 36 + enabled: false + opening_hours: + weight: 37 + enabled: true + recommendation: + weight: 38 + enabled: false text_body: weight: 4 enabled: false + user_registration_item: + weight: 40 + enabled: false + user_registration_section: + weight: 41 + enabled: false video: weight: 20 enabled: false From 6ddc53cad438072a38f077b0296c326632a8ca80 Mon Sep 17 00:00:00 2001 From: LasseStaus Date: Wed, 3 Apr 2024 20:35:32 +0200 Subject: [PATCH 3/6] Add openinghours app to dpl_react libraries DDFFORM-417 --- web/modules/custom/dpl_react/dpl_react.libraries.yml | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/web/modules/custom/dpl_react/dpl_react.libraries.yml b/web/modules/custom/dpl_react/dpl_react.libraries.yml index 9240afdda..7f1dff48e 100644 --- a/web/modules/custom/dpl_react/dpl_react.libraries.yml +++ b/web/modules/custom/dpl_react/dpl_react.libraries.yml @@ -203,6 +203,18 @@ recommendation: - dpl_react/base - dpl_react/handler +opening-hours: + remote: https://github.com/danskernesdigitalebibliotek/dpl-react + license: + name: GNU AFFERO + url: https://github.com/danskernesdigitalebibliotek/dpl-react/blob/master/LICENSE + gpl-compatible: true + js: + /libraries/dpl-react/OpeningHours.js: {} + dependencies: + - dpl_react/base + - dpl_react/handler + material-grid-automatic: remote: https://github.com/danskernesdigitalebibliotek/dpl-react license: From f78f37112288aef873b10ef03692afbd32fd108f Mon Sep 17 00:00:00 2001 From: LasseStaus Date: Wed, 3 Apr 2024 20:36:21 +0200 Subject: [PATCH 4/6] Add paragraph template for opening hours DDFFORM-417 --- .../templates/paragraphs/paragraph--opening-hours.html.twig | 1 + 1 file changed, 1 insertion(+) create mode 100644 web/themes/custom/novel/templates/paragraphs/paragraph--opening-hours.html.twig diff --git a/web/themes/custom/novel/templates/paragraphs/paragraph--opening-hours.html.twig b/web/themes/custom/novel/templates/paragraphs/paragraph--opening-hours.html.twig new file mode 100644 index 000000000..90f1ae3f8 --- /dev/null +++ b/web/themes/custom/novel/templates/paragraphs/paragraph--opening-hours.html.twig @@ -0,0 +1 @@ +{{ react_app_opening_hours }} From a41d4fbd4dd292df920d10ea98c86b36d4d9cabf Mon Sep 17 00:00:00 2001 From: LasseStaus Date: Wed, 3 Apr 2024 20:40:49 +0200 Subject: [PATCH 5/6] Add preprocess for openingHours paragraph This is added to a new dpl_opening_hours.module file to keep paragraph context related to opening hours. This prepares the data necessary for the react app opening hours. DDFFORM-417 --- .../dpl_opening_hours.module | 42 +++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 web/modules/custom/dpl_opening_hours/dpl_opening_hours.module diff --git a/web/modules/custom/dpl_opening_hours/dpl_opening_hours.module b/web/modules/custom/dpl_opening_hours/dpl_opening_hours.module new file mode 100644 index 000000000..be26b4ccc --- /dev/null +++ b/web/modules/custom/dpl_opening_hours/dpl_opening_hours.module @@ -0,0 +1,42 @@ +getParentEntity(); + if ($parentNode && $parentNode->bundle() === 'branch') { + $branchId = $parentNode->id(); + + // Prepare variables for the React app. + $variables['react_app_opening_hours'] = [ + '#theme' => 'dpl_react_app', + '#name' => 'opening-hours', + '#data' => [ + 'branch-id' => $branchId, + 'opening-hours-heading-text' => t('Opening Hours', [], ['context' => 'Opening Hours']), + 'show-opening-hours-for-week-text' => t('Show opening hours for week', [], ['context' => 'Opening Hours']), + 'week-text' => t('Week', [], ['context' => 'Opening Hours']), + ] + DplReactAppsController::externalApiBaseUrls(), + ]; + } +} From 29c79fc6a61df6817bc2c896b489d3ce462e1493 Mon Sep 17 00:00:00 2001 From: LasseStaus Date: Wed, 3 Apr 2024 20:43:49 +0200 Subject: [PATCH 6/6] Update autogenerated openingHour API doc & specs. This is all generated from task dev:codegen:dpl-cms DDFFORM-417 --- packages/cms-api/.openapi-generator/FILES | 6 +- .../DplOpeningHoursCreatePOSTRequest.php | 284 +++++++++++++++++ ...DplOpeningHoursListGET200ResponseInner.php | 285 ++++++++++++++++++ ...ngHoursListGET200ResponseInnerCategory.php | 131 ++++++++ packages/cms-api/README.md | 13 +- 5 files changed, 709 insertions(+), 10 deletions(-) create mode 100644 packages/cms-api/Model/DplOpeningHoursCreatePOSTRequest.php create mode 100644 packages/cms-api/Model/DplOpeningHoursListGET200ResponseInner.php create mode 100644 packages/cms-api/Model/DplOpeningHoursListGET200ResponseInnerCategory.php diff --git a/packages/cms-api/.openapi-generator/FILES b/packages/cms-api/.openapi-generator/FILES index 8e24bb6af..40ab688a0 100644 --- a/packages/cms-api/.openapi-generator/FILES +++ b/packages/cms-api/.openapi-generator/FILES @@ -1,6 +1,6 @@ -Model/DplOpeningHoursGET200Response.php -Model/DplOpeningHoursGETRequest.php -Model/DplOpeningHoursGETRequestCategory.php +Model/DplOpeningHoursCreatePOSTRequest.php +Model/DplOpeningHoursListGET200ResponseInner.php +Model/DplOpeningHoursListGET200ResponseInnerCategory.php README.md Service/JmsSerializer.php Service/SerializerInterface.php diff --git a/packages/cms-api/Model/DplOpeningHoursCreatePOSTRequest.php b/packages/cms-api/Model/DplOpeningHoursCreatePOSTRequest.php new file mode 100644 index 000000000..893c7fd1d --- /dev/null +++ b/packages/cms-api/Model/DplOpeningHoursCreatePOSTRequest.php @@ -0,0 +1,284 @@ +") + */ + protected ?\DateTime $date = null; + + /** + * When the opening hours start. In format HH:MM + * + * @var string|null + * @SerializedName("start_time") + * @Assert\NotNull() + * @Assert\Type("string") + * @Type("string") + */ + protected ?string $startTime = null; + + /** + * When the opening hours end. In format HH:MM + * + * @var string|null + * @SerializedName("end_time") + * @Assert\NotNull() + * @Assert\Type("string") + * @Type("string") + */ + protected ?string $endTime = null; + + /** + * The id for the branch the instance belongs to + * + * @var int|null + * @SerializedName("branch_id") + * @Assert\NotNull() + * @Assert\Type("int") + * @Type("int") + */ + protected ?int $branchId = null; + + /** + * Constructor + * @param array|null $data Associated array of property values initializing the model + */ + public function __construct(array $data = null) + { + if (is_array($data)) { + $this->id = array_key_exists('id', $data) ? $data['id'] : $this->id; + $this->category = array_key_exists('category', $data) ? $data['category'] : $this->category; + $this->date = array_key_exists('date', $data) ? $data['date'] : $this->date; + $this->startTime = array_key_exists('startTime', $data) ? $data['startTime'] : $this->startTime; + $this->endTime = array_key_exists('endTime', $data) ? $data['endTime'] : $this->endTime; + $this->branchId = array_key_exists('branchId', $data) ? $data['branchId'] : $this->branchId; + } + } + + /** + * Gets id. + * + * @return int|null + */ + public function getId(): ?int + { + return $this->id; + } + + + + /** + * Sets id. + * + * @param int|null $id An serial unique id of the opening hours instance. + * + * @return $this + */ + public function setId(?int $id = null): self + { + $this->id = $id; + + return $this; + } + + /** + * Gets category. + * + * @return DplOpeningHoursListGET200ResponseInnerCategory|null + */ + public function getCategory(): ?DplOpeningHoursListGET200ResponseInnerCategory + { + return $this->category; + } + + + + /** + * Sets category. + * + * @param DplOpeningHoursListGET200ResponseInnerCategory|null $category + * + * @return $this + */ + public function setCategory(?DplOpeningHoursListGET200ResponseInnerCategory $category): self + { + $this->category = $category; + + return $this; + } + + /** + * Gets date. + * + * @return \DateTime|null + */ + public function getDate(): ?\DateTime + { + return $this->date; + } + + + + /** + * Sets date. + * + * @param \DateTime|null $date The date which the opening hours applies to. In ISO 8601 format. + * + * @return $this + */ + public function setDate(?\DateTime $date): self + { + $this->date = $date; + + return $this; + } + + /** + * Gets startTime. + * + * @return string|null + */ + public function getStartTime(): ?string + { + return $this->startTime; + } + + + + /** + * Sets startTime. + * + * @param string|null $startTime When the opening hours start. In format HH:MM + * + * @return $this + */ + public function setStartTime(?string $startTime): self + { + $this->startTime = $startTime; + + return $this; + } + + /** + * Gets endTime. + * + * @return string|null + */ + public function getEndTime(): ?string + { + return $this->endTime; + } + + + + /** + * Sets endTime. + * + * @param string|null $endTime When the opening hours end. In format HH:MM + * + * @return $this + */ + public function setEndTime(?string $endTime): self + { + $this->endTime = $endTime; + + return $this; + } + + /** + * Gets branchId. + * + * @return int|null + */ + public function getBranchId(): ?int + { + return $this->branchId; + } + + + + /** + * Sets branchId. + * + * @param int|null $branchId The id for the branch the instance belongs to + * + * @return $this + */ + public function setBranchId(?int $branchId): self + { + $this->branchId = $branchId; + + return $this; + } +} + + diff --git a/packages/cms-api/Model/DplOpeningHoursListGET200ResponseInner.php b/packages/cms-api/Model/DplOpeningHoursListGET200ResponseInner.php new file mode 100644 index 000000000..d3f7ee74d --- /dev/null +++ b/packages/cms-api/Model/DplOpeningHoursListGET200ResponseInner.php @@ -0,0 +1,285 @@ +") + */ + protected ?\DateTime $date = null; + + /** + * When the opening hours start. In format HH:MM + * + * @var string|null + * @SerializedName("start_time") + * @Assert\NotNull() + * @Assert\Type("string") + * @Type("string") + */ + protected ?string $startTime = null; + + /** + * When the opening hours end. In format HH:MM + * + * @var string|null + * @SerializedName("end_time") + * @Assert\NotNull() + * @Assert\Type("string") + * @Type("string") + */ + protected ?string $endTime = null; + + /** + * The id for the branch the instance belongs to + * + * @var int|null + * @SerializedName("branch_id") + * @Assert\NotNull() + * @Assert\Type("int") + * @Type("int") + */ + protected ?int $branchId = null; + + /** + * Constructor + * @param array|null $data Associated array of property values initializing the model + */ + public function __construct(array $data = null) + { + if (is_array($data)) { + $this->id = array_key_exists('id', $data) ? $data['id'] : $this->id; + $this->category = array_key_exists('category', $data) ? $data['category'] : $this->category; + $this->date = array_key_exists('date', $data) ? $data['date'] : $this->date; + $this->startTime = array_key_exists('startTime', $data) ? $data['startTime'] : $this->startTime; + $this->endTime = array_key_exists('endTime', $data) ? $data['endTime'] : $this->endTime; + $this->branchId = array_key_exists('branchId', $data) ? $data['branchId'] : $this->branchId; + } + } + + /** + * Gets id. + * + * @return int|null + */ + public function getId(): ?int + { + return $this->id; + } + + + + /** + * Sets id. + * + * @param int|null $id An serial unique id of the opening hours instance. + * + * @return $this + */ + public function setId(?int $id): self + { + $this->id = $id; + + return $this; + } + + /** + * Gets category. + * + * @return DplOpeningHoursListGET200ResponseInnerCategory|null + */ + public function getCategory(): ?DplOpeningHoursListGET200ResponseInnerCategory + { + return $this->category; + } + + + + /** + * Sets category. + * + * @param DplOpeningHoursListGET200ResponseInnerCategory|null $category + * + * @return $this + */ + public function setCategory(?DplOpeningHoursListGET200ResponseInnerCategory $category): self + { + $this->category = $category; + + return $this; + } + + /** + * Gets date. + * + * @return \DateTime|null + */ + public function getDate(): ?\DateTime + { + return $this->date; + } + + + + /** + * Sets date. + * + * @param \DateTime|null $date The date which the opening hours applies to. In ISO 8601 format. + * + * @return $this + */ + public function setDate(?\DateTime $date): self + { + $this->date = $date; + + return $this; + } + + /** + * Gets startTime. + * + * @return string|null + */ + public function getStartTime(): ?string + { + return $this->startTime; + } + + + + /** + * Sets startTime. + * + * @param string|null $startTime When the opening hours start. In format HH:MM + * + * @return $this + */ + public function setStartTime(?string $startTime): self + { + $this->startTime = $startTime; + + return $this; + } + + /** + * Gets endTime. + * + * @return string|null + */ + public function getEndTime(): ?string + { + return $this->endTime; + } + + + + /** + * Sets endTime. + * + * @param string|null $endTime When the opening hours end. In format HH:MM + * + * @return $this + */ + public function setEndTime(?string $endTime): self + { + $this->endTime = $endTime; + + return $this; + } + + /** + * Gets branchId. + * + * @return int|null + */ + public function getBranchId(): ?int + { + return $this->branchId; + } + + + + /** + * Sets branchId. + * + * @param int|null $branchId The id for the branch the instance belongs to + * + * @return $this + */ + public function setBranchId(?int $branchId): self + { + $this->branchId = $branchId; + + return $this; + } +} + + diff --git a/packages/cms-api/Model/DplOpeningHoursListGET200ResponseInnerCategory.php b/packages/cms-api/Model/DplOpeningHoursListGET200ResponseInnerCategory.php new file mode 100644 index 000000000..3600a9dc4 --- /dev/null +++ b/packages/cms-api/Model/DplOpeningHoursListGET200ResponseInnerCategory.php @@ -0,0 +1,131 @@ +title = array_key_exists('title', $data) ? $data['title'] : $this->title; + $this->color = array_key_exists('color', $data) ? $data['color'] : $this->color; + } + } + + /** + * Gets title. + * + * @return string|null + */ + public function getTitle(): ?string + { + return $this->title; + } + + + + /** + * Sets title. + * + * @param string|null $title + * + * @return $this + */ + public function setTitle(?string $title): self + { + $this->title = $title; + + return $this; + } + + /** + * Gets color. + * + * @return string|null + */ + public function getColor(): ?string + { + return $this->color; + } + + + + /** + * Sets color. + * + * @param string|null $color A CSS compatible color code which can be used to represent the category + * + * @return $this + */ + public function setColor(?string $color): self + { + $this->color = $color; + + return $this; + } +} + + diff --git a/packages/cms-api/README.md b/packages/cms-api/README.md index 0e29be9cf..ecb6e6b92 100644 --- a/packages/cms-api/README.md +++ b/packages/cms-api/README.md @@ -102,11 +102,10 @@ All URIs are relative to *http://varnish:8080* Class | Method | HTTP request | Description ------------ | ------------- | ------------- | ------------- *DefaultApiInterface* | [**campaignMatchPOST**](docs/Api/DefaultApiInterface.md#campaignmatchpost) | **POST** /dpl_campaign/match | Get campaign matching search result facets -*DefaultApiInterface* | [**dplOpeningHoursDELETE**](docs/Api/DefaultApiInterface.md#dplopeninghoursdelete) | **DELETE** /dpl_opening_hours/{id} | Manage individual opening hours -*DefaultApiInterface* | [**dplOpeningHoursGET**](docs/Api/DefaultApiInterface.md#dplopeninghoursget) | **GET** /dpl_opening_hours/{id} | Manage individual opening hours +*DefaultApiInterface* | [**dplOpeningHoursCreatePOST**](docs/Api/DefaultApiInterface.md#dplopeninghourscreatepost) | **POST** /dpl_opening_hours | Create individual opening hours +*DefaultApiInterface* | [**dplOpeningHoursDeleteDELETE**](docs/Api/DefaultApiInterface.md#dplopeninghoursdeletedelete) | **DELETE** /dpl_opening_hours/{id} | Delete individual opening hours *DefaultApiInterface* | [**dplOpeningHoursListGET**](docs/Api/DefaultApiInterface.md#dplopeninghourslistget) | **GET** /dpl_opening_hours | List all opening hours -*DefaultApiInterface* | [**dplOpeningHoursPATCH**](docs/Api/DefaultApiInterface.md#dplopeninghourspatch) | **PATCH** /dpl_opening_hours/{id} | Manage individual opening hours -*DefaultApiInterface* | [**dplOpeningHoursPOST**](docs/Api/DefaultApiInterface.md#dplopeninghourspost) | **POST** /dpl_opening_hours | Manage individual opening hours +*DefaultApiInterface* | [**dplOpeningHoursUpdatePATCH**](docs/Api/DefaultApiInterface.md#dplopeninghoursupdatepatch) | **PATCH** /dpl_opening_hours/{id} | Update individual opening hours *DefaultApiInterface* | [**eventPATCH**](docs/Api/DefaultApiInterface.md#eventpatch) | **PATCH** /dpl_event/{uuid} | Update single events *DefaultApiInterface* | [**eventsGET**](docs/Api/DefaultApiInterface.md#eventsget) | **GET** /dpl_event | Retrieve all events *DefaultApiInterface* | [**proxyUrlGET**](docs/Api/DefaultApiInterface.md#proxyurlget) | **GET** /dpl-url-proxy | Generate proxy url @@ -119,9 +118,9 @@ Class | Method | HTTP request | Description - [CampaignMatchPOST200ResponseDataImage](docs/Model/CampaignMatchPOST200ResponseDataImage.md) - [CampaignMatchPOSTRequestInner](docs/Model/CampaignMatchPOSTRequestInner.md) - [CampaignMatchPOSTRequestInnerValuesInner](docs/Model/CampaignMatchPOSTRequestInnerValuesInner.md) - - [DplOpeningHoursGET200Response](docs/Model/DplOpeningHoursGET200Response.md) - - [DplOpeningHoursGETRequest](docs/Model/DplOpeningHoursGETRequest.md) - - [DplOpeningHoursGETRequestCategory](docs/Model/DplOpeningHoursGETRequestCategory.md) + - [DplOpeningHoursCreatePOSTRequest](docs/Model/DplOpeningHoursCreatePOSTRequest.md) + - [DplOpeningHoursListGET200ResponseInner](docs/Model/DplOpeningHoursListGET200ResponseInner.md) + - [DplOpeningHoursListGET200ResponseInnerCategory](docs/Model/DplOpeningHoursListGET200ResponseInnerCategory.md) - [EventPATCHRequest](docs/Model/EventPATCHRequest.md) - [EventPATCHRequestExternalData](docs/Model/EventPATCHRequestExternalData.md) - [EventsGET200ResponseInner](docs/Model/EventsGET200ResponseInner.md)