Update styling for element chooser, add checkbox for nested list

This commit is contained in:
Ramon Wenger 2022-01-19 11:31:17 +01:00
parent 3ff03e9835
commit 6f474d9261
1 changed files with 115 additions and 64 deletions

View File

@ -1,54 +1,90 @@
<template> <template>
<div <div class="content-block-element-chooser-widget__wrapper">
:class="{'content-block-element-chooser-widget--no-assignment': hideAssignment}" <template
class="content-block-element-chooser-widget"> v-if="includeListOption"
>
<h3 class="content-block-element-chooser-widget__heading">
Neuer Inhalt
</h3>
<checkbox
class="content-block-element-chooser-widget__list-toggle"
:checked="convertToList"
label="Neues Aufzählungszeichen hinzufügen"
@input="convertToList=$event"
/>
</template>
<div <div
class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--link" :class="{'content-block-element-chooser-widget--no-assignment': hideAssignment}"
data-cy="choose-link-widget" class="content-block-element-chooser-widget"
@click="changeType('link_block')"> >
<link-icon class="content-block-element-chooser-widget__link-icon"/> <div
<div class="content-block-element-chooser-widget__link-title">Link</div> class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--link"
</div> data-cy="choose-link-widget"
<div @click="changeType('link_block')"
class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--video" >
data-cy="choose-video-widget" <link-icon class="content-block-element-chooser-widget__link-icon" />
@click="changeType('video_block')"> <div class="content-block-element-chooser-widget__link-title">
<video-icon class="content-block-element-chooser-widget__link-icon"/> Link
<div class="content-block-element-chooser-widget__link-title">Video</div> </div>
</div> </div>
<div <div
class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--image" class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--video"
data-cy="choose-image-widget" data-cy="choose-video-widget"
@click="changeType('image_url_block')"> @click="changeType('video_block')"
<image-icon class="content-block-element-chooser-widget__link-icon"/> >
<div class="content-block-element-chooser-widget__link-title">Bild</div> <video-icon class="content-block-element-chooser-widget__link-icon" />
</div> <div class="content-block-element-chooser-widget__link-title">
<div Video
class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--text" </div>
data-cy="choose-text-widget" </div>
@click="changeType('text_block')"> <div
<text-icon class="content-block-element-chooser-widget__link-icon"/> class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--image"
<div class="content-block-element-chooser-widget__link-title">Text</div> data-cy="choose-image-widget"
</div> @click="changeType('image_url_block')"
<div >
class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--assignment" <image-icon class="content-block-element-chooser-widget__link-icon" />
data-cy="choose-assignment-widget" <div class="content-block-element-chooser-widget__link-title">
v-if="!hideAssignment" Bild
@click="changeType('assignment')"> </div>
<speech-bubble-icon class="content-block-element-chooser-widget__link-icon"/> </div>
<div class="content-block-element-chooser-widget__link-title">Aufgabe&nbsp;& Ergebnis</div> <div
</div> class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--text"
<div data-cy="choose-text-widget"
class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--document" @click="changeType('text_block')"
data-cy="choose-document-widget" >
@click="changeType('document_block')"> <text-icon class="content-block-element-chooser-widget__link-icon" />
<document-icon class="content-block-element-chooser-widget__link-icon"/> <div class="content-block-element-chooser-widget__link-title">
<div class="content-block-element-chooser-widget__link-title">Dokument</div> Text
</div>
</div>
<div
class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--assignment"
data-cy="choose-assignment-widget"
v-if="!hideAssignment"
@click="changeType('assignment')"
>
<speech-bubble-icon class="content-block-element-chooser-widget__link-icon" />
<div class="content-block-element-chooser-widget__link-title">
Aufgabe&nbsp;& Ergebnis
</div>
</div>
<div
class="content-block-element-chooser-widget__link content-block-element-chooser-widget__link--document"
data-cy="choose-document-widget"
@click="changeType('document_block')"
>
<document-icon class="content-block-element-chooser-widget__link-icon" />
<div class="content-block-element-chooser-widget__link-title">
Dokument
</div>
</div>
</div> </div>
</div> </div>
</template> </template>
<script> <script>
import Checkbox from '@/components/ui/Checkbox';
const LinkIcon = () => import(/* webpackChunkName: "icons" */'@/components/icons/LinkIcon'); const LinkIcon = () => import(/* webpackChunkName: "icons" */'@/components/icons/LinkIcon');
const VideoIcon = () => import(/* webpackChunkName: "icons" */'@/components/icons/VideoIcon'); const VideoIcon = () => import(/* webpackChunkName: "icons" */'@/components/icons/VideoIcon');
const ImageIcon = () => import(/* webpackChunkName: "icons" */'@/components/icons/ImageIcon'); const ImageIcon = () => import(/* webpackChunkName: "icons" */'@/components/icons/ImageIcon');
@ -63,10 +99,15 @@
hideAssignment: { hideAssignment: {
type: Boolean, type: Boolean,
default: false default: false
},
includeListOption: {
type: Boolean,
default: false
} }
}, },
components: { components: {
Checkbox,
LinkIcon, LinkIcon,
VideoIcon, VideoIcon,
ImageIcon, ImageIcon,
@ -75,9 +116,16 @@
DocumentIcon DocumentIcon
}, },
data: () => ({
convertToList: false
}),
methods: { methods: {
changeType(type) { changeType(type) {
this.$emit('change-type', type); this.$emit('change-type', {
type,
convertToList: this.convertToList
});
} }
}, },
}; };
@ -88,6 +136,7 @@
.content-block-element-chooser-widget { .content-block-element-chooser-widget {
display: -ms-grid; display: -ms-grid;
@supports (display: grid) { @supports (display: grid) {
display: grid; display: grid;
} }
@ -96,10 +145,8 @@
grid-column-gap: 0px; grid-column-gap: 0px;
font-family: $sans-serif-font-family; font-family: $sans-serif-font-family;
text-align: center; text-align: center;
border: 2px solid $color-silver-dark; //border: 2px solid $color-silver-dark;
padding: 30px 5px; //border-radius: 12px;
border-radius: 12px;
margin-top: 20px;
position: relative; position: relative;
margin-bottom: 20px; margin-bottom: 20px;
@ -133,34 +180,38 @@
-ms-grid-columns: 1fr 1fr 1fr 1fr 1fr; -ms-grid-columns: 1fr 1fr 1fr 1fr 1fr;
} }
&::before { &__heading {
content: ""; @include heading-4;
position: absolute; margin-bottom: $medium-spacing;
width: 20px; }
height: 20px;
border: 2px solid $color-silver-dark; &__list-toggle {
border-bottom: 0; margin-bottom: $medium-spacing;
border-right: 0;
background-color: white;
top: -12px;
left: 50%;
transform: translateX(-50%) rotate(45deg);
} }
&__link { &__link {
padding: 0 20px;
cursor: pointer; cursor: pointer;
border: 1px solid $color-silver;
border-radius: 4px;
height: 105px;
width: 105px;
box-sizing: border-box;
display: grid;
grid-template-rows: 1fr 45px;
justify-content: center;
justify-items: center;
align-items: center;
} }
&__link-icon { &__link-icon {
width: 40px; width: 40px;
height: 40px; height: 40px;
margin-bottom: 15px; align-self: end;
} }
&__link-text { &__link-text {
font-size: toRem(13px); font-size: toRem(13px);
align-self: start;
} }
} }
</style> </style>