port user list widget from mk

This commit is contained in:
ThatOneCalculator 2023-01-16 11:19:19 -08:00
parent fd4d46b6a4
commit cc52292985
No known key found for this signature in database
GPG key ID: 8703CACD01000000
3 changed files with 123 additions and 3 deletions

View file

@ -1329,7 +1329,7 @@ _widgets:
jobQueue: "Job Queue" jobQueue: "Job Queue"
serverMetric: "Server metrics" serverMetric: "Server metrics"
aiscript: "AiScript console" aiscript: "AiScript console"
aichan: "Ai" userList: "User list"
_cw: _cw:
hide: "Hide" hide: "Hide"
show: "Show content" show: "Show content"

View file

@ -1,12 +1,12 @@
{ {
"name": "calckey", "name": "calckey",
"version": "13.0.7-rc", "version": "13.0.8-rc",
"codename": "aqua", "codename": "aqua",
"repository": { "repository": {
"type": "git", "type": "git",
"url": "https://lavaforge.org/calckey/calckey.git" "url": "https://lavaforge.org/calckey/calckey.git"
}, },
"packageManager": "pnpm@7.24.3", "packageManager": "pnpm@7.25.0",
"private": true, "private": true,
"scripts": { "scripts": {
"rebuild": "pnpm run clean && pnpm -r run build && pnpm run gulp", "rebuild": "pnpm run clean && pnpm -r run build && pnpm run gulp",

View file

@ -0,0 +1,120 @@
<template>
<MkContainer :show-header="widgetProps.showHeader" class="mkw-userList">
<template #icon><i class="ph-user-list-bold ph-lg"></i></template>
<template #header>{{ list ? list.name : i18n.ts._widgets.userList }}</template>
<template #func="{ buttonStyleClass }"><button class="_button" :class="buttonStyleClass" @click="configure()"><i class="ph-gear-six-bold ph-lg"></i></button></template>
<div class="wsdlkfj">
<div v-if="widgetProps.listId == null" class="init">
<MkButton primary @click="chooseList">{{ i18n.ts._widgets._userList.chooseList }}</MkButton>
</div>
<MkLoading v-else-if="fetching"/>
<div v-else class="users">
<span v-for="user in users" :key="user.id" class="user">
<MkAvatar :user="user" class="avatar" indicator link preview/>
</span>
</div>
</div>
</MkContainer>
</template>
<script lang="ts" setup>
import { useWidgetPropsManager, Widget, WidgetComponentExpose } from './widget';
import { GetFormResultType } from '@/scripts/form';
import MkContainer from '@/components/MkContainer.vue';
import * as os from '@/os';
import { useInterval } from '@/scripts/use-interval';
import { i18n } from '@/i18n';
import MkButton from '@/components/MkButton.vue';
const name = 'userList';
const widgetPropsDef = {
showHeader: {
type: 'boolean' as const,
default: true,
},
listId: {
type: 'string' as const,
default: null,
hidden: true,
},
};
type WidgetProps = GetFormResultType<typeof widgetPropsDef>;
// vueimporttype
//const props = defineProps<WidgetComponentProps<WidgetProps>>();
//const emit = defineEmits<WidgetComponentEmits<WidgetProps>>();
const props = defineProps<{ widget?: Widget<WidgetProps>; }>();
const emit = defineEmits<{ (ev: 'updateProps', props: WidgetProps); }>();
const { widgetProps, configure, save } = useWidgetPropsManager(name,
widgetPropsDef,
props,
emit,
);
let list = $ref();
let users = $ref([]);
let fetching = $ref(true);
async function chooseList() {
const lists = await os.api('users/lists/list');
const { canceled, result: list } = await os.select({
title: i18n.ts.selectList,
items: lists.map(x => ({
value: x, text: x.name,
})),
default: widgetProps.listId,
});
if (canceled) return;
widgetProps.listId = list.id;
save();
fetch();
}
const fetch = () => {
if (widgetProps.listId == null) {
fetching = false;
return;
}
os.api('users/lists/show', {
listId: widgetProps.listId,
}).then(_list => {
list = _list;
os.api('users/show', {
userIds: list.userIds,
}).then(_users => {
users = _users;
fetching = false;
});
});
};
useInterval(fetch, 1000 * 60, {
immediate: true,
afterMounted: true,
});
defineExpose<WidgetComponentExpose>({
name,
configure,
id: props.widget ? props.widget.id : null,
});
</script>
<style lang="scss" module>
.wsdlkfj {
> .init {
padding: 16px;
}
> .users {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(30px, 40px));
grid-gap: 12px;
place-content: center;
padding: 16px;
> .user {
width: 100%;
height: 100%;
aspect-ratio: 1;
> .avatar {
width: 100%;
height: 100%;
}
}
}
}
</style>