Update styling for element chooser, add checkbox for nested list
This commit is contained in:
parent
3ff03e9835
commit
6f474d9261
|
|
@ -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 & 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 & 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>
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue