diff options
| author | syuilo <Syuilotan@yahoo.co.jp> | 2023-01-09 20:35:36 +0900 |
|---|---|---|
| committer | syuilo <Syuilotan@yahoo.co.jp> | 2023-01-09 20:35:36 +0900 |
| commit | d06f61f23f29b2571fb720666fb8b616bdc52e95 (patch) | |
| tree | bfb7c38af18d075ea51a35a0aae240af29140dbc /packages/frontend/src | |
| parent | feat(client): add profile widget (diff) | |
| download | misskey-d06f61f23f29b2571fb720666fb8b616bdc52e95.tar.gz misskey-d06f61f23f29b2571fb720666fb8b616bdc52e95.tar.bz2 misskey-d06f61f23f29b2571fb720666fb8b616bdc52e95.zip | |
feat(client): add instance info widget
Diffstat (limited to 'packages/frontend/src')
| -rw-r--r-- | packages/frontend/src/widgets/index.ts | 2 | ||||
| -rw-r--r-- | packages/frontend/src/widgets/instance-info.vue | 94 | ||||
| -rw-r--r-- | packages/frontend/src/widgets/profile.vue | 2 |
3 files changed, 97 insertions, 1 deletions
diff --git a/packages/frontend/src/widgets/index.ts b/packages/frontend/src/widgets/index.ts index 0b81892419..10b8d94234 100644 --- a/packages/frontend/src/widgets/index.ts +++ b/packages/frontend/src/widgets/index.ts @@ -2,6 +2,7 @@ import { App, defineAsyncComponent } from 'vue'; export default function(app: App) { app.component('MkwProfile', defineAsyncComponent(() => import('./profile.vue'))); + app.component('MkwInstanceInfo', defineAsyncComponent(() => import('./instance-info.vue'))); app.component('MkwMemo', defineAsyncComponent(() => import('./memo.vue'))); app.component('MkwNotifications', defineAsyncComponent(() => import('./notifications.vue'))); app.component('MkwTimeline', defineAsyncComponent(() => import('./timeline.vue'))); @@ -31,6 +32,7 @@ export default function(app: App) { export const widgets = [ 'profile', + 'instanceInfo', 'memo', 'notifications', 'timeline', diff --git a/packages/frontend/src/widgets/instance-info.vue b/packages/frontend/src/widgets/instance-info.vue new file mode 100644 index 0000000000..990802d847 --- /dev/null +++ b/packages/frontend/src/widgets/instance-info.vue @@ -0,0 +1,94 @@ +<template> +<div class="_panel"> + <div :class="$style.container" :style="{ backgroundImage: $instance.bannerUrl ? `url(${ $instance.bannerUrl })` : null }"> + <div :class="$style.iconContainer"> + <img :src="$instance.iconUrl ?? $instance.faviconUrl ?? '/favicon.ico'" alt="" :class="$style.icon"/> + </div> + <div :class="$style.bodyContainer"> + <div :class="$style.body"> + <MkA :class="$style.name" to="/about" behavior="window">{{ $instance.name }}</MkA> + <div :class="$style.host">{{ host }}</div> + </div> + </div> + </div> +</div> +</template> + +<script lang="ts" setup> +import { onMounted, onUnmounted, Ref, ref, watch } from 'vue'; +import { useWidgetPropsManager, Widget, WidgetComponentEmits, WidgetComponentExpose, WidgetComponentProps } from './widget'; +import { GetFormResultType } from '@/scripts/form'; +import { host } from '@/config'; + +const name = 'instanceInfo'; + +const widgetPropsDef = { +}; + +type WidgetProps = GetFormResultType<typeof widgetPropsDef>; + +// 現時点ではvueの制限によりimportしたtypeをジェネリックに渡せない +//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 } = useWidgetPropsManager(name, + widgetPropsDef, + props, + emit, +); + +defineExpose<WidgetComponentExpose>({ + name, + configure, + id: props.widget ? props.widget.id : null, +}); +</script> + +<style lang="scss" module> +.container { + position: relative; + background-size: cover; + background-position: center; + display: flex; +} + +.iconContainer { + display: inline-block; + text-align: center; + padding: 16px; +} + +.icon { + display: inline-block; + width: 60px; + height: 60px; + border-radius: 8px; + box-sizing: border-box; + border: solid 3px #fff; +} + +.bodyContainer { + display: flex; + align-items: center; + min-width: 0; + padding: 0 16px 0 0; +} + +.body { + text-overflow: ellipsis; + overflow: clip; +} + +.name { + color: #fff; + filter: drop-shadow(0 0 4px #000); + font-weight: bold; +} + +.host { + color: #fff; + filter: drop-shadow(0 0 4px #000); +} +</style> diff --git a/packages/frontend/src/widgets/profile.vue b/packages/frontend/src/widgets/profile.vue index 3c70be12c3..c6e66c1df2 100644 --- a/packages/frontend/src/widgets/profile.vue +++ b/packages/frontend/src/widgets/profile.vue @@ -6,7 +6,7 @@ </div> <div :class="$style.bodyContainer"> <div :class="$style.body"> - <MkA v-once :class="$style.name" :to="userPage($i)"> + <MkA :class="$style.name" :to="userPage($i)"> <MkUserName :user="$i"/> </MkA> <div :class="$style.username"><MkAcct :user="$i" detail/></div> |