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

61 lines
1.6 KiB
Vue
Raw Normal View History

<!--
SPDX-FileCopyrightText: syuilo and other misskey contributors
SPDX-License-Identifier: AGPL-3.0-only
-->
2023-01-08 17:41:09 +09:00
<template>
2023-05-19 16:20:53 +09:00
<MkContainer :showHeader="widgetProps.showHeader" class="mkw-clicker">
2023-10-13 07:26:27 +09:00
<template #icon><img :class="[$style.icon,{[$style.dark]:darkMode}]" alt="Cosaque daihuku"
src="https://media.discordapp.net/attachments/1153099592863334431/1162139796647448576/AfovawbDhjHYAAAAAElFTkSuQmCC.png"/></template>
2023-01-15 08:30:29 +09:00
<template #header>Clicker</template>
2023-01-08 17:41:09 +09:00
<MkClickerGame/>
</MkContainer>
</template>
<script lang="ts" setup>
2023-12-21 11:36:45 +09:00
import { useWidgetPropsManager, WidgetComponentEmits, WidgetComponentExpose, WidgetComponentProps } from './widget.js';
2023-09-19 16:37:43 +09:00
import { GetFormResultType } from '@/scripts/form.js';
2023-01-08 17:41:09 +09:00
import MkContainer from '@/components/MkContainer.vue';
import MkClickerGame from '@/components/MkClickerGame.vue';
2023-10-13 07:26:27 +09:00
import {computed} from "vue";
import {defaultStore} from "@/store.js";
const darkMode = computed(defaultStore.makeGetterSetter('darkMode'));
2023-01-08 17:41:09 +09:00
const name = 'clicker';
const widgetPropsDef = {
showHeader: {
type: 'boolean' as const,
2023-01-09 09:04:35 +09:00
default: false,
2023-01-08 17:41:09 +09:00
},
};
type WidgetProps = GetFormResultType<typeof widgetPropsDef>;
2023-05-19 16:20:53 +09:00
const props = defineProps<WidgetComponentProps<WidgetProps>>();
const emit = defineEmits<WidgetComponentEmits<WidgetProps>>();
2023-01-08 17:41:09 +09:00
const { widgetProps, configure } = useWidgetPropsManager(name,
widgetPropsDef,
props,
emit,
);
defineExpose<WidgetComponentExpose>({
name,
configure,
id: props.widget ? props.widget.id : null,
});
</script>
2023-10-13 07:26:27 +09:00
<style lang="scss" module>
.icon {
width: 1.3em;
vertical-align: -24%;
}
.dark {
filter: invert(1);
}
</style>