From 90a8b68a4bb233333891c87bd70d2ed9938f4fe6 Mon Sep 17 00:00:00 2001 From: Michael Bauer <michael-bauer@posteo.de> Date: Thu, 6 Jun 2024 17:44:51 +0200 Subject: [PATCH] TMP (DEL ME) Add AbsenceCreationDialog to Coursebook for testing until absences page in coursebook is ready. --- .../components/coursebook/Coursebook.vue | 126 +++++++++--------- 1 file changed, 66 insertions(+), 60 deletions(-) diff --git a/aleksis/apps/alsijil/frontend/components/coursebook/Coursebook.vue b/aleksis/apps/alsijil/frontend/components/coursebook/Coursebook.vue index 4e673db88..86b2a5fa2 100644 --- a/aleksis/apps/alsijil/frontend/components/coursebook/Coursebook.vue +++ b/aleksis/apps/alsijil/frontend/components/coursebook/Coursebook.vue @@ -1,67 +1,70 @@ <template> - <c-r-u-d-iterator - i18n-key="alsijil.coursebook" - :gql-query="gqlQuery" - :gql-additional-query-args="gqlQueryArgs" - :enable-create="false" - :enable-edit="false" - :elevated="false" - @lastQuery="lastQuery = $event" - ref="iterator" - fixed-header - disable-pagination - hide-default-footer - use-deep-search - > - <template #additionalActions="{ attrs, on }"> - <coursebook-filters v-model="filters" /> - </template> - <template #default="{ items }"> - <coursebook-loader /> - <coursebook-day - v-for="{ date, docs, first, last } in groupDocsByDay(items)" - v-intersect="{ - handler: intersectHandler(date, first, last), - options: { - rootMargin: '-' + topMargin + 'px 0px 0px 0px', - threshold: [0, 1], - }, - }" - :date="date" - :docs="docs" - :lastQuery="lastQuery" - :focus-on-mount="initDate && initDate.toMillis() === date.toMillis()" - @init="transition" - :key="'day-' + date" - ref="days" - /> - <coursebook-loader /> + <div> + <c-r-u-d-iterator + i18n-key="alsijil.coursebook" + :gql-query="gqlQuery" + :gql-additional-query-args="gqlQueryArgs" + :enable-create="false" + :enable-edit="false" + :elevated="false" + @lastQuery="lastQuery = $event" + ref="iterator" + fixed-header + disable-pagination + hide-default-footer + use-deep-search + > + <template #additionalActions="{ attrs, on }"> + <coursebook-filters v-model="filters" /> + </template> + <template #default="{ items }"> + <coursebook-loader /> + <coursebook-day + v-for="{ date, docs, first, last } in groupDocsByDay(items)" + v-intersect="{ + handler: intersectHandler(date, first, last), + options: { + rootMargin: '-' + topMargin + 'px 0px 0px 0px', + threshold: [0, 1], + }, + }" + :date="date" + :docs="docs" + :lastQuery="lastQuery" + :focus-on-mount="initDate && initDate.toMillis() === date.toMillis()" + @init="transition" + :key="'day-' + date" + ref="days" + /> + <coursebook-loader /> - <date-select-footer - :value="currentDate" - @input="gotoDate" - @prev="gotoPrev" - @next="gotoNext" - /> - </template> - <template #loading> - <coursebook-loader :number-of-days="10" :number-of-docs="5" /> - </template> + <date-select-footer + :value="currentDate" + @input="gotoDate" + @prev="gotoPrev" + @next="gotoNext" + /> + </template> + <template #loading> + <coursebook-loader :number-of-days="10" :number-of-docs="5" /> + </template> - <template #no-data> - <CoursebookEmptyMessage icon="mdi-book-off-outline"> - {{ $t("alsijil.coursebook.no_data") }} - </CoursebookEmptyMessage> - </template> + <template #no-data> + <CoursebookEmptyMessage icon="mdi-book-off-outline"> + {{ $t("alsijil.coursebook.no_data") }} + </CoursebookEmptyMessage> + </template> - <template #no-results> - <CoursebookEmptyMessage icon="mdi-book-alert-outline"> - {{ - $t("alsijil.coursebook.no_results", { search: $refs.iterator.search }) - }} - </CoursebookEmptyMessage> - </template> - </c-r-u-d-iterator> + <template #no-results> + <CoursebookEmptyMessage icon="mdi-book-alert-outline"> + {{ + $t("alsijil.coursebook.no_results", { search: $refs.iterator.search }) + }} + </CoursebookEmptyMessage> + </template> + </c-r-u-d-iterator> + <absence-creation-dialog /> + </div> </template> <script> @@ -74,6 +77,8 @@ import CoursebookFilters from "./CoursebookFilters.vue"; import CoursebookLoader from "./CoursebookLoader.vue"; import CoursebookEmptyMessage from "./CoursebookEmptyMessage.vue"; +import AbsenceCreationDialog from "./absences/AbsenceCreationDialog.vue"; + export default { name: "Coursebook", components: { @@ -83,6 +88,7 @@ export default { CRUDIterator, DateSelectFooter, CoursebookDay, + AbsenceCreationDialog, }, props: { filterType: { -- GitLab