Sharkey/packages/frontend/src/widgets/WidgetClicker.vue

46 lines
1.2 KiB
Vue
Raw Normal View History

<!--
SPDX-FileCopyrightText: syuilo and other misskey contributors
SPDX-License-Identifier: AGPL-3.0-only
-->
2023-01-08 09:41:09 +01:00
<template>
2023-05-19 09:20:53 +02:00
<MkContainer :showHeader="widgetProps.showHeader" class="mkw-clicker">
<template #icon><i class="ph-cookie ph-bold ph-lg"></i></template>
2023-01-15 00:30:29 +01:00
<template #header>Clicker</template>
2023-01-08 09:41:09 +01:00
<MkClickerGame/>
</MkContainer>
</template>
<script lang="ts" setup>
2023-09-29 04:22:59 +02:00
import { useWidgetPropsManager, Widget, WidgetComponentEmits, WidgetComponentExpose, WidgetComponentProps } from './widget.js';
2023-09-19 09:37:43 +02:00
import { GetFormResultType } from '@/scripts/form.js';
2023-01-08 09:41:09 +01:00
import MkContainer from '@/components/MkContainer.vue';
import MkClickerGame from '@/components/MkClickerGame.vue';
const name = 'clicker';
const widgetPropsDef = {
showHeader: {
type: 'boolean' as const,
2023-01-09 01:04:35 +01:00
default: false,
2023-01-08 09:41:09 +01:00
},
};
type WidgetProps = GetFormResultType<typeof widgetPropsDef>;
2023-05-19 09:20:53 +02:00
const props = defineProps<WidgetComponentProps<WidgetProps>>();
const emit = defineEmits<WidgetComponentEmits<WidgetProps>>();
2023-01-08 09:41:09 +01:00
const { widgetProps, configure } = useWidgetPropsManager(name,
widgetPropsDef,
props,
emit,
);
defineExpose<WidgetComponentExpose>({
name,
configure,
id: props.widget ? props.widget.id : null,
});
</script>