diff --git a/config/webpack/webpack.common.js b/config/webpack/webpack.common.js index 14c26a8f89..c9105942e9 100644 --- a/config/webpack/webpack.common.js +++ b/config/webpack/webpack.common.js @@ -145,6 +145,9 @@ module.exports = { "@feature-board-collaborative-text-editor-element": getDir( "src/modules/feature/board-collaborative-text-editor-element" ), + "@feature-board-video-conference-element": getDir( + "src/modules/feature/board-video-conference-element" + ), "@feature-board-deleted-element": getDir( "src/modules/feature/board-deleted-element" ), @@ -166,6 +169,7 @@ module.exports = { "@ui-kebab-menu": getDir("src/modules/ui/kebab-menu"), "@ui-layout": getDir("src/modules/ui/layout"), "@ui-light-box": getDir("src/modules/ui/light-box"), + "@ui-line-clamp": getDir("src/modules/ui/line-clamp"), "@ui-preview-image": getDir("src/modules/ui/preview-image"), "@ui-room-details": getDir("src/modules/ui/room-details"), "@ui-skip-link": getDir("src/modules/ui/skip-link"), diff --git a/src/assets/img/index.d.ts b/src/assets/img/index.d.ts index fedf5cbbc2..041d291d64 100644 --- a/src/assets/img/index.d.ts +++ b/src/assets/img/index.d.ts @@ -11,3 +11,7 @@ declare module "@/assets/img/collaborativeEditor.svg" { const value: string; export default value; } +declare module "@/assets/img/videoConference.svg" { + const value: string; + export default value; +} diff --git a/src/assets/img/videoConference.svg b/src/assets/img/videoConference.svg new file mode 100644 index 0000000000..e1bbc5ccc7 --- /dev/null +++ b/src/assets/img/videoConference.svg @@ -0,0 +1,86 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/components/icons/material/index.ts b/src/components/icons/material/index.ts index 5a3ce94511..2bb64c1a26 100644 --- a/src/components/icons/material/index.ts +++ b/src/components/icons/material/index.ts @@ -136,6 +136,7 @@ import { mdiTune, mdiUndo, mdiUndoVariant, + mdiVideo, mdiViewAgendaOutline, mdiViewDashboard, mdiViewDashboardOutline, @@ -282,6 +283,7 @@ export { mdiTune, mdiUndo, mdiUndoVariant, + mdiVideo, mdiViewAgendaOutline, mdiViewDashboard, mdiViewDashboardOutline, diff --git a/src/components/organisms/vCustomDialog.vue b/src/components/organisms/vCustomDialog.vue index 8e503755e0..706dedebaa 100644 --- a/src/components/organisms/vCustomDialog.vue +++ b/src/components/organisms/vCustomDialog.vue @@ -6,7 +6,7 @@ @click:outside="closeDialog" @keydown.esc="closeDialog" > - + diff --git a/src/locales/de.ts b/src/locales/de.ts index c6aae542b5..b4774c7bc6 100644 --- a/src/locales/de.ts +++ b/src/locales/de.ts @@ -167,6 +167,7 @@ export default { "common.words.color.purple": "Violett", "common.words.color.red": "Rot", "common.words.color.turquoise": "Türkis", + "common.words.color.yellow": "Gelb", "common.words.copiedToClipboard": "In die Zwischenablage kopiert", "common.words.courseGroups": "Kursgruppen", "common.words.courses": "Kurse", @@ -353,6 +354,8 @@ export default { "components.board.menu.fileElement": "Datei-Einstellungen", "components.board.menu.linkElement": "Link-Einstellungen", "components.board.menu.submissionElement": "Abgabe-Einstellungen", + "components.board.menu.videoConferenceElement": + "Videokonferenz-Einstellungen", "components.board.menu.deletedElement": "Gelöschter-Inhalt-Einstellungen", "components.board.notifications.errors.fileNameExists": "Es existiert bereits eine Datei mit diesem Namen.", @@ -448,6 +451,9 @@ export default { "components.cardElement.titleElement.validation.required": "Bitte Titel angeben.", "components.cardElement.titleElement": "Titelelement", + "components.cardElement.videoConferenceElement": "Videokonferenz", + "components.cardElement.videoConferenceElement.label": + "Videokonferenz-Titel einfügen", "components.cardElement.deletedElement": "Gelöschter Inhalt", "components.cardElement.deletedElement.warning.externalToolElement": "Tool {toolName} nicht verfügbar. Bitte an Schuladministrator:in wenden.", @@ -472,6 +478,8 @@ export default { "components.elementTypeSelection.elements.submissionElement.subtitle": "Abgabe", "components.elementTypeSelection.elements.textElement.subtitle": "Text", + "components.elementTypeSelection.elements.videoConferenceElement.subtitle": + "Videokonferenz", "components.externalTools.status.deactivated": "Deaktiviert", "components.externalTools.status.incomplete": "Unvollständig", "components.externalTools.status.latest": "Aktuell", @@ -1494,6 +1502,14 @@ export default { "Lehrkraft erfolgreich angelegt!", "pages.administration.teachers.new.title": "Lehrkraft hinzufügen", "pages.administration.teachers.table.edit.ariaLabel": "Lehrkraft bearbeiten", + "pages.common.tools.configureVideoconferenceDialog.title": + "Videokonferenz erstellen", + "pages.common.tools.configureVideoconferenceDialog.text.allModeratorPermission": + "Alle Nutzer:innen nehmen als Moderator:in teil", + "pages.common.tools.configureVideoconferenceDialog.text.mute": + "Teilnehmer:innen beim Betreten stummschalten", + "pages.common.tools.configureVideoconferenceDialog.text.waitingRoom": + "Freigabe durch Moderator:in, bevor der Raum betreten werden kann", "pages.content._id.addToTopic": "Hinzufügen zu", "pages.content._id.collection.selectElements": "Wählen Sie die Elemente, die Sie zum Thema hinzufügen möchten", @@ -1562,14 +1578,6 @@ export default { "pages.courseRooms.tabLabel.groups": "Gruppen", "pages.courseRooms.tabLabel.tools": "Tools", "pages.courseRooms.tabLabel.toolsOld": "Tools", - "pages.courseRooms.tools.configureVideoconferenceDialog.title": - "Videokonferenz {roomName} erstellen", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.allModeratorPermission": - "Alle Nutzer:innen nehmen als Moderator:in teil", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.mute": - "Teilnehmer:innen beim Betreten stummschalten", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.waitingRoom": - "Freigabe durch Moderator:in, bevor der Raum betreten werden kann", "pages.files.overview.courseFiles": "Kurs-Dateien", "pages.files.overview.favorites": "Favoriten", "pages.files.overview.personalFiles": "Meine persönlichen Dateien", @@ -1809,6 +1817,10 @@ export default { "Die Videokonferenz wurde noch nicht gestartet oder du bist nicht berechtigt, an ihr teilzunehmen.", "pages.videoConference.info.notStarted": "Die Videokonferenz wurde noch nicht gestartet.", + "pages.videoConference.info.notEnabledParticipants": + "Das Element ist nicht mehr verfügbar. Bitte an die Lehrkraft wenden.", + "pages.videoConference.info.notEnabledTeacher": + "Das Element ist nicht mehr verfügbar. Bitte an den Admin wenden.", "pages.videoConference.title": "Videokonferenz BigBlueButton", "error.500": "Es gibt Probleme im System. Wir arbeiten daran, das Problem zu beheben. Bitte später erneut versuchen.", diff --git a/src/locales/en.ts b/src/locales/en.ts index e6a8d7ee50..9432425ba4 100644 --- a/src/locales/en.ts +++ b/src/locales/en.ts @@ -168,6 +168,7 @@ export default { "common.words.color.purple": "Purple", "common.words.color.red": "Red", "common.words.color.turquoise": "Turquoise", + "common.words.color.yellow": "Yellow", "common.words.copiedToClipboard": "Copied to the clipboard", "common.words.courseGroups": "Course Groups", "common.words.courses": "Courses", @@ -350,6 +351,7 @@ export default { "components.board.menu.fileElement": "File settings", "components.board.menu.linkElement": "Link settings", "components.board.menu.submissionElement": "Submission settings", + "components.board.menu.videoConferenceElement": "Video conference settings", "components.board.menu.deletedElement": "Deleted content settings", "components.board.notifications.errors.fileNameExists": "A file with this name already exists.", @@ -445,6 +447,9 @@ export default { "components.cardElement.titleElement.validation.required": "Please enter a title.", "components.cardElement.titleElement": "Title element", + "components.cardElement.videoConferenceElement": "Video conference", + "components.cardElement.videoConferenceElement.label": + "Insert video conference title", "components.cardElement.deletedElement": "Deleted content", "components.cardElement.deletedElement.warning.externalToolElement": "Tool {toolName} not available. Please contact the school administrator.", @@ -468,6 +473,8 @@ export default { "components.elementTypeSelection.elements.submissionElement.subtitle": "Submission", "components.elementTypeSelection.elements.textElement.subtitle": "Text", + "components.elementTypeSelection.elements.videoConferenceElement.subtitle": + "Video conference", "components.externalTools.status.deactivated": "Deactivated", "components.externalTools.status.incomplete": "Configuration incomplete", "components.externalTools.status.latest": "Latest", @@ -1472,6 +1479,14 @@ export default { "pages.administration.teachers.new.success": "Teacher successfully created!", "pages.administration.teachers.new.title": "Add teacher", "pages.administration.teachers.table.edit.ariaLabel": "Edit teacher", + "pages.common.tools.configureVideoconferenceDialog.title": + "Create video conference", + "pages.common.tools.configureVideoconferenceDialog.text.allModeratorPermission": + "All users participate as moderators", + "pages.common.tools.configureVideoconferenceDialog.text.mute": + "Mute participants when entering", + "pages.common.tools.configureVideoconferenceDialog.text.waitingRoom": + "Approval by the moderator before the room can be entered", "pages.content._id.addToTopic": "To be added to", "pages.content._id.collection.selectElements": "Select the items you want to add to the topic", @@ -1538,14 +1553,6 @@ export default { "pages.courseRooms.tabLabel.groups": "Groups", "pages.courseRooms.tabLabel.tools": "Tools", "pages.courseRooms.tabLabel.toolsOld": "Tools", - "pages.courseRooms.tools.configureVideoconferenceDialog.title": - "Create video conference {roomName}", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.allModeratorPermission": - "All users participate as moderators", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.mute": - "Mute participants when entering", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.waitingRoom": - "Approval by the moderator before the room can be entered", "pages.files.overview.courseFiles": "Course files", "pages.files.overview.favorites": "Favourites", "pages.files.overview.personalFiles": "My personal files", @@ -1776,6 +1783,10 @@ export default { "The video conference hasn't started yet or you don't have permission to join it.", "pages.videoConference.info.notStarted": "The video conference hasn't started yet.", + "pages.videoConference.info.notEnabledParticipants": + "The element is no longer available. Please contact the teacher.", + "pages.videoConference.info.notEnabledTeacher": + "The element is no longer available. Please contact the admin.", "pages.videoConference.title": "Video conference BigBlueButton", "error.500": "There are problems in the system. We are working on fixing the issue. Please try again later.", diff --git a/src/locales/es.ts b/src/locales/es.ts index 53935427e8..de782f0aac 100644 --- a/src/locales/es.ts +++ b/src/locales/es.ts @@ -170,6 +170,7 @@ export default { "common.words.color.purple": "Violeta", "common.words.color.red": "Roja", "common.words.color.turquoise": "Turquesa", + "common.words.color.yellow": "Amarillo", "common.words.copiedToClipboard": "Copiado en el portapapeles", "common.words.courseGroups": "grupos de cursos", "common.words.courses": "Cursos", @@ -357,6 +358,8 @@ export default { "components.board.menu.fileElement": "Configuración del archivo", "components.board.menu.linkElement": "Configuración del enlace", "components.board.menu.submissionElement": "Configuración del envío", + "components.board.menu.videoConferenceElement": + "Configuración de la videoconferencia", "components.board.menu.deletedElement": "Configuración de contenido eliminado", "components.board.notifications.errors.fileNameExists": @@ -453,6 +456,9 @@ export default { "components.cardElement.titleElement.validation.required": "Por favor ingrese un título.", "components.cardElement.titleElement": "Elemento título", + "components.cardElement.videoConferenceElement": "Videoconferencia", + "components.cardElement.videoConferenceElement.label": + "Insertar título de la videoconferencia", "components.cardElement.deletedElement": "Contenido eliminado", "components.cardElement.deletedElement.warning.externalToolElement": "La herramienta {toolName} no está disponible. Por favor comuníquese con el administrador de la escuela.", @@ -477,6 +483,8 @@ export default { "components.elementTypeSelection.elements.submissionElement.subtitle": "Envíos", "components.elementTypeSelection.elements.textElement.subtitle": "Texto", + "components.elementTypeSelection.elements.videoConferenceElement.subtitle": + "Videoconferencia", "components.externalTools.status.deactivated": "Desactivado", "components.externalTools.status.incomplete": "Configuración incompleta", "components.externalTools.status.latest": "Actual", @@ -1517,6 +1525,14 @@ export default { "¡Profesor creado correctamente!", "pages.administration.teachers.new.title": "Añadir profesor", "pages.administration.teachers.table.edit.ariaLabel": "Editar profesor", + "pages.common.tools.configureVideoconferenceDialog.title": + "Crear videoconferencia", + "pages.common.tools.configureVideoconferenceDialog.text.allModeratorPermission": + "Todas las usuarias participan como moderadoras", + "pages.common.tools.configureVideoconferenceDialog.text.mute": + "Silenciar a las participantes al entrar", + "pages.common.tools.configureVideoconferenceDialog.text.waitingRoom": + "Aprobación del moderador antes de poder ingresar a la sala", "pages.content._id.addToTopic": "Para ser añadido a", "pages.content._id.collection.selectElements": "Selecciona los elementos que deses añadir al tema", @@ -1584,14 +1600,6 @@ export default { "pages.courseRooms.tabLabel.groups": "Grupos", "pages.courseRooms.tabLabel.tools": "Herramientas", "pages.courseRooms.tabLabel.toolsOld": "Herramientas", - "pages.courseRooms.tools.configureVideoconferenceDialog.title": - "Crear videoconferencia {roomName}", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.allModeratorPermission": - "Todas las usuarias participan como moderadoras", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.mute": - "Silenciar a las participantes al entrar", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.waitingRoom": - "Aprobación del moderador antes de poder ingresar a la sala", "pages.files.overview.courseFiles": "Archivos del curso", "pages.files.overview.favorites": "Favoritos", "pages.files.overview.personalFiles": "Archivos personales", @@ -1827,6 +1835,10 @@ export default { "La videoconferencia aún no ha comenzado o no tienes permiso para unirte.", "pages.videoConference.info.notStarted": "La videoconferencia aún no ha comenzado.", + "pages.videoConference.info.notEnabledParticipants": + "El elemento ya no está disponible. Póngase en contacto con el profesor.", + "pages.videoConference.info.notEnabledTeacher": + "El elemento ya no está disponible. Póngase en contacto con el administrador.", "pages.videoConference.title": "Videoconferencia BigBlueButton", "error.500": "Hay problemas en el sistema. Estamos trabajando para solucionar el problema. Vuelva a intentarlo más tarde.", diff --git a/src/locales/uk.ts b/src/locales/uk.ts index 1429cd4309..af0bfd3c40 100644 --- a/src/locales/uk.ts +++ b/src/locales/uk.ts @@ -170,6 +170,7 @@ export default { "common.words.color.purple": "Фіалка", "common.words.color.red": "Червоний", "common.words.color.turquoise": "Бірюза", + "common.words.color.yellow": "Жовтий", "common.words.copiedToClipboard": "Скопійовано в буфер обміну", "common.words.courseGroups": "курсові групи", "common.words.courses": "Мій курс", @@ -358,6 +359,8 @@ export default { "components.board.menu.fileElement": "Налаштування файлу", "components.board.menu.linkElement": "Налаштування посилання", "components.board.menu.submissionElement": "Налаштування Подання", + "components.board.menu.videoConferenceElement": + "Налаштування відеоконференція", "components.board.menu.deletedElement": "Видалені налаштування вмісту", "components.board.notifications.errors.fileNameExists": "Файл з такою назвою вже існує.", @@ -454,6 +457,9 @@ export default { "components.cardElement.titleElement.validation.required": "Будь ласка, введіть назву.", "components.cardElement.titleElement": "Елемент заголовка", + "components.cardElement.videoConferenceElement": "Відеоконференція", + "components.cardElement.videoConferenceElement.label": + "Вставити назву відеоконференції", "components.cardElement.deletedElement": "Видалений вміст", "components.cardElement.deletedElement.warning.externalToolElement": "Інструмент {toolName} недоступний. Будь ласка, зверніться до адміністратора школи.", @@ -476,6 +482,8 @@ export default { "components.elementTypeSelection.elements.submissionElement.subtitle": "Подання", "components.elementTypeSelection.elements.textElement.subtitle": "Текст", + "components.elementTypeSelection.elements.videoConferenceElement.subtitle": + "Відеоконференція", "components.externalTools.status.deactivated": "Деактивовано", "components.externalTools.status.incomplete": "Конфігурація не завершена", "components.externalTools.status.latest": "Останній", @@ -1500,6 +1508,14 @@ export default { "pages.administration.teachers.new.success": "Викладача успішно створено!", "pages.administration.teachers.new.title": "Додати викладача", "pages.administration.teachers.table.edit.ariaLabel": "Редагування вчителя", + "pages.common.tools.configureVideoconferenceDialog.title": + "Створити відеоконференцію", + "pages.common.tools.configureVideoconferenceDialog.text.allModeratorPermission": + "Усі користувачі беруть участь як модератори", + "pages.common.tools.configureVideoconferenceDialog.text.mute": + "Вимкнення звуку учасників при вході", + "pages.common.tools.configureVideoconferenceDialog.text.waitingRoom": + "Схвалення модератором перед входом до кімнати", "pages.content._id.addToTopic": "Для додавання в", "pages.content._id.collection.selectElements": "Виберіть елементи, які треба додати до теми", @@ -1566,14 +1582,6 @@ export default { "pages.courseRooms.tabLabel.groups": "Групи", "pages.courseRooms.tabLabel.tools": "Інструмент", "pages.courseRooms.tabLabel.toolsOld": "Інструмент", - "pages.courseRooms.tools.configureVideoconferenceDialog.title": - "Створити відеоконференцію {roomName}", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.allModeratorPermission": - "Усі користувачі беруть участь як модератори", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.mute": - "Вимкнення звуку учасників при вході", - "pages.courseRooms.tools.configureVideoconferenceDialog.text.waitingRoom": - "Схвалення модератором перед входом до кімнати", "pages.files.overview.courseFiles": "Файли курсу", "pages.files.overview.favorites": "Обрані", "pages.files.overview.personalFiles": "Мої особисті справи", @@ -1803,6 +1811,10 @@ export default { "pages.videoConference.info.noPermission": "Відеоконференція ще не почалася або у вас немає дозволу приєднатися до неї.", "pages.videoConference.info.notStarted": "Відеоконференція ще не почалася.", + "pages.videoConference.info.notEnabledParticipants": + "Елемент більше не доступний. Будь ласка, зверніться до викладача.", + "pages.videoConference.info.notEnabledTeacher": + "Елемент більше не доступний. Будь ласка, зверніться з адміністратором.", "pages.videoConference.title": "Відеоконференція BigBlueButton", "error.500": "Є проблеми в системі. Ми працюємо над усуненням проблеми. Будь ласка, спробуйте пізніше.", diff --git a/src/modules/data/board/Board.store.ts b/src/modules/data/board/Board.store.ts index e06a91adba..eeb3a9ed6f 100644 --- a/src/modules/data/board/Board.store.ts +++ b/src/modules/data/board/Board.store.ts @@ -324,7 +324,7 @@ export const useBoardStore = defineStore("boardStore", () => { const deleteBoardSuccess = (payload: DeleteBoardSuccessPayload) => { if (payload.isOwnAction === true) { router.replace({ - name: "rooms-id", + name: "room-details", params: { id: roomId.value }, }); return; diff --git a/src/modules/data/board/Board.store.unit.ts b/src/modules/data/board/Board.store.unit.ts index d5a62b912f..2bdc64d6e2 100644 --- a/src/modules/data/board/Board.store.unit.ts +++ b/src/modules/data/board/Board.store.unit.ts @@ -1196,7 +1196,7 @@ describe("BoardStore", () => { }); expect(router.replace).toHaveBeenCalledWith({ - name: "rooms-id", + name: "room-details", params: { id: "roomId" }, }); }); diff --git a/src/modules/data/board/BoardApi.composable.ts b/src/modules/data/board/BoardApi.composable.ts index f3e1d06ce2..033fdfaedc 100644 --- a/src/modules/data/board/BoardApi.composable.ts +++ b/src/modules/data/board/BoardApi.composable.ts @@ -17,6 +17,7 @@ import { RichTextElementContentBody, RoomApiFactory, SubmissionContainerElementContentBody, + VideoConferenceElementContentBody, } from "@/serverApi/v3"; import { BoardContextType } from "@/types/board/BoardContext"; import { AnyContentElement } from "@/types/board/ContentElement"; @@ -124,6 +125,13 @@ export const useBoardApi = () => { type: ContentElementType.Drawing, }; } + + if (element.type === ContentElementType.VideoConference) { + return { + content: element.content, + type: ContentElementType.VideoConference, + } as VideoConferenceElementContentBody; + } throw new Error("element.type mapping is undefined for updateElementCall"); }; diff --git a/src/modules/data/board/BoardApi.composable.unit.ts b/src/modules/data/board/BoardApi.composable.unit.ts index 2d6a275dd5..56a896b404 100644 --- a/src/modules/data/board/BoardApi.composable.unit.ts +++ b/src/modules/data/board/BoardApi.composable.unit.ts @@ -267,6 +267,29 @@ describe("BoardApi.composable", () => { ); }); + it("should call elementControllerUpdateElement api with VideoConferenceElement", async () => { + const { updateElementCall } = useBoardApi(); + const payload: serverApi.VideoConferenceElementResponse = { + id: "video-conference-element-id", + type: ContentElementType.VideoConference, + content: { + title: "Some title", + }, + timestamps: timestampsResponseFactory.build(), + }; + const data = { + content: payload.content, + type: ContentElementType.VideoConference, + }; + + await updateElementCall(payload); + + expect(elementApi.elementControllerUpdateElement).toHaveBeenCalledWith( + payload.id, + { data } + ); + }); + it("should throw error for unkown element type", async () => { const { updateElementCall } = useBoardApi(); const payload = { diff --git a/src/modules/data/room/RoomCreate.state.ts b/src/modules/data/room/RoomCreate.state.ts index 12d6e390e8..8a1c607a13 100644 --- a/src/modules/data/room/RoomCreate.state.ts +++ b/src/modules/data/room/RoomCreate.state.ts @@ -1,5 +1,5 @@ -import { RoomApiFactory, RoomColor } from "@/serverApi/v3"; -import { RoomCreateParams, RoomItem } from "@/types/room/Room"; +import { RoomApiFactory } from "@/serverApi/v3"; +import { RoomCreateParams, RoomItem, RoomColorEnum } from "@/types/room/Room"; import { $axios, mapAxiosErrorToResponseError } from "@/utils/api"; import { ref } from "vue"; @@ -9,7 +9,7 @@ export const useRoomCreateState = () => { const roomData = ref({ name: "", - color: RoomColor.BlueGrey, + color: RoomColorEnum.BlueGrey, startDate: undefined, endDate: undefined, }); diff --git a/src/modules/data/room/RoomCreate.state.unit.ts b/src/modules/data/room/RoomCreate.state.unit.ts index 8f17f278b3..f6613980d2 100644 --- a/src/modules/data/room/RoomCreate.state.unit.ts +++ b/src/modules/data/room/RoomCreate.state.unit.ts @@ -6,7 +6,7 @@ import { useApplicationError } from "@/composables/application-error.composable" import { initializeAxios, mapAxiosErrorToResponseError } from "@/utils/api"; import setupStores from "@@/tests/test-utils/setupStores"; import ApplicationErrorModule from "@/store/application-error"; -import { RoomCreateParams } from "@/types/room/Room"; +import { RoomCreateParams, RoomColorEnum } from "@/types/room/Room"; import { ref } from "vue"; import { apiResponseErrorFactory, @@ -73,7 +73,7 @@ describe("useRoomCreateState", () => { describe("createRoom", () => { const roomData = ref({ name: "Room 1", - color: serverApi.RoomColor.BlueGrey, + color: RoomColorEnum.BlueGrey, startDate: undefined, endDate: undefined, }); diff --git a/src/modules/data/room/RoomDetails.store.ts b/src/modules/data/room/RoomDetails.store.ts index 02a288c5a0..af82c1c601 100644 --- a/src/modules/data/room/RoomDetails.store.ts +++ b/src/modules/data/room/RoomDetails.store.ts @@ -1,7 +1,13 @@ import { RoomBoardItem, RoomDetails } from "@/types/room/Room"; import { ref } from "vue"; import { defineStore } from "pinia"; -import { RoomApiFactory } from "@/serverApi/v3"; +import { + BoardApiFactory, + BoardLayout, + BoardParentType, + CreateBoardBodyParams, + RoomApiFactory, +} from "@/serverApi/v3"; import { $axios, mapAxiosErrorToResponseError } from "@/utils/api"; import { createApplicationError } from "@/utils/create-application-error.factory"; @@ -17,6 +23,7 @@ export const useRoomDetailsStore = defineStore("roomDetailsStore", () => { const roomBoards = ref([]); const roomApi = RoomApiFactory(undefined, "/v3", $axios); + const boardApi = BoardApiFactory(undefined, "/v3", $axios); const fetchRoom = async (id: string) => { try { @@ -38,6 +45,22 @@ export const useRoomDetailsStore = defineStore("roomDetailsStore", () => { } }; + const createBoard = async ( + roomId: string, + layout: BoardLayout, + title: string + ) => { + const params: CreateBoardBodyParams = { + title: title, + parentId: roomId, + parentType: BoardParentType.Room, + layout, + }; + const boardId = (await boardApi.boardControllerCreateBoard(params)).data.id; + + return boardId; + }; + const resetState = () => { isLoading.value = true; room.value = undefined; @@ -51,6 +74,7 @@ export const useRoomDetailsStore = defineStore("roomDetailsStore", () => { return { deactivateRoom, fetchRoom, + createBoard, isLoading, resetState, room, diff --git a/src/modules/data/room/RoomDetails.store.unit.ts b/src/modules/data/room/RoomDetails.store.unit.ts index ae0bca7fa4..b14e8b6d23 100644 --- a/src/modules/data/room/RoomDetails.store.unit.ts +++ b/src/modules/data/room/RoomDetails.store.unit.ts @@ -8,6 +8,7 @@ import { initializeAxios, mapAxiosErrorToResponseError } from "@/utils/api"; import { apiResponseErrorFactory, axiosErrorFactory, + mockApiResponse, } from "@@/tests/test-utils"; jest.mock("@/utils/api"); @@ -35,12 +36,14 @@ const setupErrorResponse = (message = "NOT_FOUND", code = 404) => { describe("useRoomDetailsStore", () => { let roomApiMock: DeepMocked; + let boardApiMock: DeepMocked; let axiosMock: DeepMocked; let mockedCreateApplicationErrorCalls: ReturnType; beforeEach(() => { setActivePinia(createPinia()); roomApiMock = createMock(); + boardApiMock = createMock(); axiosMock = createMock(); mockedCreateApplicationErrorCalls = createMock>(); @@ -49,6 +52,7 @@ describe("useRoomDetailsStore", () => { ); jest.spyOn(serverApi, "RoomApiFactory").mockReturnValue(roomApiMock); + jest.spyOn(serverApi, "BoardApiFactory").mockReturnValue(boardApiMock); initializeAxios(axiosMock); }); @@ -135,4 +139,30 @@ describe("useRoomDetailsStore", () => { expect(store.room).toBeUndefined(); }); }); + + describe("createBoard", () => { + it("should call createBoard api", async () => { + const { store } = setup(); + const boardId = "board-id"; + const roomId = "room-id"; + const layout = serverApi.BoardLayout.Columns; + const title = "title"; + + boardApiMock.boardControllerCreateBoard.mockResolvedValue( + mockApiResponse({ + data: { id: boardId }, + }) + ); + + const result = await store.createBoard(roomId, layout, title); + + expect(result).toBe(boardId); + expect(boardApiMock.boardControllerCreateBoard).toHaveBeenCalledWith({ + title, + parentId: roomId, + parentType: serverApi.BoardParentType.Room, + layout, + }); + }); + }); }); diff --git a/src/modules/data/room/RoomEdit.state.ts b/src/modules/data/room/RoomEdit.state.ts index 6ba2853c07..5dcac87131 100644 --- a/src/modules/data/room/RoomEdit.state.ts +++ b/src/modules/data/room/RoomEdit.state.ts @@ -1,5 +1,9 @@ -import { RoomApiFactory, RoomColor } from "@/serverApi/v3"; -import { RoomDetails, RoomUpdateParams } from "@/types/room/Room"; +import { RoomApiFactory } from "@/serverApi/v3"; +import { + RoomDetails, + RoomUpdateParams, + RoomColorEnum, +} from "@/types/room/Room"; import { $axios, mapAxiosErrorToResponseError } from "@/utils/api"; import { createApplicationError } from "@/utils/create-application-error.factory"; import { ref } from "vue"; @@ -19,7 +23,7 @@ export const useRoomEditState = () => { const roomData = ref({ name: "", - color: RoomColor.BlueGrey, + color: RoomColorEnum.BlueGrey, startDate: undefined, endDate: undefined, }); diff --git a/src/modules/data/room/RoomEdit.state.unit.ts b/src/modules/data/room/RoomEdit.state.unit.ts index 52bf187f5b..fc1cc125b4 100644 --- a/src/modules/data/room/RoomEdit.state.unit.ts +++ b/src/modules/data/room/RoomEdit.state.unit.ts @@ -10,6 +10,7 @@ import { apiResponseErrorFactory, axiosErrorFactory, } from "@@/tests/test-utils"; +import { RoomColorEnum } from "@/types/room/Room"; jest.mock("@/utils/api"); const mockedMapAxiosErrorToResponseError = jest.mocked( @@ -105,7 +106,7 @@ describe("useRoomEditState", () => { expect(isLoading.value).toBe(true); const params = { name: "room-name", - color: serverApi.RoomColor.BlueGrey, + color: RoomColorEnum.BlueGrey, }; await updateRoom("room-id", params); @@ -123,7 +124,7 @@ describe("useRoomEditState", () => { const { updateRoom, isLoading } = setup(); const params = { name: "room-name", - color: serverApi.RoomColor.BlueGrey, + color: RoomColorEnum.BlueGrey, }; roomApiMock.roomControllerUpdateRoom.mockRejectedValue({ code: 404 }); diff --git a/src/modules/data/room/Rooms.state.unit.ts b/src/modules/data/room/Rooms.state.unit.ts index b5ad2d8f0f..09440ba79b 100644 --- a/src/modules/data/room/Rooms.state.unit.ts +++ b/src/modules/data/room/Rooms.state.unit.ts @@ -10,6 +10,7 @@ import { apiResponseErrorFactory, axiosErrorFactory, } from "@@/tests/test-utils"; +import { RoomColorEnum } from "@/types/room/Room"; jest.mock("@/utils/api"); const mockedMapAxiosErrorToResponseError = jest.mocked( @@ -125,7 +126,7 @@ describe("useRoomsState", () => { { id: "1", name: "Room 1", - color: serverApi.RoomColor.BlueGrey, + color: RoomColorEnum.BlueGrey, schoolId: "6749dd4e657d98af622e370c", createdAt: "2024.11.18", updatedAt: "2024.11.18", diff --git a/src/modules/data/room/roomMembers/roomMembers.composable.ts b/src/modules/data/room/roomMembers/roomMembers.composable.ts index f121d8bde3..d500b19ea3 100644 --- a/src/modules/data/room/roomMembers/roomMembers.composable.ts +++ b/src/modules/data/room/roomMembers/roomMembers.composable.ts @@ -6,8 +6,6 @@ import { SchoolApiFactory, RoomMemberResponse, SchoolForExternalInviteResponse, - UserIdAndRole, - UserIdAndRoleRoleNameEnum, } from "@/serverApi/v3"; import { $axios } from "@/utils/api"; import { useI18n } from "vue-i18n"; @@ -112,15 +110,8 @@ export const useRoomMembers = (roomId: string) => { userIds.includes(member.userId) ); - const userIdsAndRoles: UserIdAndRole[] = newMembers.map((member) => ({ - userId: member.userId, - roleName: UserIdAndRoleRoleNameEnum.Roomeditor, - })); - try { - await roomApi.roomControllerAddMembers(roomId, { - userIdsAndRoles, - }); + await roomApi.roomControllerAddMembers(roomId, { userIds }); roomMembers.value.push( ...newMembers.map((member) => ({ ...member, diff --git a/src/modules/data/room/roomMembers/roomMembers.composable.unit.ts b/src/modules/data/room/roomMembers/roomMembers.composable.unit.ts index fa066e906b..cfe59bb320 100644 --- a/src/modules/data/room/roomMembers/roomMembers.composable.unit.ts +++ b/src/modules/data/room/roomMembers/roomMembers.composable.unit.ts @@ -16,7 +16,6 @@ import { RoleName, RoomMemberResponse, SchoolUserListResponse, - UserIdAndRoleRoleNameEnum, } from "@/serverApi/v3/api"; import { useBoardNotifier } from "@util-board"; import { schoolsModule, authModule } from "@/store"; @@ -278,12 +277,7 @@ describe("useRoomMembers", () => { expect(roomApiMock.roomControllerAddMembers).toHaveBeenCalledWith( roomId, { - userIdsAndRoles: [ - { - userId: firstPotentialMember.userId, - roleName: UserIdAndRoleRoleNameEnum.Roomeditor, - }, - ], + userIds: [firstPotentialMember.userId], } ); expect(roomMembers.value).toEqual([ diff --git a/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElement.unit.ts b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElement.unit.ts new file mode 100644 index 0000000000..991d498b12 --- /dev/null +++ b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElement.unit.ts @@ -0,0 +1,609 @@ +import { + AUTH_MODULE_KEY, + ENV_CONFIG_MODULE_KEY, + NOTIFIER_MODULE_KEY, + VIDEO_CONFERENCE_MODULE_KEY, +} from "@/utils/inject"; + +import { videoConferenceElementResponseFactory } from "@@/tests/test-utils/factory/videoConferenceElementResponseFactory"; +import { + useBoardFocusHandler, + useBoardPermissions, + useContentElementState, +} from "@data-board"; +import { createMock, DeepMocked } from "@golevelup/ts-jest"; +import { shallowMount } from "@vue/test-utils"; +import { computed, ref } from "vue"; +import NotifierModule from "@/store/notifier"; +import { createModuleMocks } from "@@/tests/test-utils/mock-store-module"; +import { + ConfigResponse, + VideoConferenceElementContent, + VideoConferenceScope, +} from "@/serverApi/v3/api"; +import VideoConferenceContentElementDisplay from "./VideoConferenceContentElementDisplay.vue"; +import VideoConferenceContentElementCreate from "./VideoConferenceContentElementCreate.vue"; +import { videoConferenceElementContentFactory } from "@@/tests/test-utils/factory/videoConferenceElementContentFactory"; +import { + createTestingI18n, + createTestingVuetify, +} from "@@/tests/test-utils/setup"; +import { + BoardMenu, + BoardMenuActionDelete, + BoardMenuActionMoveDown, + BoardMenuActionMoveUp, +} from "@ui-board"; +import { VideoConferenceContentElement } from "@feature-board-video-conference-element"; +import AuthModule from "@/store/auth"; +import VideoConferenceModule from "@/store/video-conference"; +import EnvConfigModule from "@/store/env-config"; +import { Router, useRoute, useRouter } from "vue-router"; +import { VideoConferenceState } from "@/store/types/video-conference"; +import { VDialog } from "vuetify/lib/components/index.mjs"; + +jest.mock("@data-board/ContentElementState.composable"); +jest.mock("@data-board/BoardFocusHandler.composable"); +jest.mock("@data-board/BoardPermissions.composable"); + +window.open = jest.fn(); + +jest.mock("vue-router"); +const useRouterMock = useRouter; +const useRouteMock = useRoute; +useRouteMock.mockReturnValue({ params: { id: "room-id" } }); + +const mockedUseContentElementState = jest.mocked(useContentElementState); + +let defaultElement = videoConferenceElementResponseFactory.build(); +const mockedEnvConfigModule = createModuleMocks(EnvConfigModule, { + getEnv: createMock({ + FEATURE_COLUMN_BOARD_VIDEOCONFERENCE_ENABLED: true, + }), +}); + +describe("VideoConferenceContentElement", () => { + let router: DeepMocked; + let route: DeepMocked>; + let useBoardFocusHandlerMock: DeepMocked< + ReturnType + >; + let useBoardPermissionsMock: DeepMocked< + ReturnType + >; + + beforeEach(() => { + route = createMock>(); + useRouteMock.mockReturnValue(route); + useRouteMock.mockReturnValue({ params: { id: "room-id" } }); + + router = createMock(); + useRouterMock.mockReturnValue(router); + + useBoardFocusHandlerMock = + createMock>(); + useBoardPermissionsMock = createMock< + ReturnType + >({ + isTeacher: true, + hasMovePermission: false, + hasCreateCardPermission: false, + hasCreateColumnPermission: false, + hasEditPermission: false, + hasDeletePermission: false, + isStudent: false, + }); + + jest.mocked(useBoardFocusHandler).mockReturnValue(useBoardFocusHandlerMock); + + jest.mocked(useBoardPermissions).mockReturnValue(useBoardPermissionsMock); + defaultElement = videoConferenceElementResponseFactory.build(); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); + + const setupWrapper = ( + options: { + content?: VideoConferenceElementContent; + isEditMode: boolean; + role?: "teacher" | "student"; + columnIndex?: number; + rowIndex?: number; + elementIndex?: number; + videoConferenceModuleGetter?: Partial; + } = { + content: undefined, + isEditMode: true, + role: "teacher", + columnIndex: 0, + rowIndex: 1, + elementIndex: 2, + } + ) => { + const { + content, + isEditMode, + role = "teacher", + columnIndex = 0, + rowIndex = 1, + elementIndex = 2, + videoConferenceModuleGetter, + } = options; + + const element = { + ...defaultElement, + content: videoConferenceElementContentFactory.build({ + title: undefined, + ...content, + }), + }; + + mockedUseContentElementState.mockReturnValue({ + modelValue: ref(element.content), + computedElement: computed(() => element), + isLoading: ref(false), + }); + + const notifierModule = createModuleMocks(NotifierModule); + const authModule = createModuleMocks(AuthModule, { + getUserRoles: [role], + }); + + const videoConferenceModule = createModuleMocks(VideoConferenceModule, { + getVideoConferenceInfo: { + state: VideoConferenceState.NOT_STARTED, + options: { + everyAttendeeJoinsMuted: false, + moderatorMustApproveJoinRequests: false, + everybodyJoinsAsModerator: false, + }, + }, + getLoading: false, + ...videoConferenceModuleGetter, + }); + + const joinVideoConferenceMock = jest + .fn() + .mockResolvedValueOnce({ url: "https://example.com" }); + videoConferenceModule.joinVideoConference = joinVideoConferenceMock; + + const wrapper = shallowMount(VideoConferenceContentElement, { + global: { + plugins: [createTestingVuetify(), createTestingI18n()], + provide: { + [NOTIFIER_MODULE_KEY.valueOf()]: notifierModule, + [ENV_CONFIG_MODULE_KEY.valueOf()]: mockedEnvConfigModule, + [AUTH_MODULE_KEY.valueOf()]: authModule, + [VIDEO_CONFERENCE_MODULE_KEY.valueOf()]: videoConferenceModule, + }, + }, + props: { + element, + isEditMode, + columnIndex, + rowIndex, + elementIndex, + }, + }); + + return { + element, + videoConferenceModule, + wrapper, + }; + }; + + describe("when video conference element is displayed", () => { + describe("and content title is undefined", () => { + it("should not render display of video conference content", () => { + const { wrapper } = setupWrapper({ + isEditMode: false, + }); + + const videoConferenceElementDisplay = wrapper.findComponent( + VideoConferenceContentElementDisplay + ); + + expect(videoConferenceElementDisplay.exists()).toBe(false); + }); + + it("should not render video conference element menu", () => { + const { wrapper } = setupWrapper({ + isEditMode: false, + }); + + const videoConferenceElementMenu = wrapper.findComponent(BoardMenu); + + expect(videoConferenceElementMenu.exists()).toBe(false); + }); + }); + + describe("and content title is defined", () => { + it("should render display of video conference content with correct props", () => { + const videoConferenceElementContent = + videoConferenceElementContentFactory.build({ title: "test-title" }); + const { wrapper, element } = setupWrapper({ + content: videoConferenceElementContent, + isEditMode: false, + }); + + const videoConferenceElementDisplay = wrapper.findComponent( + VideoConferenceContentElementDisplay + ); + + expect(videoConferenceElementDisplay.props().title).toEqual( + element.content.title + ); + expect(videoConferenceElementDisplay.props().isEditMode).toEqual(false); + expect(videoConferenceElementDisplay.props().canStart).toEqual(true); + expect( + videoConferenceElementDisplay.props().hasParticipationPermission + ).toEqual(true); + expect(videoConferenceElementDisplay.props().isRunning).toEqual(false); + }); + + it("should have the correct aria-label", () => { + const videoConferenceElementContent = + videoConferenceElementContentFactory.build(); + const { wrapper } = setupWrapper({ + content: videoConferenceElementContent, + isEditMode: false, + }); + + const videoConferenceElement = wrapper.findComponent( + '[data-testid="video-conference-element"]' + ); + + expect(videoConferenceElement.attributes("aria-label")).toEqual( + "components.cardElement.videoConferenceElement, common.ariaLabel.newTab" + ); + }); + + describe("and element is in edit mode", () => { + it.each(["up", "down"])( + "should 'emit move-keyboard:edit' when arrow key %s is pressed", + async (key) => { + const videoConferenceElementContent = + videoConferenceElementContentFactory.build(); + const { wrapper } = setupWrapper({ + content: videoConferenceElementContent, + isEditMode: true, + }); + + const videoConferenceElement = wrapper.findComponent( + '[data-testid="video-conference-element"]' + ); + + await videoConferenceElement.trigger(`keydown.${key}`); + + expect(wrapper.emitted()).toHaveProperty("move-keyboard:edit"); + } + ); + }); + + describe("and element is in view mode", () => { + it.each(["up", "down"])( + "should not 'emit move-keyboard:edit' when arrow key %s is pressed", + async (key) => { + const videoConferenceElementContent = + videoConferenceElementContentFactory.build(); + const { wrapper } = setupWrapper({ + content: videoConferenceElementContent, + isEditMode: false, + }); + + const videoConferenceElement = wrapper.findComponent( + '[data-testid="video-conference-element"]' + ); + + await videoConferenceElement.trigger(`keydown.${key}`); + + expect(wrapper.emitted()).not.toHaveProperty("move-keyboard:edit"); + } + ); + }); + + describe("video conference element menu", () => { + it("should render video conference element menu", () => { + const videoConferenceElementContent = + videoConferenceElementContentFactory.build(); + const { wrapper } = setupWrapper({ + content: videoConferenceElementContent, + isEditMode: true, + }); + + const videoConferenceElementMenu = wrapper.findComponent(BoardMenu); + + expect(videoConferenceElementMenu.exists()).toBe(true); + }); + + it("should emit 'move-down:edit' event when move down menu item is clicked", async () => { + const videoConferenceElementContent = + videoConferenceElementContentFactory.build(); + const { wrapper } = setupWrapper({ + content: videoConferenceElementContent, + isEditMode: true, + }); + + const menuItem = wrapper.findComponent(BoardMenuActionMoveDown); + await menuItem.trigger("click"); + + expect(wrapper.emitted()).toHaveProperty("move-down:edit"); + }); + + it("should emit 'move-up:edit' event when move up menu item is clicked", async () => { + const videoConferenceElementContent = + videoConferenceElementContentFactory.build(); + const { wrapper } = setupWrapper({ + content: videoConferenceElementContent, + isEditMode: true, + }); + + const menuItem = wrapper.findComponent(BoardMenuActionMoveUp); + await menuItem.trigger("click"); + + expect(wrapper.emitted()).toHaveProperty("move-up:edit"); + }); + + it("should emit 'delete:element' event when delete menu item is clicked", async () => { + const videoConferenceElementContent = + videoConferenceElementContentFactory.build(); + const { wrapper } = setupWrapper({ + content: videoConferenceElementContent, + isEditMode: true, + }); + + const menuItem = wrapper.findComponent(BoardMenuActionDelete); + await menuItem.trigger("click"); + + expect(wrapper.emitted()).toHaveProperty("delete:element"); + }); + }); + + describe("onElementClick", () => { + describe("and video conference is not running", () => { + it("should open the configuration dialog", async () => { + const { wrapper } = setupWrapper({ + content: videoConferenceElementContentFactory.build(), + isEditMode: false, + }); + + const videoConferenceElementDisplay = wrapper.findComponent( + VideoConferenceContentElementDisplay + ); + await videoConferenceElementDisplay.vm.$emit("click"); + + const configurationDialog = wrapper.findComponent( + '[data-testid="videoconference-config-dialog"]' + ); + + expect(configurationDialog.props("modelValue")).toBe(true); + }); + }); + + describe("and video conference is running", () => { + it("should call joinVideoConference", async () => { + const { element, videoConferenceModule, wrapper } = setupWrapper({ + content: videoConferenceElementContentFactory.build(), + isEditMode: false, + videoConferenceModuleGetter: { + getVideoConferenceInfo: { + state: VideoConferenceState.RUNNING, + options: { + everyAttendeeJoinsMuted: false, + moderatorMustApproveJoinRequests: false, + everybodyJoinsAsModerator: false, + }, + }, + getLoading: true, + }, + }); + + const videoConferenceElementDisplay = wrapper.findComponent( + VideoConferenceContentElementDisplay + ); + await videoConferenceElementDisplay.vm.$emit("click"); + + expect( + videoConferenceModule.joinVideoConference + ).toHaveBeenCalledWith({ + scope: VideoConferenceScope.VideoConferenceElement, + scopeId: element.id, + }); + }); + }); + }); + + describe("onRefresh", () => { + it("should call fetchVideoConferenceInfo", async () => { + const { element, videoConferenceModule, wrapper } = setupWrapper({ + content: videoConferenceElementContentFactory.build(), + isEditMode: false, + }); + + const videoConferenceElementDisplay = wrapper.findComponent( + VideoConferenceContentElementDisplay + ); + await videoConferenceElementDisplay.vm.$emit("refresh"); + + expect( + videoConferenceModule.fetchVideoConferenceInfo + ).toHaveBeenCalledWith({ + scope: VideoConferenceScope.VideoConferenceElement, + scopeId: element.id, + }); + }); + }); + }); + }); + + describe("when video conference element is being created", () => { + describe("and no title was entered", () => { + it("should hide video conference element in view mode", () => { + const { wrapper } = setupWrapper({ + isEditMode: false, + }); + + const videoConferenceElement = wrapper.findComponent( + '[data-testid="video-conference-element"]' + ); + + expect(videoConferenceElement.attributes("class")).toContain("d-none"); + }); + + it("should not render video conference element menu in view mode", () => { + const { wrapper } = setupWrapper({ + isEditMode: false, + }); + + const videoConferenceElementMenu = wrapper.findComponent(BoardMenu); + + expect(videoConferenceElementMenu.exists()).toBe(false); + }); + }); + + describe("and element is in edit mode", () => { + it("should render VideoConferenceContentElementCreate component", () => { + const { wrapper } = setupWrapper({ isEditMode: true }); + + const videoConferenceCreateComponent = wrapper.findComponent( + VideoConferenceContentElementCreate + ); + + expect(videoConferenceCreateComponent.exists()).toBe(true); + }); + + it.each(["up", "down"])( + "should not 'emit move-keyboard:edit' when arrow key %s is pressed", + async (key) => { + const { wrapper } = setupWrapper({ + isEditMode: true, + }); + + const videoConferenceElement = wrapper.findComponent( + '[data-testid="video-conference-element"]' + ); + + await videoConferenceElement.trigger(`keydown.${key}`); + + expect(wrapper.emitted()).not.toHaveProperty("move-keyboard:edit"); + } + ); + + describe("video conference element menu", () => { + it("should render video conference element menu", () => { + const { wrapper } = setupWrapper({ + isEditMode: true, + }); + + const videoConferenceElementMenu = wrapper.findComponent(BoardMenu); + + expect(videoConferenceElementMenu.exists()).toBe(true); + }); + + it("should emit 'move-down:edit' event when move down menu item is clicked", async () => { + const { wrapper } = setupWrapper({ + isEditMode: true, + }); + + const menuItem = wrapper.findComponent(BoardMenuActionMoveDown); + await menuItem.trigger("click"); + + expect(wrapper.emitted()).toHaveProperty("move-down:edit"); + }); + + it("should emit 'move-up:edit' event when move up menu item is clicked", async () => { + const { wrapper } = setupWrapper({ + isEditMode: true, + }); + + const menuItem = wrapper.findComponent(BoardMenuActionMoveUp); + await menuItem.trigger("click"); + + expect(wrapper.emitted()).toHaveProperty("move-up:edit"); + }); + + it("should emit 'delete:element' event when delete menu item is clicked", async () => { + const { wrapper } = setupWrapper({ + isEditMode: true, + }); + + const menuItem = wrapper.findComponent(BoardMenuActionDelete); + await menuItem.trigger("click"); + + expect(wrapper.emitted()).toHaveProperty("delete:element"); + }); + }); + }); + + describe("onCreateTitle", () => { + describe("and title was provided", () => { + it("should display the title ", async () => { + const videoConferenceTitle = "Very specific vc title"; + const { wrapper } = setupWrapper({ + content: videoConferenceElementContentFactory.build({ + title: videoConferenceTitle, + }), + isEditMode: false, + }); + + expect(wrapper.html()).toEqual( + expect.stringContaining(videoConferenceTitle) + ); + }); + }); + }); + }); + describe("when a videoconference is started or joined", () => { + describe("and an error occurs", () => { + it("should display an error dialog", async () => { + const error = jest.fn(() => { + throw new Error(); + }); + const { wrapper } = setupWrapper({ + content: videoConferenceElementContentFactory.build(), + isEditMode: false, + videoConferenceModuleGetter: { + getError: error, + }, + }); + + const videoConferenceElement = wrapper.findComponent( + '[data-testid="video-conference-element"]' + ); + await videoConferenceElement.trigger("click"); + + const dialog = wrapper.findComponent({ + ref: "vDialog", + }); + + expect(dialog.props("modelValue")).toBe(true); + }); + }); + + describe("and no error occurs", () => { + it("should not display an error dialog", async () => { + const { wrapper } = setupWrapper({ + content: videoConferenceElementContentFactory.build(), + isEditMode: false, + videoConferenceModuleGetter: { + getError: null, + }, + }); + + const videoConferenceElement = wrapper.findComponent( + '[data-testid="video-conference-element"]' + ); + await videoConferenceElement.trigger("click"); + + const dialog = wrapper.findComponent({ + ref: "vDialog", + }); + + expect(dialog.props("modelValue")).toBe(false); + }); + }); + }); +}); diff --git a/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElement.vue b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElement.vue new file mode 100644 index 0000000000..dcb52f0873 --- /dev/null +++ b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElement.vue @@ -0,0 +1,377 @@ + + + + + + + + + + + + + + + + + + + + + + {{ t("error.generic") }} + + + + + + {{ t("common.labels.close") }} + + + + + + + + + + + {{ t("pages.common.tools.configureVideoconferenceDialog.title") }} + + + + + + + + + + + {{ t("common.actions.cancel") }} + + + {{ t("common.actions.create") }} + + + + + + + + + diff --git a/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementCreate.unit.ts b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementCreate.unit.ts new file mode 100644 index 0000000000..2dab55985b --- /dev/null +++ b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementCreate.unit.ts @@ -0,0 +1,72 @@ +import { + createTestingI18n, + createTestingVuetify, +} from "@@/tests/test-utils/setup"; +import { mount } from "@vue/test-utils"; +import VideoConferenceContentElementCreate from "./VideoConferenceContentElementCreate.vue"; + +const setupWrapper = () => { + const wrapper = mount(VideoConferenceContentElementCreate, { + global: { + plugins: [createTestingVuetify(), createTestingI18n()], + }, + }); + + return wrapper; +}; + +const title = "video conference title"; + +describe("VideoConferenceContentElementCreate", () => { + afterEach(() => { + jest.resetAllMocks(); + }); + + describe("when a valid title is entered", () => { + describe("and enter is pressed", () => { + it("should not show error-message", async () => { + const wrapper = setupWrapper(); + + await wrapper.findComponent({ name: "VTextarea" }).setValue(title); + await wrapper.find("form").trigger("submit.prevent"); + + const alerts = wrapper.find('[role="alert"]'); + expect(alerts.text()).toBe(""); + }); + + it("should emit create:title event", async () => { + const wrapper = setupWrapper(); + + await wrapper.findComponent({ name: "VTextarea" }).setValue(title); + await wrapper + .findComponent({ name: "VTextarea" }) + .trigger("keydown.enter"); + + expect(wrapper.emitted("create:title")).toEqual([[title]]); + }); + }); + }); + + describe("when the title field is empty", () => { + describe("and the submit button is clicked", () => { + it("should show required-error-message", async () => { + const wrapper = setupWrapper(); + + await wrapper.findComponent({ name: "VTextarea" }).setValue(""); + await wrapper.find("form").trigger("submit.prevent"); + + const alerts = wrapper.find('[role="alert"]').text(); + expect(alerts).toEqual("common.validation.required2"); + }); + + it("should not emit create:title event", async () => { + const wrapper = setupWrapper(); + + await wrapper.findComponent({ name: "VTextarea" }).setValue(""); + await wrapper.find("form").trigger("submit.prevent"); + + expect(wrapper.emitted("create:title")).toBeUndefined(); + }); + }); + }); +}); diff --git a/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementCreate.vue b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementCreate.vue new file mode 100644 index 0000000000..21a0800882 --- /dev/null +++ b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementCreate.vue @@ -0,0 +1,85 @@ + + + + + + + + + + + {{ mdiCheck }} + {{ t("common.actions.save") }} + + + + + + + + + + + + + + + diff --git a/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementDisplay.unit.ts b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementDisplay.unit.ts new file mode 100644 index 0000000000..291efc4b1e --- /dev/null +++ b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementDisplay.unit.ts @@ -0,0 +1,248 @@ +import { mount, VueWrapper } from "@vue/test-utils"; +import { + createTestingI18n, + createTestingVuetify, +} from "@@/tests/test-utils/setup"; +import VideoConferenceContentElementDisplay from "./VideoConferenceContentElementDisplay.vue"; +import { BOARD_IS_LIST_LAYOUT } from "@util-board"; +import { ENV_CONFIG_MODULE_KEY } from "@/utils/inject"; +import { createModuleMocks } from "@@/tests/test-utils/mock-store-module"; +import { envConfigModule } from "@/store"; +import EnvConfigModule from "@/store/env-config"; +import { createMock } from "@golevelup/ts-jest"; +import { ConfigResponse } from "@/serverApi/v3"; +import setupStores from "@@/tests/test-utils/setupStores"; +import { envsFactory } from "@@/tests/test-utils"; + +const mockedEnvConfigModule = createModuleMocks(EnvConfigModule, { + getEnv: createMock({ + FEATURE_COLUMN_BOARD_VIDEOCONFERENCE_ENABLED: true, + }), +}); + +const setupWrapper = ({ + propsData = {}, + envOverrides = {}, +}: { + propsData?: object; + envOverrides?: Partial; +} = {}) => { + const envs = envsFactory.build({ + FEATURE_COLUMN_BOARD_VIDEOCONFERENCE_ENABLED: true, + ...envOverrides, + }); + envConfigModule.setEnvs(envs); + + const wrapper = mount(VideoConferenceContentElementDisplay, { + global: { + plugins: [createTestingVuetify(), createTestingI18n()], + provide: { + [BOARD_IS_LIST_LAYOUT as symbol]: false, + [ENV_CONFIG_MODULE_KEY.valueOf()]: mockedEnvConfigModule, + }, + }, + props: { + isEditMode: false, + isRunning: false, + hasParticipationPermission: false, + canStart: false, + title: "", + ...propsData, + }, + }); + + return wrapper; +}; + +describe("VideoConferenceContentElementDisplay", () => { + beforeEach(() => { + setupStores({ envConfigModule: EnvConfigModule }); + }); + + afterEach(() => { + jest.resetAllMocks(); + }); + + describe("Title", () => { + it("should display a title", () => { + const title = "video conference"; + const wrapper = setupWrapper({ + propsData: { + isEditMode: false, + isRunning: false, + hasParticipationPermission: true, + canStart: true, + title, + }, + }); + + const titleElement = wrapper.find( + '[data-testid="content-element-title-slot"]' + ); + expect(titleElement.text()).toEqual(title); + }); + }); + + describe("Alerts", () => { + describe("and the feature is disabled", () => { + it("should show 'not enabled for teacher' alert", () => { + const wrapper = setupWrapper({ + propsData: { + isRunning: false, + hasParticipationPermission: true, + canStart: true, + title: "video conference", + }, + envOverrides: { + FEATURE_COLUMN_BOARD_VIDEOCONFERENCE_ENABLED: false, + }, + }); + + const alert = wrapper.findComponent( + '[data-testid="vc-info-box-no-feature"]' + ); + const text = alert.find("span.my-auto"); + expect(text.text()).toEqual( + "pages.videoConference.info.notEnabledTeacher" + ); + }); + }); + + describe("and video conference is not running", () => { + it("should show 'not started' alert for a participant", () => { + const wrapper = setupWrapper({ + propsData: { + isRunning: false, + hasParticipationPermission: true, + canStart: false, + title: "video conference", + }, + }); + + const alert = wrapper.findComponent('[data-testid="vc-info-box"]'); + const text = alert.find("span.my-auto"); + expect(text.text()).toEqual("pages.videoConference.info.notStarted"); + }); + + it("should show 'no permission' alert for a user with no participation permission", () => { + const wrapper = setupWrapper({ + propsData: { + isRunning: false, + hasParticipationPermission: false, + canStart: false, + title: "video conference", + }, + }); + + const alert = wrapper.findComponent('[data-testid="vc-info-box"]'); + const text = alert.find("span.my-auto"); + expect(text.text()).toEqual("pages.videoConference.info.noPermission"); + }); + + it("should not display any alert when the user is a teacher", () => { + const wrapper = setupWrapper({ + propsData: { + isRunning: false, + hasParticipationPermission: true, + canStart: true, + title: "video conference", + }, + }); + + const alert = wrapper.find('[data-testid="vc-info-box-show"]'); + expect(alert.exists()).toEqual(false); + }); + }); + + describe("and video conference is running", () => { + it("should show 'no permission' alert when user has no participation permission", () => { + const wrapper = setupWrapper({ + propsData: { + isRunning: true, + hasParticipationPermission: false, + canStart: false, + title: "video conference", + }, + }); + + const alert = wrapper.findComponent( + '[data-testid="vc-info-box-no-permission"]' + ); + const text = alert.find("span.my-auto"); + expect(text.text()).toEqual("pages.videoConference.info.noPermission"); + }); + + it("should display a pulsating dot when the user has permission", () => { + const wrapper = setupWrapper({ + propsData: { + isRunning: true, + hasParticipationPermission: true, + canStart: true, + title: "video conference", + }, + }); + + const dot = wrapper.find('[data-testid="vc-pulsating-dot"]'); + expect(dot.exists()).toEqual(true); + }); + }); + }); + + describe("Events", () => { + const triggerClick = async (wrapper: VueWrapper) => { + const element = wrapper.find( + '[data-testid="board-video-conference-element"]' + ); + await element.trigger("click"); + }; + + describe("and video conference is running", () => { + it("should emit a click event when the user can join and the conference is running", async () => { + const wrapper = setupWrapper({ + propsData: { + isEditMode: false, + isRunning: true, + hasParticipationPermission: true, + canStart: false, + title: "video conference", + }, + }); + + await triggerClick(wrapper); + expect(wrapper.emitted("click")).toBeDefined(); + }); + }); + + describe("and video conference is not running", () => { + it("should emit a refresh event when the user can join", async () => { + const wrapper = setupWrapper({ + propsData: { + isEditMode: false, + isRunning: false, + hasParticipationPermission: true, + canStart: false, + title: "video conference", + }, + }); + + await triggerClick(wrapper); + expect(wrapper.emitted("refresh")).toBeDefined(); + }); + + it("should emit a click event when the user is a teacher", async () => { + const wrapper = setupWrapper({ + propsData: { + isEditMode: false, + isRunning: false, + hasParticipationPermission: true, + canStart: true, + title: "video conference", + }, + }); + + await triggerClick(wrapper); + expect(wrapper.emitted("click")).toBeDefined(); + }); + }); + }); +}); diff --git a/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementDisplay.vue b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementDisplay.vue new file mode 100644 index 0000000000..e863102603 --- /dev/null +++ b/src/modules/feature/board-video-conference-element/components/VideoConferenceContentElementDisplay.vue @@ -0,0 +1,213 @@ + + + + + + + + + {{ t("pages.videoConference.info.notEnabledTeacher") }} + + + + + + + + + {{ alertMessage }} + + + + + + + + + {{ noPermissionMessage }} + + + + + + + + {{ title }} + + + + + + + + + + + + + + diff --git a/src/modules/feature/board-video-conference-element/index.ts b/src/modules/feature/board-video-conference-element/index.ts new file mode 100644 index 0000000000..678738239b --- /dev/null +++ b/src/modules/feature/board-video-conference-element/index.ts @@ -0,0 +1,3 @@ +import VideoConferenceContentElement from "./components/VideoConferenceContentElement.vue"; + +export { VideoConferenceContentElement }; diff --git a/src/modules/feature/board/board/Board.unit.ts b/src/modules/feature/board/board/Board.unit.ts index b7339b7fef..03d68e7045 100644 --- a/src/modules/feature/board/board/Board.unit.ts +++ b/src/modules/feature/board/board/Board.unit.ts @@ -882,7 +882,7 @@ describe("Board", () => { expect(wrapperVM.isBoardVisible).toBe(false); expect(router.replace).toHaveBeenCalledWith({ - name: "rooms-id", + name: "room-details", params: { id: mockRoomId }, }); expect( diff --git a/src/modules/feature/board/board/Board.vue b/src/modules/feature/board/board/Board.vue index 4b7bac62ad..05d59f0475 100644 --- a/src/modules/feature/board/board/Board.vue +++ b/src/modules/feature/board/board/Board.vue @@ -322,7 +322,7 @@ watch( setAlert(); if (!(isBoardVisible.value || isTeacher)) { - router.replace({ name: "rooms-id", params: { id: roomId.value } }); + router.replace({ name: "room-details", params: { id: roomId.value } }); applicationErrorModule.setError( createApplicationError( HttpStatusCode.Forbidden, diff --git a/src/modules/feature/board/card/ContentElementList.unit.ts b/src/modules/feature/board/card/ContentElementList.unit.ts index c616528806..ba50b62e47 100644 --- a/src/modules/feature/board/card/ContentElementList.unit.ts +++ b/src/modules/feature/board/card/ContentElementList.unit.ts @@ -19,6 +19,7 @@ import { RichTextContentElement } from "@feature-board-text-element"; import { createMock } from "@golevelup/ts-jest"; import { shallowMount } from "@vue/test-utils"; import ContentElementList from "./ContentElementList.vue"; +import { VideoConferenceContentElement } from "@feature-board-video-conference-element"; describe("ContentElementList", () => { const setup = (props: { @@ -44,7 +45,7 @@ describe("ContentElementList", () => { [ENV_CONFIG_MODULE_KEY.valueOf()]: mockedEnvConfigModule, }, }, - props: { ...props }, + props: { ...props, rowIndex: 0, columnIndex: 0 }, }); return { wrapper }; @@ -93,6 +94,10 @@ describe("ContentElementList", () => { elementType: ContentElementType.Deleted, component: DeletedElement, }, + { + elementType: ContentElementType.VideoConference, + component: VideoConferenceContentElement, + }, ]; it.each(elementComponents)( diff --git a/src/modules/feature/board/card/ContentElementList.vue b/src/modules/feature/board/card/ContentElementList.vue index 940a4dc4ff..abbb4ab1ad 100644 --- a/src/modules/feature/board/card/ContentElementList.vue +++ b/src/modules/feature/board/card/ContentElementList.vue @@ -89,6 +89,19 @@ @move-up:edit="onMoveElementUp(index, element)" @delete:element="onDeleteElement" /> + { + return element.type === ContentElementType.VideoConference; +}; + +const showVideoConferenceElement = ( + element: AnyContentElement +): element is VideoConferenceElementResponse => { + return ( + envConfigModule.getEnv.FEATURE_COLUMN_BOARD_VIDEOCONFERENCE_ENABLED && + isVideoConferenceElementResponse(element) + ); +}; + const onMoveElementDown = ( elementIndex: number, element: AnyContentElement diff --git a/src/modules/feature/board/shared/AddElementDialog.composable.ts b/src/modules/feature/board/shared/AddElementDialog.composable.ts index 7fc101c201..41b07a8a7d 100644 --- a/src/modules/feature/board/shared/AddElementDialog.composable.ts +++ b/src/modules/feature/board/shared/AddElementDialog.composable.ts @@ -10,6 +10,7 @@ import { mdiPuzzleOutline, mdiTextBoxEditOutline, mdiTrayArrowUp, + mdiVideo, } from "@icons/material"; import { useBoardNotifier } from "@util-board"; import { useI18n } from "vue-i18n"; @@ -158,6 +159,17 @@ export const useAddElementDialog = ( }); } + if (envConfigModule.getEnv.FEATURE_COLUMN_BOARD_VIDEOCONFERENCE_ENABLED) { + options.push({ + icon: mdiVideo, + label: t( + "components.elementTypeSelection.elements.videoConferenceElement.subtitle" + ), + action: () => onElementClick(ContentElementType.VideoConference), + testId: "create-element-video-conference", + }); + } + const askType = () => { elementTypeOptions.value = options; isDialogOpen.value = true; diff --git a/src/modules/feature/board/shared/AddElementDialog.composable.unit.ts b/src/modules/feature/board/shared/AddElementDialog.composable.unit.ts index c98f39be04..8531c6486f 100644 --- a/src/modules/feature/board/shared/AddElementDialog.composable.unit.ts +++ b/src/modules/feature/board/shared/AddElementDialog.composable.unit.ts @@ -103,7 +103,10 @@ describe("ElementTypeSelection Composable", () => { await onElementClick(elementType); expect(addElementMock).toHaveBeenCalledTimes(1); - expect(addElementMock).toBeCalledWith({ type: elementType, cardId }); + expect(addElementMock).toHaveBeenCalledWith({ + type: elementType, + cardId, + }); expect(isDialogOpen.value).toBe(false); }); @@ -210,7 +213,7 @@ describe("ElementTypeSelection Composable", () => { await onElementClick(elementType); - expect(showCustomNotifierMock).toBeCalledTimes(0); + expect(showCustomNotifierMock).toHaveBeenCalledTimes(0); }); }); @@ -288,6 +291,7 @@ describe("ElementTypeSelection Composable", () => { FEATURE_TLDRAW_ENABLED: true, FEATURE_COLUMN_BOARD_COLLABORATIVE_TEXT_EDITOR_ENABLED: true, FEATURE_PREFERRED_CTL_TOOLS_ENABLED: true, + FEATURE_COLUMN_BOARD_VIDEOCONFERENCE_ENABLED: true, } ) => { const cardId = "cardId"; @@ -335,8 +339,8 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[0].action; action(); - expect(addElementMock).toBeCalledTimes(1); - expect(addElementMock).toBeCalledWith({ + expect(addElementMock).toHaveBeenCalledTimes(1); + expect(addElementMock).toHaveBeenCalledWith({ type: ContentElementType.RichText, cardId, }); @@ -351,7 +355,7 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[0].action; action(); - expect(closeDialogMock).toBeCalledTimes(1); + expect(closeDialogMock).toHaveBeenCalledTimes(1); }); }); @@ -365,8 +369,8 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[1].action; action(); - expect(addElementMock).toBeCalledTimes(1); - expect(addElementMock).toBeCalledWith({ + expect(addElementMock).toHaveBeenCalledTimes(1); + expect(addElementMock).toHaveBeenCalledWith({ type: ContentElementType.File, cardId, }); @@ -382,7 +386,7 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[1].action; action(); - expect(closeDialogMock).toBeCalledTimes(1); + expect(closeDialogMock).toHaveBeenCalledTimes(1); }); }); @@ -395,8 +399,8 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[2].action; action(); - expect(addElementMock).toBeCalledTimes(1); - expect(addElementMock).toBeCalledWith({ + expect(addElementMock).toHaveBeenCalledTimes(1); + expect(addElementMock).toHaveBeenCalledWith({ type: ContentElementType.SubmissionContainer, cardId, }); @@ -411,7 +415,7 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[2].action; action(); - expect(closeDialogMock).toBeCalledTimes(1); + expect(closeDialogMock).toHaveBeenCalledTimes(1); }); }); @@ -425,8 +429,8 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[3].action; action(); - expect(addElementMock).toBeCalledTimes(1); - expect(addElementMock).toBeCalledWith({ + expect(addElementMock).toHaveBeenCalledTimes(1); + expect(addElementMock).toHaveBeenCalledWith({ type: ContentElementType.ExternalTool, cardId, }); @@ -442,7 +446,7 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[3].action; action(); - expect(closeDialogMock).toBeCalledTimes(1); + expect(closeDialogMock).toHaveBeenCalledTimes(1); }); }); describe("when the DrawingElement action is called", () => { @@ -455,8 +459,8 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[4].action; action(); - expect(addElementMock).toBeCalledTimes(1); - expect(addElementMock).toBeCalledWith({ + expect(addElementMock).toHaveBeenCalledTimes(1); + expect(addElementMock).toHaveBeenCalledWith({ type: ContentElementType.Drawing, cardId, }); @@ -472,7 +476,7 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[4].action; action(); - expect(closeDialogMock).toBeCalledTimes(1); + expect(closeDialogMock).toHaveBeenCalledTimes(1); }); }); describe("when the CollaborativeTextEditorElement action is called", () => { @@ -485,8 +489,8 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[5].action; action(); - expect(addElementMock).toBeCalledTimes(1); - expect(addElementMock).toBeCalledWith({ + expect(addElementMock).toHaveBeenCalledTimes(1); + expect(addElementMock).toHaveBeenCalledWith({ type: ContentElementType.CollaborativeTextEditor, cardId, }); @@ -502,7 +506,38 @@ describe("ElementTypeSelection Composable", () => { const action = elementTypeOptions.value[5].action; action(); - expect(closeDialogMock).toBeCalledTimes(1); + expect(closeDialogMock).toHaveBeenCalledTimes(1); + }); + }); + describe("when the VideoConference action is called", () => { + it("should call video conference element function with right argument", async () => { + const { elementTypeOptions, addElementMock, cardId } = setup(); + const { askType } = useAddElementDialog(addElementMock, cardId); + + askType(); + + console.log(elementTypeOptions.value); + const action = elementTypeOptions.value[7].action; + action(); + + expect(addElementMock).toHaveBeenCalledTimes(1); + expect(addElementMock).toHaveBeenCalledWith({ + type: ContentElementType.VideoConference, + cardId, + }); + }); + + it("should set isDialogOpen to false", async () => { + const { elementTypeOptions, addElementMock, closeDialogMock, cardId } = + setup(); + const { askType } = useAddElementDialog(addElementMock, cardId); + + askType(); + + const action = elementTypeOptions.value[7].action; + action(); + + expect(closeDialogMock).toHaveBeenCalledTimes(1); }); }); }); diff --git a/src/modules/feature/board/shared/AddElementDialog.vue b/src/modules/feature/board/shared/AddElementDialog.vue index 186d9eb050..c42dc76d72 100644 --- a/src/modules/feature/board/shared/AddElementDialog.vue +++ b/src/modules/feature/board/shared/AddElementDialog.vue @@ -6,11 +6,9 @@ > - {{ $t("components.elementTypeSelection.dialog.title") }} + {{ t("components.elementTypeSelection.dialog.title") }} - + - {{ $t("common.labels.close") }} + {{ t("common.labels.close") }} @@ -37,10 +35,13 @@ import { ExtendedIconBtn } from "@ui-extended-icon-btn"; import { computed, ComputedRef } from "vue"; import { useSharedElementTypeSelection } from "./SharedElementTypeSelection.composable"; +import { useI18n } from "vue-i18n"; const { isDialogOpen, closeDialog, elementTypeOptions } = useSharedElementTypeSelection(); +const { t } = useI18n(); + const dialogWidth: ComputedRef = computed(() => elementTypeOptions.value.length >= 3 ? 426 : 320 ); diff --git a/src/modules/feature/room/BoardGrid.vue b/src/modules/feature/room/BoardGrid.vue index 0439c5bdc0..25f86243e3 100644 --- a/src/modules/feature/room/BoardGrid.vue +++ b/src/modules/feature/room/BoardGrid.vue @@ -4,6 +4,7 @@ v-for="(board, index) in boards" :key="board.id" cols="12" + sm="6" md="4" xl="3" > diff --git a/src/modules/feature/room/BoardTile.unit.ts b/src/modules/feature/room/BoardTile.unit.ts index 6229d21a97..3ae2b7eaef 100644 --- a/src/modules/feature/room/BoardTile.unit.ts +++ b/src/modules/feature/room/BoardTile.unit.ts @@ -42,7 +42,7 @@ describe("@feature-room/BoardTile", () => { it("should display tile in draft style", () => { const { wrapper } = setup({ board: mockBoard, index: 0 }); - expect(wrapper.classes()).toContain("board-is-draft"); + expect(wrapper.classes()).toContain("opacity-70"); }); }); }); diff --git a/src/modules/feature/room/BoardTile.vue b/src/modules/feature/room/BoardTile.vue index 2f643bd0f4..7e8659437c 100644 --- a/src/modules/feature/room/BoardTile.vue +++ b/src/modules/feature/room/BoardTile.vue @@ -1,23 +1,26 @@ {{ subtitleText }} - {{ board.title }} + + {{ board.title }} + @@ -28,6 +31,7 @@ import { RoomBoardItem } from "@/types/room/Room"; import { mdiViewAgendaOutline, mdiViewDashboardOutline } from "@icons/material"; import { computed, PropType, toRef } from "vue"; import { useI18n } from "vue-i18n"; +import { LineClamp } from "@ui-line-clamp"; const props = defineProps({ board: { type: Object as PropType, required: true }, @@ -35,7 +39,6 @@ const props = defineProps({ }); const { t } = useI18n(); - const board = toRef(props, "board"); const isListBoard = computed(() => { @@ -50,6 +53,7 @@ const subtitleIcon = computed(() => { const icon = isListBoard.value ? mdiViewAgendaOutline : mdiViewDashboardOutline; + return icon; }); @@ -62,6 +66,7 @@ const subtitleText = computed(() => { const suffix = ` - ${t("common.words.draft")}`; return text + suffix; } + return text; }); @@ -69,17 +74,3 @@ const boardPath = computed(() => { return `/boards/${board.value.id}`; }); - - diff --git a/src/modules/feature/room/RoomColorPicker/RoomColorPicker.unit.ts b/src/modules/feature/room/RoomColorPicker/RoomColorPicker.unit.ts index 68459cdc87..9bc9964f9b 100644 --- a/src/modules/feature/room/RoomColorPicker/RoomColorPicker.unit.ts +++ b/src/modules/feature/room/RoomColorPicker/RoomColorPicker.unit.ts @@ -5,7 +5,7 @@ import { import { mount } from "@vue/test-utils"; import { ComponentProps } from "vue-component-type-helpers"; import RoomColorPicker from "./RoomColorPicker.vue"; -import { RoomColor } from "@/serverApi/v3"; +import { RoomColorEnum } from "@/types/room/Room"; describe("@feature-room/RoomColorPicker", () => { const setup = (props?: ComponentProps) => { @@ -42,7 +42,7 @@ describe("@feature-room/RoomColorPicker", () => { describe("when a color is given", () => { it("should render given color as selected", () => { - const { wrapper } = setup({ color: RoomColor.Red }); + const { wrapper } = setup({ color: RoomColorEnum.Red }); const selectedColor = wrapper.findComponent( "[data-testid=color-swatch-red]" diff --git a/src/modules/feature/room/RoomColorPicker/RoomColorPicker.vue b/src/modules/feature/room/RoomColorPicker/RoomColorPicker.vue index bd8f65954e..b338f94c02 100644 --- a/src/modules/feature/room/RoomColorPicker/RoomColorPicker.vue +++ b/src/modules/feature/room/RoomColorPicker/RoomColorPicker.vue @@ -5,7 +5,7 @@ role="radiogroup" aria-labelledby="room-color-label" > - + , - default: RoomColor.BlueGrey, + type: String as PropType, + default: RoomColorEnum.BlueGrey, }, label: { type: String, @@ -36,11 +36,11 @@ const emit = defineEmits(["update:color"]); const currentColor = useVModel(props, "color", emit); -const isSelected = (color: RoomColor) => { +const isSelected = (color: RoomColorEnum) => { return color === currentColor.value; }; -const onUpdateColor = (color: RoomColor) => { +const onUpdateColor = (color: RoomColorEnum) => { emit("update:color", color); }; diff --git a/src/modules/feature/room/RoomColorPicker/RoomColorPickerSwatch.unit.ts b/src/modules/feature/room/RoomColorPicker/RoomColorPickerSwatch.unit.ts index e8628e22a1..6bef47a803 100644 --- a/src/modules/feature/room/RoomColorPicker/RoomColorPickerSwatch.unit.ts +++ b/src/modules/feature/room/RoomColorPicker/RoomColorPickerSwatch.unit.ts @@ -5,7 +5,7 @@ import { import { mount } from "@vue/test-utils"; import { ComponentProps } from "vue-component-type-helpers"; import RoomColorPickerSwatch from "./RoomColorPickerSwatch.vue"; -import { RoomColor } from "@/serverApi/v3"; +import { RoomColorEnum } from "@/types/room/Room"; describe("@feature-room/RoomColorPicker/RoomColorPickerSwatch", () => { const setup = (props?: ComponentProps) => { @@ -37,7 +37,7 @@ describe("@feature-room/RoomColorPicker/RoomColorPickerSwatch", () => { describe("when color is set", () => { it("should render with given color", () => { - const { wrapper } = setup({ color: RoomColor.Red, isSelected: true }); + const { wrapper } = setup({ color: RoomColorEnum.Red, isSelected: true }); const selectedColor = wrapper.findComponent( "[data-testid=color-swatch-red]" @@ -47,7 +47,7 @@ describe("@feature-room/RoomColorPicker/RoomColorPickerSwatch", () => { }); it("should render selected icon", () => { - const { wrapper } = setup({ color: RoomColor.Red, isSelected: true }); + const { wrapper } = setup({ color: RoomColorEnum.Red, isSelected: true }); const selectedColor = wrapper.findComponent( "[data-testid=color-swatch-red]" diff --git a/src/modules/feature/room/RoomColorPicker/RoomColorPickerSwatch.vue b/src/modules/feature/room/RoomColorPicker/RoomColorPickerSwatch.vue index 0a8040fc82..bc6d72cbd0 100644 --- a/src/modules/feature/room/RoomColorPicker/RoomColorPickerSwatch.vue +++ b/src/modules/feature/room/RoomColorPicker/RoomColorPickerSwatch.vue @@ -16,12 +16,12 @@ import { computed, PropType } from "vue"; import { mdiCheckCircleOutline } from "@icons/material"; import { useI18n } from "vue-i18n"; -import { RoomColor } from "@/serverApi/v3"; +import { RoomColorEnum } from "@/types/room/Room"; const props = defineProps({ color: { - type: String as PropType, - default: RoomColor.BlueGrey, + type: String as PropType, + default: RoomColorEnum.BlueGrey, }, isSelected: { type: Boolean, diff --git a/src/modules/feature/room/RoomDetails.unit.ts b/src/modules/feature/room/RoomDetails.unit.ts deleted file mode 100644 index 397dc62f95..0000000000 --- a/src/modules/feature/room/RoomDetails.unit.ts +++ /dev/null @@ -1,41 +0,0 @@ -import { - createTestingVuetify, - createTestingI18n, -} from "@@/tests/test-utils/setup"; -import { mount } from "@vue/test-utils"; -import { ComponentProps } from "vue-component-type-helpers"; -import RoomDetails from "./RoomDetails.vue"; -import { RoomDetails as RoomDetailsType } from "@/types/room/Room"; -import { RoomColor } from "@/serverApi/v3"; - -const mockRoom: RoomDetailsType = { - id: "59cce2c61113d1132c98dc06", - name: "A11Y for Beginners", - color: RoomColor.Magenta, - schoolId: "123", - startDate: "", - endDate: "", - permissions: [], - createdAt: "2017-09-28T11:49:39.924Z", - updatedAt: "2017-09-28T11:49:39.924Z", -}; - -describe("@feature-room/RoomDetails", () => { - const setup = (props: ComponentProps) => { - const wrapper = mount(RoomDetails, { - global: { - plugins: [createTestingVuetify(), createTestingI18n()], - }, - props, - }); - - return { wrapper }; - }; - - it("should render BoardGrid", async () => { - const { wrapper } = setup({ room: mockRoom }); - - const boardGrid = wrapper.findComponent({ name: "BoardGrid" }); - expect(boardGrid.exists()).toStrictEqual(true); - }); -}); diff --git a/src/modules/feature/room/RoomDetails.vue b/src/modules/feature/room/RoomDetails.vue deleted file mode 100644 index 943590ae5e..0000000000 --- a/src/modules/feature/room/RoomDetails.vue +++ /dev/null @@ -1,18 +0,0 @@ - - - - - - - diff --git a/src/modules/feature/room/RoomForm.unit.ts b/src/modules/feature/room/RoomForm.unit.ts index 7130e978af..1b680e6c84 100644 --- a/src/modules/feature/room/RoomForm.unit.ts +++ b/src/modules/feature/room/RoomForm.unit.ts @@ -5,19 +5,18 @@ import { import { flushPromises, mount } from "@vue/test-utils"; import { ComponentProps } from "vue-component-type-helpers"; import RoomForm from "./RoomForm.vue"; -import { RoomCreateParams } from "@/types/room/Room"; -import { RoomColor } from "@/serverApi/v3"; +import { RoomColorEnum, RoomCreateParams } from "@/types/room/Room"; const mockRoom: RoomCreateParams = { name: "A11Y for Beginners", - color: RoomColor.Magenta, + color: RoomColorEnum.Magenta, startDate: "", endDate: "", }; const emptyMockRoom: RoomCreateParams = { name: "", - color: RoomColor.Magenta, + color: RoomColorEnum.Magenta, startDate: undefined, endDate: undefined, }; diff --git a/src/modules/feature/room/RoomMenu.unit.ts b/src/modules/feature/room/RoomMenu.unit.ts new file mode 100644 index 0000000000..6d00358806 --- /dev/null +++ b/src/modules/feature/room/RoomMenu.unit.ts @@ -0,0 +1,167 @@ +import { + createTestingVuetify, + createTestingI18n, +} from "@@/tests/test-utils/setup"; +import { mount } from "@vue/test-utils"; +import RoomMenu from "./RoomMenu.vue"; +import { RouterLink } from "vue-router"; +import { ref } from "vue"; +import { useRoomAuthorization } from "./roomAuthorization.composable"; +import { createTestingPinia } from "@pinia/testing"; + +jest.mock("@feature-room/roomAuthorization.composable"); +const roomPermissions: ReturnType = { + canCreateRoom: ref(false), + canViewRoom: ref(false), + canEditRoom: ref(false), + canDeleteRoom: ref(false), +}; +(useRoomAuthorization as jest.Mock).mockReturnValue(roomPermissions); + +describe("@feature-room/RoomMenu", () => { + const setup = () => { + const wrapper = mount(RoomMenu, { + global: { + plugins: [ + createTestingVuetify(), + createTestingI18n(), + createTestingPinia(), + ], + stubs: { + RouterLink, + }, + }, + }); + + const menuBtn = wrapper.findComponent("[data-testid=room-menu]"); + + return { wrapper, menuBtn }; + }; + + describe("when user has no edit and delete permissions", () => { + it("should contain no menu items", async () => { + roomPermissions.canEditRoom.value = false; + roomPermissions.canDeleteRoom.value = false; + + const { wrapper, menuBtn } = setup(); + await menuBtn.trigger("click"); + + const menuItems = wrapper.findAllComponents({ name: "VListItem" }); + + expect(menuItems.length).toEqual(0); + }); + }); + + describe("when user only has edit permission", () => { + it("should contain edit and manage members menu items", async () => { + roomPermissions.canEditRoom.value = true; + roomPermissions.canDeleteRoom.value = false; + + const { wrapper, menuBtn } = setup(); + await menuBtn.trigger("click"); + + const menuItems = wrapper.findAllComponents({ name: "VListItem" }); + expect(menuItems.length).toEqual(2); + + const editMenuItem = wrapper.findComponent( + "[data-testid=room-action-edit]" + ); + const manageMembersMenuItem = wrapper.findComponent( + "[data-testid=room-action-manage-members]" + ); + const deleteMenuItem = wrapper.findComponent( + "[data-testid=room-action-delete]" + ); + + expect(editMenuItem.exists()).toBe(true); + expect(manageMembersMenuItem.exists()).toBe(true); + expect(deleteMenuItem.exists()).toBe(false); + }); + }); + + describe("when user only has delete permission", () => { + it("should only contain delete menu item", async () => { + roomPermissions.canEditRoom.value = false; + roomPermissions.canDeleteRoom.value = true; + const { wrapper, menuBtn } = setup(); + await menuBtn.trigger("click"); + + const menuItems = wrapper.findAllComponents({ name: "VListItem" }); + expect(menuItems.length).toEqual(1); + + const editMenuItem = wrapper.findComponent( + "[data-testid=room-action-edit]" + ); + const manageMembersMenuItem = wrapper.findComponent( + "[data-testid=room-action-manage-members]" + ); + const deleteMenuItem = wrapper.findComponent( + "[data-testid=room-action-delete]" + ); + + expect(editMenuItem.exists()).toBe(false); + expect(manageMembersMenuItem.exists()).toBe(false); + expect(deleteMenuItem.exists()).toBe(true); + }); + }); + + describe("when user has both edit and delete permissions", () => { + it("should show all menu items", async () => { + roomPermissions.canEditRoom.value = true; + roomPermissions.canDeleteRoom.value = true; + const { wrapper, menuBtn } = setup(); + await menuBtn.trigger("click"); + + const menuItems = wrapper.findAllComponents({ name: "VListItem" }); + + expect(menuItems.length).toEqual(3); + }); + }); + + describe("when clicking on menu button", () => { + roomPermissions.canEditRoom.value = true; + roomPermissions.canDeleteRoom.value = true; + + describe("and clicking on edit button", () => { + it("should emit 'room:edit' event", async () => { + const { wrapper, menuBtn } = setup(); + await menuBtn.trigger("click"); + + const editButton = wrapper.getComponent( + "[data-testid=room-action-edit]" + ); + await editButton.trigger("click"); + + expect(wrapper.emitted("room:edit")).toHaveLength(1); + }); + }); + + describe("and clicking on manage members button", () => { + it("should emit 'room:manage-members' event", async () => { + const { wrapper, menuBtn } = setup(); + await menuBtn.trigger("click"); + + const editButton = wrapper.getComponent( + "[data-testid=room-action-manage-members]" + ); + await editButton.trigger("click"); + + expect(wrapper.emitted("room:manage-members")).toHaveLength(1); + }); + }); + + describe("and clicking on delete button", () => { + it("should emit 'room:delete' event", async () => { + const { wrapper, menuBtn } = setup(); + await menuBtn.trigger("click"); + + const editButton = wrapper.getComponent( + "[data-testid=room-action-delete]" + ); + await editButton.trigger("click"); + + expect(wrapper.emitted("room:delete")).toHaveLength(1); + }); + }); + }); +}); diff --git a/src/modules/feature/room/RoomMenu.vue b/src/modules/feature/room/RoomMenu.vue new file mode 100644 index 0000000000..3844d7e351 --- /dev/null +++ b/src/modules/feature/room/RoomMenu.vue @@ -0,0 +1,67 @@ + + + $emit('room:edit')" + > + + + + + {{ $t("common.actions.edit") }} + + + $emit('room:manage-members')" + > + + + + + {{ $t("pages.rooms.members.manage") }} + + + $emit('room:delete')" + > + + + + + {{ $t("common.actions.delete") }} + + + + + + diff --git a/src/modules/feature/room/RoomTile.unit.ts b/src/modules/feature/room/RoomTile.unit.ts index 5089d73021..1988d052b3 100644 --- a/src/modules/feature/room/RoomTile.unit.ts +++ b/src/modules/feature/room/RoomTile.unit.ts @@ -5,13 +5,12 @@ import { import { mount } from "@vue/test-utils"; import { ComponentProps } from "vue-component-type-helpers"; import RoomTile from "./RoomTile.vue"; -import { RoomItem } from "@/types/room/Room"; -import { RoomColor } from "@/serverApi/v3"; +import { RoomItem, RoomColorEnum } from "@/types/room/Room"; const mockRoom: RoomItem = { id: "123", name: "A11Y for Beginners", - color: RoomColor.Magenta, + color: RoomColorEnum.Magenta, schoolId: "123", createdAt: "2024-10-11T16:36:06.434Z", updatedAt: "2024-10-11T16:36:06.434Z", diff --git a/src/modules/feature/room/RoomTile.vue b/src/modules/feature/room/RoomTile.vue index 0a406b2f22..b0985a59eb 100644 --- a/src/modules/feature/room/RoomTile.vue +++ b/src/modules/feature/room/RoomTile.vue @@ -17,9 +17,9 @@ diff --git a/src/modules/page/room/RoomDetailsSwitch.page.unit.ts b/src/modules/page/room/RoomDetailsSwitch.page.unit.ts new file mode 100644 index 0000000000..7d75d22c0c --- /dev/null +++ b/src/modules/page/room/RoomDetailsSwitch.page.unit.ts @@ -0,0 +1,162 @@ +import { ENV_CONFIG_MODULE_KEY } from "@/utils/inject"; +import EnvConfigModule from "@/store/env-config"; +import { envsFactory, mockedPiniaStoreTyping } from "@@/tests/test-utils"; +import { createModuleMocks } from "@@/tests/test-utils/mock-store-module"; +import { + createTestingI18n, + createTestingVuetify, +} from "@@/tests/test-utils/setup"; +import { RoomVariant, useRoomDetailsStore } from "@data-room"; +import { RoomDetailsSwitchPage } from "@page-room"; +import { createTestingPinia } from "@pinia/testing"; +import { ref } from "vue"; +import setupStores from "@@/tests/test-utils/setupStores"; +import { roomFactory } from "@@/tests/test-utils/factory/room/roomFactory"; +import { Router, useRoute, useRouter } from "vue-router"; +import { createMock } from "@golevelup/ts-jest"; +import { useRoomAuthorization } from "@feature-room"; + +jest.mock("vue-router", () => ({ + useRoute: jest.fn(), + useRouter: jest.fn(), +})); + +jest.mock("@feature-room/roomAuthorization.composable"); +const roomPermissions: ReturnType = { + canCreateRoom: ref(false), + canViewRoom: ref(false), + canEditRoom: ref(false), + canDeleteRoom: ref(false), +}; +(useRoomAuthorization as jest.Mock).mockReturnValue(roomPermissions); + +describe("@pages/RoomsDetailsSwitch.page.vue", () => { + const router = createMock(); + const useRouteMock = useRoute; + useRouteMock.mockReturnValue({ params: { id: "room-id" }, push: jest.fn() }); + const useRouterMock = useRouter; + + beforeEach(() => { + useRouterMock.mockReturnValue(router); + setupStores({ + envConfigModule: EnvConfigModule, + }); + }); + + const setup = ( + { + isLoading, + roomVariant, + }: { + isLoading: boolean; + roomVariant?: RoomVariant; + } = { isLoading: false, roomVariant: RoomVariant.ROOM } + ) => { + const envConfigModule = createModuleMocks(EnvConfigModule, { + getEnv: envsFactory.build({ + FEATURE_BOARD_LAYOUT_ENABLED: true, + FEATURE_ROOMS_ENABLED: true, + }), + }); + + const room = roomFactory.build(); + + const wrapper = mount(RoomDetailsSwitchPage, { + global: { + plugins: [ + createTestingVuetify(), + createTestingI18n(), + createTestingPinia({ + initialState: { + roomDetailsStore: { + isLoading, + room, + roomVariant, + roomBoards: [], + }, + }, + }), + ], + provide: { + [ENV_CONFIG_MODULE_KEY.valueOf()]: envConfigModule, + }, + stubs: { + CourseRoomDetailsPage: true, + "RoomDetails.page": true, + }, + }, + router, + }); + + const roomDetailsStore = mockedPiniaStoreTyping(useRoomDetailsStore); + + return { + wrapper, + roomDetailsStore, + }; + }; + + describe("when page is loading", () => { + it("should render loading state", async () => { + const { wrapper } = setup({ isLoading: true }); + const loadingState = wrapper.findComponent({ name: "VProgressCircular" }); + + expect(loadingState.exists()).toBe(true); + }); + + describe("and user has access to rooms", () => { + it("should fetch room", () => { + roomPermissions.canCreateRoom.value = true; + const { roomDetailsStore } = setup({ isLoading: true }); + + expect(roomDetailsStore.fetchRoom).toHaveBeenCalled(); + }); + }); + + describe("and user does not have access to rooms", () => { + it("should deactivate room", () => { + roomPermissions.canCreateRoom.value = false; + const { roomDetailsStore } = setup({ isLoading: true }); + + expect(roomDetailsStore.deactivateRoom).toHaveBeenCalled(); + }); + }); + }); + + describe("when page has loaded", () => { + it("should not render a loading indication", async () => { + const { wrapper } = setup({ isLoading: false }); + const loadingState = wrapper.findComponent({ name: "VProgressCircular" }); + + expect(loadingState.exists()).toBe(false); + }); + + describe("and room variant is ROOM", () => { + it("should render room details page", () => { + roomPermissions.canCreateRoom.value = true; + const { wrapper } = setup({ + isLoading: false, + roomVariant: RoomVariant.ROOM, + }); + + expect(wrapper.html()).toBe( + "" + ); + }); + }); + + describe("and room variant is COURSE_ROOM", () => { + it("should render course-room details page", () => { + roomPermissions.canCreateRoom.value = true; + const { wrapper } = setup({ + isLoading: false, + roomVariant: RoomVariant.COURSE_ROOM, + }); + + expect(wrapper.html()).toBe( + "" + ); + }); + }); + }); +}); diff --git a/src/modules/page/room/RoomDetailsSwitch.page.vue b/src/modules/page/room/RoomDetailsSwitch.page.vue new file mode 100644 index 0000000000..baec865be6 --- /dev/null +++ b/src/modules/page/room/RoomDetailsSwitch.page.vue @@ -0,0 +1,58 @@ + + + + + + + + + + + + + diff --git a/src/modules/page/room/RoomEdit.page.unit.ts b/src/modules/page/room/RoomEdit.page.unit.ts index 8ff11f927b..69e1b458a7 100644 --- a/src/modules/page/room/RoomEdit.page.unit.ts +++ b/src/modules/page/room/RoomEdit.page.unit.ts @@ -6,8 +6,7 @@ import { useRoomEditState } from "@data-room"; import { RoomEditPage } from "@page-room"; import { Breadcrumb } from "@/components/templates/default-wireframe.types"; import { useRoute, useRouter } from "vue-router"; -import { RoomUpdateParams } from "@/types/room/Room"; -import { RoomColor } from "@/serverApi/v3"; +import { RoomUpdateParams, RoomColorEnum } from "@/types/room/Room"; import { RoomForm } from "@feature-room"; import { nextTick } from "vue"; import { NOTIFIER_MODULE_KEY } from "@/utils/inject"; @@ -50,7 +49,7 @@ jest.mock("@/utils/pageTitle", () => ({ const roomParams: RoomUpdateParams = { name: "test", - color: RoomColor.Blue, + color: RoomColorEnum.Blue, }; describe("@pages/RoomEdit.page.vue", () => { @@ -111,13 +110,13 @@ describe("@pages/RoomEdit.page.vue", () => { expect(updateRoom).toHaveBeenCalledWith(roomIdMock, roomParams); }); - it("should navigate to 'rooms-id' with correct room id on save", async () => { + it("should navigate to 'room-details' with correct room id on save", async () => { const { roomFormComponent, router } = setup(); roomFormComponent.vm.$emit("save", roomParams); expect(router.push).toHaveBeenCalledWith({ - name: "rooms-id", + name: "room-details", params: { id: roomIdMock }, }); }); @@ -128,7 +127,7 @@ describe("@pages/RoomEdit.page.vue", () => { roomFormComponent.vm.$emit("cancel", roomParams); expect(router.push).toHaveBeenCalledWith({ - name: "rooms-id", + name: "room-details", params: { id: roomIdMock }, }); }); diff --git a/src/modules/page/room/RoomEdit.page.vue b/src/modules/page/room/RoomEdit.page.vue index ae1973bd61..899cc5eed1 100644 --- a/src/modules/page/room/RoomEdit.page.vue +++ b/src/modules/page/room/RoomEdit.page.vue @@ -56,7 +56,7 @@ const onSave = async (payload: { room: RoomUpdateParams }) => { await updateRoom(route.params.id as string, payload.room); router.push({ - name: "rooms-id", + name: "room-details", params: { id: route.params.id as string }, }); } catch (error: unknown) { @@ -78,7 +78,7 @@ const isInvalidRequestError = (error: unknown): boolean => { const onCancel = () => { router.push({ - name: "rooms-id", + name: "room-details", params: { id: route.params.id as string }, }); }; diff --git a/src/modules/page/room/RoomMembers.page.unit.ts b/src/modules/page/room/RoomMembers.page.unit.ts index fb6712e379..9c32138cd1 100644 --- a/src/modules/page/room/RoomMembers.page.unit.ts +++ b/src/modules/page/room/RoomMembers.page.unit.ts @@ -18,7 +18,7 @@ import setupStores from "@@/tests/test-utils/setupStores"; import { ref } from "vue"; import { RoleName, RoomDetailsResponse } from "@/serverApi/v3"; import vueDompurifyHTMLPlugin from "vue-dompurify-html"; -import { roomDetailsFactory } from "@@/tests/test-utils/factory/roomDetailsFactory"; +import { roomFactory } from "@@/tests/test-utils/factory/room"; import { VBtn, VDialog } from "vuetify/lib/components/index.mjs"; import { AddMembers, MembersTable } from "@feature-room"; import { mdiPlus } from "@icons/material"; @@ -55,7 +55,7 @@ describe("RoomMembersPage", () => { const buildRoom = () => { const roomMembersSchools = roomMemberSchoolResponseFactory.buildList(3); - const room = roomDetailsFactory.build(); + const room = roomFactory.build(); const potentialMembers = roomMemberListFactory.buildList(3); mockRoomMemberCalls.schools = ref(roomMembersSchools); diff --git a/src/modules/page/room/Rooms.page.unit.ts b/src/modules/page/room/Rooms.page.unit.ts index 17389bbb54..299bb1f453 100644 --- a/src/modules/page/room/Rooms.page.unit.ts +++ b/src/modules/page/room/Rooms.page.unit.ts @@ -158,7 +158,7 @@ describe("RoomsPage", () => { importFLow.vm.$emit("success", "newName", "newId"); expect(router.replace).toHaveBeenCalledWith({ - name: "rooms-id", + name: "room-details", params: { id: "newId" }, }); }); diff --git a/src/modules/page/room/Rooms.page.vue b/src/modules/page/room/Rooms.page.vue index 24506c687a..8795b917bf 100644 --- a/src/modules/page/room/Rooms.page.vue +++ b/src/modules/page/room/Rooms.page.vue @@ -68,7 +68,7 @@ onMounted(() => { const onImportSuccess = (newName: string, id: string) => { showImportSuccess(newName); - router.replace({ name: "rooms-id", params: { id } }); + router.replace({ name: "room-details", params: { id } }); }; const showImportSuccess = (newName: string) => { diff --git a/src/modules/page/room/index.ts b/src/modules/page/room/index.ts index 5e2dd79e26..a27b2009f8 100644 --- a/src/modules/page/room/index.ts +++ b/src/modules/page/room/index.ts @@ -2,6 +2,7 @@ import RoomsPage from "./Rooms.page.vue"; import RoomCreatePage from "./RoomCreate.page.vue"; import RoomEditPage from "./RoomEdit.page.vue"; import RoomDetailsPage from "./RoomDetails.page.vue"; +import RoomDetailsSwitchPage from "./RoomDetailsSwitch.page.vue"; import RoomMembersPage from "./RoomMembers.page.vue"; export { @@ -9,5 +10,6 @@ export { RoomCreatePage, RoomEditPage, RoomDetailsPage, + RoomDetailsSwitchPage, RoomMembersPage, }; diff --git a/src/modules/ui/board/BoardMenu.vue b/src/modules/ui/board/BoardMenu.vue index ac0bbafcc4..1b3af48de8 100644 --- a/src/modules/ui/board/BoardMenu.vue +++ b/src/modules/ui/board/BoardMenu.vue @@ -72,6 +72,8 @@ const ariaLabelForScope: Record = { [BoardMenuScope.DELETED_ELEMENT]: "components.board.menu.deletedElement", [BoardMenuScope.MEDIA_EXTERNAL_TOOL_ELEMENT]: "components.board.menu.mediaExternalToolElement", + [BoardMenuScope.VIDEO_CONFERENCE_ELEMENT]: + "components.board.menu.videoConferenceElement", }; const boardMenuAriaLabel = computed(() => { diff --git a/src/modules/ui/board/BoardMenuActionDelete.vue b/src/modules/ui/board/BoardMenuActionDelete.vue index bc92407518..242b708831 100644 --- a/src/modules/ui/board/BoardMenuActionDelete.vue +++ b/src/modules/ui/board/BoardMenuActionDelete.vue @@ -43,6 +43,8 @@ const languageKeyForScopeType: Record = { [BoardMenuScope.DELETED_ELEMENT]: "components.cardElement.deletedElement", [BoardMenuScope.MEDIA_EXTERNAL_TOOL_ELEMENT]: "components.cardElement.mediaExternalToolElement", + [BoardMenuScope.VIDEO_CONFERENCE_ELEMENT]: + "components.cardElement.videoConferenceElement", }; const onClick = (): void => { diff --git a/src/modules/ui/board/LineClamp.vue b/src/modules/ui/board/LineClamp.vue deleted file mode 100644 index 6eb968793a..0000000000 --- a/src/modules/ui/board/LineClamp.vue +++ /dev/null @@ -1,65 +0,0 @@ - - - - - - - - - - {{ tooltipText }} - - - - - - - - - - - diff --git a/src/modules/ui/board/board-menu-scope.ts b/src/modules/ui/board/board-menu-scope.ts index 22739f219b..dae8193365 100644 --- a/src/modules/ui/board/board-menu-scope.ts +++ b/src/modules/ui/board/board-menu-scope.ts @@ -10,4 +10,5 @@ export enum BoardMenuScope { SUBMISSION_ELEMENT = "submissionElement", DELETED_ELEMENT = "deletedElement", MEDIA_EXTERNAL_TOOL_ELEMENT = "mediaExternalToolElement", + VIDEO_CONFERENCE_ELEMENT = "videoConferenceElement", } diff --git a/src/modules/ui/board/content-element/ContentElementBar.vue b/src/modules/ui/board/content-element/ContentElementBar.vue index 186f59f259..d2a9c9e162 100644 --- a/src/modules/ui/board/content-element/ContentElementBar.vue +++ b/src/modules/ui/board/content-element/ContentElementBar.vue @@ -44,7 +44,10 @@ - + @@ -70,7 +73,7 @@ + + diff --git a/src/modules/ui/line-clamp/index.ts b/src/modules/ui/line-clamp/index.ts new file mode 100644 index 0000000000..ccd8bc30f8 --- /dev/null +++ b/src/modules/ui/line-clamp/index.ts @@ -0,0 +1,3 @@ +import LineClamp from "./LineClamp.vue"; + +export { LineClamp }; diff --git a/src/pages/course-rooms/CourseRoomOverview.page.vue b/src/pages/course-rooms/CourseRoomOverview.page.vue index 41c734e2d2..c4f5470028 100644 --- a/src/pages/course-rooms/CourseRoomOverview.page.vue +++ b/src/pages/course-rooms/CourseRoomOverview.page.vue @@ -388,7 +388,7 @@ export default defineComponent({ onImportSuccess(name, id) { this.showImportSuccess(name); if (id) { - this.$router.replace({ name: "rooms-id", params: { id } }); + this.$router.replace({ name: "room-details", params: { id } }); } else { this.$router.replace({ name: "course-room-overview" }); courseRoomListModule.fetch(); diff --git a/src/pages/course-rooms/tools/RoomVideoConferenceSection.unit.ts b/src/pages/course-rooms/tools/RoomVideoConferenceSection.unit.ts index 3508b32fe3..9eda6802bc 100644 --- a/src/pages/course-rooms/tools/RoomVideoConferenceSection.unit.ts +++ b/src/pages/course-rooms/tools/RoomVideoConferenceSection.unit.ts @@ -563,7 +563,7 @@ describe("RoomVideoConferenceSection", () => { const title = cardTitle.text(); expect(title).toContain( - 'pages.courseRooms.tools.configureVideoconferenceDialog.title {"roomName":"roomName"}' + "pages.common.tools.configureVideoconferenceDialog.title" ); }); }); diff --git a/src/pages/course-rooms/tools/RoomVideoConferenceSection.vue b/src/pages/course-rooms/tools/RoomVideoConferenceSection.vue index dad2fc8129..ea307c7e4c 100644 --- a/src/pages/course-rooms/tools/RoomVideoConferenceSection.vue +++ b/src/pages/course-rooms/tools/RoomVideoConferenceSection.vue @@ -35,14 +35,7 @@ class="text-h4 my-2" data-testId="videoconference-config-dialog-title" > - {{ - $t( - "pages.courseRooms.tools.configureVideoconferenceDialog.title", - { - roomName: roomName, - } - ) - }} + {{ $t("pages.common.tools.configureVideoconferenceDialog.title") }} @@ -50,9 +43,7 @@ v-model="videoConferenceOptions.everyAttendeeJoinsMuted" data-testId="every-attendee-joins-muted" :label=" - $t( - 'pages.courseRooms.tools.configureVideoconferenceDialog.text.mute' - ) + $t('pages.common.tools.configureVideoconferenceDialog.text.mute') " :hide-details="true" /> @@ -61,7 +52,7 @@ data-testId="moderator-must-approve-join-requests" :label=" $t( - 'pages.courseRooms.tools.configureVideoconferenceDialog.text.waitingRoom' + 'pages.common.tools.configureVideoconferenceDialog.text.waitingRoom' ) " :hide-details="true" @@ -71,7 +62,7 @@ data-testId="everybody-joins-as-moderator" :label=" $t( - 'pages.courseRooms.tools.configureVideoconferenceDialog.text.allModeratorPermission' + 'pages.common.tools.configureVideoconferenceDialog.text.allModeratorPermission' ) " :hide-details="true" @@ -131,6 +122,7 @@ import { import VCustomDialog from "@/components/organisms/vCustomDialog.vue"; import CourseRoomDetailsModule from "@/store/course-room-details"; import { mdiCheck } from "@icons/material"; +import { useDisplay } from "vuetify/lib/framework.mjs"; export default defineComponent({ name: "RoomVideoConferenceSection", @@ -150,9 +142,13 @@ export default defineComponent({ COURSE_ROOM_DETAILS_MODULE_KEY ); - const roomName = computed( - () => courseRoomDetailsModule.getRoomData.title ?? "" - ); + const { smAndUp } = useDisplay(); + const maxLengthTitle = smAndUp.value ? 40 : 25; + + const roomName = computed(() => { + const title = courseRoomDetailsModule.getRoomData.title ?? ""; + return title.slice(0, maxLengthTitle); + }); const videoConferenceInfo: ComputedRef = computed( () => videoConferenceModule.getVideoConferenceInfo diff --git a/src/router/routes.ts b/src/router/routes.ts index ce89422cf8..8bf54b687f 100644 --- a/src/router/routes.ts +++ b/src/router/routes.ts @@ -262,8 +262,8 @@ export const routes: Readonly[] = [ }, { path: `/rooms/:id(${REGEX_ID})`, - component: async () => (await import("@page-room")).RoomDetailsPage, - name: "rooms-id", + component: async () => (await import("@page-room")).RoomDetailsSwitchPage, + name: "room-details", }, { path: `/rooms/:id(${REGEX_ID})/edit`, diff --git a/src/serverApi/v3/api.ts b/src/serverApi/v3/api.ts index c5e9f4e80d..1e6ef9bd53 100644 --- a/src/serverApi/v3/api.ts +++ b/src/serverApi/v3/api.ts @@ -5,7 +5,7 @@ * This is v3 of Schulcloud-Verbund-Software Server. Checkout /docs for v1. * * The version of the OpenAPI document: 3.0 - * + * * * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech). * https://openapi-generator.tech @@ -22,7 +22,7 @@ import { DUMMY_BASE_URL, assertParamExists, setApiKeyToObject, setBasicAuthToObj import { BASE_PATH, COLLECTION_FORMATS, RequestArgs, BaseAPI, RequiredError } from './base'; /** - * + * * @export * @interface AccountByIdBodyParams */ @@ -47,44 +47,44 @@ export interface AccountByIdBodyParams { activated?: boolean | null; } /** - * + * * @export * @interface AccountResponse */ export interface AccountResponse { /** - * + * * @type {string} * @memberof AccountResponse */ id: string; /** - * + * * @type {string} * @memberof AccountResponse */ username: string; /** - * + * * @type {string} * @memberof AccountResponse */ userId: string; /** - * + * * @type {boolean} * @memberof AccountResponse */ activated: boolean; /** - * + * * @type {string} * @memberof AccountResponse */ updatedAt: string; } /** - * + * * @export * @interface AccountSearchListResponse */ @@ -115,33 +115,33 @@ export interface AccountSearchListResponse { limit: number; } /** - * + * * @export * @interface AddRoomMembersBodyParams */ export interface AddRoomMembersBodyParams { /** - * Array of userIds and their roles inside of the room - * @type {Array} + * The IDs of the users + * @type {Array} * @memberof AddRoomMembersBodyParams */ - userIdsAndRoles: Array; + userIds: Array; } /** - * + * * @export * @interface AlertResponse */ export interface AlertResponse { /** - * + * * @type {Array} * @memberof AlertResponse */ data: Array; } /** - * + * * @export * @interface ApiValidationError */ @@ -178,13 +178,13 @@ export interface ApiValidationError { details?: object; } /** - * + * * @export * @interface AuthorizationBodyParams */ export interface AuthorizationBodyParams { /** - * + * * @type {AuthorizationContextParams} * @memberof AuthorizationBodyParams */ @@ -224,7 +224,7 @@ export enum AuthorizationBodyParamsReferenceTypeEnum { } /** - * + * * @export * @interface AuthorizationContextParams */ @@ -428,113 +428,113 @@ export enum AuthorizationContextParamsRequiredPermissionsEnum { } /** - * + * * @export * @interface AuthorizedReponse */ export interface AuthorizedReponse { /** - * + * * @type {string} * @memberof AuthorizedReponse */ userId: string; /** - * + * * @type {boolean} * @memberof AuthorizedReponse */ isAuthorized: boolean; } /** - * + * * @export * @interface BasicToolConfigParams */ export interface BasicToolConfigParams { /** - * + * * @type {string} * @memberof BasicToolConfigParams */ type: string; /** - * + * * @type {string} * @memberof BasicToolConfigParams */ baseUrl: string; } /** - * + * * @export * @interface BoardColumnBoardResponse */ export interface BoardColumnBoardResponse { /** - * + * * @type {string} * @memberof BoardColumnBoardResponse */ id: string; /** - * + * * @type {string} * @memberof BoardColumnBoardResponse */ title: string; /** - * + * * @type {boolean} * @memberof BoardColumnBoardResponse */ published: boolean; /** - * + * * @type {string} * @memberof BoardColumnBoardResponse */ createdAt: string; /** - * + * * @type {string} * @memberof BoardColumnBoardResponse */ updatedAt: string; /** - * + * * @type {string} * @memberof BoardColumnBoardResponse */ columnBoardId: string; /** - * + * * @type {BoardLayout} * @memberof BoardColumnBoardResponse */ layout: BoardLayout; } /** - * + * * @export * @interface BoardContextResponse */ export interface BoardContextResponse { /** - * + * * @type {string} * @memberof BoardContextResponse */ id: string; /** - * + * * @type {BoardExternalReferenceType} * @memberof BoardContextResponse */ type: BoardExternalReferenceType; } /** - * + * * @export * @interface BoardElementResponse */ @@ -564,7 +564,7 @@ export enum BoardElementResponseTypeEnum { } /** - * + * * @export * @enum {string} */ @@ -575,7 +575,7 @@ export enum BoardExternalReferenceType { } /** - * + * * @export * @enum {string} */ @@ -586,68 +586,68 @@ export enum BoardLayout { } /** - * + * * @export * @interface BoardLessonResponse */ export interface BoardLessonResponse { /** - * + * * @type {string} * @memberof BoardLessonResponse */ id: string; /** - * + * * @type {string} * @memberof BoardLessonResponse */ name: string; /** - * + * * @type {string} * @memberof BoardLessonResponse */ courseName?: string; /** - * + * * @type {number} * @memberof BoardLessonResponse */ numberOfPublishedTasks: number; /** - * + * * @type {number} * @memberof BoardLessonResponse */ numberOfDraftTasks: number; /** - * + * * @type {number} * @memberof BoardLessonResponse */ numberOfPlannedTasks: number; /** - * + * * @type {string} * @memberof BoardLessonResponse */ createdAt: string; /** - * + * * @type {string} * @memberof BoardLessonResponse */ updatedAt: string; /** - * + * * @type {boolean} * @memberof BoardLessonResponse */ hidden: boolean; } /** - * + * * @export * @enum {string} */ @@ -658,222 +658,222 @@ export enum BoardParentType { } /** - * + * * @export * @interface BoardResponse */ export interface BoardResponse { /** - * + * * @type {string} * @memberof BoardResponse */ id: string; /** - * + * * @type {string} * @memberof BoardResponse */ title: string; /** - * + * * @type {Array} * @memberof BoardResponse */ columns: Array; /** - * + * * @type {TimestampsResponse} * @memberof BoardResponse */ timestamps: TimestampsResponse; /** - * + * * @type {boolean} * @memberof BoardResponse */ isVisible: boolean; /** - * + * * @type {string} * @memberof BoardResponse */ layout: string; } /** - * + * * @export * @interface BoardTaskResponse */ export interface BoardTaskResponse { /** - * + * * @type {string} * @memberof BoardTaskResponse */ id: string; /** - * + * * @type {string} * @memberof BoardTaskResponse */ name: string; /** - * + * * @type {string} * @memberof BoardTaskResponse */ availableDate?: string; /** - * + * * @type {string} * @memberof BoardTaskResponse */ dueDate?: string; /** - * + * * @type {string} * @memberof BoardTaskResponse */ courseName?: string; /** - * + * * @type {string} * @memberof BoardTaskResponse */ description?: string; /** - * + * * @type {string} * @memberof BoardTaskResponse */ displayColor?: string; /** - * + * * @type {string} * @memberof BoardTaskResponse */ createdAt: string; /** - * + * * @type {string} * @memberof BoardTaskResponse */ updatedAt: string; /** - * + * * @type {BoardTaskStatusResponse} * @memberof BoardTaskResponse */ status: BoardTaskStatusResponse; } /** - * + * * @export * @interface BoardTaskStatusResponse */ export interface BoardTaskStatusResponse { /** - * + * * @type {number} * @memberof BoardTaskStatusResponse */ submitted: number; /** - * + * * @type {number} * @memberof BoardTaskStatusResponse */ maxSubmissions: number; /** - * + * * @type {number} * @memberof BoardTaskStatusResponse */ graded: number; /** - * + * * @type {boolean} * @memberof BoardTaskStatusResponse */ isDraft: boolean; /** - * + * * @type {boolean} * @memberof BoardTaskStatusResponse */ isSubstitutionTeacher: boolean; /** - * + * * @type {boolean} * @memberof BoardTaskStatusResponse */ isFinished: boolean; } /** - * + * * @export * @interface CardListResponse */ export interface CardListResponse { /** - * + * * @type {Array} * @memberof CardListResponse */ data: Array; } /** - * + * * @export * @interface CardResponse */ export interface CardResponse { /** - * + * * @type {string} * @memberof CardResponse */ id: string; /** - * + * * @type {string} * @memberof CardResponse */ title?: string; /** - * + * * @type {number} * @memberof CardResponse */ height: number; /** - * - * @type {Array} + * + * @type {Array} * @memberof CardResponse */ - elements: Array; + elements: Array; /** - * + * * @type {VisibilitySettingsResponse} * @memberof CardResponse */ visibilitySettings: VisibilitySettingsResponse; /** - * + * * @type {TimestampsResponse} * @memberof CardResponse */ timestamps: TimestampsResponse; } /** - * + * * @export * @interface CardSkeletonResponse */ export interface CardSkeletonResponse { /** - * + * * @type {string} * @memberof CardSkeletonResponse */ @@ -886,74 +886,74 @@ export interface CardSkeletonResponse { height: number; } /** - * + * * @export * @interface ChangeLanguageParams */ export interface ChangeLanguageParams { /** - * + * * @type {LanguageType} * @memberof ChangeLanguageParams */ language: LanguageType; } /** - * + * * @export * @interface ClassInfoResponse */ export interface ClassInfoResponse { /** - * + * * @type {string} * @memberof ClassInfoResponse */ id: string; /** - * + * * @type {string} * @memberof ClassInfoResponse */ type: ClassInfoResponseTypeEnum; /** - * + * * @type {string} * @memberof ClassInfoResponse */ name: string; /** - * + * * @type {string} * @memberof ClassInfoResponse */ externalSourceName?: string; /** - * + * * @type {Array} * @memberof ClassInfoResponse */ teacherNames: Array; /** - * + * * @type {string} * @memberof ClassInfoResponse */ schoolYear?: string; /** - * + * * @type {boolean} * @memberof ClassInfoResponse */ isUpgradable?: boolean; /** - * + * * @type {number} * @memberof ClassInfoResponse */ studentCount: number; /** - * + * * @type {Array} * @memberof ClassInfoResponse */ @@ -970,7 +970,7 @@ export enum ClassInfoResponseTypeEnum { } /** - * + * * @export * @interface ClassInfoSearchListResponse */ @@ -1001,7 +1001,7 @@ export interface ClassInfoSearchListResponse { limit: number; } /** - * + * * @export * @enum {string} */ @@ -1011,26 +1011,26 @@ export enum ClassRequestContext { } /** - * + * * @export * @interface ClassResponse */ export interface ClassResponse { /** - * + * * @type {string} * @memberof ClassResponse */ name: string; /** - * + * * @type {number} * @memberof ClassResponse */ gradeLevel: number; } /** - * + * * @export * @enum {string} */ @@ -1043,38 +1043,38 @@ export enum ClassSortQueryType { } /** - * + * * @export * @interface CollaborativeTextEditorElementResponse */ export interface CollaborativeTextEditorElementResponse { /** - * + * * @type {string} * @memberof CollaborativeTextEditorElementResponse */ id: string; /** - * + * * @type {ContentElementType} * @memberof CollaborativeTextEditorElementResponse */ type: ContentElementType; /** - * + * * @type {TimestampsResponse} * @memberof CollaborativeTextEditorElementResponse */ timestamps: TimestampsResponse; /** - * + * * @type {object} * @memberof CollaborativeTextEditorElementResponse */ content: object; } /** - * + * * @export * @enum {string} */ @@ -1083,498 +1083,504 @@ export enum CollaborativeTextEditorParentType { } /** - * + * * @export * @interface CollaborativeTextEditorResponse */ export interface CollaborativeTextEditorResponse { /** - * + * * @type {string} * @memberof CollaborativeTextEditorResponse */ url: string; } /** - * + * * @export * @interface CollapsableBodyParams */ export interface CollapsableBodyParams { /** - * + * * @type {boolean} * @memberof CollapsableBodyParams */ collapsed: boolean; } /** - * + * * @export * @interface ColorBodyParams */ export interface ColorBodyParams { /** - * + * * @type {MediaBoardColors} * @memberof ColorBodyParams */ backgroundColor: MediaBoardColors; } /** - * + * * @export * @interface ColumnResponse */ export interface ColumnResponse { /** - * + * * @type {string} * @memberof ColumnResponse */ id: string; /** - * + * * @type {string} * @memberof ColumnResponse */ title: string; /** - * + * * @type {Array} * @memberof ColumnResponse */ cards: Array; /** - * + * * @type {TimestampsResponse} * @memberof ColumnResponse */ timestamps: TimestampsResponse; } /** - * + * * @export * @interface ConfigResponse */ export interface ConfigResponse { /** - * + * * @type {string} * @memberof ConfigResponse */ ACCESSIBILITY_REPORT_EMAIL: string; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_NEW_SCHOOL_ADMINISTRATION_PAGE_AS_DEFAULT_ENABLED: boolean; /** - * + * * @type {number} * @memberof ConfigResponse */ MIGRATION_END_GRACE_PERIOD_MS: number; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_CTL_TOOLS_TAB_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_LTI_TOOLS_TAB_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_SHOW_OUTDATED_USERS: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_ENABLE_LDAP_SYNC_DURING_MIGRATION: boolean; /** - * + * * @type {number} * @memberof ConfigResponse */ CTL_TOOLS_RELOAD_TIME_MS: number; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_SHOW_NEW_CLASS_VIEW_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_SHOW_NEW_ROOMS_VIEW_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_CTL_TOOLS_COPY_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_PREFERRED_CTL_TOOLS_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_SHOW_MIGRATION_WIZARD: boolean; /** - * + * * @type {string} * @memberof ConfigResponse */ MIGRATION_WIZARD_DOCUMENTATION_LINK?: string; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_TLDRAW_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ ADMIN_TABLES_DISPLAY_CONSENT_COLUMN: boolean; /** - * + * * @type {string} * @memberof ConfigResponse */ ALERT_STATUS_URL: string | null; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_ES_COLLECTIONS_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_EXTENSIONS_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_TEAMS_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_LERNSTORE_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_ADMIN_TOGGLE_STUDENT_LERNSTORE_VIEW_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ TEACHER_STUDENT_VISIBILITY__IS_CONFIGURABLE: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ TEACHER_STUDENT_VISIBILITY__IS_ENABLED_BY_DEFAULT: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ TEACHER_STUDENT_VISIBILITY__IS_VISIBLE: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_SCHOOL_POLICY_ENABLED_NEW: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_SCHOOL_TERMS_OF_USE_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_NEXBOARD_COPY_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_VIDEOCONFERENCE_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_COLUMN_BOARD_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_COLUMN_BOARD_SUBMISSIONS_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_COLUMN_BOARD_COLLABORATIVE_TEXT_EDITOR_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_COLUMN_BOARD_LINK_ELEMENT_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_COLUMN_BOARD_EXTERNAL_TOOLS_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_COLUMN_BOARD_SHARE: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_COLUMN_BOARD_SOCKET_ENABLED: boolean; /** - * + * + * @type {boolean} + * @memberof ConfigResponse + */ + FEATURE_COLUMN_BOARD_VIDEOCONFERENCE_ENABLED: boolean; + /** + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_COURSE_SHARE: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_LOGIN_LINK_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_LESSON_SHARE: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_TASK_SHARE: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_BOARD_LAYOUT_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_USER_MIGRATION_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ CALENDAR_SERVICE_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_COPY_SERVICE_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_CONSENT_NECESSARY: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_COMMON_CARTRIDGE_COURSE_EXPORT_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_COMMON_CARTRIDGE_COURSE_IMPORT_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_SCHOOL_SANIS_USER_MIGRATION_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_SCHULCONNEX_COURSE_SYNC_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_ALLOW_INSECURE_LDAP_URL_ENABLED: boolean; /** - * + * * @type {string} * @memberof ConfigResponse */ GHOST_BASE_URL: string; /** - * + * * @type {boolean} * @memberof ConfigResponse */ ROCKETCHAT_SERVICE_ENABLED: boolean; /** - * + * * @type {Array} * @memberof ConfigResponse */ I18N__AVAILABLE_LANGUAGES: Array; /** - * + * * @type {LanguageType} * @memberof ConfigResponse */ I18N__DEFAULT_LANGUAGE: LanguageType; /** - * + * * @type {LanguageType} * @memberof ConfigResponse */ I18N__FALLBACK_LANGUAGE: LanguageType; /** - * + * * @type {Timezone} * @memberof ConfigResponse */ I18N__DEFAULT_TIMEZONE: Timezone; /** - * + * * @type {number} * @memberof ConfigResponse */ JWT_SHOW_TIMEOUT_WARNING_SECONDS: number; /** - * + * * @type {number} * @memberof ConfigResponse */ JWT_TIMEOUT_SECONDS: number; /** - * + * * @type {string} * @memberof ConfigResponse */ NOT_AUTHENTICATED_REDIRECT_URL: string; /** - * + * * @type {string} * @memberof ConfigResponse */ DOCUMENT_BASE_DIR: string; /** - * + * * @type {SchulcloudTheme} * @memberof ConfigResponse */ SC_THEME: SchulcloudTheme; /** - * + * * @type {string} * @memberof ConfigResponse */ SC_TITLE: string; /** - * + * * @type {string} * @memberof ConfigResponse */ TRAINING_URL: string; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_MEDIA_SHELF_ENABLED: boolean; /** - * + * * @type {string} * @memberof ConfigResponse */ BOARD_COLLABORATION_URI: string; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_SCHULCONNEX_MEDIA_LICENSE_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_AI_TUTOR_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_ROOMS_ENABLED: boolean; /** - * + * * @type {boolean} * @memberof ConfigResponse */ FEATURE_EXTERNAL_SYSTEM_LOGOUT_ENABLED: boolean; } /** - * + * * @export * @interface ConsentRequestBody */ @@ -1629,7 +1635,7 @@ export interface ConsentRequestBody { remember_for?: number; } /** - * + * * @export * @interface ConsentResponse */ @@ -1641,7 +1647,7 @@ export interface ConsentResponse { */ acr: string; /** - * + * * @type {Array} * @memberof ConsentResponse */ @@ -1653,13 +1659,13 @@ export interface ConsentResponse { */ challenge: string; /** - * + * * @type {OauthClientResponse} * @memberof ConsentResponse */ client: OauthClientResponse; /** - * + * * @type {object} * @memberof ConsentResponse */ @@ -1677,7 +1683,7 @@ export interface ConsentResponse { */ login_session_id: string; /** - * + * * @type {OidcContextResponse} * @memberof ConsentResponse */ @@ -1689,7 +1695,7 @@ export interface ConsentResponse { */ request_url: string; /** - * + * * @type {Array} * @memberof ConsentResponse */ @@ -1714,7 +1720,7 @@ export interface ConsentResponse { subject: string; } /** - * + * * @export * @interface ConsentSessionResponse */ @@ -1739,26 +1745,26 @@ export interface ConsentSessionResponse { challenge: string; } /** - * + * * @export * @interface ConsentsResponse */ export interface ConsentsResponse { /** - * + * * @type {UserConsentResponse} * @memberof ConsentsResponse */ userConsent: UserConsentResponse; /** - * + * * @type {Array} * @memberof ConsentsResponse */ parentConsents: Array; } /** - * + * * @export * @enum {string} */ @@ -1770,30 +1776,31 @@ export enum ContentElementType { SubmissionContainer = 'submissionContainer', ExternalTool = 'externalTool', CollaborativeTextEditor = 'collaborativeTextEditor', + VideoConference = 'videoConference', Deleted = 'deleted' } /** - * + * * @export * @interface ContextExternalToolBodyParams */ export interface ContextExternalToolBodyParams { /** - * + * * @type {string} * @memberof ContextExternalToolBodyParams */ contextId: string; /** - * + * * @type {ToolContextType} * @memberof ContextExternalToolBodyParams */ contextType: ToolContextType; } /** - * + * * @export * @interface ContextExternalToolConfigurationStatusResponse */ @@ -1836,161 +1843,161 @@ export interface ContextExternalToolConfigurationStatusResponse { isNotLicensed: boolean; } /** - * + * * @export * @interface ContextExternalToolConfigurationTemplateListResponse */ export interface ContextExternalToolConfigurationTemplateListResponse { /** - * + * * @type {Array} * @memberof ContextExternalToolConfigurationTemplateListResponse */ data: Array; } /** - * + * * @export * @interface ContextExternalToolConfigurationTemplateResponse */ export interface ContextExternalToolConfigurationTemplateResponse { /** - * + * * @type {string} * @memberof ContextExternalToolConfigurationTemplateResponse */ externalToolId: string; /** - * + * * @type {string} * @memberof ContextExternalToolConfigurationTemplateResponse */ schoolExternalToolId: string; /** - * + * * @type {string} * @memberof ContextExternalToolConfigurationTemplateResponse */ name: string; /** - * + * * @type {string} * @memberof ContextExternalToolConfigurationTemplateResponse */ baseUrl: string; /** - * + * * @type {string} * @memberof ContextExternalToolConfigurationTemplateResponse */ logoUrl?: string; /** - * + * * @type {Array} * @memberof ContextExternalToolConfigurationTemplateResponse */ parameters: Array; } /** - * + * * @export * @interface ContextExternalToolCountPerContextResponse */ export interface ContextExternalToolCountPerContextResponse { /** - * + * * @type {number} * @memberof ContextExternalToolCountPerContextResponse */ course: number; /** - * + * * @type {number} * @memberof ContextExternalToolCountPerContextResponse */ boardElement: number; /** - * + * * @type {number} * @memberof ContextExternalToolCountPerContextResponse */ mediaBoard: number; } /** - * + * * @export * @interface ContextExternalToolPostParams */ export interface ContextExternalToolPostParams { /** - * + * * @type {string} * @memberof ContextExternalToolPostParams */ schoolToolId: string; /** - * + * * @type {string} * @memberof ContextExternalToolPostParams */ contextId: string; /** - * + * * @type {string} * @memberof ContextExternalToolPostParams */ contextType: string; /** - * + * * @type {string} * @memberof ContextExternalToolPostParams */ displayName?: string; /** - * + * * @type {Array} * @memberof ContextExternalToolPostParams */ parameters?: Array; } /** - * + * * @export * @interface ContextExternalToolResponse */ export interface ContextExternalToolResponse { /** - * + * * @type {string} * @memberof ContextExternalToolResponse */ id: string; /** - * + * * @type {string} * @memberof ContextExternalToolResponse */ schoolToolId: string; /** - * + * * @type {string} * @memberof ContextExternalToolResponse */ contextId: string; /** - * + * * @type {string} * @memberof ContextExternalToolResponse */ contextType: ContextExternalToolResponseContextTypeEnum; /** - * + * * @type {string} * @memberof ContextExternalToolResponse */ displayName?: string; /** - * + * * @type {Array} * @memberof ContextExternalToolResponse */ @@ -2008,20 +2015,20 @@ export enum ContextExternalToolResponseContextTypeEnum { } /** - * + * * @export * @interface ContextExternalToolSearchListResponse */ export interface ContextExternalToolSearchListResponse { /** - * + * * @type {Array} * @memberof ContextExternalToolSearchListResponse */ data: Array; } /** - * + * * @export * @interface CopyApiResponse */ @@ -2108,7 +2115,8 @@ export enum CopyApiResponseTypeEnum { Task = 'TASK', TaskGroup = 'TASK_GROUP', TimeGroup = 'TIME_GROUP', - UserGroup = 'USER_GROUP' + UserGroup = 'USER_GROUP', + VideoConferenceElement = 'VIDEO_CONFERENCE_ELEMENT' } /** * @export @@ -2123,38 +2131,38 @@ export enum CopyApiResponseStatusEnum { } /** - * + * * @export * @interface CountyResponse */ export interface CountyResponse { /** - * + * * @type {string} * @memberof CountyResponse */ id: string; /** - * + * * @type {string} * @memberof CountyResponse */ name: string; /** - * + * * @type {number} * @memberof CountyResponse */ countyId: number; /** - * + * * @type {string} * @memberof CountyResponse */ antaresKey: string; } /** - * + * * @export * @interface CourseCommonCartridgeMetadataResponse */ @@ -2185,7 +2193,7 @@ export interface CourseCommonCartridgeMetadataResponse { copyRightOwners: Array; } /** - * + * * @export * @interface CourseExportBodyParams */ @@ -2210,44 +2218,44 @@ export interface CourseExportBodyParams { columnBoards: Array; } /** - * + * * @export * @interface CourseInfoDataResponse */ export interface CourseInfoDataResponse { /** - * + * * @type {string} * @memberof CourseInfoDataResponse */ id: string; /** - * + * * @type {string} * @memberof CourseInfoDataResponse */ name: string; /** - * + * * @type {Array} * @memberof CourseInfoDataResponse */ teacherNames: Array; /** - * + * * @type {Array} * @memberof CourseInfoDataResponse */ classNames: Array; /** - * + * * @type {string} * @memberof CourseInfoDataResponse */ syncedGroup?: string; } /** - * + * * @export * @interface CourseInfoListResponse */ @@ -2278,26 +2286,26 @@ export interface CourseInfoListResponse { limit: number; } /** - * + * * @export * @interface CourseInfoResponse */ export interface CourseInfoResponse { /** - * + * * @type {string} * @memberof CourseInfoResponse */ id: string; /** - * + * * @type {string} * @memberof CourseInfoResponse */ name: string; } /** - * + * * @export * @interface CourseMetadataListResponse */ @@ -2328,7 +2336,7 @@ export interface CourseMetadataListResponse { limit: number; } /** - * + * * @export * @interface CourseMetadataResponse */ @@ -2377,7 +2385,7 @@ export interface CourseMetadataResponse { copyingSince?: string; } /** - * + * * @export * @enum {string} */ @@ -2386,7 +2394,7 @@ export enum CourseSortProps { } /** - * + * * @export * @enum {string} */ @@ -2396,7 +2404,7 @@ export enum CourseStatus { } /** - * + * * @export * @interface CourseSyncBodyParams */ @@ -2409,7 +2417,7 @@ export interface CourseSyncBodyParams { groupId: string; } /** - * + * * @export * @interface CreateBoardBodyParams */ @@ -2427,39 +2435,39 @@ export interface CreateBoardBodyParams { */ parentId: string; /** - * + * * @type {BoardParentType} * @memberof CreateBoardBodyParams */ parentType: BoardParentType; /** - * + * * @type {BoardLayout} * @memberof CreateBoardBodyParams */ layout: BoardLayout; } /** - * + * * @export * @interface CreateBoardResponse */ export interface CreateBoardResponse { /** - * + * * @type {string} * @memberof CreateBoardResponse */ id: string; } /** - * + * * @export * @interface CreateCardBodyParams */ export interface CreateCardBodyParams { /** - * + * * @type {Array} * @memberof CreateCardBodyParams */ @@ -2478,17 +2486,18 @@ export enum CreateCardBodyParamsRequiredEmptyElementsEnum { SubmissionContainer = 'submissionContainer', ExternalTool = 'externalTool', CollaborativeTextEditor = 'collaborativeTextEditor', + VideoConference = 'videoConference', Deleted = 'deleted' } /** - * + * * @export * @interface CreateContentElementBodyParams */ export interface CreateContentElementBodyParams { /** - * + * * @type {ContentElementType} * @memberof CreateContentElementBodyParams */ @@ -2501,7 +2510,7 @@ export interface CreateContentElementBodyParams { toPosition?: number; } /** - * + * * @export * @interface CreateMediaElementBodyParams */ @@ -2526,7 +2535,7 @@ export interface CreateMediaElementBodyParams { schoolExternalToolId: string; } /** - * + * * @export * @interface CreateNewsParams */ @@ -2574,7 +2583,7 @@ export enum CreateNewsParamsTargetModelEnum { } /** - * + * * @export * @interface CreateRoomBodyParams */ @@ -2586,7 +2595,7 @@ export interface CreateRoomBodyParams { */ name: string; /** - * + * * @type {RoomColor} * @memberof CreateRoomBodyParams */ @@ -2605,7 +2614,7 @@ export interface CreateRoomBodyParams { endDate?: string; } /** - * + * * @export * @interface CreateSubmissionItemBodyParams */ @@ -2618,184 +2627,184 @@ export interface CreateSubmissionItemBodyParams { completed: boolean; } /** - * + * * @export * @interface CustomParameterEntryParam */ export interface CustomParameterEntryParam { /** - * + * * @type {string} * @memberof CustomParameterEntryParam */ name: string; /** - * + * * @type {string} * @memberof CustomParameterEntryParam */ value?: string; } /** - * + * * @export * @interface CustomParameterEntryResponse */ export interface CustomParameterEntryResponse { /** - * + * * @type {string} * @memberof CustomParameterEntryResponse */ name: string; /** - * + * * @type {string} * @memberof CustomParameterEntryResponse */ value?: string; } /** - * + * * @export * @interface CustomParameterPostParams */ export interface CustomParameterPostParams { /** - * + * * @type {string} * @memberof CustomParameterPostParams */ name: string; /** - * + * * @type {string} * @memberof CustomParameterPostParams */ displayName: string; /** - * + * * @type {string} * @memberof CustomParameterPostParams */ description?: string; /** - * + * * @type {string} * @memberof CustomParameterPostParams */ defaultValue?: string; /** - * + * * @type {string} * @memberof CustomParameterPostParams */ regex?: string; /** - * + * * @type {string} * @memberof CustomParameterPostParams */ regexComment?: string; /** - * + * * @type {string} * @memberof CustomParameterPostParams */ scope: string; /** - * + * * @type {string} * @memberof CustomParameterPostParams */ location: string; /** - * + * * @type {string} * @memberof CustomParameterPostParams */ type: string; /** - * + * * @type {boolean} * @memberof CustomParameterPostParams */ isOptional: boolean; /** - * + * * @type {boolean} * @memberof CustomParameterPostParams */ isProtected: boolean; } /** - * + * * @export * @interface CustomParameterResponse */ export interface CustomParameterResponse { /** - * + * * @type {string} * @memberof CustomParameterResponse */ name: string; /** - * + * * @type {string} * @memberof CustomParameterResponse */ displayName: string; /** - * + * * @type {string} * @memberof CustomParameterResponse */ description?: string; /** - * + * * @type {string} * @memberof CustomParameterResponse */ defaultValue?: string; /** - * + * * @type {string} * @memberof CustomParameterResponse */ regex?: string; /** - * + * * @type {string} * @memberof CustomParameterResponse */ regexComment?: string; /** - * + * * @type {string} * @memberof CustomParameterResponse */ scope: CustomParameterResponseScopeEnum; /** - * + * * @type {string} * @memberof CustomParameterResponse */ location: CustomParameterResponseLocationEnum; /** - * + * * @type {string} * @memberof CustomParameterResponse */ type: CustomParameterResponseTypeEnum; /** - * + * * @type {boolean} * @memberof CustomParameterResponse */ isOptional: boolean; /** - * + * * @type {boolean} * @memberof CustomParameterResponse */ @@ -2837,7 +2846,7 @@ export enum CustomParameterResponseTypeEnum { } /** - * + * * @export * @interface DashboardGridElementResponse */ @@ -2904,7 +2913,7 @@ export interface DashboardGridElementResponse { isSynchronized: boolean; } /** - * + * * @export * @interface DashboardGridSubElementResponse */ @@ -2935,7 +2944,7 @@ export interface DashboardGridSubElementResponse { displayColor: string; } /** - * + * * @export * @interface DashboardResponse */ @@ -2954,139 +2963,139 @@ export interface DashboardResponse { gridElements: Array; } /** - * + * * @export * @interface DeletedElementContent */ export interface DeletedElementContent { /** - * + * * @type {string} * @memberof DeletedElementContent */ title: string; /** - * + * * @type {ContentElementType} * @memberof DeletedElementContent */ deletedElementType: ContentElementType; /** - * + * * @type {string} * @memberof DeletedElementContent */ description: string; } /** - * + * * @export * @interface DeletedElementResponse */ export interface DeletedElementResponse { /** - * + * * @type {string} * @memberof DeletedElementResponse */ id: string; /** - * + * * @type {ContentElementType} * @memberof DeletedElementResponse */ type: ContentElementType; /** - * + * * @type {DeletedElementContent} * @memberof DeletedElementResponse */ content: DeletedElementContent; /** - * + * * @type {TimestampsResponse} * @memberof DeletedElementResponse */ timestamps: TimestampsResponse; } /** - * + * * @export * @interface DrawingContentBody */ export interface DrawingContentBody { /** - * + * * @type {string} * @memberof DrawingContentBody */ description: string; } /** - * + * * @export * @interface DrawingElementContent */ export interface DrawingElementContent { /** - * + * * @type {string} * @memberof DrawingElementContent */ description: string; } /** - * + * * @export * @interface DrawingElementContentBody */ export interface DrawingElementContentBody { /** - * + * * @type {ContentElementType} * @memberof DrawingElementContentBody */ type: ContentElementType; /** - * + * * @type {DrawingContentBody} * @memberof DrawingElementContentBody */ content: DrawingContentBody; } /** - * + * * @export * @interface DrawingElementResponse */ export interface DrawingElementResponse { /** - * + * * @type {string} * @memberof DrawingElementResponse */ id: string; /** - * + * * @type {ContentElementType} * @memberof DrawingElementResponse */ type: ContentElementType; /** - * + * * @type {TimestampsResponse} * @memberof DrawingElementResponse */ timestamps: TimestampsResponse; /** - * + * * @type {DrawingElementContent} * @memberof DrawingElementResponse */ content: DrawingElementContent; } /** - * + * * @export * @interface EntityNotFoundError */ @@ -3123,26 +3132,26 @@ export interface EntityNotFoundError { details?: object; } /** - * + * * @export * @interface ExternalSourceResponse */ export interface ExternalSourceResponse { /** - * + * * @type {string} * @memberof ExternalSourceResponse */ externalId: string; /** - * + * * @type {string} * @memberof ExternalSourceResponse */ systemId: string; } /** - * + * * @export * @interface ExternalToolBulkCreateParams */ @@ -3155,20 +3164,20 @@ export interface ExternalToolBulkCreateParams { data: Array; } /** - * + * * @export * @interface ExternalToolContentBody */ export interface ExternalToolContentBody { /** - * + * * @type {string} * @memberof ExternalToolContentBody */ contextExternalToolId?: string; } /** - * + * * @export * @interface ExternalToolCreateParams */ @@ -3259,70 +3268,70 @@ export interface ExternalToolCreateParams { iconName?: string; } /** - * + * * @export * @interface ExternalToolElementContent */ export interface ExternalToolElementContent { /** - * + * * @type {string} * @memberof ExternalToolElementContent */ contextExternalToolId: string | null; } /** - * + * * @export * @interface ExternalToolElementContentBody */ export interface ExternalToolElementContentBody { /** - * + * * @type {ContentElementType} * @memberof ExternalToolElementContentBody */ type: ContentElementType; /** - * + * * @type {ExternalToolContentBody} * @memberof ExternalToolElementContentBody */ content: ExternalToolContentBody; } /** - * + * * @export * @interface ExternalToolElementResponse */ export interface ExternalToolElementResponse { /** - * + * * @type {string} * @memberof ExternalToolElementResponse */ id: string; /** - * + * * @type {ContentElementType} * @memberof ExternalToolElementResponse */ type: ContentElementType; /** - * + * * @type {ExternalToolElementContent} * @memberof ExternalToolElementResponse */ content: ExternalToolElementContent; /** - * + * * @type {TimestampsResponse} * @memberof ExternalToolElementResponse */ timestamps: TimestampsResponse; } /** - * + * * @export * @interface ExternalToolMediumParams */ @@ -3347,7 +3356,7 @@ export interface ExternalToolMediumParams { mediaSourceId?: string; } /** - * + * * @export * @interface ExternalToolMediumResponse */ @@ -3372,26 +3381,26 @@ export interface ExternalToolMediumResponse { mediaSourceId?: string; } /** - * + * * @export * @interface ExternalToolMetadataResponse */ export interface ExternalToolMetadataResponse { /** - * + * * @type {number} * @memberof ExternalToolMetadataResponse */ schoolExternalToolCount: number; /** - * + * * @type {ContextExternalToolCountPerContextResponse} * @memberof ExternalToolMetadataResponse */ contextExternalToolCountPerContext: ContextExternalToolCountPerContextResponse; } /** - * + * * @export * @interface ExternalToolResponse */ @@ -3488,7 +3497,7 @@ export interface ExternalToolResponse { iconName?: string; } /** - * + * * @export * @interface ExternalToolSearchListResponse */ @@ -3519,7 +3528,7 @@ export interface ExternalToolSearchListResponse { limit: number; } /** - * + * * @export * @interface ExternalToolUpdateParams */ @@ -3531,7 +3540,7 @@ export interface ExternalToolUpdateParams { */ id: string; /** - * + * * @type {string} * @memberof ExternalToolUpdateParams */ @@ -3573,7 +3582,7 @@ export interface ExternalToolUpdateParams { */ parameters?: Array; /** - * + * * @type {boolean} * @memberof ExternalToolUpdateParams */ @@ -3616,132 +3625,132 @@ export interface ExternalToolUpdateParams { iconName?: string; } /** - * + * * @export * @interface FederalStateResponse */ export interface FederalStateResponse { /** - * + * * @type {string} * @memberof FederalStateResponse */ id: string; /** - * + * * @type {string} * @memberof FederalStateResponse */ name: string; /** - * + * * @type {string} * @memberof FederalStateResponse */ abbreviation: string; /** - * + * * @type {string} * @memberof FederalStateResponse */ logoUrl: string; /** - * + * * @type {Array} * @memberof FederalStateResponse */ counties: Array; } /** - * + * * @export * @interface FileContentBody */ export interface FileContentBody { /** - * + * * @type {string} * @memberof FileContentBody */ caption: string; /** - * + * * @type {string} * @memberof FileContentBody */ alternativeText: string; } /** - * + * * @export * @interface FileElementContent */ export interface FileElementContent { /** - * + * * @type {string} * @memberof FileElementContent */ caption: string; /** - * + * * @type {string} * @memberof FileElementContent */ alternativeText: string; } /** - * + * * @export * @interface FileElementContentBody */ export interface FileElementContentBody { /** - * + * * @type {ContentElementType} * @memberof FileElementContentBody */ type: ContentElementType; /** - * + * * @type {FileContentBody} * @memberof FileElementContentBody */ content: FileContentBody; } /** - * + * * @export * @interface FileElementResponse */ export interface FileElementResponse { /** - * + * * @type {string} * @memberof FileElementResponse */ id: string; /** - * + * * @type {ContentElementType} * @memberof FileElementResponse */ type: ContentElementType; /** - * + * * @type {FileElementContent} * @memberof FileElementResponse */ content: FileElementContent; /** - * + * * @type {TimestampsResponse} * @memberof FileElementResponse */ timestamps: TimestampsResponse; } /** - * + * * @export * @enum {string} */ @@ -3750,7 +3759,7 @@ export enum FileStorageType { } /** - * + * * @export * @interface ForbiddenOperationError */ @@ -3787,7 +3796,7 @@ export interface ForbiddenOperationError { details?: object; } /** - * + * * @export * @interface ForceMigrationParams */ @@ -3818,20 +3827,20 @@ export interface ForceMigrationParams { forceExtendedMode: boolean; } /** - * + * * @export * @interface GetMetaTagDataBody */ export interface GetMetaTagDataBody { /** - * + * * @type {string} * @memberof GetMetaTagDataBody */ url: string; } /** - * + * * @export * @interface GroupListResponse */ @@ -3862,49 +3871,49 @@ export interface GroupListResponse { limit: number; } /** - * + * * @export * @interface GroupResponse */ export interface GroupResponse { /** - * + * * @type {string} * @memberof GroupResponse */ id: string; /** - * + * * @type {string} * @memberof GroupResponse */ name: string; /** - * + * * @type {string} * @memberof GroupResponse */ type: GroupResponseTypeEnum; /** - * + * * @type {Array} * @memberof GroupResponse */ users: Array; /** - * + * * @type {ExternalSourceResponse} * @memberof GroupResponse */ externalSource?: ExternalSourceResponse; /** - * + * * @type {PeriodResponse} * @memberof GroupResponse */ validPeriod?: PeriodResponse; /** - * + * * @type {string} * @memberof GroupResponse */ @@ -3923,38 +3932,38 @@ export enum GroupResponseTypeEnum { } /** - * + * * @export * @interface GroupUserResponse */ export interface GroupUserResponse { /** - * + * * @type {string} * @memberof GroupUserResponse */ id: string; /** - * + * * @type {string} * @memberof GroupUserResponse */ firstName: string; /** - * + * * @type {string} * @memberof GroupUserResponse */ lastName: string; /** - * + * * @type {RoleName} * @memberof GroupUserResponse */ role: RoleName; } /** - * + * * @export * @interface ImportUserListResponse */ @@ -3985,7 +3994,7 @@ export interface ImportUserListResponse { limit: number; } /** - * + * * @export * @interface ImportUserResponse */ @@ -4057,7 +4066,7 @@ export enum ImportUserResponseRoleNamesEnum { } /** - * + * * @export * @enum {string} */ @@ -4066,7 +4075,7 @@ export enum InstanceFeature { } /** - * + * * @export * @enum {string} */ @@ -4078,7 +4087,7 @@ export enum LanguageType { } /** - * + * * @export * @enum {string} */ @@ -4090,57 +4099,57 @@ export enum LaunchType { } /** - * + * * @export * @interface LayoutBodyParams */ export interface LayoutBodyParams { /** - * + * * @type {MediaBoardLayoutType} * @memberof LayoutBodyParams */ layout: MediaBoardLayoutType; } /** - * + * * @export * @interface LdapAuthorizationBodyParams */ export interface LdapAuthorizationBodyParams { /** - * + * * @type {string} * @memberof LdapAuthorizationBodyParams */ systemId: string; /** - * + * * @type {string} * @memberof LdapAuthorizationBodyParams */ username: string; /** - * + * * @type {string} * @memberof LdapAuthorizationBodyParams */ password: string; /** - * + * * @type {string} * @memberof LdapAuthorizationBodyParams */ schoolId: string; } /** - * + * * @export * @interface LessonContentResponse */ export interface LessonContentResponse { /** - * + * * @type {object} * @memberof LessonContentResponse */ @@ -4165,13 +4174,13 @@ export interface LessonContentResponse { */ title: string; /** - * + * * @type {string} * @memberof LessonContentResponse */ component: LessonContentResponseComponentEnum; /** - * + * * @type {boolean} * @memberof LessonContentResponse */ @@ -4192,7 +4201,7 @@ export enum LessonContentResponseComponentEnum { } /** - * + * * @export * @interface LessonCopyApiParams */ @@ -4205,79 +4214,79 @@ export interface LessonCopyApiParams { courseId?: string; } /** - * + * * @export * @interface LessonLinkedTaskResponse */ export interface LessonLinkedTaskResponse { /** - * + * * @type {string} * @memberof LessonLinkedTaskResponse */ name: string; /** - * + * * @type {string} * @memberof LessonLinkedTaskResponse */ description: string; /** - * + * * @type {string} * @memberof LessonLinkedTaskResponse */ descriptionInputFormat: LessonLinkedTaskResponseDescriptionInputFormatEnum; /** - * + * * @type {string} * @memberof LessonLinkedTaskResponse */ availableDate: string | null; /** - * + * * @type {string} * @memberof LessonLinkedTaskResponse */ dueDate: string | null; /** - * + * * @type {boolean} * @memberof LessonLinkedTaskResponse */ _private: boolean; /** - * + * * @type {boolean} * @memberof LessonLinkedTaskResponse */ publicSubmissions: boolean | null; /** - * + * * @type {boolean} * @memberof LessonLinkedTaskResponse */ teamSubmissions: boolean | null; /** - * + * * @type {string} * @memberof LessonLinkedTaskResponse */ creator: string | null; /** - * + * * @type {string} * @memberof LessonLinkedTaskResponse */ courseId: string | null; /** - * + * * @type {Array} * @memberof LessonLinkedTaskResponse */ submissionIds: Array; /** - * + * * @type {Array} * @memberof LessonLinkedTaskResponse */ @@ -4296,7 +4305,7 @@ export enum LessonLinkedTaskResponseDescriptionInputFormatEnum { } /** - * + * * @export * @interface LessonMetadataListResponse */ @@ -4327,7 +4336,7 @@ export interface LessonMetadataListResponse { limit: number; } /** - * + * * @export * @interface LessonMetadataResponse */ @@ -4346,7 +4355,7 @@ export interface LessonMetadataResponse { name: string; } /** - * + * * @export * @interface LessonResponse */ @@ -4408,150 +4417,150 @@ export interface LessonResponse { materials: Array; } /** - * + * * @export * @interface LinkContentBody */ export interface LinkContentBody { /** - * + * * @type {string} * @memberof LinkContentBody */ url: string; /** - * + * * @type {string} * @memberof LinkContentBody */ title: string; /** - * + * * @type {string} * @memberof LinkContentBody */ description: string; /** - * + * * @type {string} * @memberof LinkContentBody */ imageUrl: string; /** - * + * * @type {string} * @memberof LinkContentBody */ originalImageUrl: string; } /** - * + * * @export * @interface LinkElementContent */ export interface LinkElementContent { /** - * + * * @type {string} * @memberof LinkElementContent */ url: string; /** - * + * * @type {string} * @memberof LinkElementContent */ title: string; /** - * + * * @type {string} * @memberof LinkElementContent */ description?: string; /** - * + * * @type {string} * @memberof LinkElementContent */ originalImageUrl?: string; /** - * + * * @type {string} * @memberof LinkElementContent */ imageUrl?: string; } /** - * + * * @export * @interface LinkElementContentBody */ export interface LinkElementContentBody { /** - * + * * @type {ContentElementType} * @memberof LinkElementContentBody */ type: ContentElementType; /** - * + * * @type {LinkContentBody} * @memberof LinkElementContentBody */ content: LinkContentBody; } /** - * + * * @export * @interface LinkElementResponse */ export interface LinkElementResponse { /** - * + * * @type {string} * @memberof LinkElementResponse */ id: string; /** - * + * * @type {ContentElementType} * @memberof LinkElementResponse */ type: ContentElementType; /** - * + * * @type {LinkElementContent} * @memberof LinkElementResponse */ content: LinkElementContent; /** - * + * * @type {TimestampsResponse} * @memberof LinkElementResponse */ timestamps: TimestampsResponse; } /** - * + * * @export * @interface LocalAuthorizationBodyParams */ export interface LocalAuthorizationBodyParams { /** - * + * * @type {string} * @memberof LocalAuthorizationBodyParams */ username: string; /** - * + * * @type {string} * @memberof LocalAuthorizationBodyParams */ password: string; } /** - * + * * @export * @interface LoginRequestBody */ @@ -4600,332 +4609,332 @@ export interface LoginRequestBody { remember_for?: number; } /** - * + * * @export * @interface LoginResponse */ export interface LoginResponse { /** - * + * * @type {string} * @memberof LoginResponse */ accessToken: string; } /** - * + * * @export * @interface Lti11DeepLinkContentItemListParams */ export interface Lti11DeepLinkContentItemListParams { /** - * + * * @type {string} * @memberof Lti11DeepLinkContentItemListParams */ context: string; /** - * + * * @type {Array} * @memberof Lti11DeepLinkContentItemListParams */ graph: Array; } /** - * + * * @export * @interface Lti11DeepLinkParams */ export interface Lti11DeepLinkParams { /** - * + * * @type {string} * @memberof Lti11DeepLinkParams */ lti_message_type: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParams */ lti_version: string; /** - * + * * @type {Lti11DeepLinkContentItemListParams} * @memberof Lti11DeepLinkParams */ content_items?: Lti11DeepLinkContentItemListParams; /** - * + * * @type {string} * @memberof Lti11DeepLinkParams */ data: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParams */ oauth_version: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParams */ oauth_nonce: string; /** - * + * * @type {number} * @memberof Lti11DeepLinkParams */ oauth_timestamp: number; /** - * + * * @type {string} * @memberof Lti11DeepLinkParams */ oauth_signature_method: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParams */ oauth_consumer_key: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParams */ oauth_signature: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParams */ oauth_callback?: string; } /** - * + * * @export * @interface Lti11DeepLinkParamsRaw */ export interface Lti11DeepLinkParamsRaw { /** - * + * * @type {string} * @memberof Lti11DeepLinkParamsRaw */ lti_message_type: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParamsRaw */ lti_version: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParamsRaw */ content_items?: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParamsRaw */ data: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParamsRaw */ oauth_version: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParamsRaw */ oauth_nonce: string; /** - * + * * @type {number} * @memberof Lti11DeepLinkParamsRaw */ oauth_timestamp: number; /** - * + * * @type {string} * @memberof Lti11DeepLinkParamsRaw */ oauth_signature_method: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParamsRaw */ oauth_consumer_key: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParamsRaw */ oauth_signature: string; /** - * + * * @type {string} * @memberof Lti11DeepLinkParamsRaw */ oauth_callback?: string; } /** - * + * * @export * @interface Lti11ToolConfigCreateParams */ export interface Lti11ToolConfigCreateParams { /** - * + * * @type {ToolConfigType} * @memberof Lti11ToolConfigCreateParams */ type: ToolConfigType; /** - * + * * @type {string} * @memberof Lti11ToolConfigCreateParams */ baseUrl: string; /** - * + * * @type {string} * @memberof Lti11ToolConfigCreateParams */ key: string; /** - * + * * @type {string} * @memberof Lti11ToolConfigCreateParams */ secret: string; /** - * + * * @type {LtiMessageType} * @memberof Lti11ToolConfigCreateParams */ lti_message_type: LtiMessageType; /** - * + * * @type {LtiPrivacyPermission} * @memberof Lti11ToolConfigCreateParams */ privacy_permission: LtiPrivacyPermission; /** - * + * * @type {string} * @memberof Lti11ToolConfigCreateParams */ launch_presentation_locale: string; } /** - * + * * @export * @interface Lti11ToolConfigUpdateParams */ export interface Lti11ToolConfigUpdateParams { /** - * + * * @type {ToolConfigType} * @memberof Lti11ToolConfigUpdateParams */ type: ToolConfigType; /** - * + * * @type {string} * @memberof Lti11ToolConfigUpdateParams */ baseUrl: string; /** - * + * * @type {string} * @memberof Lti11ToolConfigUpdateParams */ key: string; /** - * + * * @type {string} * @memberof Lti11ToolConfigUpdateParams */ secret?: string; /** - * + * * @type {LtiMessageType} * @memberof Lti11ToolConfigUpdateParams */ lti_message_type: LtiMessageType; /** - * + * * @type {LtiPrivacyPermission} * @memberof Lti11ToolConfigUpdateParams */ privacy_permission: LtiPrivacyPermission; /** - * + * * @type {string} * @memberof Lti11ToolConfigUpdateParams */ launch_presentation_locale: string; } /** - * + * * @export * @interface LtiDeepLinkResponse */ export interface LtiDeepLinkResponse { /** - * + * * @type {string} * @memberof LtiDeepLinkResponse */ mediaType: string; /** - * + * * @type {string} * @memberof LtiDeepLinkResponse */ title?: string; /** - * + * * @type {string} * @memberof LtiDeepLinkResponse */ text?: string; /** - * + * * @type {string} * @memberof LtiDeepLinkResponse */ availableFrom?: string; /** - * + * * @type {string} * @memberof LtiDeepLinkResponse */ availableUntil?: string; /** - * + * * @type {string} * @memberof LtiDeepLinkResponse */ submissionFrom?: string; /** - * + * * @type {string} * @memberof LtiDeepLinkResponse */ submissionUntil?: string; } /** - * + * * @export * @enum {string} */ @@ -4935,7 +4944,7 @@ export enum LtiMessageType { } /** - * + * * @export * @enum {string} */ @@ -4948,7 +4957,7 @@ export enum LtiPrivacyPermission { } /** - * + * * @export * @interface MaterialResponse */ @@ -5003,188 +5012,188 @@ export interface MaterialResponse { merlinReference: string; } /** - * + * * @export * @interface MeAccountResponse */ export interface MeAccountResponse { /** - * + * * @type {string} * @memberof MeAccountResponse */ id: string; } /** - * + * * @export * @interface MeResponse */ export interface MeResponse { /** - * + * * @type {MeSchoolResponse} * @memberof MeResponse */ school: MeSchoolResponse; /** - * + * * @type {MeUserResponse} * @memberof MeResponse */ user: MeUserResponse; /** - * + * * @type {Array} * @memberof MeResponse */ roles: Array; /** - * + * * @type {Array} * @memberof MeResponse */ permissions: Array; /** - * + * * @type {LanguageType} * @memberof MeResponse */ language: LanguageType; /** - * + * * @type {MeAccountResponse} * @memberof MeResponse */ account: MeAccountResponse; /** - * + * * @type {MeSystemResponse} * @memberof MeResponse */ system?: MeSystemResponse; } /** - * + * * @export * @interface MeRoleResponse */ export interface MeRoleResponse { /** - * + * * @type {string} * @memberof MeRoleResponse */ id: string; /** - * + * * @type {string} * @memberof MeRoleResponse */ name: string; } /** - * + * * @export * @interface MeSchoolLogoResponse */ export interface MeSchoolLogoResponse { /** - * + * * @type {string} * @memberof MeSchoolLogoResponse */ url?: string; /** - * + * * @type {string} * @memberof MeSchoolLogoResponse */ name?: string; } /** - * + * * @export * @interface MeSchoolResponse */ export interface MeSchoolResponse { /** - * + * * @type {string} * @memberof MeSchoolResponse */ id: string; /** - * + * * @type {string} * @memberof MeSchoolResponse */ name: string; /** - * + * * @type {MeSchoolLogoResponse} * @memberof MeSchoolResponse */ logo: MeSchoolLogoResponse; } /** - * + * * @export * @interface MeSystemResponse */ export interface MeSystemResponse { /** - * + * * @type {string} * @memberof MeSystemResponse */ id: string; /** - * + * * @type {string} * @memberof MeSystemResponse */ name?: string; /** - * + * * @type {boolean} * @memberof MeSystemResponse */ hasEndSessionEndpoint: boolean; } /** - * + * * @export * @interface MeUserResponse */ export interface MeUserResponse { /** - * + * * @type {string} * @memberof MeUserResponse */ id: string; /** - * + * * @type {string} * @memberof MeUserResponse */ firstName: string; /** - * + * * @type {string} * @memberof MeUserResponse */ lastName: string; /** - * + * * @type {string} * @memberof MeUserResponse */ customAvatarBackgroundColor?: string; } /** - * + * * @export * @interface MediaAvailableLineElementResponse */ @@ -5221,7 +5230,7 @@ export interface MediaAvailableLineElementResponse { thumbnailUrl?: string; } /** - * + * * @export * @interface MediaAvailableLineResponse */ @@ -5233,7 +5242,7 @@ export interface MediaAvailableLineResponse { */ elements: Array; /** - * + * * @type {MediaBoardColors} * @memberof MediaAvailableLineResponse */ @@ -5246,7 +5255,7 @@ export interface MediaAvailableLineResponse { collapsed: boolean; } /** - * + * * @export * @enum {string} */ @@ -5274,7 +5283,7 @@ export enum MediaBoardColors { } /** - * + * * @export * @enum {string} */ @@ -5285,7 +5294,7 @@ export enum MediaBoardLayoutType { } /** - * + * * @export * @interface MediaBoardResponse */ @@ -5309,14 +5318,14 @@ export interface MediaBoardResponse { */ timestamps: TimestampsResponse; /** - * + * * @type {MediaBoardLayoutType} * @memberof MediaBoardResponse */ layout: MediaBoardLayoutType; } /** - * + * * @export * @interface MediaExternalToolElementContent */ @@ -5329,7 +5338,7 @@ export interface MediaExternalToolElementContent { contextExternalToolId: string; } /** - * + * * @export * @interface MediaExternalToolElementResponse */ @@ -5354,7 +5363,7 @@ export interface MediaExternalToolElementResponse { timestamps: TimestampsResponse; } /** - * + * * @export * @interface MediaLineResponse */ @@ -5384,7 +5393,7 @@ export interface MediaLineResponse { */ timestamps: TimestampsResponse; /** - * + * * @type {MediaBoardColors} * @memberof MediaLineResponse */ @@ -5397,149 +5406,149 @@ export interface MediaLineResponse { collapsed: boolean; } /** - * + * * @export * @interface Message */ export interface Message { /** - * + * * @type {string} * @memberof Message */ title: string; /** - * + * * @type {string} * @memberof Message */ text: string; /** - * + * * @type {string} * @memberof Message */ timestamp: string; /** - * + * * @type {MessageOrigin} * @memberof Message */ origin: MessageOrigin; /** - * + * * @type {string} * @memberof Message */ url: string; /** - * + * * @type {string} * @memberof Message */ status: string; /** - * + * * @type {string} * @memberof Message */ createdAt: string; } /** - * + * * @export * @interface MessageOrigin */ export interface MessageOrigin { /** - * + * * @type {number} * @memberof MessageOrigin */ message_id: number; /** - * + * * @type {string} * @memberof MessageOrigin */ page: string; } /** - * + * * @export * @interface MetaTagExtractorResponse */ export interface MetaTagExtractorResponse { /** - * + * * @type {string} * @memberof MetaTagExtractorResponse */ url: string; /** - * + * * @type {string} * @memberof MetaTagExtractorResponse */ title: string; /** - * + * * @type {string} * @memberof MetaTagExtractorResponse */ description: string; /** - * + * * @type {string} * @memberof MetaTagExtractorResponse */ originalImageUrl: string; /** - * + * * @type {string} * @memberof MetaTagExtractorResponse */ imageUrl: string; /** - * + * * @type {string} * @memberof MetaTagExtractorResponse */ type: string; /** - * + * * @type {string} * @memberof MetaTagExtractorResponse */ parentTitle: string; /** - * + * * @type {string} * @memberof MetaTagExtractorResponse */ parentType: string; } /** - * + * * @export * @interface MoveCardBodyParams */ export interface MoveCardBodyParams { /** - * + * * @type {string} * @memberof MoveCardBodyParams */ toColumnId: string; /** - * + * * @type {number} * @memberof MoveCardBodyParams */ toPosition: number; } /** - * + * * @export * @interface MoveColumnBodyParams */ @@ -5551,33 +5560,33 @@ export interface MoveColumnBodyParams { */ toBoardId: string; /** - * + * * @type {number} * @memberof MoveColumnBodyParams */ toPosition: number; } /** - * + * * @export * @interface MoveContentElementBody */ export interface MoveContentElementBody { /** - * + * * @type {string} * @memberof MoveContentElementBody */ toCardId: string; /** - * + * * @type {number} * @memberof MoveContentElementBody */ toPosition: number; } /** - * + * * @export * @interface MoveElementBodyParams */ @@ -5596,38 +5605,38 @@ export interface MoveElementBodyParams { toPosition: number; } /** - * + * * @export * @interface MoveElementParams */ export interface MoveElementParams { /** - * + * * @type {MoveElementPositionParams} * @memberof MoveElementParams */ from: MoveElementPositionParams; /** - * + * * @type {MoveElementPositionParams} * @memberof MoveElementParams */ to: MoveElementPositionParams; } /** - * + * * @export * @interface MoveElementPositionParams */ export interface MoveElementPositionParams { /** - * + * * @type {number} * @memberof MoveElementPositionParams */ x: number; /** - * + * * @type {number} * @memberof MoveElementPositionParams */ @@ -5640,7 +5649,7 @@ export interface MoveElementPositionParams { groupIndex?: number; } /** - * + * * @export * @interface NewsListResponse */ @@ -5671,7 +5680,7 @@ export interface NewsListResponse { limit: number; } /** - * + * * @export * @interface NewsResponse */ @@ -5713,7 +5722,7 @@ export interface NewsResponse { */ sourceDescription?: string; /** - * + * * @type {NewsTargetModel} * @memberof NewsResponse */ @@ -5778,7 +5787,7 @@ export enum NewsResponseSourceEnum { } /** - * + * * @export * @enum {string} */ @@ -5789,204 +5798,204 @@ export enum NewsTargetModel { } /** - * + * * @export * @interface OAuthTokenDto */ export interface OAuthTokenDto { /** - * + * * @type {string} * @memberof OAuthTokenDto */ idToken: string; /** - * + * * @type {string} * @memberof OAuthTokenDto */ refreshToken: string; /** - * + * * @type {string} * @memberof OAuthTokenDto */ accessToken: string; } /** - * + * * @export * @interface Oauth2AuthorizationBodyParams */ export interface Oauth2AuthorizationBodyParams { /** - * + * * @type {string} * @memberof Oauth2AuthorizationBodyParams */ redirectUri: string; /** - * + * * @type {string} * @memberof Oauth2AuthorizationBodyParams */ code: string; /** - * + * * @type {string} * @memberof Oauth2AuthorizationBodyParams */ systemId: string; } /** - * + * * @export * @interface Oauth2MigrationParams */ export interface Oauth2MigrationParams { /** - * + * * @type {string} * @memberof Oauth2MigrationParams */ redirectUri: string; /** - * + * * @type {string} * @memberof Oauth2MigrationParams */ code: string; /** - * + * * @type {string} * @memberof Oauth2MigrationParams */ systemId: string; } /** - * + * * @export * @interface Oauth2ToolConfigCreateParams */ export interface Oauth2ToolConfigCreateParams { /** - * + * * @type {string} * @memberof Oauth2ToolConfigCreateParams */ type: string; /** - * + * * @type {string} * @memberof Oauth2ToolConfigCreateParams */ baseUrl: string; /** - * + * * @type {string} * @memberof Oauth2ToolConfigCreateParams */ clientId: string; /** - * + * * @type {string} * @memberof Oauth2ToolConfigCreateParams */ clientSecret: string; /** - * + * * @type {boolean} * @memberof Oauth2ToolConfigCreateParams */ skipConsent: boolean; /** - * + * * @type {string} * @memberof Oauth2ToolConfigCreateParams */ frontchannelLogoutUri?: string; /** - * + * * @type {string} * @memberof Oauth2ToolConfigCreateParams */ scope?: string; /** - * + * * @type {Array} * @memberof Oauth2ToolConfigCreateParams */ redirectUris: Array; /** - * + * * @type {string} * @memberof Oauth2ToolConfigCreateParams */ tokenEndpointAuthMethod: string; } /** - * + * * @export * @interface Oauth2ToolConfigUpdateParams */ export interface Oauth2ToolConfigUpdateParams { /** - * + * * @type {string} * @memberof Oauth2ToolConfigUpdateParams */ type: string; /** - * + * * @type {string} * @memberof Oauth2ToolConfigUpdateParams */ baseUrl: string; /** - * + * * @type {string} * @memberof Oauth2ToolConfigUpdateParams */ clientId: string; /** - * + * * @type {string} * @memberof Oauth2ToolConfigUpdateParams */ clientSecret?: string; /** - * + * * @type {boolean} * @memberof Oauth2ToolConfigUpdateParams */ skipConsent: boolean; /** - * + * * @type {string} * @memberof Oauth2ToolConfigUpdateParams */ frontchannelLogoutUri?: string; /** - * + * * @type {string} * @memberof Oauth2ToolConfigUpdateParams */ scope?: string; /** - * + * * @type {Array} * @memberof Oauth2ToolConfigUpdateParams */ redirectUris: Array; /** - * + * * @type {string} * @memberof Oauth2ToolConfigUpdateParams */ tokenEndpointAuthMethod: string; } /** - * + * * @export * @interface OauthClientCreateBody */ @@ -6053,37 +6062,37 @@ export interface OauthClientCreateBody { response_types?: Array; } /** - * + * * @export * @interface OauthClientResponse */ export interface OauthClientResponse { /** - * + * * @type {Array} * @memberof OauthClientResponse */ allowed_cors_origins?: Array; /** - * + * * @type {Array} * @memberof OauthClientResponse */ audience: Array; /** - * + * * @type {string} * @memberof OauthClientResponse */ authorization_code_grant_access_token_lifespan: string; /** - * + * * @type {string} * @memberof OauthClientResponse */ authorization_code_grant_id_token_lifespan: string; /** - * + * * @type {string} * @memberof OauthClientResponse */ @@ -6101,7 +6110,7 @@ export interface OauthClientResponse { */ backchannel_logout_uri: string; /** - * + * * @type {string} * @memberof OauthClientResponse */ @@ -6131,7 +6140,7 @@ export interface OauthClientResponse { */ client_uri: string; /** - * + * * @type {Array} * @memberof OauthClientResponse */ @@ -6161,19 +6170,19 @@ export interface OauthClientResponse { */ grant_types?: Array; /** - * + * * @type {string} * @memberof OauthClientResponse */ implicit_grant_access_token_lifespan: string; /** - * + * * @type {string} * @memberof OauthClientResponse */ implicit_grant_id_token_lifespan: string; /** - * + * * @type {object} * @memberof OauthClientResponse */ @@ -6185,7 +6194,7 @@ export interface OauthClientResponse { */ jwks_uri: string; /** - * + * * @type {string} * @memberof OauthClientResponse */ @@ -6197,7 +6206,7 @@ export interface OauthClientResponse { */ logo_uri: string; /** - * + * * @type {object} * @memberof OauthClientResponse */ @@ -6209,13 +6218,13 @@ export interface OauthClientResponse { */ owner: string; /** - * + * * @type {string} * @memberof OauthClientResponse */ password_grant_access_token_lifespan: string; /** - * + * * @type {string} * @memberof OauthClientResponse */ @@ -6227,31 +6236,31 @@ export interface OauthClientResponse { */ policy_uri: string; /** - * + * * @type {Array} * @memberof OauthClientResponse */ post_logout_redirect_uris?: Array; /** - * + * * @type {Array} * @memberof OauthClientResponse */ redirect_uris?: Array; /** - * + * * @type {string} * @memberof OauthClientResponse */ refresh_token_grant_access_token_lifespan: string; /** - * + * * @type {string} * @memberof OauthClientResponse */ refresh_token_grant_id_token_lifespan: string; /** - * + * * @type {string} * @memberof OauthClientResponse */ @@ -6275,7 +6284,7 @@ export interface OauthClientResponse { */ request_object_signing_alg: string; /** - * + * * @type {Array} * @memberof OauthClientResponse */ @@ -6305,13 +6314,13 @@ export interface OauthClientResponse { */ subject_type: string; /** - * + * * @type {string} * @memberof OauthClientResponse */ token_endpoint_auth_method: string; /** - * + * * @type {string} * @memberof OauthClientResponse */ @@ -6329,14 +6338,14 @@ export interface OauthClientResponse { */ updated_at: string; /** - * JWS alg algorithm [JWA] REQUIRED for signing UserInfo Responses. + * JWS alg algorithm [JWA] REQUIRED for signing UserInfo Responses. * @type {string} * @memberof OauthClientResponse */ userinfo_signed_response_alg: string; } /** - * + * * @export * @interface OauthClientUpdateBody */ @@ -6397,7 +6406,7 @@ export interface OauthClientUpdateBody { response_types?: Array; } /** - * + * * @export * @interface OauthConfigResponse */ @@ -6482,7 +6491,7 @@ export interface OauthConfigResponse { endSessionEndpoint?: string; } /** - * + * * @export * @interface OauthProviderLoginResponse */ @@ -6500,13 +6509,13 @@ export interface OauthProviderLoginResponse { */ challenge: string; /** - * + * * @type {OauthClientResponse} * @memberof OauthProviderLoginResponse */ client: OauthClientResponse; /** - * + * * @type {OidcContextResponse} * @memberof OauthProviderLoginResponse */ @@ -6518,7 +6527,7 @@ export interface OauthProviderLoginResponse { */ request_url: string; /** - * + * * @type {Array} * @memberof OauthProviderLoginResponse */ @@ -6549,100 +6558,100 @@ export interface OauthProviderLoginResponse { subject: string; } /** - * + * * @export * @interface OidcContextResponse */ export interface OidcContextResponse { /** - * + * * @type {Array} * @memberof OidcContextResponse */ acr_values: Array; /** - * + * * @type {string} * @memberof OidcContextResponse */ display: string; /** - * + * * @type {object} * @memberof OidcContextResponse */ id_token_hint_claims: object; /** - * + * * @type {string} * @memberof OidcContextResponse */ login_hint: string; /** - * + * * @type {Array} * @memberof OidcContextResponse */ ui_locales: Array; } /** - * + * * @export * @interface OidcLogoutBodyParams */ export interface OidcLogoutBodyParams { /** - * + * * @type {string} * @memberof OidcLogoutBodyParams */ logout_token: string; } /** - * + * * @export * @interface ParentConsentResponse */ export interface ParentConsentResponse { /** - * + * * @type {string} * @memberof ParentConsentResponse */ form: string; /** - * + * * @type {boolean} * @memberof ParentConsentResponse */ privacyConsent: boolean; /** - * + * * @type {boolean} * @memberof ParentConsentResponse */ termsOfUseConsent: boolean; /** - * + * * @type {string} * @memberof ParentConsentResponse */ dateOfPrivacyConsent: string; /** - * + * * @type {string} * @memberof ParentConsentResponse */ dateOfTermsOfUseConsent: string; /** - * + * * @type {string} * @memberof ParentConsentResponse */ _id: string; } /** - * + * * @export * @interface PatchGroupParams */ @@ -6655,7 +6664,7 @@ export interface PatchGroupParams { title: string; } /** - * + * * @export * @interface PatchMyAccountParams */ @@ -6692,7 +6701,7 @@ export interface PatchMyAccountParams { lastName?: string | null; } /** - * + * * @export * @interface PatchMyPasswordParams */ @@ -6711,7 +6720,7 @@ export interface PatchMyPasswordParams { confirmPassword: string; } /** - * + * * @export * @interface PatchOrderParams */ @@ -6724,7 +6733,7 @@ export interface PatchOrderParams { elements: Array; } /** - * + * * @export * @interface PatchVisibilityParams */ @@ -6737,26 +6746,26 @@ export interface PatchVisibilityParams { visibility: boolean; } /** - * + * * @export * @interface PeriodResponse */ export interface PeriodResponse { /** - * + * * @type {string} * @memberof PeriodResponse */ from: string; /** - * + * * @type {string} * @memberof PeriodResponse */ until: string; } /** - * + * * @export * @enum {string} */ @@ -6933,20 +6942,20 @@ export enum Permission { } /** - * + * * @export * @interface PreferredToolListResponse */ export interface PreferredToolListResponse { /** - * + * * @type {Array} * @memberof PreferredToolListResponse */ data: Array; } /** - * + * * @export * @interface PreferredToolResponse */ @@ -6971,58 +6980,58 @@ export interface PreferredToolResponse { iconName: string; } /** - * + * * @export * @interface ProviderConfigResponse */ export interface ProviderConfigResponse { /** - * + * * @type {string} * @memberof ProviderConfigResponse */ provider: string; } /** - * + * * @export * @interface PseudonymResponse */ export interface PseudonymResponse { /** - * + * * @type {string} * @memberof PseudonymResponse */ id: string; /** - * + * * @type {string} * @memberof PseudonymResponse */ toolId: string; /** - * + * * @type {string} * @memberof PseudonymResponse */ userId: string; } /** - * + * * @export * @interface PublicSystemListResponse */ export interface PublicSystemListResponse { /** - * + * * @type {Array} * @memberof PublicSystemListResponse */ data: Array; } /** - * + * * @export * @interface PublicSystemResponse */ @@ -7059,7 +7068,7 @@ export interface PublicSystemResponse { oauthConfig?: OauthConfigResponse | null; } /** - * + * * @export * @interface RedirectResponse */ @@ -7072,7 +7081,7 @@ export interface RedirectResponse { redirect_to: string; } /** - * + * * @export * @interface RemoveRoomMembersBodyParams */ @@ -7085,75 +7094,75 @@ export interface RemoveRoomMembersBodyParams { userIds: Array; } /** - * + * * @export * @interface RenameBodyParams */ export interface RenameBodyParams { /** - * + * * @type {string} * @memberof RenameBodyParams */ title: string; } /** - * + * * @export * @interface ResolvedUserResponse */ export interface ResolvedUserResponse { /** - * + * * @type {string} * @memberof ResolvedUserResponse */ firstName: string; /** - * + * * @type {string} * @memberof ResolvedUserResponse */ lastName: string; /** - * + * * @type {string} * @memberof ResolvedUserResponse */ id: string; /** - * + * * @type {string} * @memberof ResolvedUserResponse */ createdAt: string; /** - * + * * @type {string} * @memberof ResolvedUserResponse */ updatedAt: string; /** - * + * * @type {Array} * @memberof ResolvedUserResponse */ roles: Array; /** - * + * * @type {Array} * @memberof ResolvedUserResponse */ permissions: Array; /** - * + * * @type {string} * @memberof ResolvedUserResponse */ schoolId: string; } /** - * + * * @export * @interface RichText */ @@ -7184,95 +7193,95 @@ export enum RichTextTypeEnum { } /** - * + * * @export * @interface RichTextContentBody */ export interface RichTextContentBody { /** - * + * * @type {string} * @memberof RichTextContentBody */ text: string; /** - * + * * @type {string} * @memberof RichTextContentBody */ inputFormat: string; } /** - * + * * @export * @interface RichTextElementContent */ export interface RichTextElementContent { /** - * + * * @type {string} * @memberof RichTextElementContent */ text: string; /** - * + * * @type {string} * @memberof RichTextElementContent */ inputFormat: string; } /** - * + * * @export * @interface RichTextElementContentBody */ export interface RichTextElementContentBody { /** - * + * * @type {ContentElementType} * @memberof RichTextElementContentBody */ type: ContentElementType; /** - * + * * @type {RichTextContentBody} * @memberof RichTextElementContentBody */ content: RichTextContentBody; } /** - * + * * @export * @interface RichTextElementResponse */ export interface RichTextElementResponse { /** - * + * * @type {string} * @memberof RichTextElementResponse */ id: string; /** - * + * * @type {ContentElementType} * @memberof RichTextElementResponse */ type: ContentElementType; /** - * + * * @type {RichTextElementContent} * @memberof RichTextElementResponse */ content: RichTextElementContent; /** - * + * * @type {TimestampsResponse} * @memberof RichTextElementResponse */ timestamps: TimestampsResponse; } /** - * + * * @export * @enum {string} */ @@ -7305,50 +7314,50 @@ export enum RoleName { } /** - * + * * @export * @interface RoomBoardItemResponse */ export interface RoomBoardItemResponse { /** - * + * * @type {string} * @memberof RoomBoardItemResponse */ id: string; /** - * + * * @type {string} * @memberof RoomBoardItemResponse */ title: string; /** - * + * * @type {BoardLayout} * @memberof RoomBoardItemResponse */ layout: BoardLayout; /** - * + * * @type {boolean} * @memberof RoomBoardItemResponse */ isVisible: boolean; /** - * + * * @type {string} * @memberof RoomBoardItemResponse */ createdAt: string; /** - * + * * @type {string} * @memberof RoomBoardItemResponse */ updatedAt: string; } /** - * + * * @export * @interface RoomBoardListResponse */ @@ -7379,7 +7388,7 @@ export interface RoomBoardListResponse { limit: number; } /** - * + * * @export * @enum {string} */ @@ -7388,6 +7397,7 @@ export enum RoomColor { Pink = 'pink', Red = 'red', Orange = 'orange', + Yellow = 'yellow', Olive = 'olive', Green = 'green', Turquoise = 'turquoise', @@ -7399,123 +7409,123 @@ export enum RoomColor { } /** - * + * * @export * @interface RoomDetailsResponse */ export interface RoomDetailsResponse { /** - * + * * @type {string} * @memberof RoomDetailsResponse */ id: string; /** - * + * * @type {string} * @memberof RoomDetailsResponse */ name: string; /** - * + * * @type {RoomColor} * @memberof RoomDetailsResponse */ color: RoomColor; /** - * + * * @type {string} * @memberof RoomDetailsResponse */ schoolId: string; /** - * + * * @type {string} * @memberof RoomDetailsResponse */ startDate?: string; /** - * + * * @type {string} * @memberof RoomDetailsResponse */ endDate?: string; /** - * + * * @type {string} * @memberof RoomDetailsResponse */ createdAt: string; /** - * + * * @type {string} * @memberof RoomDetailsResponse */ updatedAt: string; /** - * + * * @type {Array} * @memberof RoomDetailsResponse */ permissions: Array; } /** - * + * * @export * @interface RoomItemResponse */ export interface RoomItemResponse { /** - * + * * @type {string} * @memberof RoomItemResponse */ id: string; /** - * + * * @type {string} * @memberof RoomItemResponse */ name: string; /** - * + * * @type {RoomColor} * @memberof RoomItemResponse */ color: RoomColor; /** - * + * * @type {string} * @memberof RoomItemResponse */ schoolId: string; /** - * + * * @type {string} * @memberof RoomItemResponse */ startDate?: string; /** - * + * * @type {string} * @memberof RoomItemResponse */ endDate?: string; /** - * + * * @type {string} * @memberof RoomItemResponse */ createdAt: string; /** - * + * * @type {string} * @memberof RoomItemResponse */ updatedAt: string; } /** - * + * * @export * @interface RoomListResponse */ @@ -7546,70 +7556,70 @@ export interface RoomListResponse { limit: number; } /** - * + * * @export * @interface RoomMemberListResponse */ export interface RoomMemberListResponse { /** - * + * * @type {Array} * @memberof RoomMemberListResponse */ data: Array; } /** - * + * * @export * @interface RoomMemberResponse */ export interface RoomMemberResponse { /** - * + * * @type {string} * @memberof RoomMemberResponse */ firstName: string; /** - * + * * @type {string} * @memberof RoomMemberResponse */ lastName: string; /** - * + * * @type {string} * @memberof RoomMemberResponse */ roleName: string; /** - * + * * @type {string} * @memberof RoomMemberResponse */ schoolName: string; /** - * + * * @type {string} * @memberof RoomMemberResponse */ userId: string; } /** - * + * * @export * @interface SchoolExistsResponse */ export interface SchoolExistsResponse { /** - * + * * @type {boolean} * @memberof SchoolExistsResponse */ exists: boolean; } /** - * + * * @export * @interface SchoolExternalToolConfigurationStatusResponse */ @@ -7628,88 +7638,88 @@ export interface SchoolExternalToolConfigurationStatusResponse { isGloballyDeactivated: boolean; } /** - * + * * @export * @interface SchoolExternalToolConfigurationTemplateListResponse */ export interface SchoolExternalToolConfigurationTemplateListResponse { /** - * + * * @type {Array} * @memberof SchoolExternalToolConfigurationTemplateListResponse */ data: Array; } /** - * + * * @export * @interface SchoolExternalToolConfigurationTemplateResponse */ export interface SchoolExternalToolConfigurationTemplateResponse { /** - * + * * @type {string} * @memberof SchoolExternalToolConfigurationTemplateResponse */ externalToolId: string; /** - * + * * @type {string} * @memberof SchoolExternalToolConfigurationTemplateResponse */ name: string; /** - * + * * @type {string} * @memberof SchoolExternalToolConfigurationTemplateResponse */ baseUrl: string; /** - * + * * @type {string} * @memberof SchoolExternalToolConfigurationTemplateResponse */ logoUrl?: string; /** - * + * * @type {Array} * @memberof SchoolExternalToolConfigurationTemplateResponse */ parameters: Array; } /** - * + * * @export * @interface SchoolExternalToolMetadataResponse */ export interface SchoolExternalToolMetadataResponse { /** - * + * * @type {ContextExternalToolCountPerContextResponse} * @memberof SchoolExternalToolMetadataResponse */ contextExternalToolCountPerContext: ContextExternalToolCountPerContextResponse; } /** - * + * * @export * @interface SchoolExternalToolPostParams */ export interface SchoolExternalToolPostParams { /** - * + * * @type {string} * @memberof SchoolExternalToolPostParams */ toolId: string; /** - * + * * @type {string} * @memberof SchoolExternalToolPostParams */ schoolId: string; /** - * + * * @type {Array} * @memberof SchoolExternalToolPostParams */ @@ -7722,75 +7732,75 @@ export interface SchoolExternalToolPostParams { isDeactivated: boolean; } /** - * + * * @export * @interface SchoolExternalToolResponse */ export interface SchoolExternalToolResponse { /** - * + * * @type {string} * @memberof SchoolExternalToolResponse */ id: string; /** - * + * * @type {string} * @memberof SchoolExternalToolResponse */ name: string; /** - * + * * @type {string} * @memberof SchoolExternalToolResponse */ toolId: string; /** - * + * * @type {string} * @memberof SchoolExternalToolResponse */ schoolId: string; /** - * + * * @type {boolean} * @memberof SchoolExternalToolResponse */ isDeactivated: boolean; /** - * + * * @type {Array} * @memberof SchoolExternalToolResponse */ parameters: Array; /** - * + * * @type {SchoolExternalToolConfigurationStatusResponse} * @memberof SchoolExternalToolResponse */ status: SchoolExternalToolConfigurationStatusResponse; /** - * + * * @type {Array} * @memberof SchoolExternalToolResponse */ restrictToContexts?: Array; } /** - * + * * @export * @interface SchoolExternalToolSearchListResponse */ export interface SchoolExternalToolSearchListResponse { /** - * + * * @type {Array} * @memberof SchoolExternalToolSearchListResponse */ data: Array; } /** - * + * * @export * @enum {string} */ @@ -7807,51 +7817,51 @@ export enum SchoolFeature { } /** - * + * * @export * @interface SchoolForExternalInviteResponse */ export interface SchoolForExternalInviteResponse { /** - * + * * @type {string} * @memberof SchoolForExternalInviteResponse */ id: string; /** - * + * * @type {string} * @memberof SchoolForExternalInviteResponse */ name: string; } /** - * + * * @export * @interface SchoolForLdapLoginResponse */ export interface SchoolForLdapLoginResponse { /** - * + * * @type {string} * @memberof SchoolForLdapLoginResponse */ id: string; /** - * + * * @type {string} * @memberof SchoolForLdapLoginResponse */ name: string; /** - * + * * @type {Array} * @memberof SchoolForLdapLoginResponse */ systems: Array; } /** - * + * * @export * @interface SchoolInfoResponse */ @@ -7870,45 +7880,45 @@ export interface SchoolInfoResponse { name: string; } /** - * + * * @export * @interface SchoolLogo */ export interface SchoolLogo { /** - * + * * @type {string} * @memberof SchoolLogo */ dataUrl?: string; /** - * + * * @type {string} * @memberof SchoolLogo */ name?: string; } /** - * + * * @export * @interface SchoolPermissionsParams */ export interface SchoolPermissionsParams { /** - * + * * @type {TeacherPermissionParams} * @memberof SchoolPermissionsParams */ teacher?: TeacherPermissionParams; /** - * + * * @type {StudentPermissionParams} * @memberof SchoolPermissionsParams */ student?: StudentPermissionParams; } /** - * + * * @export * @enum {string} */ @@ -7921,231 +7931,231 @@ export enum SchoolPurpose { } /** - * + * * @export * @interface SchoolResponse */ export interface SchoolResponse { /** - * + * * @type {string} * @memberof SchoolResponse */ id: string; /** - * + * * @type {string} * @memberof SchoolResponse */ createdAt: string; /** - * + * * @type {string} * @memberof SchoolResponse */ updatedAt: string; /** - * + * * @type {string} * @memberof SchoolResponse */ name: string; /** - * + * * @type {string} * @memberof SchoolResponse */ officialSchoolNumber?: string; /** - * + * * @type {SchoolYearResponse} * @memberof SchoolResponse */ currentYear?: SchoolYearResponse; /** - * + * * @type {FederalStateResponse} * @memberof SchoolResponse */ federalState: FederalStateResponse; /** - * + * * @type {CountyResponse} * @memberof SchoolResponse */ county?: CountyResponse; /** - * + * * @type {SchoolPurpose} * @memberof SchoolResponse */ purpose?: SchoolPurpose; /** - * + * * @type {Array} * @memberof SchoolResponse */ features: Array; /** - * + * * @type {Array} * @memberof SchoolResponse */ systemIds: Array; /** - * + * * @type {boolean} * @memberof SchoolResponse */ inUserMigration?: boolean; /** - * + * * @type {boolean} * @memberof SchoolResponse */ inMaintenance: boolean; /** - * + * * @type {boolean} * @memberof SchoolResponse */ isExternal: boolean; /** - * + * * @type {SchoolLogo} * @memberof SchoolResponse */ logo?: SchoolLogo; /** - * + * * @type {FileStorageType} * @memberof SchoolResponse */ fileStorageType?: FileStorageType; /** - * + * * @type {string} * @memberof SchoolResponse */ language?: string; /** - * + * * @type {string} * @memberof SchoolResponse */ timezone?: string; /** - * + * * @type {object} * @memberof SchoolResponse */ permissions?: object; /** - * + * * @type {YearsResponse} * @memberof SchoolResponse */ years: YearsResponse; /** - * + * * @type {Array} * @memberof SchoolResponse */ instanceFeatures: Array; } /** - * + * * @export * @interface SchoolSystemResponse */ export interface SchoolSystemResponse { /** - * + * * @type {string} * @memberof SchoolSystemResponse */ id: string; /** - * + * * @type {string} * @memberof SchoolSystemResponse */ type: string; /** - * + * * @type {string} * @memberof SchoolSystemResponse */ alias?: string; /** - * + * * @type {ProviderConfigResponse} * @memberof SchoolSystemResponse */ ldapConfig?: ProviderConfigResponse; /** - * + * * @type {ProviderConfigResponse} * @memberof SchoolSystemResponse */ oauthConfig?: ProviderConfigResponse; } /** - * + * * @export * @interface SchoolUpdateBodyParams */ export interface SchoolUpdateBodyParams { /** - * + * * @type {string} * @memberof SchoolUpdateBodyParams */ name?: string; /** - * + * * @type {string} * @memberof SchoolUpdateBodyParams */ officialSchoolNumber?: string; /** - * + * * @type {SchoolLogo} * @memberof SchoolUpdateBodyParams */ logo?: SchoolLogo; /** - * + * * @type {string} * @memberof SchoolUpdateBodyParams */ fileStorageType?: SchoolUpdateBodyParamsFileStorageTypeEnum; /** - * + * * @type {LanguageType} * @memberof SchoolUpdateBodyParams */ language?: LanguageType; /** - * + * * @type {Array} * @memberof SchoolUpdateBodyParams */ features?: Array; /** - * + * * @type {SchoolPermissionsParams} * @memberof SchoolUpdateBodyParams */ permissions?: SchoolPermissionsParams; /** - * + * * @type {string} * @memberof SchoolUpdateBodyParams */ countyId?: string; /** - * + * * @type {boolean} * @memberof SchoolUpdateBodyParams */ @@ -8161,7 +8171,7 @@ export enum SchoolUpdateBodyParamsFileStorageTypeEnum { } /** - * + * * @export * @interface SchoolUserListResponse */ @@ -8192,38 +8202,38 @@ export interface SchoolUserListResponse { limit: number; } /** - * + * * @export * @interface SchoolUserResponse */ export interface SchoolUserResponse { /** - * + * * @type {string} * @memberof SchoolUserResponse */ firstName: string; /** - * + * * @type {string} * @memberof SchoolUserResponse */ lastName: string; /** - * + * * @type {string} * @memberof SchoolUserResponse */ schoolName: string; /** - * + * * @type {string} * @memberof SchoolUserResponse */ id: string; } /** - * + * * @export * @enum {string} */ @@ -8234,100 +8244,100 @@ export enum SchoolYearQueryType { } /** - * + * * @export * @interface SchoolYearResponse */ export interface SchoolYearResponse { /** - * + * * @type {string} * @memberof SchoolYearResponse */ id: string; /** - * + * * @type {string} * @memberof SchoolYearResponse */ name: string; /** - * + * * @type {string} * @memberof SchoolYearResponse */ startDate: string; /** - * + * * @type {string} * @memberof SchoolYearResponse */ endDate: string; } /** - * + * * @export * @interface SchulConneXProvisioningOptionsParams */ export interface SchulConneXProvisioningOptionsParams { /** - * + * * @type {boolean} * @memberof SchulConneXProvisioningOptionsParams */ groupProvisioningClassesEnabled: boolean; /** - * + * * @type {boolean} * @memberof SchulConneXProvisioningOptionsParams */ groupProvisioningCoursesEnabled: boolean; /** - * + * * @type {boolean} * @memberof SchulConneXProvisioningOptionsParams */ groupProvisioningOtherEnabled: boolean; /** - * + * * @type {boolean} * @memberof SchulConneXProvisioningOptionsParams */ schoolExternalToolProvisioningEnabled: boolean; } /** - * + * * @export * @interface SchulConneXProvisioningOptionsResponse */ export interface SchulConneXProvisioningOptionsResponse { /** - * + * * @type {boolean} * @memberof SchulConneXProvisioningOptionsResponse */ groupProvisioningClassesEnabled: boolean; /** - * + * * @type {boolean} * @memberof SchulConneXProvisioningOptionsResponse */ groupProvisioningCoursesEnabled: boolean; /** - * + * * @type {boolean} * @memberof SchulConneXProvisioningOptionsResponse */ groupProvisioningOtherEnabled: boolean; /** - * + * * @type {boolean} * @memberof SchulConneXProvisioningOptionsResponse */ schoolExternalToolProvisioningEnabled: boolean; } /** - * + * * @export * @enum {string} */ @@ -8339,20 +8349,20 @@ export enum SchulcloudTheme { } /** - * + * * @export * @interface SetHeightBodyParams */ export interface SetHeightBodyParams { /** - * + * * @type {number} * @memberof SetHeightBodyParams */ height: number; } /** - * + * * @export * @interface ShareTokenBodyParams */ @@ -8395,7 +8405,7 @@ export enum ShareTokenBodyParamsParentTypeEnum { } /** - * + * * @export * @interface ShareTokenImportBodyParams */ @@ -8414,25 +8424,25 @@ export interface ShareTokenImportBodyParams { destinationId?: string | null; } /** - * + * * @export * @interface ShareTokenInfoResponse */ export interface ShareTokenInfoResponse { /** - * + * * @type {string} * @memberof ShareTokenInfoResponse */ token: string; /** - * + * * @type {string} * @memberof ShareTokenInfoResponse */ parentType: ShareTokenInfoResponseParentTypeEnum; /** - * + * * @type {string} * @memberof ShareTokenInfoResponse */ @@ -8451,19 +8461,19 @@ export enum ShareTokenInfoResponseParentTypeEnum { } /** - * + * * @export * @interface ShareTokenPayloadResponse */ export interface ShareTokenPayloadResponse { /** - * + * * @type {string} * @memberof ShareTokenPayloadResponse */ parentType: ShareTokenPayloadResponseParentTypeEnum; /** - * + * * @type {string} * @memberof ShareTokenPayloadResponse */ @@ -8482,32 +8492,32 @@ export enum ShareTokenPayloadResponseParentTypeEnum { } /** - * + * * @export * @interface ShareTokenResponse */ export interface ShareTokenResponse { /** - * + * * @type {string} * @memberof ShareTokenResponse */ token: string; /** - * + * * @type {ShareTokenPayloadResponse} * @memberof ShareTokenResponse */ payload: ShareTokenPayloadResponse; /** - * + * * @type {string} * @memberof ShareTokenResponse */ expiresAt?: string; } /** - * + * * @export * @interface SingleColumnBoardResponse */ @@ -8550,20 +8560,20 @@ export interface SingleColumnBoardResponse { isSynchronized: boolean; } /** - * + * * @export * @interface StudentPermissionParams */ export interface StudentPermissionParams { /** - * + * * @type {boolean} * @memberof StudentPermissionParams */ LERNSTORE_VIEW?: boolean; } /** - * + * * @export * @interface SubmissionContainerContentBody */ @@ -8576,7 +8586,7 @@ export interface SubmissionContainerContentBody { dueDate?: string; } /** - * + * * @export * @interface SubmissionContainerElementContent */ @@ -8589,207 +8599,207 @@ export interface SubmissionContainerElementContent { dueDate: string; } /** - * + * * @export * @interface SubmissionContainerElementContentBody */ export interface SubmissionContainerElementContentBody { /** - * + * * @type {ContentElementType} * @memberof SubmissionContainerElementContentBody */ type: ContentElementType; /** - * + * * @type {SubmissionContainerContentBody} * @memberof SubmissionContainerElementContentBody */ content: SubmissionContainerContentBody; } /** - * + * * @export * @interface SubmissionContainerElementResponse */ export interface SubmissionContainerElementResponse { /** - * + * * @type {string} * @memberof SubmissionContainerElementResponse */ id: string; /** - * + * * @type {ContentElementType} * @memberof SubmissionContainerElementResponse */ type: ContentElementType; /** - * + * * @type {SubmissionContainerElementContent} * @memberof SubmissionContainerElementResponse */ content: SubmissionContainerElementContent; /** - * + * * @type {TimestampsResponse} * @memberof SubmissionContainerElementResponse */ timestamps: TimestampsResponse; } /** - * + * * @export * @interface SubmissionItemResponse */ export interface SubmissionItemResponse { /** - * + * * @type {string} * @memberof SubmissionItemResponse */ id: string; /** - * + * * @type {TimestampsResponse} * @memberof SubmissionItemResponse */ timestamps: TimestampsResponse; /** - * + * * @type {boolean} * @memberof SubmissionItemResponse */ completed: boolean; /** - * + * * @type {string} * @memberof SubmissionItemResponse */ userId: string; /** - * + * * @type {Array} * @memberof SubmissionItemResponse */ elements: Array; } /** - * + * * @export * @interface SubmissionStatusListResponse */ export interface SubmissionStatusListResponse { /** - * + * * @type {Array} * @memberof SubmissionStatusListResponse */ data: Array; } /** - * + * * @export * @interface SubmissionStatusResponse */ export interface SubmissionStatusResponse { /** - * + * * @type {string} * @memberof SubmissionStatusResponse */ id: string; /** - * + * * @type {Array} * @memberof SubmissionStatusResponse */ submitters: Array; /** - * + * * @type {boolean} * @memberof SubmissionStatusResponse */ isSubmitted: boolean; /** - * + * * @type {number} * @memberof SubmissionStatusResponse */ grade?: number; /** - * + * * @type {boolean} * @memberof SubmissionStatusResponse */ isGraded: boolean; /** - * + * * @type {string} * @memberof SubmissionStatusResponse */ submittingCourseGroupName?: string; } /** - * + * * @export * @interface SubmissionsResponse */ export interface SubmissionsResponse { /** - * + * * @type {Array} * @memberof SubmissionsResponse */ submissionItemsResponse: Array; /** - * + * * @type {Array} * @memberof SubmissionsResponse */ users: Array; } /** - * + * * @export * @interface SuccessfulResponse */ export interface SuccessfulResponse { /** - * + * * @type {boolean} * @memberof SuccessfulResponse */ successful: boolean; } /** - * + * * @export * @interface SystemForLdapLoginResponse */ export interface SystemForLdapLoginResponse { /** - * + * * @type {string} * @memberof SystemForLdapLoginResponse */ id: string; /** - * + * * @type {string} * @memberof SystemForLdapLoginResponse */ type: string; /** - * + * * @type {string} * @memberof SystemForLdapLoginResponse */ alias: string; } /** - * + * * @export * @enum {string} */ @@ -8807,7 +8817,7 @@ export enum SystemType { } /** - * + * * @export * @interface TargetInfoResponse */ @@ -8826,20 +8836,20 @@ export interface TargetInfoResponse { name: string; } /** - * + * * @export * @interface TargetUserIdParams */ export interface TargetUserIdParams { /** - * + * * @type {string} * @memberof TargetUserIdParams */ userId: string; } /** - * + * * @export * @interface TaskCopyApiParams */ @@ -8858,7 +8868,7 @@ export interface TaskCopyApiParams { lessonId?: string; } /** - * + * * @export * @interface TaskListResponse */ @@ -8889,49 +8899,49 @@ export interface TaskListResponse { limit: number; } /** - * + * * @export * @interface TaskResponse */ export interface TaskResponse { /** - * + * * @type {string} * @memberof TaskResponse */ id: string; /** - * + * * @type {string} * @memberof TaskResponse */ name: string; /** - * + * * @type {string} * @memberof TaskResponse */ availableDate?: string; /** - * + * * @type {string} * @memberof TaskResponse */ dueDate?: string; /** - * + * * @type {string} * @memberof TaskResponse */ courseName: string; /** - * + * * @type {string} * @memberof TaskResponse */ lessonName?: string; /** - * + * * @type {string} * @memberof TaskResponse */ @@ -8943,156 +8953,156 @@ export interface TaskResponse { */ description?: RichText; /** - * + * * @type {boolean} * @memberof TaskResponse */ lessonHidden: boolean; /** - * + * * @type {string} * @memberof TaskResponse */ displayColor?: string; /** - * + * * @type {string} * @memberof TaskResponse */ createdAt: string; /** - * + * * @type {string} * @memberof TaskResponse */ updatedAt: string; /** - * + * * @type {TaskStatusResponse} * @memberof TaskResponse */ status: TaskStatusResponse; } /** - * + * * @export * @interface TaskStatusResponse */ export interface TaskStatusResponse { /** - * + * * @type {number} * @memberof TaskStatusResponse */ submitted: number; /** - * + * * @type {number} * @memberof TaskStatusResponse */ maxSubmissions: number; /** - * + * * @type {number} * @memberof TaskStatusResponse */ graded: number; /** - * + * * @type {boolean} * @memberof TaskStatusResponse */ isDraft: boolean; /** - * + * * @type {boolean} * @memberof TaskStatusResponse */ isSubstitutionTeacher: boolean; /** - * + * * @type {boolean} * @memberof TaskStatusResponse */ isFinished: boolean; } /** - * + * * @export * @interface TeacherPermissionParams */ export interface TeacherPermissionParams { /** - * + * * @type {boolean} * @memberof TeacherPermissionParams */ STUDENT_LIST?: boolean; } /** - * + * * @export * @interface TeamPermissionsBody */ export interface TeamPermissionsBody { /** - * + * * @type {boolean} * @memberof TeamPermissionsBody */ read: boolean; /** - * + * * @type {boolean} * @memberof TeamPermissionsBody */ write: boolean; /** - * + * * @type {boolean} * @memberof TeamPermissionsBody */ create: boolean; /** - * + * * @type {boolean} * @memberof TeamPermissionsBody */ _delete: boolean; /** - * + * * @type {boolean} * @memberof TeamPermissionsBody */ share: boolean; } /** - * + * * @export * @interface TimestampsResponse */ export interface TimestampsResponse { /** - * + * * @type {string} * @memberof TimestampsResponse */ lastUpdatedAt: string; /** - * + * * @type {string} * @memberof TimestampsResponse */ createdAt: string; /** - * + * * @type {string} * @memberof TimestampsResponse */ deletedAt?: string; } /** - * + * * @export * @enum {string} */ @@ -9101,7 +9111,7 @@ export enum Timezone { } /** - * + * * @export * @enum {string} */ @@ -9112,7 +9122,7 @@ export enum ToolConfigType { } /** - * + * * @export * @enum {string} */ @@ -9123,20 +9133,20 @@ export enum ToolContextType { } /** - * + * * @export * @interface ToolContextTypesListResponse */ export interface ToolContextTypesListResponse { /** - * + * * @type {Array} * @memberof ToolContextTypesListResponse */ data: Array; } /** - * + * * @export * @interface ToolLaunchRequestResponse */ @@ -9166,7 +9176,7 @@ export interface ToolLaunchRequestResponse { */ openNewTab?: boolean; /** - * + * * @type {LaunchType} * @memberof ToolLaunchRequestResponse */ @@ -9183,20 +9193,20 @@ export enum ToolLaunchRequestResponseMethodEnum { } /** - * + * * @export * @interface ToolReferenceListResponse */ export interface ToolReferenceListResponse { /** - * + * * @type {Array} * @memberof ToolReferenceListResponse */ data: Array; } /** - * + * * @export * @interface ToolReferenceResponse */ @@ -9250,40 +9260,40 @@ export interface ToolReferenceResponse { */ isLtiDeepLinkingTool: boolean; /** - * + * * @type {LtiDeepLinkResponse} * @memberof ToolReferenceResponse */ ltiDeepLink?: LtiDeepLinkResponse; } /** - * + * * @export * @interface UpdateBoardTitleParams */ export interface UpdateBoardTitleParams { /** - * + * * @type {string} * @memberof UpdateBoardTitleParams */ title: string; } /** - * + * * @export * @interface UpdateElementContentBodyParams */ export interface UpdateElementContentBodyParams { /** - * - * @type {FileElementContentBody | LinkElementContentBody | RichTextElementContentBody | SubmissionContainerElementContentBody | ExternalToolElementContentBody | DrawingElementContentBody} + * + * @type {FileElementContentBody | LinkElementContentBody | RichTextElementContentBody | SubmissionContainerElementContentBody | ExternalToolElementContentBody | DrawingElementContentBody | VideoConferenceElementContentBody} * @memberof UpdateElementContentBodyParams */ - data: FileElementContentBody | LinkElementContentBody | RichTextElementContentBody | SubmissionContainerElementContentBody | ExternalToolElementContentBody | DrawingElementContentBody; + data: FileElementContentBody | LinkElementContentBody | RichTextElementContentBody | SubmissionContainerElementContentBody | ExternalToolElementContentBody | DrawingElementContentBody | VideoConferenceElementContentBody; } /** - * + * * @export * @interface UpdateFlagParams */ @@ -9296,7 +9306,7 @@ export interface UpdateFlagParams { flagged: boolean; } /** - * + * * @export * @interface UpdateMatchParams */ @@ -9309,7 +9319,7 @@ export interface UpdateMatchParams { userId: string; } /** - * + * * @export * @interface UpdateNewsParams */ @@ -9334,7 +9344,7 @@ export interface UpdateNewsParams { displayAt?: string; } /** - * + * * @export * @interface UpdateRoomBodyParams */ @@ -9346,7 +9356,7 @@ export interface UpdateRoomBodyParams { */ name: string; /** - * + * * @type {RoomColor} * @memberof UpdateRoomBodyParams */ @@ -9365,7 +9375,7 @@ export interface UpdateRoomBodyParams { endDate?: string; } /** - * + * * @export * @interface UpdateSubmissionItemBodyParams */ @@ -9378,100 +9388,69 @@ export interface UpdateSubmissionItemBodyParams { completed: boolean; } /** - * + * * @export * @interface UserConsentResponse */ export interface UserConsentResponse { /** - * + * * @type {string} * @memberof UserConsentResponse */ form: string; /** - * + * * @type {boolean} * @memberof UserConsentResponse */ privacyConsent: boolean; /** - * + * * @type {boolean} * @memberof UserConsentResponse */ termsOfUseConsent: boolean; /** - * + * * @type {string} * @memberof UserConsentResponse */ dateOfPrivacyConsent: string; /** - * + * * @type {string} * @memberof UserConsentResponse */ dateOfTermsOfUseConsent: string; } /** - * + * * @export * @interface UserDataResponse */ export interface UserDataResponse { /** - * + * * @type {string} * @memberof UserDataResponse */ firstName: string; /** - * + * * @type {string} * @memberof UserDataResponse */ lastName: string; /** - * + * * @type {string} * @memberof UserDataResponse */ userId: string; } /** - * - * @export - * @interface UserIdAndRole - */ -export interface UserIdAndRole { - /** - * The ID of the user - * @type {string} - * @memberof UserIdAndRole - */ - userId: string; - /** - * The role of the user - * @type {string} - * @memberof UserIdAndRole - */ - roleName: UserIdAndRoleRoleNameEnum; -} - -/** - * @export - * @enum {string} - */ -export enum UserIdAndRoleRoleNameEnum { - Roomowner = 'roomowner', - Roomadmin = 'roomadmin', - Roomeditor = 'roomeditor', - Roomviewer = 'roomviewer' -} - -/** - * + * * @export * @interface UserInfoResponse */ @@ -9496,7 +9475,7 @@ export interface UserInfoResponse { lastName?: string; } /** - * + * * @export * @interface UserListResponse */ @@ -9527,20 +9506,20 @@ export interface UserListResponse { limit: number; } /** - * + * * @export * @interface UserLoginMigrationMandatoryParams */ export interface UserLoginMigrationMandatoryParams { /** - * + * * @type {boolean} * @memberof UserLoginMigrationMandatoryParams */ mandatory: boolean; } /** - * + * * @export * @interface UserLoginMigrationResponse */ @@ -9589,7 +9568,7 @@ export interface UserLoginMigrationResponse { finishedAt?: string; } /** - * + * * @export * @interface UserLoginMigrationSearchListResponse */ @@ -9620,7 +9599,7 @@ export interface UserLoginMigrationSearchListResponse { limit: number; } /** - * + * * @export * @interface UserMatchListResponse */ @@ -9651,7 +9630,7 @@ export interface UserMatchListResponse { limit: number; } /** - * + * * @export * @interface UserMatchResponse */ @@ -9713,92 +9692,92 @@ export enum UserMatchResponseMatchedByEnum { } /** - * + * * @export * @interface UserResponse */ export interface UserResponse { /** - * + * * @type {string} * @memberof UserResponse */ _id: string; /** - * + * * @type {string} * @memberof UserResponse */ firstName: string; /** - * + * * @type {string} * @memberof UserResponse */ lastName: string; /** - * + * * @type {string} * @memberof UserResponse */ email: string; /** - * + * * @type {string} * @memberof UserResponse */ createdAt: string; /** - * + * * @type {string} * @memberof UserResponse */ birthday: string; /** - * + * * @type {object} * @memberof UserResponse */ preferences: object; /** - * + * * @type {string} * @memberof UserResponse */ consentStatus: string; /** - * + * * @type {ConsentsResponse} * @memberof UserResponse */ consent: ConsentsResponse; /** - * + * * @type {Array} * @memberof UserResponse */ classes: Array; /** - * + * * @type {string} * @memberof UserResponse */ importHash: string; /** - * + * * @type {string} * @memberof UserResponse */ lastLoginSystemChange: string; /** - * + * * @type {string} * @memberof UserResponse */ outdatedSince: string; } /** - * + * * @export * @interface ValidationError */ @@ -9818,61 +9797,137 @@ export interface ValidationError { /** * The error title. * @type {string} - * @memberof ValidationError + * @memberof ValidationError + */ + title: string; + /** + * The error message. + * @type {string} + * @memberof ValidationError + */ + message: string; + /** + * The error details. + * @type {object} + * @memberof ValidationError + */ + details?: object; +} +/** + * + * @export + * @interface VideoConferenceContentBody + */ +export interface VideoConferenceContentBody { + /** + * + * @type {string} + * @memberof VideoConferenceContentBody + */ + title: string; +} +/** + * + * @export + * @interface VideoConferenceCreateParams + */ +export interface VideoConferenceCreateParams { + /** + * + * @type {boolean} + * @memberof VideoConferenceCreateParams + */ + everyAttendeeJoinsMuted?: boolean; + /** + * + * @type {boolean} + * @memberof VideoConferenceCreateParams + */ + everybodyJoinsAsModerator?: boolean; + /** + * + * @type {boolean} + * @memberof VideoConferenceCreateParams + */ + moderatorMustApproveJoinRequests?: boolean; + /** + * The URL that the BigBlueButton client will go to after users click the OK button on the ‘You have been logged out’ or ’This session was ended’ message. Has to be a URL from the same domain that the conference is started from. + * @type {string} + * @memberof VideoConferenceCreateParams + */ + logoutUrl?: string; +} +/** + * + * @export + * @interface VideoConferenceElementContent + */ +export interface VideoConferenceElementContent { + /** + * + * @type {string} + * @memberof VideoConferenceElementContent */ title: string; +} +/** + * + * @export + * @interface VideoConferenceElementContentBody + */ +export interface VideoConferenceElementContentBody { /** - * The error message. - * @type {string} - * @memberof ValidationError + * + * @type {ContentElementType} + * @memberof VideoConferenceElementContentBody */ - message: string; + type: ContentElementType; /** - * The error details. - * @type {object} - * @memberof ValidationError + * + * @type {VideoConferenceContentBody} + * @memberof VideoConferenceElementContentBody */ - details?: object; + content: VideoConferenceContentBody; } /** - * + * * @export - * @interface VideoConferenceCreateParams + * @interface VideoConferenceElementResponse */ -export interface VideoConferenceCreateParams { +export interface VideoConferenceElementResponse { /** - * - * @type {boolean} - * @memberof VideoConferenceCreateParams + * + * @type {string} + * @memberof VideoConferenceElementResponse */ - everyAttendeeJoinsMuted?: boolean; + id: string; /** - * - * @type {boolean} - * @memberof VideoConferenceCreateParams + * + * @type {ContentElementType} + * @memberof VideoConferenceElementResponse */ - everybodyJoinsAsModerator?: boolean; + type: ContentElementType; /** - * - * @type {boolean} - * @memberof VideoConferenceCreateParams + * + * @type {TimestampsResponse} + * @memberof VideoConferenceElementResponse */ - moderatorMustApproveJoinRequests?: boolean; + timestamps: TimestampsResponse; /** - * The URL that the BigBlueButton client will go to after users click the OK button on the ‘You have been logged out’ or ’This session was ended’ message. Has to be a URL from the same domain that the conference is started from. - * @type {string} - * @memberof VideoConferenceCreateParams + * + * @type {VideoConferenceElementContent} + * @memberof VideoConferenceElementResponse */ - logoutUrl?: string; + content: VideoConferenceElementContent; } /** - * + * * @export * @interface VideoConferenceInfoResponse */ export interface VideoConferenceInfoResponse { /** - * + * * @type {VideoConferenceStateResponse} * @memberof VideoConferenceInfoResponse */ @@ -9885,7 +9940,7 @@ export interface VideoConferenceInfoResponse { options: VideoConferenceOptionsResponse; } /** - * + * * @export * @interface VideoConferenceJoinResponse */ @@ -9898,7 +9953,7 @@ export interface VideoConferenceJoinResponse { url: string; } /** - * + * * @export * @interface VideoConferenceOptionsResponse */ @@ -9923,17 +9978,19 @@ export interface VideoConferenceOptionsResponse { moderatorMustApproveJoinRequests: boolean; } /** - * + * * @export * @enum {string} */ export enum VideoConferenceScope { Course = 'course', - Event = 'event' + Event = 'event', + Room = 'room', + VideoConferenceElement = 'video-conference-element' } /** - * + * * @export * @enum {string} */ @@ -9944,57 +10001,57 @@ export enum VideoConferenceStateResponse { } /** - * + * * @export * @interface VisibilityBodyParams */ export interface VisibilityBodyParams { /** - * + * * @type {boolean} * @memberof VisibilityBodyParams */ isVisible: boolean; } /** - * + * * @export * @interface VisibilitySettingsResponse */ export interface VisibilitySettingsResponse { /** - * + * * @type {string} * @memberof VisibilitySettingsResponse */ publishedAt?: string; } /** - * + * * @export * @interface YearsResponse */ export interface YearsResponse { /** - * + * * @type {Array} * @memberof YearsResponse */ schoolYears: Array; /** - * + * * @type {SchoolYearResponse} * @memberof YearsResponse */ activeYear: SchoolYearResponse; /** - * + * * @type {SchoolYearResponse} * @memberof YearsResponse */ lastYear: SchoolYearResponse; /** - * + * * @type {SchoolYearResponse} * @memberof YearsResponse */ @@ -10008,7 +10065,7 @@ export interface YearsResponse { export const AccountApiAxiosParamCreator = function (configuration?: Configuration) { return { /** - * + * * @summary Deletes an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. * @param {*} [options] Override http request option. @@ -10035,7 +10092,7 @@ export const AccountApiAxiosParamCreator = function (configuration?: Configurati await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -10046,7 +10103,7 @@ export const AccountApiAxiosParamCreator = function (configuration?: Configurati }; }, /** - * + * * @summary Returns an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. * @param {*} [options] Override http request option. @@ -10073,7 +10130,7 @@ export const AccountApiAxiosParamCreator = function (configuration?: Configurati await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -10084,9 +10141,9 @@ export const AccountApiAxiosParamCreator = function (configuration?: Configurati }; }, /** - * + * * @summary Updates the the temporary account password for the authenticated user. - * @param {PatchMyPasswordParams} patchMyPasswordParams + * @param {PatchMyPasswordParams} patchMyPasswordParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10110,7 +10167,7 @@ export const AccountApiAxiosParamCreator = function (configuration?: Configurati await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -10124,7 +10181,7 @@ export const AccountApiAxiosParamCreator = function (configuration?: Configurati }; }, /** - * + * * @summary Returns all accounts which satisfies the given criteria. For unlimited access Superhero role is REQUIRED. * @param {'userId' | 'username'} type The search criteria. * @param {string} value The search value. @@ -10171,7 +10228,7 @@ export const AccountApiAxiosParamCreator = function (configuration?: Configurati } - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -10182,10 +10239,10 @@ export const AccountApiAxiosParamCreator = function (configuration?: Configurati }; }, /** - * + * * @summary Updates an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. - * @param {AccountByIdBodyParams} accountByIdBodyParams + * @param {AccountByIdBodyParams} accountByIdBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10212,7 +10269,7 @@ export const AccountApiAxiosParamCreator = function (configuration?: Configurati await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -10226,9 +10283,9 @@ export const AccountApiAxiosParamCreator = function (configuration?: Configurati }; }, /** - * + * * @summary Updates an account for the authenticated user. - * @param {PatchMyAccountParams} patchMyAccountParams + * @param {PatchMyAccountParams} patchMyAccountParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10252,7 +10309,7 @@ export const AccountApiAxiosParamCreator = function (configuration?: Configurati await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -10276,7 +10333,7 @@ export const AccountApiFp = function(configuration?: Configuration) { const localVarAxiosParamCreator = AccountApiAxiosParamCreator(configuration) return { /** - * + * * @summary Deletes an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. * @param {*} [options] Override http request option. @@ -10287,7 +10344,7 @@ export const AccountApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Returns an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. * @param {*} [options] Override http request option. @@ -10298,9 +10355,9 @@ export const AccountApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Updates the the temporary account password for the authenticated user. - * @param {PatchMyPasswordParams} patchMyPasswordParams + * @param {PatchMyPasswordParams} patchMyPasswordParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10309,7 +10366,7 @@ export const AccountApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Returns all accounts which satisfies the given criteria. For unlimited access Superhero role is REQUIRED. * @param {'userId' | 'username'} type The search criteria. * @param {string} value The search value. @@ -10323,10 +10380,10 @@ export const AccountApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Updates an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. - * @param {AccountByIdBodyParams} accountByIdBodyParams + * @param {AccountByIdBodyParams} accountByIdBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10335,9 +10392,9 @@ export const AccountApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Updates an account for the authenticated user. - * @param {PatchMyAccountParams} patchMyAccountParams + * @param {PatchMyAccountParams} patchMyAccountParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10356,7 +10413,7 @@ export const AccountApiFactory = function (configuration?: Configuration, basePa const localVarFp = AccountApiFp(configuration) return { /** - * + * * @summary Deletes an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. * @param {*} [options] Override http request option. @@ -10366,7 +10423,7 @@ export const AccountApiFactory = function (configuration?: Configuration, basePa return localVarFp.accountControllerDeleteAccountById(id, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Returns an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. * @param {*} [options] Override http request option. @@ -10376,9 +10433,9 @@ export const AccountApiFactory = function (configuration?: Configuration, basePa return localVarFp.accountControllerFindAccountById(id, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Updates the the temporary account password for the authenticated user. - * @param {PatchMyPasswordParams} patchMyPasswordParams + * @param {PatchMyPasswordParams} patchMyPasswordParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10386,7 +10443,7 @@ export const AccountApiFactory = function (configuration?: Configuration, basePa return localVarFp.accountControllerReplaceMyPassword(patchMyPasswordParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Returns all accounts which satisfies the given criteria. For unlimited access Superhero role is REQUIRED. * @param {'userId' | 'username'} type The search criteria. * @param {string} value The search value. @@ -10399,10 +10456,10 @@ export const AccountApiFactory = function (configuration?: Configuration, basePa return localVarFp.accountControllerSearchAccounts(type, value, skip, limit, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Updates an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. - * @param {AccountByIdBodyParams} accountByIdBodyParams + * @param {AccountByIdBodyParams} accountByIdBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10410,9 +10467,9 @@ export const AccountApiFactory = function (configuration?: Configuration, basePa return localVarFp.accountControllerUpdateAccountById(id, accountByIdBodyParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Updates an account for the authenticated user. - * @param {PatchMyAccountParams} patchMyAccountParams + * @param {PatchMyAccountParams} patchMyAccountParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10429,7 +10486,7 @@ export const AccountApiFactory = function (configuration?: Configuration, basePa */ export interface AccountApiInterface { /** - * + * * @summary Deletes an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. * @param {*} [options] Override http request option. @@ -10439,7 +10496,7 @@ export interface AccountApiInterface { accountControllerDeleteAccountById(id: string, options?: any): AxiosPromise; /** - * + * * @summary Returns an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. * @param {*} [options] Override http request option. @@ -10449,9 +10506,9 @@ export interface AccountApiInterface { accountControllerFindAccountById(id: string, options?: any): AxiosPromise; /** - * + * * @summary Updates the the temporary account password for the authenticated user. - * @param {PatchMyPasswordParams} patchMyPasswordParams + * @param {PatchMyPasswordParams} patchMyPasswordParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AccountApiInterface @@ -10459,7 +10516,7 @@ export interface AccountApiInterface { accountControllerReplaceMyPassword(patchMyPasswordParams: PatchMyPasswordParams, options?: any): AxiosPromise; /** - * + * * @summary Returns all accounts which satisfies the given criteria. For unlimited access Superhero role is REQUIRED. * @param {'userId' | 'username'} type The search criteria. * @param {string} value The search value. @@ -10472,10 +10529,10 @@ export interface AccountApiInterface { accountControllerSearchAccounts(type: 'userId' | 'username', value: string, skip?: number, limit?: number, options?: any): AxiosPromise; /** - * + * * @summary Updates an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. - * @param {AccountByIdBodyParams} accountByIdBodyParams + * @param {AccountByIdBodyParams} accountByIdBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AccountApiInterface @@ -10483,9 +10540,9 @@ export interface AccountApiInterface { accountControllerUpdateAccountById(id: string, accountByIdBodyParams: AccountByIdBodyParams, options?: any): AxiosPromise; /** - * + * * @summary Updates an account for the authenticated user. - * @param {PatchMyAccountParams} patchMyAccountParams + * @param {PatchMyAccountParams} patchMyAccountParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AccountApiInterface @@ -10502,7 +10559,7 @@ export interface AccountApiInterface { */ export class AccountApi extends BaseAPI implements AccountApiInterface { /** - * + * * @summary Deletes an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. * @param {*} [options] Override http request option. @@ -10514,7 +10571,7 @@ export class AccountApi extends BaseAPI implements AccountApiInterface { } /** - * + * * @summary Returns an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. * @param {*} [options] Override http request option. @@ -10526,9 +10583,9 @@ export class AccountApi extends BaseAPI implements AccountApiInterface { } /** - * + * * @summary Updates the the temporary account password for the authenticated user. - * @param {PatchMyPasswordParams} patchMyPasswordParams + * @param {PatchMyPasswordParams} patchMyPasswordParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AccountApi @@ -10538,7 +10595,7 @@ export class AccountApi extends BaseAPI implements AccountApiInterface { } /** - * + * * @summary Returns all accounts which satisfies the given criteria. For unlimited access Superhero role is REQUIRED. * @param {'userId' | 'username'} type The search criteria. * @param {string} value The search value. @@ -10553,10 +10610,10 @@ export class AccountApi extends BaseAPI implements AccountApiInterface { } /** - * + * * @summary Updates an account with given id. Superhero role is REQUIRED. * @param {string} id The id for the account. - * @param {AccountByIdBodyParams} accountByIdBodyParams + * @param {AccountByIdBodyParams} accountByIdBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AccountApi @@ -10566,9 +10623,9 @@ export class AccountApi extends BaseAPI implements AccountApiInterface { } /** - * + * * @summary Updates an account for the authenticated user. - * @param {PatchMyAccountParams} patchMyAccountParams + * @param {PatchMyAccountParams} patchMyAccountParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AccountApi @@ -10586,7 +10643,7 @@ export class AccountApi extends BaseAPI implements AccountApiInterface { export const AdminStudentsApiAxiosParamCreator = function (configuration?: Configuration) { return { /** - * + * * @summary Returns an student with given id. * @param {string} id The id of the user. * @param {*} [options] Override http request option. @@ -10613,7 +10670,7 @@ export const AdminStudentsApiAxiosParamCreator = function (configuration?: Confi await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -10624,15 +10681,15 @@ export const AdminStudentsApiAxiosParamCreator = function (configuration?: Confi }; }, /** - * + * * @summary Returns all students which satisfies the given criteria. * @param {number} [skip] Number of elements (not pages) to be skipped * @param {number} [limit] Page limit, defaults to 10. * @param {number} [$limit] Page limit, defaults to 25. * @param {number} [$skip] Number of elements (not pages) to be skipped - * @param {Array} [classes] - * @param {string} [searchQuery] - * @param {Array} [users] + * @param {Array} [classes] + * @param {string} [searchQuery] + * @param {Array} [users] * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10682,7 +10739,7 @@ export const AdminStudentsApiAxiosParamCreator = function (configuration?: Confi } - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -10703,7 +10760,7 @@ export const AdminStudentsApiFp = function(configuration?: Configuration) { const localVarAxiosParamCreator = AdminStudentsApiAxiosParamCreator(configuration) return { /** - * + * * @summary Returns an student with given id. * @param {string} id The id of the user. * @param {*} [options] Override http request option. @@ -10714,15 +10771,15 @@ export const AdminStudentsApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Returns all students which satisfies the given criteria. * @param {number} [skip] Number of elements (not pages) to be skipped * @param {number} [limit] Page limit, defaults to 10. * @param {number} [$limit] Page limit, defaults to 25. * @param {number} [$skip] Number of elements (not pages) to be skipped - * @param {Array} [classes] - * @param {string} [searchQuery] - * @param {Array} [users] + * @param {Array} [classes] + * @param {string} [searchQuery] + * @param {Array} [users] * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10741,7 +10798,7 @@ export const AdminStudentsApiFactory = function (configuration?: Configuration, const localVarFp = AdminStudentsApiFp(configuration) return { /** - * + * * @summary Returns an student with given id. * @param {string} id The id of the user. * @param {*} [options] Override http request option. @@ -10751,15 +10808,15 @@ export const AdminStudentsApiFactory = function (configuration?: Configuration, return localVarFp.adminApiStudentsControllerFindStudentById(id, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Returns all students which satisfies the given criteria. * @param {number} [skip] Number of elements (not pages) to be skipped * @param {number} [limit] Page limit, defaults to 10. * @param {number} [$limit] Page limit, defaults to 25. * @param {number} [$skip] Number of elements (not pages) to be skipped - * @param {Array} [classes] - * @param {string} [searchQuery] - * @param {Array} [users] + * @param {Array} [classes] + * @param {string} [searchQuery] + * @param {Array} [users] * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10776,7 +10833,7 @@ export const AdminStudentsApiFactory = function (configuration?: Configuration, */ export interface AdminStudentsApiInterface { /** - * + * * @summary Returns an student with given id. * @param {string} id The id of the user. * @param {*} [options] Override http request option. @@ -10786,15 +10843,15 @@ export interface AdminStudentsApiInterface { adminApiStudentsControllerFindStudentById(id: string, options?: any): AxiosPromise; /** - * + * * @summary Returns all students which satisfies the given criteria. * @param {number} [skip] Number of elements (not pages) to be skipped * @param {number} [limit] Page limit, defaults to 10. * @param {number} [$limit] Page limit, defaults to 25. * @param {number} [$skip] Number of elements (not pages) to be skipped - * @param {Array} [classes] - * @param {string} [searchQuery] - * @param {Array} [users] + * @param {Array} [classes] + * @param {string} [searchQuery] + * @param {Array} [users] * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AdminStudentsApiInterface @@ -10811,7 +10868,7 @@ export interface AdminStudentsApiInterface { */ export class AdminStudentsApi extends BaseAPI implements AdminStudentsApiInterface { /** - * + * * @summary Returns an student with given id. * @param {string} id The id of the user. * @param {*} [options] Override http request option. @@ -10823,15 +10880,15 @@ export class AdminStudentsApi extends BaseAPI implements AdminStudentsApiInterfa } /** - * + * * @summary Returns all students which satisfies the given criteria. * @param {number} [skip] Number of elements (not pages) to be skipped * @param {number} [limit] Page limit, defaults to 10. * @param {number} [$limit] Page limit, defaults to 25. * @param {number} [$skip] Number of elements (not pages) to be skipped - * @param {Array} [classes] - * @param {string} [searchQuery] - * @param {Array} [users] + * @param {Array} [classes] + * @param {string} [searchQuery] + * @param {Array} [users] * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AdminStudentsApi @@ -10849,7 +10906,7 @@ export class AdminStudentsApi extends BaseAPI implements AdminStudentsApiInterfa export const AdminTeachersApiAxiosParamCreator = function (configuration?: Configuration) { return { /** - * + * * @summary Returns a teacher with given id. * @param {string} id The id of the user. * @param {*} [options] Override http request option. @@ -10876,7 +10933,7 @@ export const AdminTeachersApiAxiosParamCreator = function (configuration?: Confi await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -10887,15 +10944,15 @@ export const AdminTeachersApiAxiosParamCreator = function (configuration?: Confi }; }, /** - * + * * @summary Returns all teachers which satisfies the given criteria. * @param {number} [skip] Number of elements (not pages) to be skipped * @param {number} [limit] Page limit, defaults to 10. * @param {number} [$limit] Page limit, defaults to 25. * @param {number} [$skip] Number of elements (not pages) to be skipped - * @param {Array} [classes] - * @param {string} [searchQuery] - * @param {Array} [users] + * @param {Array} [classes] + * @param {string} [searchQuery] + * @param {Array} [users] * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -10945,7 +11002,7 @@ export const AdminTeachersApiAxiosParamCreator = function (configuration?: Confi } - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -10966,7 +11023,7 @@ export const AdminTeachersApiFp = function(configuration?: Configuration) { const localVarAxiosParamCreator = AdminTeachersApiAxiosParamCreator(configuration) return { /** - * + * * @summary Returns a teacher with given id. * @param {string} id The id of the user. * @param {*} [options] Override http request option. @@ -10977,15 +11034,15 @@ export const AdminTeachersApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Returns all teachers which satisfies the given criteria. * @param {number} [skip] Number of elements (not pages) to be skipped * @param {number} [limit] Page limit, defaults to 10. * @param {number} [$limit] Page limit, defaults to 25. * @param {number} [$skip] Number of elements (not pages) to be skipped - * @param {Array} [classes] - * @param {string} [searchQuery] - * @param {Array} [users] + * @param {Array} [classes] + * @param {string} [searchQuery] + * @param {Array} [users] * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11004,7 +11061,7 @@ export const AdminTeachersApiFactory = function (configuration?: Configuration, const localVarFp = AdminTeachersApiFp(configuration) return { /** - * + * * @summary Returns a teacher with given id. * @param {string} id The id of the user. * @param {*} [options] Override http request option. @@ -11014,15 +11071,15 @@ export const AdminTeachersApiFactory = function (configuration?: Configuration, return localVarFp.adminApiTeachersControllerFindTeacherById(id, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Returns all teachers which satisfies the given criteria. * @param {number} [skip] Number of elements (not pages) to be skipped * @param {number} [limit] Page limit, defaults to 10. * @param {number} [$limit] Page limit, defaults to 25. * @param {number} [$skip] Number of elements (not pages) to be skipped - * @param {Array} [classes] - * @param {string} [searchQuery] - * @param {Array} [users] + * @param {Array} [classes] + * @param {string} [searchQuery] + * @param {Array} [users] * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11039,7 +11096,7 @@ export const AdminTeachersApiFactory = function (configuration?: Configuration, */ export interface AdminTeachersApiInterface { /** - * + * * @summary Returns a teacher with given id. * @param {string} id The id of the user. * @param {*} [options] Override http request option. @@ -11049,15 +11106,15 @@ export interface AdminTeachersApiInterface { adminApiTeachersControllerFindTeacherById(id: string, options?: any): AxiosPromise; /** - * + * * @summary Returns all teachers which satisfies the given criteria. * @param {number} [skip] Number of elements (not pages) to be skipped * @param {number} [limit] Page limit, defaults to 10. * @param {number} [$limit] Page limit, defaults to 25. * @param {number} [$skip] Number of elements (not pages) to be skipped - * @param {Array} [classes] - * @param {string} [searchQuery] - * @param {Array} [users] + * @param {Array} [classes] + * @param {string} [searchQuery] + * @param {Array} [users] * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AdminTeachersApiInterface @@ -11074,7 +11131,7 @@ export interface AdminTeachersApiInterface { */ export class AdminTeachersApi extends BaseAPI implements AdminTeachersApiInterface { /** - * + * * @summary Returns a teacher with given id. * @param {string} id The id of the user. * @param {*} [options] Override http request option. @@ -11086,15 +11143,15 @@ export class AdminTeachersApi extends BaseAPI implements AdminTeachersApiInterfa } /** - * + * * @summary Returns all teachers which satisfies the given criteria. * @param {number} [skip] Number of elements (not pages) to be skipped * @param {number} [limit] Page limit, defaults to 10. * @param {number} [$limit] Page limit, defaults to 25. * @param {number} [$skip] Number of elements (not pages) to be skipped - * @param {Array} [classes] - * @param {string} [searchQuery] - * @param {Array} [users] + * @param {Array} [classes] + * @param {string} [searchQuery] + * @param {Array} [users] * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AdminTeachersApi @@ -11112,7 +11169,7 @@ export class AdminTeachersApi extends BaseAPI implements AdminTeachersApiInterfa export const AlertApiAxiosParamCreator = function (configuration?: Configuration) { return { /** - * + * * @summary Get allerts * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11131,7 +11188,7 @@ export const AlertApiAxiosParamCreator = function (configuration?: Configuration const localVarQueryParameter = {} as any; - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -11152,7 +11209,7 @@ export const AlertApiFp = function(configuration?: Configuration) { const localVarAxiosParamCreator = AlertApiAxiosParamCreator(configuration) return { /** - * + * * @summary Get allerts * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11172,7 +11229,7 @@ export const AlertApiFactory = function (configuration?: Configuration, basePath const localVarFp = AlertApiFp(configuration) return { /** - * + * * @summary Get allerts * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11190,7 +11247,7 @@ export const AlertApiFactory = function (configuration?: Configuration, basePath */ export interface AlertApiInterface { /** - * + * * @summary Get allerts * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11208,7 +11265,7 @@ export interface AlertApiInterface { */ export class AlertApi extends BaseAPI implements AlertApiInterface { /** - * + * * @summary Get allerts * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11227,9 +11284,9 @@ export class AlertApi extends BaseAPI implements AlertApiInterface { export const AuthenticationApiAxiosParamCreator = function (configuration?: Configuration) { return { /** - * + * * @summary Starts the login process for users which are authenticated via LDAP - * @param {LdapAuthorizationBodyParams} ldapAuthorizationBodyParams + * @param {LdapAuthorizationBodyParams} ldapAuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11249,7 +11306,7 @@ export const AuthenticationApiAxiosParamCreator = function (configuration?: Conf const localVarQueryParameter = {} as any; - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -11263,9 +11320,9 @@ export const AuthenticationApiAxiosParamCreator = function (configuration?: Conf }; }, /** - * + * * @summary Starts the login process for users which are locally managed. - * @param {LocalAuthorizationBodyParams} localAuthorizationBodyParams + * @param {LocalAuthorizationBodyParams} localAuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11285,7 +11342,7 @@ export const AuthenticationApiAxiosParamCreator = function (configuration?: Conf const localVarQueryParameter = {} as any; - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -11299,9 +11356,9 @@ export const AuthenticationApiAxiosParamCreator = function (configuration?: Conf }; }, /** - * + * * @summary Starts the login process for users which are authenticated via OAuth 2. - * @param {Oauth2AuthorizationBodyParams} oauth2AuthorizationBodyParams + * @param {Oauth2AuthorizationBodyParams} oauth2AuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11321,7 +11378,7 @@ export const AuthenticationApiAxiosParamCreator = function (configuration?: Conf const localVarQueryParameter = {} as any; - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -11335,7 +11392,7 @@ export const AuthenticationApiAxiosParamCreator = function (configuration?: Conf }; }, /** - * + * * @summary Logs out a user from the external system. * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11358,7 +11415,7 @@ export const AuthenticationApiAxiosParamCreator = function (configuration?: Conf await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -11369,7 +11426,7 @@ export const AuthenticationApiAxiosParamCreator = function (configuration?: Conf }; }, /** - * + * * @summary Logs out a user. * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11392,7 +11449,7 @@ export const AuthenticationApiAxiosParamCreator = function (configuration?: Conf await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -11403,9 +11460,9 @@ export const AuthenticationApiAxiosParamCreator = function (configuration?: Conf }; }, /** - * + * * @summary Logs out a user for a given logout token from an external oidc system. - * @param {OidcLogoutBodyParams} oidcLogoutBodyParams + * @param {OidcLogoutBodyParams} oidcLogoutBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11425,7 +11482,7 @@ export const AuthenticationApiAxiosParamCreator = function (configuration?: Conf const localVarQueryParameter = {} as any; - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -11449,9 +11506,9 @@ export const AuthenticationApiFp = function(configuration?: Configuration) { const localVarAxiosParamCreator = AuthenticationApiAxiosParamCreator(configuration) return { /** - * + * * @summary Starts the login process for users which are authenticated via LDAP - * @param {LdapAuthorizationBodyParams} ldapAuthorizationBodyParams + * @param {LdapAuthorizationBodyParams} ldapAuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11460,9 +11517,9 @@ export const AuthenticationApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Starts the login process for users which are locally managed. - * @param {LocalAuthorizationBodyParams} localAuthorizationBodyParams + * @param {LocalAuthorizationBodyParams} localAuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11471,9 +11528,9 @@ export const AuthenticationApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Starts the login process for users which are authenticated via OAuth 2. - * @param {Oauth2AuthorizationBodyParams} oauth2AuthorizationBodyParams + * @param {Oauth2AuthorizationBodyParams} oauth2AuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11482,7 +11539,7 @@ export const AuthenticationApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Logs out a user from the external system. * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11492,7 +11549,7 @@ export const AuthenticationApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Logs out a user. * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11502,9 +11559,9 @@ export const AuthenticationApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Logs out a user for a given logout token from an external oidc system. - * @param {OidcLogoutBodyParams} oidcLogoutBodyParams + * @param {OidcLogoutBodyParams} oidcLogoutBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11523,9 +11580,9 @@ export const AuthenticationApiFactory = function (configuration?: Configuration, const localVarFp = AuthenticationApiFp(configuration) return { /** - * + * * @summary Starts the login process for users which are authenticated via LDAP - * @param {LdapAuthorizationBodyParams} ldapAuthorizationBodyParams + * @param {LdapAuthorizationBodyParams} ldapAuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11533,9 +11590,9 @@ export const AuthenticationApiFactory = function (configuration?: Configuration, return localVarFp.loginControllerLoginLdap(ldapAuthorizationBodyParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Starts the login process for users which are locally managed. - * @param {LocalAuthorizationBodyParams} localAuthorizationBodyParams + * @param {LocalAuthorizationBodyParams} localAuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11543,9 +11600,9 @@ export const AuthenticationApiFactory = function (configuration?: Configuration, return localVarFp.loginControllerLoginLocal(localAuthorizationBodyParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Starts the login process for users which are authenticated via OAuth 2. - * @param {Oauth2AuthorizationBodyParams} oauth2AuthorizationBodyParams + * @param {Oauth2AuthorizationBodyParams} oauth2AuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11553,7 +11610,7 @@ export const AuthenticationApiFactory = function (configuration?: Configuration, return localVarFp.loginControllerLoginOauth2(oauth2AuthorizationBodyParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Logs out a user from the external system. * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11562,7 +11619,7 @@ export const AuthenticationApiFactory = function (configuration?: Configuration, return localVarFp.logoutControllerExternalSystemLogout(options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Logs out a user. * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11571,9 +11628,9 @@ export const AuthenticationApiFactory = function (configuration?: Configuration, return localVarFp.logoutControllerLogout(options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Logs out a user for a given logout token from an external oidc system. - * @param {OidcLogoutBodyParams} oidcLogoutBodyParams + * @param {OidcLogoutBodyParams} oidcLogoutBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11590,9 +11647,9 @@ export const AuthenticationApiFactory = function (configuration?: Configuration, */ export interface AuthenticationApiInterface { /** - * + * * @summary Starts the login process for users which are authenticated via LDAP - * @param {LdapAuthorizationBodyParams} ldapAuthorizationBodyParams + * @param {LdapAuthorizationBodyParams} ldapAuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AuthenticationApiInterface @@ -11600,9 +11657,9 @@ export interface AuthenticationApiInterface { loginControllerLoginLdap(ldapAuthorizationBodyParams: LdapAuthorizationBodyParams, options?: any): AxiosPromise; /** - * + * * @summary Starts the login process for users which are locally managed. - * @param {LocalAuthorizationBodyParams} localAuthorizationBodyParams + * @param {LocalAuthorizationBodyParams} localAuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AuthenticationApiInterface @@ -11610,9 +11667,9 @@ export interface AuthenticationApiInterface { loginControllerLoginLocal(localAuthorizationBodyParams: LocalAuthorizationBodyParams, options?: any): AxiosPromise; /** - * + * * @summary Starts the login process for users which are authenticated via OAuth 2. - * @param {Oauth2AuthorizationBodyParams} oauth2AuthorizationBodyParams + * @param {Oauth2AuthorizationBodyParams} oauth2AuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AuthenticationApiInterface @@ -11620,7 +11677,7 @@ export interface AuthenticationApiInterface { loginControllerLoginOauth2(oauth2AuthorizationBodyParams: Oauth2AuthorizationBodyParams, options?: any): AxiosPromise; /** - * + * * @summary Logs out a user from the external system. * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11629,7 +11686,7 @@ export interface AuthenticationApiInterface { logoutControllerExternalSystemLogout(options?: any): AxiosPromise; /** - * + * * @summary Logs out a user. * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11638,9 +11695,9 @@ export interface AuthenticationApiInterface { logoutControllerLogout(options?: any): AxiosPromise; /** - * + * * @summary Logs out a user for a given logout token from an external oidc system. - * @param {OidcLogoutBodyParams} oidcLogoutBodyParams + * @param {OidcLogoutBodyParams} oidcLogoutBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AuthenticationApiInterface @@ -11657,9 +11714,9 @@ export interface AuthenticationApiInterface { */ export class AuthenticationApi extends BaseAPI implements AuthenticationApiInterface { /** - * + * * @summary Starts the login process for users which are authenticated via LDAP - * @param {LdapAuthorizationBodyParams} ldapAuthorizationBodyParams + * @param {LdapAuthorizationBodyParams} ldapAuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AuthenticationApi @@ -11669,9 +11726,9 @@ export class AuthenticationApi extends BaseAPI implements AuthenticationApiInter } /** - * + * * @summary Starts the login process for users which are locally managed. - * @param {LocalAuthorizationBodyParams} localAuthorizationBodyParams + * @param {LocalAuthorizationBodyParams} localAuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AuthenticationApi @@ -11681,9 +11738,9 @@ export class AuthenticationApi extends BaseAPI implements AuthenticationApiInter } /** - * + * * @summary Starts the login process for users which are authenticated via OAuth 2. - * @param {Oauth2AuthorizationBodyParams} oauth2AuthorizationBodyParams + * @param {Oauth2AuthorizationBodyParams} oauth2AuthorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AuthenticationApi @@ -11693,7 +11750,7 @@ export class AuthenticationApi extends BaseAPI implements AuthenticationApiInter } /** - * + * * @summary Logs out a user from the external system. * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11704,7 +11761,7 @@ export class AuthenticationApi extends BaseAPI implements AuthenticationApiInter } /** - * + * * @summary Logs out a user. * @param {*} [options] Override http request option. * @throws {RequiredError} @@ -11715,9 +11772,9 @@ export class AuthenticationApi extends BaseAPI implements AuthenticationApiInter } /** - * + * * @summary Logs out a user for a given logout token from an external oidc system. - * @param {OidcLogoutBodyParams} oidcLogoutBodyParams + * @param {OidcLogoutBodyParams} oidcLogoutBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AuthenticationApi @@ -11735,9 +11792,9 @@ export class AuthenticationApi extends BaseAPI implements AuthenticationApiInter export const AuthorizationApiAxiosParamCreator = function (configuration?: Configuration) { return { /** - * + * * @summary Checks if user is authorized to perform the given operation. - * @param {AuthorizationBodyParams} authorizationBodyParams + * @param {AuthorizationBodyParams} authorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11761,7 +11818,7 @@ export const AuthorizationApiAxiosParamCreator = function (configuration?: Confi await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -11785,9 +11842,9 @@ export const AuthorizationApiFp = function(configuration?: Configuration) { const localVarAxiosParamCreator = AuthorizationApiAxiosParamCreator(configuration) return { /** - * + * * @summary Checks if user is authorized to perform the given operation. - * @param {AuthorizationBodyParams} authorizationBodyParams + * @param {AuthorizationBodyParams} authorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11806,9 +11863,9 @@ export const AuthorizationApiFactory = function (configuration?: Configuration, const localVarFp = AuthorizationApiFp(configuration) return { /** - * + * * @summary Checks if user is authorized to perform the given operation. - * @param {AuthorizationBodyParams} authorizationBodyParams + * @param {AuthorizationBodyParams} authorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11825,9 +11882,9 @@ export const AuthorizationApiFactory = function (configuration?: Configuration, */ export interface AuthorizationApiInterface { /** - * + * * @summary Checks if user is authorized to perform the given operation. - * @param {AuthorizationBodyParams} authorizationBodyParams + * @param {AuthorizationBodyParams} authorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AuthorizationApiInterface @@ -11844,9 +11901,9 @@ export interface AuthorizationApiInterface { */ export class AuthorizationApi extends BaseAPI implements AuthorizationApiInterface { /** - * + * * @summary Checks if user is authorized to perform the given operation. - * @param {AuthorizationBodyParams} authorizationBodyParams + * @param {AuthorizationBodyParams} authorizationBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof AuthorizationApi @@ -11864,7 +11921,7 @@ export class AuthorizationApi extends BaseAPI implements AuthorizationApiInterfa export const BoardApiAxiosParamCreator = function (configuration?: Configuration) { return { /** - * + * * @summary Create a board copy. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -11891,7 +11948,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -11902,9 +11959,9 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration }; }, /** - * + * * @summary Create a new board. - * @param {CreateBoardBodyParams} createBoardBodyParams + * @param {CreateBoardBodyParams} createBoardBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -11928,7 +11985,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -11942,7 +11999,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration }; }, /** - * + * * @summary Create a new column on a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -11969,7 +12026,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -11980,7 +12037,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration }; }, /** - * + * * @summary Delete a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12007,7 +12064,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -12018,7 +12075,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration }; }, /** - * + * * @summary Get the context of a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12045,7 +12102,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -12056,7 +12113,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration }; }, /** - * + * * @summary Get the skeleton of a a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12083,7 +12140,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -12094,10 +12151,10 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration }; }, /** - * + * * @summary Update the title of a board. * @param {string} boardId The id of the board. - * @param {UpdateBoardTitleParams} updateBoardTitleParams + * @param {UpdateBoardTitleParams} updateBoardTitleParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12124,7 +12181,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -12138,10 +12195,10 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration }; }, /** - * + * * @summary Update the visibility of a board. * @param {string} boardId The id of the board. - * @param {VisibilityBodyParams} visibilityBodyParams + * @param {VisibilityBodyParams} visibilityBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12168,7 +12225,7 @@ export const BoardApiAxiosParamCreator = function (configuration?: Configuration await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -12192,7 +12249,7 @@ export const BoardApiFp = function(configuration?: Configuration) { const localVarAxiosParamCreator = BoardApiAxiosParamCreator(configuration) return { /** - * + * * @summary Create a board copy. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12203,9 +12260,9 @@ export const BoardApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Create a new board. - * @param {CreateBoardBodyParams} createBoardBodyParams + * @param {CreateBoardBodyParams} createBoardBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12214,7 +12271,7 @@ export const BoardApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Create a new column on a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12225,7 +12282,7 @@ export const BoardApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Delete a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12236,7 +12293,7 @@ export const BoardApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Get the context of a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12247,7 +12304,7 @@ export const BoardApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Get the skeleton of a a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12258,10 +12315,10 @@ export const BoardApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Update the title of a board. * @param {string} boardId The id of the board. - * @param {UpdateBoardTitleParams} updateBoardTitleParams + * @param {UpdateBoardTitleParams} updateBoardTitleParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12270,10 +12327,10 @@ export const BoardApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Update the visibility of a board. * @param {string} boardId The id of the board. - * @param {VisibilityBodyParams} visibilityBodyParams + * @param {VisibilityBodyParams} visibilityBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12292,7 +12349,7 @@ export const BoardApiFactory = function (configuration?: Configuration, basePath const localVarFp = BoardApiFp(configuration) return { /** - * + * * @summary Create a board copy. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12302,9 +12359,9 @@ export const BoardApiFactory = function (configuration?: Configuration, basePath return localVarFp.boardControllerCopyBoard(boardId, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Create a new board. - * @param {CreateBoardBodyParams} createBoardBodyParams + * @param {CreateBoardBodyParams} createBoardBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12312,7 +12369,7 @@ export const BoardApiFactory = function (configuration?: Configuration, basePath return localVarFp.boardControllerCreateBoard(createBoardBodyParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Create a new column on a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12322,7 +12379,7 @@ export const BoardApiFactory = function (configuration?: Configuration, basePath return localVarFp.boardControllerCreateColumn(boardId, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Delete a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12332,7 +12389,7 @@ export const BoardApiFactory = function (configuration?: Configuration, basePath return localVarFp.boardControllerDeleteBoard(boardId, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Get the context of a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12342,7 +12399,7 @@ export const BoardApiFactory = function (configuration?: Configuration, basePath return localVarFp.boardControllerGetBoardContext(boardId, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Get the skeleton of a a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12352,10 +12409,10 @@ export const BoardApiFactory = function (configuration?: Configuration, basePath return localVarFp.boardControllerGetBoardSkeleton(boardId, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Update the title of a board. * @param {string} boardId The id of the board. - * @param {UpdateBoardTitleParams} updateBoardTitleParams + * @param {UpdateBoardTitleParams} updateBoardTitleParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12363,10 +12420,10 @@ export const BoardApiFactory = function (configuration?: Configuration, basePath return localVarFp.boardControllerUpdateBoardTitle(boardId, updateBoardTitleParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Update the visibility of a board. * @param {string} boardId The id of the board. - * @param {VisibilityBodyParams} visibilityBodyParams + * @param {VisibilityBodyParams} visibilityBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12383,7 +12440,7 @@ export const BoardApiFactory = function (configuration?: Configuration, basePath */ export interface BoardApiInterface { /** - * + * * @summary Create a board copy. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12393,9 +12450,9 @@ export interface BoardApiInterface { boardControllerCopyBoard(boardId: string, options?: any): AxiosPromise; /** - * + * * @summary Create a new board. - * @param {CreateBoardBodyParams} createBoardBodyParams + * @param {CreateBoardBodyParams} createBoardBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardApiInterface @@ -12403,7 +12460,7 @@ export interface BoardApiInterface { boardControllerCreateBoard(createBoardBodyParams: CreateBoardBodyParams, options?: any): AxiosPromise; /** - * + * * @summary Create a new column on a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12413,7 +12470,7 @@ export interface BoardApiInterface { boardControllerCreateColumn(boardId: string, options?: any): AxiosPromise; /** - * + * * @summary Delete a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12423,7 +12480,7 @@ export interface BoardApiInterface { boardControllerDeleteBoard(boardId: string, options?: any): AxiosPromise; /** - * + * * @summary Get the context of a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12433,7 +12490,7 @@ export interface BoardApiInterface { boardControllerGetBoardContext(boardId: string, options?: any): AxiosPromise; /** - * + * * @summary Get the skeleton of a a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12443,10 +12500,10 @@ export interface BoardApiInterface { boardControllerGetBoardSkeleton(boardId: string, options?: any): AxiosPromise; /** - * + * * @summary Update the title of a board. * @param {string} boardId The id of the board. - * @param {UpdateBoardTitleParams} updateBoardTitleParams + * @param {UpdateBoardTitleParams} updateBoardTitleParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardApiInterface @@ -12454,10 +12511,10 @@ export interface BoardApiInterface { boardControllerUpdateBoardTitle(boardId: string, updateBoardTitleParams: UpdateBoardTitleParams, options?: any): AxiosPromise; /** - * + * * @summary Update the visibility of a board. * @param {string} boardId The id of the board. - * @param {VisibilityBodyParams} visibilityBodyParams + * @param {VisibilityBodyParams} visibilityBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardApiInterface @@ -12474,7 +12531,7 @@ export interface BoardApiInterface { */ export class BoardApi extends BaseAPI implements BoardApiInterface { /** - * + * * @summary Create a board copy. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12486,9 +12543,9 @@ export class BoardApi extends BaseAPI implements BoardApiInterface { } /** - * + * * @summary Create a new board. - * @param {CreateBoardBodyParams} createBoardBodyParams + * @param {CreateBoardBodyParams} createBoardBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardApi @@ -12498,7 +12555,7 @@ export class BoardApi extends BaseAPI implements BoardApiInterface { } /** - * + * * @summary Create a new column on a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12510,7 +12567,7 @@ export class BoardApi extends BaseAPI implements BoardApiInterface { } /** - * + * * @summary Delete a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12522,7 +12579,7 @@ export class BoardApi extends BaseAPI implements BoardApiInterface { } /** - * + * * @summary Get the context of a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12534,7 +12591,7 @@ export class BoardApi extends BaseAPI implements BoardApiInterface { } /** - * + * * @summary Get the skeleton of a a board. * @param {string} boardId The id of the board. * @param {*} [options] Override http request option. @@ -12546,10 +12603,10 @@ export class BoardApi extends BaseAPI implements BoardApiInterface { } /** - * + * * @summary Update the title of a board. * @param {string} boardId The id of the board. - * @param {UpdateBoardTitleParams} updateBoardTitleParams + * @param {UpdateBoardTitleParams} updateBoardTitleParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardApi @@ -12559,10 +12616,10 @@ export class BoardApi extends BaseAPI implements BoardApiInterface { } /** - * + * * @summary Update the visibility of a board. * @param {string} boardId The id of the board. - * @param {VisibilityBodyParams} visibilityBodyParams + * @param {VisibilityBodyParams} visibilityBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardApi @@ -12580,10 +12637,10 @@ export class BoardApi extends BaseAPI implements BoardApiInterface { export const BoardCardApiAxiosParamCreator = function (configuration?: Configuration) { return { /** - * + * * @summary Create a new element on a card. * @param {string} cardId The id of the card. - * @param {CreateContentElementBodyParams} createContentElementBodyParams + * @param {CreateContentElementBodyParams} createContentElementBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12610,7 +12667,7 @@ export const BoardCardApiAxiosParamCreator = function (configuration?: Configura await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -12624,7 +12681,7 @@ export const BoardCardApiAxiosParamCreator = function (configuration?: Configura }; }, /** - * + * * @summary Delete a single card. * @param {string} cardId The id of the card. * @param {*} [options] Override http request option. @@ -12651,7 +12708,7 @@ export const BoardCardApiAxiosParamCreator = function (configuration?: Configura await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -12662,7 +12719,7 @@ export const BoardCardApiAxiosParamCreator = function (configuration?: Configura }; }, /** - * + * * @summary Get a list of cards by their ids. * @param {Array} ids Array of Ids to be loaded * @param {*} [options] Override http request option. @@ -12692,7 +12749,7 @@ export const BoardCardApiAxiosParamCreator = function (configuration?: Configura } - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -12703,10 +12760,10 @@ export const BoardCardApiAxiosParamCreator = function (configuration?: Configura }; }, /** - * + * * @summary Move a single card. * @param {string} cardId The id of the card. - * @param {MoveCardBodyParams} moveCardBodyParams + * @param {MoveCardBodyParams} moveCardBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12733,7 +12790,7 @@ export const BoardCardApiAxiosParamCreator = function (configuration?: Configura await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -12747,10 +12804,10 @@ export const BoardCardApiAxiosParamCreator = function (configuration?: Configura }; }, /** - * + * * @summary Update the height of a single card. * @param {string} cardId The id of the card. - * @param {SetHeightBodyParams} setHeightBodyParams + * @param {SetHeightBodyParams} setHeightBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12777,7 +12834,7 @@ export const BoardCardApiAxiosParamCreator = function (configuration?: Configura await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -12791,10 +12848,10 @@ export const BoardCardApiAxiosParamCreator = function (configuration?: Configura }; }, /** - * + * * @summary Update the title of a single card. * @param {string} cardId The id of the card. - * @param {RenameBodyParams} renameBodyParams + * @param {RenameBodyParams} renameBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12821,7 +12878,7 @@ export const BoardCardApiAxiosParamCreator = function (configuration?: Configura await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -12845,19 +12902,19 @@ export const BoardCardApiFp = function(configuration?: Configuration) { const localVarAxiosParamCreator = BoardCardApiAxiosParamCreator(configuration) return { /** - * + * * @summary Create a new element on a card. * @param {string} cardId The id of the card. - * @param {CreateContentElementBodyParams} createContentElementBodyParams + * @param {CreateContentElementBodyParams} createContentElementBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ - async cardControllerCreateElement(cardId: string, createContentElementBodyParams: CreateContentElementBodyParams, options?: any): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise> { + async cardControllerCreateElement(cardId: string, createContentElementBodyParams: CreateContentElementBodyParams, options?: any): Promise<(axios?: AxiosInstance, basePath?: string) => AxiosPromise> { const localVarAxiosArgs = await localVarAxiosParamCreator.cardControllerCreateElement(cardId, createContentElementBodyParams, options); return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Delete a single card. * @param {string} cardId The id of the card. * @param {*} [options] Override http request option. @@ -12868,7 +12925,7 @@ export const BoardCardApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Get a list of cards by their ids. * @param {Array} ids Array of Ids to be loaded * @param {*} [options] Override http request option. @@ -12879,10 +12936,10 @@ export const BoardCardApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Move a single card. * @param {string} cardId The id of the card. - * @param {MoveCardBodyParams} moveCardBodyParams + * @param {MoveCardBodyParams} moveCardBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12891,10 +12948,10 @@ export const BoardCardApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Update the height of a single card. * @param {string} cardId The id of the card. - * @param {SetHeightBodyParams} setHeightBodyParams + * @param {SetHeightBodyParams} setHeightBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12903,10 +12960,10 @@ export const BoardCardApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Update the title of a single card. * @param {string} cardId The id of the card. - * @param {RenameBodyParams} renameBodyParams + * @param {RenameBodyParams} renameBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12925,18 +12982,18 @@ export const BoardCardApiFactory = function (configuration?: Configuration, base const localVarFp = BoardCardApiFp(configuration) return { /** - * + * * @summary Create a new element on a card. * @param {string} cardId The id of the card. - * @param {CreateContentElementBodyParams} createContentElementBodyParams + * @param {CreateContentElementBodyParams} createContentElementBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ - cardControllerCreateElement(cardId: string, createContentElementBodyParams: CreateContentElementBodyParams, options?: any): AxiosPromise { + cardControllerCreateElement(cardId: string, createContentElementBodyParams: CreateContentElementBodyParams, options?: any): AxiosPromise { return localVarFp.cardControllerCreateElement(cardId, createContentElementBodyParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Delete a single card. * @param {string} cardId The id of the card. * @param {*} [options] Override http request option. @@ -12946,7 +13003,7 @@ export const BoardCardApiFactory = function (configuration?: Configuration, base return localVarFp.cardControllerDeleteCard(cardId, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Get a list of cards by their ids. * @param {Array} ids Array of Ids to be loaded * @param {*} [options] Override http request option. @@ -12956,10 +13013,10 @@ export const BoardCardApiFactory = function (configuration?: Configuration, base return localVarFp.cardControllerGetCards(ids, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Move a single card. * @param {string} cardId The id of the card. - * @param {MoveCardBodyParams} moveCardBodyParams + * @param {MoveCardBodyParams} moveCardBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12967,10 +13024,10 @@ export const BoardCardApiFactory = function (configuration?: Configuration, base return localVarFp.cardControllerMoveCard(cardId, moveCardBodyParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Update the height of a single card. * @param {string} cardId The id of the card. - * @param {SetHeightBodyParams} setHeightBodyParams + * @param {SetHeightBodyParams} setHeightBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12978,10 +13035,10 @@ export const BoardCardApiFactory = function (configuration?: Configuration, base return localVarFp.cardControllerUpdateCardHeight(cardId, setHeightBodyParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Update the title of a single card. * @param {string} cardId The id of the card. - * @param {RenameBodyParams} renameBodyParams + * @param {RenameBodyParams} renameBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -12998,18 +13055,18 @@ export const BoardCardApiFactory = function (configuration?: Configuration, base */ export interface BoardCardApiInterface { /** - * + * * @summary Create a new element on a card. * @param {string} cardId The id of the card. - * @param {CreateContentElementBodyParams} createContentElementBodyParams + * @param {CreateContentElementBodyParams} createContentElementBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardCardApiInterface */ - cardControllerCreateElement(cardId: string, createContentElementBodyParams: CreateContentElementBodyParams, options?: any): AxiosPromise; + cardControllerCreateElement(cardId: string, createContentElementBodyParams: CreateContentElementBodyParams, options?: any): AxiosPromise; /** - * + * * @summary Delete a single card. * @param {string} cardId The id of the card. * @param {*} [options] Override http request option. @@ -13019,7 +13076,7 @@ export interface BoardCardApiInterface { cardControllerDeleteCard(cardId: string, options?: any): AxiosPromise; /** - * + * * @summary Get a list of cards by their ids. * @param {Array} ids Array of Ids to be loaded * @param {*} [options] Override http request option. @@ -13029,10 +13086,10 @@ export interface BoardCardApiInterface { cardControllerGetCards(ids: Array, options?: any): AxiosPromise; /** - * + * * @summary Move a single card. * @param {string} cardId The id of the card. - * @param {MoveCardBodyParams} moveCardBodyParams + * @param {MoveCardBodyParams} moveCardBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardCardApiInterface @@ -13040,10 +13097,10 @@ export interface BoardCardApiInterface { cardControllerMoveCard(cardId: string, moveCardBodyParams: MoveCardBodyParams, options?: any): AxiosPromise; /** - * + * * @summary Update the height of a single card. * @param {string} cardId The id of the card. - * @param {SetHeightBodyParams} setHeightBodyParams + * @param {SetHeightBodyParams} setHeightBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardCardApiInterface @@ -13051,10 +13108,10 @@ export interface BoardCardApiInterface { cardControllerUpdateCardHeight(cardId: string, setHeightBodyParams: SetHeightBodyParams, options?: any): AxiosPromise; /** - * + * * @summary Update the title of a single card. * @param {string} cardId The id of the card. - * @param {RenameBodyParams} renameBodyParams + * @param {RenameBodyParams} renameBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardCardApiInterface @@ -13071,10 +13128,10 @@ export interface BoardCardApiInterface { */ export class BoardCardApi extends BaseAPI implements BoardCardApiInterface { /** - * + * * @summary Create a new element on a card. * @param {string} cardId The id of the card. - * @param {CreateContentElementBodyParams} createContentElementBodyParams + * @param {CreateContentElementBodyParams} createContentElementBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardCardApi @@ -13084,7 +13141,7 @@ export class BoardCardApi extends BaseAPI implements BoardCardApiInterface { } /** - * + * * @summary Delete a single card. * @param {string} cardId The id of the card. * @param {*} [options] Override http request option. @@ -13096,7 +13153,7 @@ export class BoardCardApi extends BaseAPI implements BoardCardApiInterface { } /** - * + * * @summary Get a list of cards by their ids. * @param {Array} ids Array of Ids to be loaded * @param {*} [options] Override http request option. @@ -13108,10 +13165,10 @@ export class BoardCardApi extends BaseAPI implements BoardCardApiInterface { } /** - * + * * @summary Move a single card. * @param {string} cardId The id of the card. - * @param {MoveCardBodyParams} moveCardBodyParams + * @param {MoveCardBodyParams} moveCardBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardCardApi @@ -13121,10 +13178,10 @@ export class BoardCardApi extends BaseAPI implements BoardCardApiInterface { } /** - * + * * @summary Update the height of a single card. * @param {string} cardId The id of the card. - * @param {SetHeightBodyParams} setHeightBodyParams + * @param {SetHeightBodyParams} setHeightBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardCardApi @@ -13134,10 +13191,10 @@ export class BoardCardApi extends BaseAPI implements BoardCardApiInterface { } /** - * + * * @summary Update the title of a single card. * @param {string} cardId The id of the card. - * @param {RenameBodyParams} renameBodyParams + * @param {RenameBodyParams} renameBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardCardApi @@ -13155,10 +13212,10 @@ export class BoardCardApi extends BaseAPI implements BoardCardApiInterface { export const BoardColumnApiAxiosParamCreator = function (configuration?: Configuration) { return { /** - * + * * @summary Create a new card on a column. * @param {string} columnId The id of the column. - * @param {CreateCardBodyParams} [createCardBodyParams] + * @param {CreateCardBodyParams} [createCardBodyParams] * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -13183,7 +13240,7 @@ export const BoardColumnApiAxiosParamCreator = function (configuration?: Configu await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -13197,7 +13254,7 @@ export const BoardColumnApiAxiosParamCreator = function (configuration?: Configu }; }, /** - * + * * @summary Delete a single column. * @param {string} columnId The id of the column. * @param {*} [options] Override http request option. @@ -13224,7 +13281,7 @@ export const BoardColumnApiAxiosParamCreator = function (configuration?: Configu await setBearerAuthToObject(localVarHeaderParameter, configuration) - + setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); let headersFromBaseOptions = baseOptions && baseOptions.headers ? baseOptions.headers : {}; localVarRequestOptions.headers = {...localVarHeaderParameter, ...headersFromBaseOptions, ...options.headers}; @@ -13235,10 +13292,10 @@ export const BoardColumnApiAxiosParamCreator = function (configuration?: Configu }; }, /** - * + * * @summary Move a single column. * @param {string} columnId The id of the column. - * @param {MoveColumnBodyParams} moveColumnBodyParams + * @param {MoveColumnBodyParams} moveColumnBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -13265,7 +13322,7 @@ export const BoardColumnApiAxiosParamCreator = function (configuration?: Configu await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -13279,10 +13336,10 @@ export const BoardColumnApiAxiosParamCreator = function (configuration?: Configu }; }, /** - * + * * @summary Update the title of a single column. * @param {string} columnId The id of the column. - * @param {RenameBodyParams} renameBodyParams + * @param {RenameBodyParams} renameBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -13309,7 +13366,7 @@ export const BoardColumnApiAxiosParamCreator = function (configuration?: Configu await setBearerAuthToObject(localVarHeaderParameter, configuration) - + localVarHeaderParameter['Content-Type'] = 'application/json'; setSearchParams(localVarUrlObj, localVarQueryParameter, options.query); @@ -13333,10 +13390,10 @@ export const BoardColumnApiFp = function(configuration?: Configuration) { const localVarAxiosParamCreator = BoardColumnApiAxiosParamCreator(configuration) return { /** - * + * * @summary Create a new card on a column. * @param {string} columnId The id of the column. - * @param {CreateCardBodyParams} [createCardBodyParams] + * @param {CreateCardBodyParams} [createCardBodyParams] * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -13345,7 +13402,7 @@ export const BoardColumnApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Delete a single column. * @param {string} columnId The id of the column. * @param {*} [options] Override http request option. @@ -13356,10 +13413,10 @@ export const BoardColumnApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Move a single column. * @param {string} columnId The id of the column. - * @param {MoveColumnBodyParams} moveColumnBodyParams + * @param {MoveColumnBodyParams} moveColumnBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -13368,10 +13425,10 @@ export const BoardColumnApiFp = function(configuration?: Configuration) { return createRequestFunction(localVarAxiosArgs, globalAxios, BASE_PATH, configuration); }, /** - * + * * @summary Update the title of a single column. * @param {string} columnId The id of the column. - * @param {RenameBodyParams} renameBodyParams + * @param {RenameBodyParams} renameBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -13390,10 +13447,10 @@ export const BoardColumnApiFactory = function (configuration?: Configuration, ba const localVarFp = BoardColumnApiFp(configuration) return { /** - * + * * @summary Create a new card on a column. * @param {string} columnId The id of the column. - * @param {CreateCardBodyParams} [createCardBodyParams] + * @param {CreateCardBodyParams} [createCardBodyParams] * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -13401,7 +13458,7 @@ export const BoardColumnApiFactory = function (configuration?: Configuration, ba return localVarFp.columnControllerCreateCard(columnId, createCardBodyParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Delete a single column. * @param {string} columnId The id of the column. * @param {*} [options] Override http request option. @@ -13411,10 +13468,10 @@ export const BoardColumnApiFactory = function (configuration?: Configuration, ba return localVarFp.columnControllerDeleteColumn(columnId, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Move a single column. * @param {string} columnId The id of the column. - * @param {MoveColumnBodyParams} moveColumnBodyParams + * @param {MoveColumnBodyParams} moveColumnBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -13422,10 +13479,10 @@ export const BoardColumnApiFactory = function (configuration?: Configuration, ba return localVarFp.columnControllerMoveColumn(columnId, moveColumnBodyParams, options).then((request) => request(axios, basePath)); }, /** - * + * * @summary Update the title of a single column. * @param {string} columnId The id of the column. - * @param {RenameBodyParams} renameBodyParams + * @param {RenameBodyParams} renameBodyParams * @param {*} [options] Override http request option. * @throws {RequiredError} */ @@ -13442,10 +13499,10 @@ export const BoardColumnApiFactory = function (configuration?: Configuration, ba */ export interface BoardColumnApiInterface { /** - * + * * @summary Create a new card on a column. * @param {string} columnId The id of the column. - * @param {CreateCardBodyParams} [createCardBodyParams] + * @param {CreateCardBodyParams} [createCardBodyParams] * @param {*} [options] Override http request option. * @throws {RequiredError} * @memberof BoardColumnApiInterface @@ -13453,7 +13510,7 @@ export interface BoardColumnApiInterface { columnControllerCreateCard(columnId: string, createCardBodyParams?: CreateCardBodyParams, options?: any): AxiosPromise