iceshrimp-legacy/packages/client/src/ui/universal.widgets.vue

112 lines
2 KiB
Vue
Raw Normal View History

<template>
<aside class="widgets" :aria-label="i18n.ts._deck._columns.widgets">
2023-04-08 02:01:42 +02:00
<MkAd class="a" :prefer="['widget']" />
<XWidgets
:edit="editMode"
:widgets="defaultStore.reactiveState.widgets.value"
@add-widget="addWidget"
@remove-widget="removeWidget"
@update-widget="updateWidget"
@update-widgets="updateWidgets"
@exit="editMode = false"
/>
<button
v-if="editMode"
class="_textButton"
style="font-size: 0.9em"
@click="editMode = false"
>
<i class="ph-check ph-bold ph-lg"></i> {{ i18n.ts.editWidgetsExit }}
</button>
<button
v-else
class="_textButton mk-widget-edit"
style="font-size: 0.9em"
@click="editMode = true"
>
<i class="ph-pencil ph-bold ph-lg"></i> {{ i18n.ts.editWidgets }}
</button>
2023-05-10 22:20:52 +02:00
</aside>
</template>
<script lang="ts" setup>
2023-04-08 02:01:42 +02:00
import { onMounted } from "vue";
import XWidgets from "@/components/MkWidgets.vue";
import { i18n } from "@/i18n";
import { defaultStore } from "@/store";
const emit = defineEmits<{
2023-04-08 02:01:42 +02:00
(ev: "mounted", el: Element): void;
}>();
2023-07-17 00:32:32 +02:00
const editMode = $ref(false);
const rootEl = $ref<HTMLDivElement>();
onMounted(() => {
2023-04-08 02:01:42 +02:00
emit("mounted", rootEl);
});
function addWidget(widget) {
2023-04-08 02:01:42 +02:00
defaultStore.set("widgets", [
{
...widget,
place: null,
},
...defaultStore.state.widgets,
]);
}
function removeWidget(widget) {
2023-04-08 02:01:42 +02:00
defaultStore.set(
"widgets",
2023-07-06 03:28:27 +02:00
defaultStore.state.widgets.filter((w) => w.id !== widget.id),
2023-04-08 02:01:42 +02:00
);
}
function updateWidget({ id, data }) {
2023-04-08 02:01:42 +02:00
defaultStore.set(
"widgets",
defaultStore.state.widgets.map((w) =>
w.id === id
? {
...w,
data,
}
2023-07-06 03:28:27 +02:00
: w,
),
2023-04-08 02:01:42 +02:00
);
}
function updateWidgets(widgets) {
2023-04-08 02:01:42 +02:00
defaultStore.set("widgets", widgets);
}
</script>
<style lang="scss" scoped>
.widgets {
height: min-content;
min-height: 100vh;
2023-06-09 05:30:14 +02:00
padding: var(--margin) 0;
box-sizing: border-box;
2023-06-26 00:19:37 +02:00
display: flex;
flex-direction: column;
2023-06-26 00:49:12 +02:00
> :deep(*) {
2023-06-26 00:19:37 +02:00
margin-top: var(--margin);
width: 300px;
2023-06-09 05:30:14 +02:00
&:first-child {
margin-top: 0;
}
}
2023-06-26 00:19:37 +02:00
.a:empty {
display: none;
}
> .add {
margin: 0 auto;
}
}
</style>