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

44 lines
1.2 KiB
Vue
Raw Normal View History

2023-01-08 10:41:09 +02:00
<template>
<MkContainer :show-header="widgetProps.showHeader" class="mkw-clicker">
2023-01-15 01:30:29 +02:00
<template #icon><i class="ti ti-cookie"></i></template>
<template #header>Clicker</template>
2023-01-08 10:41:09 +02:00
<MkClickerGame/>
</MkContainer>
</template>
<script lang="ts" setup>
import { useWidgetPropsManager, Widget, WidgetComponentExpose } from './widget';
2023-01-08 10:41:09 +02:00
import { GetFormResultType } from '@/scripts/form';
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 02:04:35 +02:00
default: false,
2023-01-08 10:41:09 +02:00
},
};
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>