hippofish/packages/client/src/components/MkPostFormDialog.vue

71 lines
1.5 KiB
Vue
Raw Normal View History

<template>
2023-04-08 02:01:42 +02:00
<MkModal
ref="modal"
:prefer-type="'dialog'"
2024-04-12 10:37:32 +02:00
@click="modal!.close()"
2023-04-08 02:01:42 +02:00
@closed="onModalClosed()"
>
<MkPostForm
ref="form"
style="margin: 0 auto auto auto"
v-bind="props"
autofocus
freeze-after-posted
@posted="onPosted"
2024-04-12 10:37:32 +02:00
@cancel="modal!.close()"
@esc="modal!.close()"
2023-04-08 02:01:42 +02:00
/>
2023-02-19 00:27:12 +01:00
</MkModal>
2023-02-19 00:53:19 +01:00
</template>
2023-02-19 00:53:19 +01:00
<script lang="ts" setup>
import { shallowRef } from "vue";
2024-04-09 19:18:08 +02:00
import type { entities, languages } from "firefish-js";
2023-04-08 02:01:42 +02:00
import MkModal from "@/components/MkModal.vue";
import MkPostForm from "@/components/MkPostForm.vue";
import type { NoteVisibility } from "@/types/note";
2024-04-13 17:08:58 +02:00
import type { NoteDraft } from "@/types/post-form";
2023-02-19 00:53:19 +01:00
const props = defineProps<{
reply?: entities.Note;
renote?: entities.Note;
2024-04-10 16:25:11 +02:00
channel?: entities.Channel;
mention?: entities.User;
specified?: entities.User;
2023-02-19 00:53:19 +01:00
initialText?: string;
2024-04-09 19:18:08 +02:00
initialVisibility?: NoteVisibility;
2024-04-13 17:08:58 +02:00
initialLanguage?: (typeof languages)[number];
initialFiles?: entities.DriveFile[];
2023-02-19 00:53:19 +01:00
initialLocalOnly?: boolean;
initialVisibleUsers?: entities.User[];
2024-04-13 17:08:58 +02:00
initialNote?: NoteDraft;
2023-02-19 00:53:19 +01:00
instant?: boolean;
fixed?: boolean;
autofocus?: boolean;
editId?: entities.Note["id"];
2024-04-15 09:12:51 +02:00
selectRange?: [
start: number,
end: number,
direction?: "forward" | "backward" | "none",
];
2023-02-19 00:53:19 +01:00
}>();
2023-02-19 00:27:12 +01:00
2023-02-19 00:53:19 +01:00
const emit = defineEmits<{
2023-04-08 02:01:42 +02:00
(ev: "closed"): void;
2023-02-19 00:53:19 +01:00
}>();
2023-02-19 00:27:12 +01:00
2023-09-02 01:27:33 +02:00
const modal = shallowRef<InstanceType<typeof MkModal>>();
const form = shallowRef<InstanceType<typeof MkPostForm>>();
2023-02-19 00:27:12 +01:00
2023-02-19 00:53:19 +01:00
function onPosted() {
2024-04-13 17:08:58 +02:00
modal.value!.close({
2023-02-19 00:53:19 +01:00
useSendAnimation: true,
});
}
2023-02-19 00:27:12 +01:00
2023-02-19 00:53:19 +01:00
function onModalClosed() {
2023-04-08 02:01:42 +02:00
emit("closed");
2023-02-19 00:53:19 +01:00
}
</script>