summaryrefslogtreecommitdiff
path: root/packages/client/src/components/widgets.vue
diff options
context:
space:
mode:
Diffstat (limited to 'packages/client/src/components/widgets.vue')
-rw-r--r--packages/client/src/components/widgets.vue146
1 files changed, 0 insertions, 146 deletions
diff --git a/packages/client/src/components/widgets.vue b/packages/client/src/components/widgets.vue
deleted file mode 100644
index 74dd79f733..0000000000
--- a/packages/client/src/components/widgets.vue
+++ /dev/null
@@ -1,146 +0,0 @@
-<template>
-<div class="vjoppmmu">
- <template v-if="edit">
- <header>
- <MkSelect v-model="widgetAdderSelected" style="margin-bottom: var(--margin)" class="mk-widget-select">
- <template #label>{{ $ts.selectWidget }}</template>
- <option v-for="widget in widgetDefs" :key="widget" :value="widget">{{ $t(`_widgets.${widget}`) }}</option>
- </MkSelect>
- <MkButton inline primary class="mk-widget-add" @click="addWidget"><i class="fas fa-plus"></i> {{ $ts.add }}</MkButton>
- <MkButton inline @click="$emit('exit')">{{ $ts.close }}</MkButton>
- </header>
- <XDraggable
- v-model="widgets_"
- item-key="id"
- handle=".handle"
- animation="150"
- >
- <template #item="{element}">
- <div class="customize-container">
- <button class="config _button" @click.prevent.stop="configWidget(element.id)"><i class="fas fa-cog"></i></button>
- <button class="remove _button" @click.prevent.stop="removeWidget(element)"><i class="fas fa-times"></i></button>
- <component :is="`mkw-${element.name}`" :ref="el => widgetRefs[element.id] = el" class="handle" :widget="element" @updateProps="updateWidget(element.id, $event)"/>
- </div>
- </template>
- </XDraggable>
- </template>
- <component :is="`mkw-${widget.name}`" v-for="widget in widgets" v-else :key="widget.id" class="widget" :widget="widget" @updateProps="updateWidget(widget.id, $event)"/>
-</div>
-</template>
-
-<script lang="ts">
-import { defineComponent, defineAsyncComponent, reactive, ref, computed } from 'vue';
-import { v4 as uuid } from 'uuid';
-import MkSelect from '@/components/form/select.vue';
-import MkButton from '@/components/ui/button.vue';
-import { widgets as widgetDefs } from '@/widgets';
-
-export default defineComponent({
- components: {
- XDraggable: defineAsyncComponent(() => import('vuedraggable')),
- MkSelect,
- MkButton,
- },
-
- props: {
- widgets: {
- type: Array,
- required: true,
- },
- edit: {
- type: Boolean,
- required: true,
- },
- },
-
- emits: ['updateWidgets', 'addWidget', 'removeWidget', 'updateWidget', 'exit'],
-
- setup(props, context) {
- const widgetRefs = reactive({});
- const configWidget = (id: string) => {
- widgetRefs[id].configure();
- };
- const widgetAdderSelected = ref(null);
- const addWidget = () => {
- if (widgetAdderSelected.value == null) return;
-
- context.emit('addWidget', {
- name: widgetAdderSelected.value,
- id: uuid(),
- data: {},
- });
-
- widgetAdderSelected.value = null;
- };
- const removeWidget = (widget) => {
- context.emit('removeWidget', widget);
- };
- const updateWidget = (id, data) => {
- context.emit('updateWidget', { id, data });
- };
- const widgets_ = computed({
- get: () => props.widgets,
- set: (value) => {
- context.emit('updateWidgets', value);
- },
- });
-
- return {
- widgetRefs,
- configWidget,
- widgetAdderSelected,
- widgetDefs,
- addWidget,
- removeWidget,
- updateWidget,
- widgets_,
- };
- },
-});
-</script>
-
-<style lang="scss" scoped>
-.vjoppmmu {
- > header {
- margin: 16px 0;
-
- > * {
- width: 100%;
- padding: 4px;
- }
- }
-
- > .widget, .customize-container {
- margin: var(--margin) 0;
-
- &:first-of-type {
- margin-top: 0;
- }
- }
-
- .customize-container {
- position: relative;
- cursor: move;
-
- > .config,
- > .remove {
- position: absolute;
- z-index: 10000;
- top: 8px;
- width: 32px;
- height: 32px;
- color: #fff;
- background: rgba(#000, 0.7);
- border-radius: 4px;
- }
-
- > .config {
- right: 8px + 8px + 32px;
- }
-
- > .remove {
- right: 8px;
- }
- }
-}
-</style>