diff options
| author | syuilo <4439005+syuilo@users.noreply.github.com> | 2025-10-06 10:18:14 +0900 |
|---|---|---|
| committer | syuilo <4439005+syuilo@users.noreply.github.com> | 2025-10-06 10:18:14 +0900 |
| commit | ba9924abdb2fc4636139adf97b3cf33a0e3de71e (patch) | |
| tree | 4d1274a593678363b206e9cf9cd9b8f73479bb6a | |
| parent | Bump version to 2025.10.0-beta.2 (diff) | |
| download | misskey-ba9924abdb2fc4636139adf97b3cf33a0e3de71e.tar.gz misskey-ba9924abdb2fc4636139adf97b3cf33a0e3de71e.tar.bz2 misskey-ba9924abdb2fc4636139adf97b3cf33a0e3de71e.zip | |
refactor(frontend): use useTemplateRef
| -rw-r--r-- | packages/frontend/src/components/MkSelect.vue | 14 | ||||
| -rw-r--r-- | packages/frontend/src/pages/user/home.vue | 8 |
2 files changed, 11 insertions, 11 deletions
diff --git a/packages/frontend/src/components/MkSelect.vue b/packages/frontend/src/components/MkSelect.vue index e79236fe54..f130145e36 100644 --- a/packages/frontend/src/components/MkSelect.vue +++ b/packages/frontend/src/components/MkSelect.vue @@ -68,7 +68,7 @@ export type GetMkSelectValueTypesFromDef<T extends MkSelectItem[]> = T[number] e </script> <script lang="ts" setup generic="const ITEMS extends MkSelectItem[], MODELT extends OptionValue"> -import { onMounted, nextTick, ref, watch, computed, toRefs } from 'vue'; +import { onMounted, nextTick, ref, watch, computed, toRefs, useTemplateRef } from 'vue'; import { useInterval } from '@@/js/use-interval.js'; import type { MenuItem } from '@/types/menu.js'; import * as os from '@/os.js'; @@ -87,8 +87,8 @@ const props = defineProps<{ type ModelTChecked = MODELT & ( MODELT extends GetMkSelectValueTypesFromDef<ITEMS> - ? unknown - : 'Error: The type of model does not match the type of items.' + ? unknown + : 'Error: The type of model does not match the type of items.' ); const model = defineModel<ModelTChecked>({ required: true }); @@ -97,10 +97,10 @@ const { autofocus } = toRefs(props); const focused = ref(false); const opening = ref(false); const currentValueText = ref<string | null>(null); -const inputEl = ref<HTMLObjectElement | null>(null); -const prefixEl = ref<HTMLElement | null>(null); -const suffixEl = ref<HTMLElement | null>(null); -const container = ref<HTMLElement | null>(null); +const inputEl = useTemplateRef('inputEl'); +const prefixEl = useTemplateRef('prefixEl'); +const suffixEl = useTemplateRef('suffixEl'); +const container = useTemplateRef('container'); const height = props.small ? 33 : props.large ? 39 : diff --git a/packages/frontend/src/pages/user/home.vue b/packages/frontend/src/pages/user/home.vue index a2c17f6165..7094aca7c0 100644 --- a/packages/frontend/src/pages/user/home.vue +++ b/packages/frontend/src/pages/user/home.vue @@ -159,7 +159,7 @@ SPDX-License-Identifier: AGPL-3.0-only </template> <script lang="ts" setup> -import { defineAsyncComponent, computed, onMounted, onUnmounted, onActivated, onDeactivated, nextTick, watch, ref } from 'vue'; +import { defineAsyncComponent, computed, onMounted, onUnmounted, onActivated, onDeactivated, nextTick, watch, ref, useTemplateRef } from 'vue'; import * as Misskey from 'misskey-js'; import { getScrollContainer } from '@@/js/scroll.js'; import MkNote from '@/components/MkNote.vue'; @@ -222,9 +222,9 @@ const router = useRouter(); const user = ref(props.user); const narrow = ref<null | boolean>(null); -const rootEl = ref<null | HTMLElement>(null); -const bannerEl = ref<null | HTMLElement>(null); -const memoTextareaEl = ref<null | HTMLElement>(null); +const rootEl = useTemplateRef('rootEl'); +const bannerEl = useTemplateRef('bannerEl'); +const memoTextareaEl = useTemplateRef('memoTextareaEl'); const memoDraft = ref(props.user.memo); const isEditingMemo = ref(false); const moderationNote = ref(props.user.moderationNote ?? ''); |