2020-01-29 20:37:25 +01:00
|
|
|
<template>
|
2023-04-08 02:01:42 +02:00
|
|
|
<MkModal
|
|
|
|
ref="modal"
|
|
|
|
:prefer-type="'dialog'"
|
|
|
|
@click="done(true)"
|
|
|
|
@closed="emit('closed')"
|
|
|
|
>
|
2023-02-19 00:34:41 +01:00
|
|
|
<div :class="$style.root">
|
|
|
|
<div v-if="icon" :class="$style.icon">
|
|
|
|
<i :class="icon"></i>
|
2022-10-26 07:44:38 +02:00
|
|
|
</div>
|
2023-04-08 02:01:42 +02:00
|
|
|
<div
|
|
|
|
v-else-if="!input && !select"
|
2023-10-19 19:55:48 +02:00
|
|
|
:class="[$style.icon, $style[`type_${type}`]]"
|
2023-04-08 02:01:42 +02:00
|
|
|
>
|
|
|
|
<i
|
|
|
|
v-if="type === 'success'"
|
2023-10-19 19:55:48 +02:00
|
|
|
:class="[$style.iconInner, iconClass('ph-check')]"
|
2023-04-08 02:01:42 +02:00
|
|
|
></i>
|
|
|
|
<i
|
|
|
|
v-else-if="type === 'error'"
|
2023-10-22 10:44:32 +02:00
|
|
|
:class="[
|
|
|
|
$style.iconInner,
|
|
|
|
iconClass('ph-circle-wavy-warning'),
|
|
|
|
]"
|
2023-04-08 02:01:42 +02:00
|
|
|
></i>
|
|
|
|
<i
|
|
|
|
v-else-if="type === 'warning'"
|
2023-10-19 19:55:48 +02:00
|
|
|
:class="[$style.iconInner, iconClass('ph-warning')]"
|
2023-04-08 02:01:42 +02:00
|
|
|
></i>
|
|
|
|
<i
|
|
|
|
v-else-if="type === 'info'"
|
2023-10-19 19:55:48 +02:00
|
|
|
:class="[$style.iconInner, iconClass('ph-info')]"
|
2023-04-08 02:01:42 +02:00
|
|
|
></i>
|
|
|
|
<i
|
|
|
|
v-else-if="type === 'question'"
|
2023-10-19 19:55:48 +02:00
|
|
|
:class="[$style.iconInner, iconClass('ph-question')]"
|
2023-04-08 02:01:42 +02:00
|
|
|
></i>
|
|
|
|
<MkLoading
|
|
|
|
v-else-if="type === 'waiting'"
|
|
|
|
:class="$style.iconInner"
|
|
|
|
:em="true"
|
|
|
|
/>
|
2023-02-19 00:34:41 +01:00
|
|
|
</div>
|
2023-04-08 02:01:42 +02:00
|
|
|
<header v-if="title" :class="$style.title">
|
|
|
|
<Mfm :text="title" />
|
|
|
|
</header>
|
|
|
|
<header
|
|
|
|
v-if="title == null && input && input.type === 'password'"
|
|
|
|
:class="$style.title"
|
|
|
|
>
|
|
|
|
<Mfm :text="i18n.ts.password" />
|
|
|
|
</header>
|
2023-06-16 01:12:32 +02:00
|
|
|
<div v-if="text" :class="$style.text">
|
2023-09-27 10:18:47 +02:00
|
|
|
<span
|
|
|
|
v-if="isPlaintext === true"
|
|
|
|
style="white-space: pre-line"
|
|
|
|
>{{ text }}</span
|
|
|
|
>
|
2023-09-27 09:46:43 +02:00
|
|
|
<Mfm v-else :text="text" />
|
2023-06-16 01:12:32 +02:00
|
|
|
</div>
|
2023-04-08 02:01:42 +02:00
|
|
|
<MkInput
|
|
|
|
v-if="input && input.type !== 'paragraph'"
|
2023-07-17 00:32:32 +02:00
|
|
|
ref="inputEl"
|
2023-04-08 02:01:42 +02:00
|
|
|
v-model="inputValue"
|
|
|
|
autofocus
|
2023-06-16 01:12:32 +02:00
|
|
|
:autocomplete="input.autocomplete"
|
2023-06-12 08:25:10 +02:00
|
|
|
:type="input.type == 'search' ? 'search' : input.type || 'text'"
|
2023-04-08 02:01:42 +02:00
|
|
|
:placeholder="input.placeholder || undefined"
|
2023-06-12 06:57:20 +02:00
|
|
|
:style="{
|
2023-06-12 08:25:10 +02:00
|
|
|
width: input.type === 'search' ? '300px' : null,
|
2023-06-12 06:57:20 +02:00
|
|
|
}"
|
2023-07-17 00:32:32 +02:00
|
|
|
@keydown="onInputKeydown"
|
2023-04-08 02:01:42 +02:00
|
|
|
>
|
|
|
|
<template v-if="input.type === 'password'" #prefix
|
2023-10-17 03:57:20 +02:00
|
|
|
><i :class="iconClass('ph-password')"></i
|
2023-04-08 02:01:42 +02:00
|
|
|
></template>
|
2023-06-16 01:12:32 +02:00
|
|
|
<template #caption>
|
|
|
|
<span
|
|
|
|
v-if="
|
|
|
|
okButtonDisabled &&
|
|
|
|
disabledReason === 'charactersExceeded'
|
|
|
|
"
|
2023-07-06 03:28:27 +02:00
|
|
|
v-text="
|
|
|
|
i18n.t('_dialog.charactersExceeded', {
|
|
|
|
current: (inputValue as string).length,
|
|
|
|
max: input.maxLength ?? 'NaN',
|
|
|
|
})
|
|
|
|
"
|
2023-06-16 01:12:32 +02:00
|
|
|
/>
|
|
|
|
<span
|
|
|
|
v-else-if="
|
|
|
|
okButtonDisabled &&
|
|
|
|
disabledReason === 'charactersBelow'
|
|
|
|
"
|
2023-07-06 03:28:27 +02:00
|
|
|
v-text="
|
|
|
|
i18n.t('_dialog.charactersBelow', {
|
|
|
|
current: (inputValue as string).length,
|
|
|
|
min: input.minLength ?? 'NaN',
|
|
|
|
})
|
|
|
|
"
|
2023-06-16 01:12:32 +02:00
|
|
|
/>
|
|
|
|
</template>
|
2023-06-12 08:25:10 +02:00
|
|
|
<template v-if="input.type === 'search'" #suffix>
|
2023-06-08 19:01:51 +02:00
|
|
|
<button
|
2023-07-17 00:32:32 +02:00
|
|
|
v-tooltip.noDelay="i18n.ts.filter"
|
2023-06-08 19:01:51 +02:00
|
|
|
class="_buttonIcon"
|
|
|
|
@click.stop="openSearchFilters"
|
|
|
|
>
|
2023-10-17 03:57:20 +02:00
|
|
|
<i :class="iconClass('ph-funnel', false)"></i>
|
2023-06-08 19:01:51 +02:00
|
|
|
</button>
|
|
|
|
</template>
|
2023-02-19 00:34:41 +01:00
|
|
|
</MkInput>
|
2023-04-08 02:01:42 +02:00
|
|
|
<MkTextarea
|
|
|
|
v-if="input && input.type === 'paragraph'"
|
|
|
|
v-model="inputValue"
|
|
|
|
autofocus
|
2023-11-07 15:01:24 +01:00
|
|
|
type="paragraph"
|
2023-04-08 02:01:42 +02:00
|
|
|
:placeholder="input.placeholder || undefined"
|
|
|
|
>
|
2023-03-19 08:22:28 +01:00
|
|
|
</MkTextarea>
|
2023-02-19 00:34:41 +01:00
|
|
|
<MkSelect v-if="select" v-model="selectedValue" autofocus>
|
|
|
|
<template v-if="select.items">
|
2023-04-08 02:01:42 +02:00
|
|
|
<option v-for="item in select.items" :value="item.value">
|
|
|
|
{{ item.text }}
|
|
|
|
</option>
|
2023-02-19 00:34:41 +01:00
|
|
|
</template>
|
|
|
|
<template v-else>
|
2023-04-08 02:01:42 +02:00
|
|
|
<optgroup
|
|
|
|
v-for="groupedItem in select.groupedItems"
|
|
|
|
:label="groupedItem.label"
|
|
|
|
>
|
|
|
|
<option
|
|
|
|
v-for="item in groupedItem.items"
|
|
|
|
:value="item.value"
|
|
|
|
>
|
|
|
|
{{ item.text }}
|
|
|
|
</option>
|
2023-02-19 00:34:41 +01:00
|
|
|
</optgroup>
|
|
|
|
</template>
|
|
|
|
</MkSelect>
|
2023-06-08 19:01:51 +02:00
|
|
|
|
2023-04-08 02:01:42 +02:00
|
|
|
<div
|
|
|
|
v-if="(showOkButton || showCancelButton) && !actions"
|
|
|
|
:class="$style.buttons"
|
|
|
|
>
|
2023-02-19 00:34:41 +01:00
|
|
|
<div v-if="!isYesNo">
|
2023-04-08 02:01:42 +02:00
|
|
|
<MkButton
|
|
|
|
v-if="showOkButton"
|
|
|
|
inline
|
|
|
|
primary
|
|
|
|
:autofocus="!input && !select"
|
2023-06-16 01:12:32 +02:00
|
|
|
:disabled="okButtonDisabled"
|
2023-04-08 02:01:42 +02:00
|
|
|
@click="ok"
|
|
|
|
>{{
|
|
|
|
showCancelButton || input || select
|
|
|
|
? i18n.ts.ok
|
|
|
|
: i18n.ts.gotIt
|
|
|
|
}}</MkButton
|
|
|
|
>
|
|
|
|
<MkButton
|
|
|
|
v-if="showCancelButton || input || select"
|
|
|
|
inline
|
|
|
|
@click="cancel"
|
|
|
|
>{{ i18n.ts.cancel }}</MkButton
|
|
|
|
>
|
2023-02-19 00:34:41 +01:00
|
|
|
</div>
|
|
|
|
<div v-else>
|
2023-04-08 02:01:42 +02:00
|
|
|
<MkButton
|
|
|
|
v-if="showOkButton"
|
|
|
|
inline
|
|
|
|
primary
|
|
|
|
:autofocus="!input && !select"
|
|
|
|
@click="ok"
|
2023-06-16 01:12:32 +02:00
|
|
|
>{{ i18n.ts.yes }}
|
|
|
|
</MkButton>
|
2023-04-08 02:01:42 +02:00
|
|
|
<MkButton
|
|
|
|
v-if="showCancelButton || input || select"
|
|
|
|
inline
|
|
|
|
@click="cancel"
|
|
|
|
>{{ i18n.ts.no }}</MkButton
|
|
|
|
>
|
2023-02-19 00:34:41 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="actions" :class="$style.buttons">
|
2023-04-08 02:01:42 +02:00
|
|
|
<MkButton
|
|
|
|
v-for="action in actions"
|
|
|
|
:key="action.text"
|
|
|
|
inline
|
|
|
|
:primary="action.primary"
|
|
|
|
@click="
|
|
|
|
() => {
|
|
|
|
action.callback();
|
2023-11-07 15:01:24 +01:00
|
|
|
modal?.close(null);
|
2023-04-08 02:01:42 +02:00
|
|
|
}
|
|
|
|
"
|
|
|
|
>{{ action.text }}</MkButton
|
|
|
|
>
|
2022-10-26 07:44:38 +02:00
|
|
|
</div>
|
2020-10-17 13:12:00 +02:00
|
|
|
</div>
|
2023-02-19 00:34:41 +01:00
|
|
|
</MkModal>
|
2020-01-29 20:37:25 +01:00
|
|
|
</template>
|
|
|
|
|
2022-01-10 16:05:18 +01:00
|
|
|
<script lang="ts" setup>
|
2023-09-02 01:27:33 +02:00
|
|
|
import { computed, onBeforeUnmount, onMounted, ref, shallowRef } from "vue";
|
2023-07-19 18:37:11 +02:00
|
|
|
import * as Acct from "firefish-js/built/acct";
|
2023-04-08 02:01:42 +02:00
|
|
|
import MkModal from "@/components/MkModal.vue";
|
|
|
|
import MkButton from "@/components/MkButton.vue";
|
|
|
|
import MkInput from "@/components/form/input.vue";
|
|
|
|
import MkTextarea from "@/components/form/textarea.vue";
|
|
|
|
import MkSelect from "@/components/form/select.vue";
|
2023-06-08 19:01:51 +02:00
|
|
|
import * as os from "@/os";
|
2023-04-08 02:01:42 +02:00
|
|
|
import { i18n } from "@/i18n";
|
2023-10-17 03:57:20 +02:00
|
|
|
import iconClass from "@/scripts/icon";
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2023-07-17 00:32:32 +02:00
|
|
|
interface Input {
|
2023-04-08 02:01:42 +02:00
|
|
|
type: HTMLInputElement["type"];
|
2022-01-10 16:05:18 +01:00
|
|
|
placeholder?: string | null;
|
2023-06-16 01:12:32 +02:00
|
|
|
autocomplete?: string;
|
|
|
|
default: string | number | null;
|
|
|
|
minLength?: number;
|
|
|
|
maxLength?: number;
|
2023-07-17 00:32:32 +02:00
|
|
|
}
|
2022-01-10 16:05:18 +01:00
|
|
|
|
2023-07-17 00:32:32 +02:00
|
|
|
interface Select {
|
2022-01-10 16:05:18 +01:00
|
|
|
items: {
|
|
|
|
value: string;
|
|
|
|
text: string;
|
|
|
|
}[];
|
|
|
|
groupedItems: {
|
|
|
|
label: string;
|
|
|
|
items: {
|
|
|
|
value: string;
|
|
|
|
text: string;
|
|
|
|
}[];
|
|
|
|
}[];
|
|
|
|
default: string | null;
|
2023-07-17 00:32:32 +02:00
|
|
|
}
|
2022-01-10 16:05:18 +01:00
|
|
|
|
2023-04-08 02:01:42 +02:00
|
|
|
const props = withDefaults(
|
|
|
|
defineProps<{
|
|
|
|
type?:
|
|
|
|
| "success"
|
|
|
|
| "error"
|
|
|
|
| "warning"
|
|
|
|
| "info"
|
|
|
|
| "question"
|
2023-06-08 19:01:51 +02:00
|
|
|
| "waiting"
|
|
|
|
| "search";
|
2023-04-08 02:01:42 +02:00
|
|
|
title: string;
|
|
|
|
text?: string;
|
2023-09-27 09:46:43 +02:00
|
|
|
isPlaintext?: boolean;
|
2023-04-08 02:01:42 +02:00
|
|
|
input?: Input;
|
|
|
|
select?: Select;
|
|
|
|
icon?: string;
|
|
|
|
actions?: {
|
|
|
|
text: string;
|
|
|
|
primary?: boolean;
|
|
|
|
callback: (...args: any[]) => void;
|
|
|
|
}[];
|
|
|
|
showOkButton?: boolean;
|
|
|
|
showCancelButton?: boolean;
|
|
|
|
isYesNo?: boolean;
|
|
|
|
|
|
|
|
cancelableByBgClick?: boolean;
|
|
|
|
okText?: string;
|
|
|
|
cancelText?: string;
|
|
|
|
}>(),
|
|
|
|
{
|
|
|
|
type: "info",
|
|
|
|
showOkButton: true,
|
|
|
|
showCancelButton: false,
|
|
|
|
isYesNo: false,
|
|
|
|
|
|
|
|
cancelableByBgClick: true,
|
2023-09-27 09:46:43 +02:00
|
|
|
isPlaintext: false,
|
2023-07-06 03:28:27 +02:00
|
|
|
},
|
2023-04-08 02:01:42 +02:00
|
|
|
);
|
2022-01-10 16:05:18 +01:00
|
|
|
|
|
|
|
const emit = defineEmits<{
|
2023-04-08 02:01:42 +02:00
|
|
|
(ev: "done", v: { canceled: boolean; result: any }): void;
|
|
|
|
(ev: "closed"): void;
|
2022-01-10 16:05:18 +01:00
|
|
|
}>();
|
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
const modal = shallowRef<InstanceType<typeof MkModal>>();
|
2022-01-10 16:05:18 +01:00
|
|
|
|
2023-06-16 01:12:32 +02:00
|
|
|
const inputValue = ref<string | number | null>(props.input?.default ?? null);
|
|
|
|
const selectedValue = ref(props.select?.default ?? null);
|
|
|
|
|
2023-09-02 01:27:33 +02:00
|
|
|
const disabledReason = ref<null | "charactersExceeded" | "charactersBelow">(
|
|
|
|
null,
|
|
|
|
);
|
2023-08-12 02:44:46 +02:00
|
|
|
const okButtonDisabled = computed<boolean>(() => {
|
2023-06-16 01:12:32 +02:00
|
|
|
if (props.input) {
|
|
|
|
if (props.input.minLength) {
|
|
|
|
if (
|
|
|
|
(inputValue.value || inputValue.value === "") &&
|
|
|
|
(inputValue.value as string).length < props.input.minLength
|
|
|
|
) {
|
2023-08-12 02:44:46 +02:00
|
|
|
disabledReason.value = "charactersBelow";
|
2023-06-16 01:12:32 +02:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (props.input.maxLength) {
|
|
|
|
if (
|
|
|
|
inputValue.value &&
|
|
|
|
(inputValue.value as string).length > props.input.maxLength
|
|
|
|
) {
|
2023-08-12 02:44:46 +02:00
|
|
|
disabledReason.value = "charactersExceeded";
|
2023-06-16 01:12:32 +02:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
});
|
2022-01-10 16:05:18 +01:00
|
|
|
|
2023-06-08 19:01:51 +02:00
|
|
|
const inputEl = ref<typeof MkInput>();
|
|
|
|
|
2022-01-10 16:05:18 +01:00
|
|
|
function done(canceled: boolean, result?) {
|
2023-04-08 02:01:42 +02:00
|
|
|
emit("done", { canceled, result });
|
2023-11-07 15:01:24 +01:00
|
|
|
modal.value?.close(null);
|
2022-01-10 16:05:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
async function ok() {
|
|
|
|
if (!props.showOkButton) return;
|
|
|
|
|
2023-04-08 02:01:42 +02:00
|
|
|
const result = props.input
|
|
|
|
? inputValue.value
|
|
|
|
: props.select
|
2024-02-11 18:50:57 +01:00
|
|
|
? selectedValue.value
|
|
|
|
: true;
|
2022-01-10 16:05:18 +01:00
|
|
|
done(false, result);
|
|
|
|
}
|
|
|
|
|
|
|
|
function cancel() {
|
|
|
|
done(true);
|
|
|
|
}
|
|
|
|
/*
|
|
|
|
function onBgClick() {
|
|
|
|
if (props.cancelableByBgClick) cancel();
|
|
|
|
}
|
|
|
|
*/
|
2022-05-26 15:53:09 +02:00
|
|
|
function onKeydown(evt: KeyboardEvent) {
|
2023-04-08 02:01:42 +02:00
|
|
|
if (evt.key === "Escape") cancel();
|
2022-01-10 16:05:18 +01:00
|
|
|
}
|
|
|
|
|
2022-05-26 15:53:09 +02:00
|
|
|
function onInputKeydown(evt: KeyboardEvent) {
|
2023-04-08 02:01:42 +02:00
|
|
|
if (evt.key === "Enter") {
|
2022-05-26 15:53:09 +02:00
|
|
|
evt.preventDefault();
|
|
|
|
evt.stopPropagation();
|
2022-01-10 16:05:18 +01:00
|
|
|
ok();
|
2020-01-29 20:37:25 +01:00
|
|
|
}
|
2022-01-10 16:05:18 +01:00
|
|
|
}
|
|
|
|
|
2023-06-12 10:39:52 +02:00
|
|
|
function formatDateToYYYYMMDD(date) {
|
|
|
|
const year = date.getFullYear();
|
|
|
|
const month = ("0" + (date.getMonth() + 1)).slice(-2);
|
2023-06-14 02:32:01 +02:00
|
|
|
const day = ("0" + (date.getDate() + 1)).slice(-2);
|
2023-06-14 02:16:10 +02:00
|
|
|
return `${year}-${month}-${day}`;
|
2023-06-12 10:39:52 +02:00
|
|
|
}
|
|
|
|
|
2023-11-07 15:01:24 +01:00
|
|
|
/**
|
|
|
|
* Appends a new search parameter to the value in the input field.
|
|
|
|
* Trims any extra whitespace before and after, then adds a space at the end so a user can immediately
|
|
|
|
* begin typing a new criteria.
|
|
|
|
* @param value The value to append.
|
|
|
|
*/
|
|
|
|
function appendFilter(value: string) {
|
|
|
|
return (
|
|
|
|
[
|
|
|
|
typeof inputValue.value === "string"
|
|
|
|
? inputValue.value.trim()
|
|
|
|
: inputValue.value,
|
|
|
|
value,
|
|
|
|
]
|
|
|
|
.join(" ")
|
|
|
|
.trim() + " "
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2023-06-08 19:01:51 +02:00
|
|
|
async function openSearchFilters(ev) {
|
2023-06-11 02:48:35 +02:00
|
|
|
await os.popupMenu(
|
|
|
|
[
|
|
|
|
{
|
2023-11-07 15:01:24 +01:00
|
|
|
icon: `${iconClass("ph-user")}`,
|
2023-06-12 04:05:50 +02:00
|
|
|
text: i18n.ts._filters.fromUser,
|
2023-06-11 02:48:35 +02:00
|
|
|
action: () => {
|
|
|
|
os.selectUser().then((user) => {
|
2023-11-07 15:01:24 +01:00
|
|
|
inputValue.value = appendFilter(
|
|
|
|
"from:@" + Acct.toString(user),
|
|
|
|
);
|
2023-06-11 02:48:35 +02:00
|
|
|
});
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2023-06-12 11:19:27 +02:00
|
|
|
type: "parent",
|
2023-06-12 04:05:50 +02:00
|
|
|
text: i18n.ts._filters.withFile,
|
2023-11-07 15:01:24 +01:00
|
|
|
icon: `${iconClass("ph-paperclip")}`,
|
2023-06-12 11:19:27 +02:00
|
|
|
children: [
|
|
|
|
{
|
|
|
|
text: i18n.ts.image,
|
2023-11-07 15:01:24 +01:00
|
|
|
icon: `${iconClass("ph-image-square")}`,
|
2023-06-12 11:19:27 +02:00
|
|
|
action: () => {
|
2023-11-07 15:01:24 +01:00
|
|
|
inputValue.value = appendFilter("has:image");
|
2023-06-12 11:19:27 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: i18n.ts.video,
|
2023-11-07 15:01:24 +01:00
|
|
|
icon: `${iconClass("ph-video-camera")}`,
|
2023-06-12 11:19:27 +02:00
|
|
|
action: () => {
|
2023-11-07 15:01:24 +01:00
|
|
|
inputValue.value = appendFilter("has:video");
|
2023-06-12 11:19:27 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: i18n.ts.audio,
|
2023-11-07 15:01:24 +01:00
|
|
|
icon: `${iconClass("ph-music-note")}`,
|
2023-06-12 11:19:27 +02:00
|
|
|
action: () => {
|
2023-11-07 15:01:24 +01:00
|
|
|
inputValue.value = appendFilter("has:audio");
|
2023-06-12 11:19:27 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: i18n.ts.file,
|
2023-11-07 15:01:24 +01:00
|
|
|
icon: `${iconClass("ph-file")}`,
|
2023-06-12 11:19:27 +02:00
|
|
|
action: () => {
|
2023-11-07 15:01:24 +01:00
|
|
|
inputValue.value = appendFilter("has:file");
|
2023-06-12 11:19:27 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
2023-06-11 02:48:35 +02:00
|
|
|
},
|
|
|
|
{
|
2023-11-07 15:01:24 +01:00
|
|
|
icon: `${iconClass("ph-link")}`,
|
2023-06-12 04:05:50 +02:00
|
|
|
text: i18n.ts._filters.fromDomain,
|
2023-06-11 02:48:35 +02:00
|
|
|
action: () => {
|
2023-11-07 15:01:24 +01:00
|
|
|
inputValue.value = appendFilter("domain:");
|
2023-06-11 02:48:35 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2023-11-07 15:01:24 +01:00
|
|
|
icon: `${iconClass("ph-calendar-blank")}`,
|
2023-06-12 04:05:50 +02:00
|
|
|
text: i18n.ts._filters.notesBefore,
|
2023-06-11 02:48:35 +02:00
|
|
|
action: () => {
|
|
|
|
os.inputDate({
|
2023-06-12 04:05:50 +02:00
|
|
|
title: i18n.ts._filters.notesBefore,
|
2023-06-11 02:48:35 +02:00
|
|
|
}).then((res) => {
|
|
|
|
if (res.canceled) return;
|
2023-11-07 15:01:24 +01:00
|
|
|
inputValue.value = appendFilter(
|
|
|
|
"before:" + formatDateToYYYYMMDD(res.result),
|
|
|
|
);
|
2023-06-11 02:48:35 +02:00
|
|
|
});
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2023-11-07 15:01:24 +01:00
|
|
|
icon: `${iconClass("ph-calendar-blank")}`,
|
2023-06-12 04:05:50 +02:00
|
|
|
text: i18n.ts._filters.notesAfter,
|
2023-06-11 02:48:35 +02:00
|
|
|
action: () => {
|
|
|
|
os.inputDate({
|
2023-06-12 04:05:50 +02:00
|
|
|
title: i18n.ts._filters.notesAfter,
|
2023-06-11 02:48:35 +02:00
|
|
|
}).then((res) => {
|
|
|
|
if (res.canceled) return;
|
2023-11-07 15:01:24 +01:00
|
|
|
inputValue.value = appendFilter(
|
|
|
|
"after:" + formatDateToYYYYMMDD(res.result),
|
|
|
|
);
|
2023-06-11 02:48:35 +02:00
|
|
|
});
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2023-11-07 15:01:24 +01:00
|
|
|
icon: `${iconClass("ph-eye")}`,
|
2023-06-12 04:05:50 +02:00
|
|
|
text: i18n.ts._filters.followingOnly,
|
2023-06-11 02:48:35 +02:00
|
|
|
action: () => {
|
2023-11-07 15:01:24 +01:00
|
|
|
inputValue.value = appendFilter("filter:following");
|
2023-06-11 02:48:35 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
2023-11-07 15:01:24 +01:00
|
|
|
icon: `${iconClass("ph-users-three")}`,
|
2023-06-12 04:05:50 +02:00
|
|
|
text: i18n.ts._filters.followersOnly,
|
2023-06-11 02:48:35 +02:00
|
|
|
action: () => {
|
2023-11-07 15:01:24 +01:00
|
|
|
inputValue.value = appendFilter("filter:followers");
|
2023-06-11 02:48:35 +02:00
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
ev.target,
|
2023-07-06 03:28:27 +02:00
|
|
|
{ noReturnFocus: true },
|
2023-06-11 02:48:35 +02:00
|
|
|
);
|
2023-11-07 15:01:24 +01:00
|
|
|
inputEl.value?.focus();
|
|
|
|
if (typeof inputValue.value === "string") {
|
|
|
|
inputEl.value?.selectRange(
|
|
|
|
inputValue.value.length,
|
|
|
|
inputValue.value.length,
|
|
|
|
); // cursor at end
|
|
|
|
}
|
2023-06-08 19:01:51 +02:00
|
|
|
}
|
|
|
|
|
2022-01-10 16:05:18 +01:00
|
|
|
onMounted(() => {
|
2023-04-08 02:01:42 +02:00
|
|
|
document.addEventListener("keydown", onKeydown);
|
2022-01-10 16:05:18 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
onBeforeUnmount(() => {
|
2023-04-08 02:01:42 +02:00
|
|
|
document.removeEventListener("keydown", onKeydown);
|
2020-01-29 20:37:25 +01:00
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
<style lang="scss" module>
|
|
|
|
.root {
|
2020-10-17 13:12:00 +02:00
|
|
|
position: relative;
|
2023-02-19 00:34:41 +01:00
|
|
|
margin: auto;
|
2020-10-17 13:12:00 +02:00
|
|
|
padding: 32px;
|
|
|
|
min-width: 320px;
|
|
|
|
max-width: 480px;
|
|
|
|
box-sizing: border-box;
|
|
|
|
text-align: center;
|
|
|
|
background: var(--panel);
|
|
|
|
border-radius: var(--radius);
|
2023-02-19 00:34:41 +01:00
|
|
|
}
|
2020-10-17 13:12:00 +02:00
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
.icon {
|
|
|
|
font-size: 24px;
|
2021-11-28 12:07:37 +01:00
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
& + .title {
|
|
|
|
margin-top: 8px;
|
|
|
|
}
|
|
|
|
}
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
.iconInner {
|
|
|
|
display: block;
|
|
|
|
margin: 0 auto;
|
|
|
|
}
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
.type_info {
|
|
|
|
color: var(--accent);
|
|
|
|
}
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
.type_success {
|
|
|
|
color: var(--success);
|
|
|
|
}
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
.type_error {
|
|
|
|
color: var(--error);
|
|
|
|
}
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
.type_warning {
|
|
|
|
color: var(--warn);
|
|
|
|
}
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
.title {
|
|
|
|
margin: 0 0 8px 0;
|
|
|
|
font-weight: bold;
|
|
|
|
font-size: 1.1em;
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
& + .text {
|
|
|
|
margin-top: 8px;
|
2020-10-17 13:12:00 +02:00
|
|
|
}
|
2023-02-19 00:34:41 +01:00
|
|
|
}
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
.text {
|
|
|
|
margin: 16px 0 0 0;
|
|
|
|
}
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2023-02-19 00:34:41 +01:00
|
|
|
.buttons {
|
|
|
|
margin-top: 16px;
|
|
|
|
display: flex;
|
|
|
|
gap: 8px;
|
|
|
|
flex-wrap: wrap;
|
|
|
|
justify-content: center;
|
2020-01-29 20:37:25 +01:00
|
|
|
}
|
|
|
|
</style>
|