Merge branch 'develop'
This commit is contained in:
commit
afd33cb53d
|
|
@ -1,7 +1,7 @@
|
|||
<script setup lang="ts">
|
||||
import LearningContentContainer from "@/components/learningPath/LearningContentContainer.vue";
|
||||
import { useCircleStore } from "@/stores/circle";
|
||||
import type { LearningContent } from "@/types";
|
||||
import type { LearningContent, LearningContentType } from "@/types";
|
||||
import log from "loglevel";
|
||||
import { computed } from "vue";
|
||||
|
||||
|
|
@ -9,6 +9,7 @@ import DescriptionBlock from "@/components/learningPath/blocks/DescriptionBlock.
|
|||
import DescriptionTextBlock from "@/components/learningPath/blocks/DescriptionTextBlock.vue";
|
||||
import FeedbackBlock from "@/components/learningPath/blocks/FeedbackBlock.vue";
|
||||
import IframeBlock from "@/components/learningPath/blocks/IframeBlock.vue";
|
||||
import MediaLibraryBlock from "@/components/learningPath/blocks/MediaLibraryBlock.vue";
|
||||
import PlaceholderBlock from "@/components/learningPath/blocks/PlaceholderBlock.vue";
|
||||
import VideoBlock from "@/components/learningPath/blocks/VideoBlock.vue";
|
||||
|
||||
|
|
@ -29,7 +30,7 @@ const block = computed(() => {
|
|||
});
|
||||
|
||||
// can't use the type as component name, as some are reserved HTML components, e.g. video
|
||||
const COMPONENTS: Record<string, any> = {
|
||||
const COMPONENTS: Record<LearningContentType, any> = {
|
||||
// todo: can we find a better type here than any? ^
|
||||
placeholder: PlaceholderBlock,
|
||||
video: VideoBlock,
|
||||
|
|
@ -39,6 +40,10 @@ const COMPONENTS: Record<string, any> = {
|
|||
test: IframeBlock,
|
||||
learningmodule: IframeBlock,
|
||||
feedback: FeedbackBlock,
|
||||
book: DescriptionBlock,
|
||||
document: DescriptionBlock,
|
||||
media_library: MediaLibraryBlock,
|
||||
online_training: DescriptionBlock,
|
||||
};
|
||||
const DEFAULT_BLOCK = DescriptionBlock;
|
||||
|
||||
|
|
|
|||
|
|
@ -212,6 +212,22 @@ def create_default_users(user_model=User, group_model=Group, default_password=No
|
|||
password="myafa1234",
|
||||
language="fr",
|
||||
)
|
||||
_create_student_user(
|
||||
email="patrick.muster@eiger-versicherungen.ch",
|
||||
first_name="Patrick",
|
||||
last_name="Muster",
|
||||
avatar_url="/static/avatars/uk1.michael.meier.jpg",
|
||||
password="myvbv1234",
|
||||
language="de",
|
||||
)
|
||||
_create_student_user(
|
||||
email="geraldine.kolly@assurance.ch",
|
||||
first_name="Géraldine",
|
||||
last_name="Kolly",
|
||||
avatar_url="/static/avatars/uk1.patrizia.huggel.jpg",
|
||||
password="myafa1234",
|
||||
language="fr",
|
||||
)
|
||||
|
||||
|
||||
def _get_or_create_user(user_model, *args, **kwargs):
|
||||
|
|
|
|||
|
|
@ -66,8 +66,8 @@ def command():
|
|||
title="Versicherungsvermittler/-in",
|
||||
)
|
||||
create_vv_new_competence_profile(course_id=COURSE_VERSICHERUNGSVERMITTLERIN_ID)
|
||||
create_vv_new_learning_path()
|
||||
create_default_media_library(course_id=COURSE_VERSICHERUNGSVERMITTLERIN_ID)
|
||||
create_vv_new_learning_path()
|
||||
|
||||
# Überbetriebliche Kurse DE
|
||||
create_versicherungsvermittlerin_with_categories(
|
||||
|
|
@ -173,33 +173,16 @@ def command():
|
|||
course_id=course["course_id"],
|
||||
title=course["title"],
|
||||
)
|
||||
# for user_data in default_users:
|
||||
# CourseSessionUser.objects.create(
|
||||
# course_session=cs,
|
||||
# user=User.objects.get(username=user_data["email"]),
|
||||
# )
|
||||
# csu = CourseSessionUser.objects.create(
|
||||
# course_session=cs,
|
||||
# user=User.objects.get(username="trainer-uk1.einstieg@eiger-versicherungen.ch"),
|
||||
# )
|
||||
# csu.expert.add(Circle.objects.get(slug="überbetriebliche-kurse-lp-circle-einstieg"))
|
||||
# csu = CourseSessionUser.objects.create(
|
||||
# course_session=cs,
|
||||
# user=User.objects.get(username="trainer-uk1.analyse@eiger-versicherungen.ch"),
|
||||
# )
|
||||
# csu.expert.add(Circle.objects.get(slug="überbetriebliche-kurse-lp-circle-analyse"))
|
||||
# csu = CourseSessionUser.objects.create(
|
||||
# course_session=cs,
|
||||
# user=User.objects.get(username="student-uk1-bern@eiger-versicherungen.ch"),
|
||||
# )
|
||||
|
||||
# figma demo users and data
|
||||
csu = CourseSessionUser.objects.create(
|
||||
course_session=cs,
|
||||
user=User.objects.get(username="patrizia.huggel@eiger-versicherungen.ch"),
|
||||
role=CourseSessionUser.Role.EXPERT,
|
||||
)
|
||||
if course["course_id"] == COURSE_UK:
|
||||
csu = CourseSessionUser.objects.create(
|
||||
course_session=cs,
|
||||
user=User.objects.get(
|
||||
username="patrizia.huggel@eiger-versicherungen.ch"
|
||||
),
|
||||
role=CourseSessionUser.Role.EXPERT,
|
||||
)
|
||||
csu.expert.add(
|
||||
Circle.objects.get(slug="überbetriebliche-kurse-lp-circle-kickoff")
|
||||
)
|
||||
|
|
@ -247,6 +230,13 @@ def command():
|
|||
user=User.objects.get(username="axel.manderbach@lernetz.ch"),
|
||||
)
|
||||
|
||||
_csu = CourseSessionUser.objects.create(
|
||||
course_session=cs,
|
||||
user=User.objects.get(
|
||||
username="patrick.muster@eiger-versicherungen.ch"
|
||||
),
|
||||
)
|
||||
|
||||
create_feedback(
|
||||
Circle.objects.get(slug="überbetriebliche-kurse-lp-circle-kickoff"),
|
||||
cs,
|
||||
|
|
@ -263,10 +253,26 @@ def command():
|
|||
Circle.objects.get(slug="überbetriebliche-kurse-lp-circle-basis"), cs, 4
|
||||
)
|
||||
elif course["course_id"] == COURSE_UK_FR:
|
||||
csu = CourseSessionUser.objects.create(
|
||||
course_session=cs,
|
||||
user=User.objects.get(username="geraldine.kolly@assurance.ch"),
|
||||
role=CourseSessionUser.Role.EXPERT,
|
||||
)
|
||||
csu.expert.add(
|
||||
Circle.objects.get(
|
||||
slug="course-hors-établissement-lp-circle-coup-denvoi"
|
||||
)
|
||||
)
|
||||
_csu = CourseSessionUser.objects.create(
|
||||
course_session=cs,
|
||||
user=User.objects.get(username="luca.dupont@assurance.ch"),
|
||||
)
|
||||
csu = CourseSessionUser.objects.create(
|
||||
course_session=cs,
|
||||
user=User.objects.get(username="andreas.feuz@eiger-versicherungen.ch"),
|
||||
role=CourseSessionUser.Role.EXPERT,
|
||||
)
|
||||
|
||||
for fr_circle in Circle.objects.filter(
|
||||
slug__startswith="course-hors-établissement-lp"
|
||||
):
|
||||
|
|
@ -429,7 +435,7 @@ def command():
|
|||
"michael.meier@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-fahrzeug-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-fahrzeug-lc-mediathek-fahrzeug",
|
||||
"success",
|
||||
"michael.meier@example.com",
|
||||
),
|
||||
|
|
@ -494,7 +500,7 @@ def command():
|
|||
"michael.meier@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek-haushalt-teil-1",
|
||||
"success",
|
||||
"michael.meier@example.com",
|
||||
),
|
||||
|
|
@ -509,7 +515,7 @@ def command():
|
|||
"michael.meier@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek-haushalt-teil-1",
|
||||
"success",
|
||||
"michael.meier@example.com",
|
||||
),
|
||||
|
|
@ -534,7 +540,7 @@ def command():
|
|||
"michael.meier@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek-haushalt-teil-1",
|
||||
"success",
|
||||
"michael.meier@example.com",
|
||||
),
|
||||
|
|
@ -674,7 +680,7 @@ def command():
|
|||
"lina.egger@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-fahrzeug-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-fahrzeug-lc-mediathek-fahrzeug",
|
||||
"success",
|
||||
"lina.egger@example.com",
|
||||
),
|
||||
|
|
@ -739,7 +745,7 @@ def command():
|
|||
"lina.egger@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek-haushalt-teil-1",
|
||||
"success",
|
||||
"lina.egger@example.com",
|
||||
),
|
||||
|
|
@ -779,7 +785,7 @@ def command():
|
|||
"lina.egger@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek-haushalt-teil-1",
|
||||
"success",
|
||||
"lina.egger@example.com",
|
||||
),
|
||||
|
|
@ -804,7 +810,7 @@ def command():
|
|||
"lina.egger@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-2-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-2-lc-mediathek-haushalt-teil-2",
|
||||
"success",
|
||||
"lina.egger@example.com",
|
||||
),
|
||||
|
|
@ -814,7 +820,7 @@ def command():
|
|||
"lina.egger@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek-haushalt-teil-1",
|
||||
"success",
|
||||
"lina.egger@example.com",
|
||||
),
|
||||
|
|
@ -929,7 +935,7 @@ def command():
|
|||
"evelyn.schmid@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-fahrzeug-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-fahrzeug-lc-mediathek-fahrzeug",
|
||||
"success",
|
||||
"evelyn.schmid@example.com",
|
||||
),
|
||||
|
|
@ -994,7 +1000,7 @@ def command():
|
|||
"evelyn.schmid@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek-haushalt-teil-1",
|
||||
"success",
|
||||
"evelyn.schmid@example.com",
|
||||
),
|
||||
|
|
@ -1024,7 +1030,7 @@ def command():
|
|||
"evelyn.schmid@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-1-lc-mediathek-haushalt-teil-1",
|
||||
"success",
|
||||
"evelyn.schmid@example.com",
|
||||
),
|
||||
|
|
@ -1059,7 +1065,7 @@ def command():
|
|||
"evelyn.schmid@example.com",
|
||||
),
|
||||
(
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-2-lc-mediathek",
|
||||
"überbetriebliche-kurse-lp-circle-haushalt-teil-2-lc-mediathek-haushalt-teil-2",
|
||||
"success",
|
||||
"evelyn.schmid@example.com",
|
||||
),
|
||||
|
|
|
|||
|
|
@ -1,6 +1,7 @@
|
|||
import wagtail_factories
|
||||
from django.conf import settings
|
||||
from django.core.management import call_command
|
||||
from slugify import slugify
|
||||
from wagtail.models import Locale, Page, Site
|
||||
from wagtail_localize.models import LocaleSynchronization
|
||||
|
||||
|
|
@ -14,6 +15,7 @@ from vbv_lernwelt.learnpath.tests.learning_path_factories import (
|
|||
LearningPathFactory,
|
||||
LearningSequenceFactory,
|
||||
LearningUnitFactory,
|
||||
MediaLibraryBlockFactory,
|
||||
TopicFactory,
|
||||
)
|
||||
|
||||
|
|
@ -149,10 +151,37 @@ damit du erfolgreich mit deinem Lernpfad (durch-)starten kannst.
|
|||
title="Verschaffe dir einen Überblick",
|
||||
parent=circle,
|
||||
)
|
||||
LearningContentFactory(
|
||||
title="Mediathek",
|
||||
parent=circle,
|
||||
)
|
||||
|
||||
first_title = title.split()[0]
|
||||
if first_title in [
|
||||
"Haushalt",
|
||||
"Reisen",
|
||||
"Wohneigentum",
|
||||
"KMU",
|
||||
"Einkommenssicherung",
|
||||
"Pensionierung",
|
||||
"Gesundheit",
|
||||
]:
|
||||
LearningContentFactory(
|
||||
title=f"Mediathek {title}",
|
||||
parent=circle,
|
||||
contents=[
|
||||
(
|
||||
"media_library",
|
||||
MediaLibraryBlockFactory(
|
||||
# TODO: sollen die ÜKs auf die gleichen Mediatheken verlinken
|
||||
# wie im Verischerungsvermittler?
|
||||
url=f"/media/überbetriebliche-kurse-media/category/{slugify(first_title)}"
|
||||
),
|
||||
)
|
||||
],
|
||||
)
|
||||
else:
|
||||
LearningContentFactory(
|
||||
title="Mediathek",
|
||||
parent=circle,
|
||||
)
|
||||
|
||||
LearningContentFactory(
|
||||
title="Vorbereitungsauftrag",
|
||||
parent=circle,
|
||||
|
|
@ -209,8 +238,16 @@ damit du erfolgreich mit deinem Lernpfad (durch-)starten kannst.
|
|||
parent=circle,
|
||||
)
|
||||
LearningContentFactory(
|
||||
title="Mediathek",
|
||||
title=f"Mediathek {title}",
|
||||
parent=circle,
|
||||
contents=[
|
||||
(
|
||||
"media_library",
|
||||
MediaLibraryBlockFactory(
|
||||
url=f"/media/überbetriebliche-kurse-media/category/{slugify(title)}"
|
||||
),
|
||||
)
|
||||
],
|
||||
)
|
||||
LearningContentFactory(
|
||||
title="Vorbereitungsauftrag",
|
||||
|
|
|
|||
|
|
@ -1,6 +1,7 @@
|
|||
import wagtail_factories
|
||||
from django.conf import settings
|
||||
from django.core.management import call_command
|
||||
from slugify import slugify
|
||||
from wagtail.models import Locale, Page, Site
|
||||
from wagtail.rich_text import RichText
|
||||
from wagtail_localize.models import LocaleSynchronization
|
||||
|
|
@ -19,6 +20,7 @@ from vbv_lernwelt.learnpath.tests.learning_path_factories import (
|
|||
LearningPathFactory,
|
||||
LearningSequenceFactory,
|
||||
LearningUnitFactory,
|
||||
MediaLibraryBlockFactory,
|
||||
ResourceBlockFactory,
|
||||
TestBlockFactory,
|
||||
TopicFactory,
|
||||
|
|
@ -372,8 +374,16 @@ def create_circle_fahrzeug(lp, title="Fahrzeug"):
|
|||
],
|
||||
)
|
||||
LearningContentFactory(
|
||||
title="Mediathek",
|
||||
title=f"Mediathek {title}",
|
||||
parent=circle,
|
||||
contents=[
|
||||
(
|
||||
"media_library",
|
||||
MediaLibraryBlockFactory(
|
||||
url=f"/media/versicherungsvermittler-in-media/category/{slugify(title)}"
|
||||
),
|
||||
)
|
||||
],
|
||||
)
|
||||
|
||||
LearningSequenceFactory(title="Einstieg", parent=circle, icon="it-icon-ls-watch")
|
||||
|
|
@ -467,8 +477,16 @@ def create_circle_rechtsstreitigkeiten(lp, title="Rechtsstreitigkeiten"):
|
|||
],
|
||||
)
|
||||
LearningContentFactory(
|
||||
title="Mediathek",
|
||||
title=f"Mediathek {title}",
|
||||
parent=circle,
|
||||
contents=[
|
||||
(
|
||||
"media_library",
|
||||
MediaLibraryBlockFactory(
|
||||
url=f"/media/versicherungsvermittler-in-media/category/{slugify(title)}"
|
||||
),
|
||||
)
|
||||
],
|
||||
)
|
||||
|
||||
LearningSequenceFactory(
|
||||
|
|
@ -507,8 +525,16 @@ def create_circle_reisen(lp, title="Reisen"):
|
|||
],
|
||||
)
|
||||
LearningContentFactory(
|
||||
title="Mediathek",
|
||||
title=f"Mediathek {title}",
|
||||
parent=circle,
|
||||
contents=[
|
||||
(
|
||||
"media_library",
|
||||
MediaLibraryBlockFactory(
|
||||
url=f"/media/versicherungsvermittler-in-media/category/{slugify(title)}"
|
||||
),
|
||||
)
|
||||
],
|
||||
)
|
||||
|
||||
LearningSequenceFactory(title="Einstieg", parent=circle, icon="it-icon-ls-watch")
|
||||
|
|
@ -577,8 +603,16 @@ def create_circle_einkommenssicherung(lp, title="Einkommenssicherung"):
|
|||
],
|
||||
)
|
||||
LearningContentFactory(
|
||||
title="Mediathek",
|
||||
title=f"Mediathek {title}",
|
||||
parent=circle,
|
||||
contents=[
|
||||
(
|
||||
"media_library",
|
||||
MediaLibraryBlockFactory(
|
||||
url=f"/media/versicherungsvermittler-in-media/category/{slugify(title)}"
|
||||
),
|
||||
)
|
||||
],
|
||||
)
|
||||
|
||||
LearningSequenceFactory(title="Einstieg", parent=circle, icon="it-icon-ls-watch")
|
||||
|
|
@ -652,8 +686,16 @@ def create_circle_standard_small(
|
|||
],
|
||||
)
|
||||
LearningContentFactory(
|
||||
title="Mediathek",
|
||||
title=f"Mediathek {title}",
|
||||
parent=circle,
|
||||
contents=[
|
||||
(
|
||||
"media_library",
|
||||
MediaLibraryBlockFactory(
|
||||
url=f"/media/versicherungsvermittler-in-media/category/{slugify(title, allow_unicode=True)}"
|
||||
),
|
||||
)
|
||||
],
|
||||
)
|
||||
|
||||
if lu_title is None:
|
||||
|
|
@ -688,8 +730,16 @@ def create_circle_standard(lp, title, lc_title, goals=None, description=None):
|
|||
],
|
||||
)
|
||||
LearningContentFactory(
|
||||
title="Mediathek",
|
||||
title=f"Mediathek {title}",
|
||||
parent=circle,
|
||||
contents=[
|
||||
(
|
||||
"media_library",
|
||||
MediaLibraryBlockFactory(
|
||||
url=f"/media/versicherungsvermittler-in-media/category/{slugify(title)}"
|
||||
),
|
||||
)
|
||||
],
|
||||
)
|
||||
|
||||
LearningSequenceFactory(title="Einstieg", parent=circle, icon="it-icon-ls-watch")
|
||||
|
|
|
|||
Loading…
Reference in New Issue