mirror of
https://github.com/misskey-dev/misskey.git
synced 2025-01-26 22:49:13 +01:00
selectFileの調整
(ウォーターマークの画像を指定するところでウォーターマークをかけるかどうかの設定が出るのは変すぎるので)
This commit is contained in:
parent
00a5b5b777
commit
79882895c5
10 changed files with 86 additions and 40 deletions
packages/frontend/src
|
@ -116,7 +116,7 @@ import { formatTimeString } from '@/scripts/format-time-string.js';
|
||||||
import { Autocomplete } from '@/scripts/autocomplete.js';
|
import { Autocomplete } from '@/scripts/autocomplete.js';
|
||||||
import * as os from '@/os.js';
|
import * as os from '@/os.js';
|
||||||
import { misskeyApi } from '@/scripts/misskey-api.js';
|
import { misskeyApi } from '@/scripts/misskey-api.js';
|
||||||
import { selectFiles } from '@/scripts/select-file.js';
|
import { selectFile } from '@/scripts/select-file.js';
|
||||||
import { defaultStore, notePostInterruptors, postFormActions } from '@/store.js';
|
import { defaultStore, notePostInterruptors, postFormActions } from '@/store.js';
|
||||||
import MkInfo from '@/components/MkInfo.vue';
|
import MkInfo from '@/components/MkInfo.vue';
|
||||||
import { i18n } from '@/i18n.js';
|
import { i18n } from '@/i18n.js';
|
||||||
|
@ -413,7 +413,10 @@ function focus() {
|
||||||
function chooseFileFrom(ev) {
|
function chooseFileFrom(ev) {
|
||||||
if (props.mock) return;
|
if (props.mock) return;
|
||||||
|
|
||||||
selectFiles(ev.currentTarget ?? ev.target, i18n.ts.attachFile).then(files_ => {
|
selectFile(ev.currentTarget ?? ev.target, {
|
||||||
|
label: i18n.ts.attachFile,
|
||||||
|
multiple: true,
|
||||||
|
}).then(files_ => {
|
||||||
for (const file of files_) {
|
for (const file of files_) {
|
||||||
files.value.push(file);
|
files.value.push(file);
|
||||||
}
|
}
|
||||||
|
|
|
@ -68,7 +68,9 @@ watch(description, () => {
|
||||||
});
|
});
|
||||||
|
|
||||||
function setAvatar(ev) {
|
function setAvatar(ev) {
|
||||||
chooseFileFromPc(false).then(async (files) => {
|
chooseFileFromPc({
|
||||||
|
multiple: false,
|
||||||
|
}).then(async (files) => {
|
||||||
const file = files[0];
|
const file = files[0];
|
||||||
|
|
||||||
let originalOrCropped = file;
|
let originalOrCropped = file;
|
||||||
|
|
|
@ -189,7 +189,7 @@ async function archive() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function setBannerImage(evt) {
|
function setBannerImage(evt) {
|
||||||
selectFile(evt.currentTarget ?? evt.target, null).then(file => {
|
selectFile(evt.currentTarget ?? evt.target).then(file => {
|
||||||
bannerId.value = file.id;
|
bannerId.value = file.id;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -121,7 +121,7 @@ watch(roleIdsThatCanBeUsedThisEmojiAsReaction, async () => {
|
||||||
const imgUrl = computed(() => file.value ? file.value.url : props.emoji ? `/emoji/${props.emoji.name}.webp` : null);
|
const imgUrl = computed(() => file.value ? file.value.url : props.emoji ? `/emoji/${props.emoji.name}.webp` : null);
|
||||||
|
|
||||||
async function changeImage(ev: Event) {
|
async function changeImage(ev: Event) {
|
||||||
file.value = await selectFile(ev.currentTarget ?? ev.target, null);
|
file.value = await selectFile(ev.currentTarget ?? ev.target);
|
||||||
const candidate = file.value.name.replace(/\.(.+)$/, '');
|
const candidate = file.value.name.replace(/\.(.+)$/, '');
|
||||||
if (candidate.match(/^[a-z0-9_]+$/)) {
|
if (candidate.match(/^[a-z0-9_]+$/)) {
|
||||||
name.value = candidate;
|
name.value = candidate;
|
||||||
|
|
|
@ -21,7 +21,7 @@ SPDX-License-Identifier: AGPL-3.0-only
|
||||||
<div class="name">{{ file.name }}</div>
|
<div class="name">{{ file.name }}</div>
|
||||||
<button v-tooltip="i18n.ts.remove" class="remove _button" @click="remove(file)"><i class="ti ti-x"></i></button>
|
<button v-tooltip="i18n.ts.remove" class="remove _button" @click="remove(file)"><i class="ti ti-x"></i></button>
|
||||||
</div>
|
</div>
|
||||||
<MkButton primary @click="selectFile"><i class="ti ti-plus"></i> {{ i18n.ts.attachFile }}</MkButton>
|
<MkButton primary @click="chooseFile"><i class="ti ti-plus"></i> {{ i18n.ts.attachFile }}</MkButton>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<MkSwitch v-model="isSensitive">{{ i18n.ts.markAsSensitive }}</MkSwitch>
|
<MkSwitch v-model="isSensitive">{{ i18n.ts.markAsSensitive }}</MkSwitch>
|
||||||
|
@ -45,7 +45,7 @@ import MkInput from '@/components/MkInput.vue';
|
||||||
import MkTextarea from '@/components/MkTextarea.vue';
|
import MkTextarea from '@/components/MkTextarea.vue';
|
||||||
import MkSwitch from '@/components/MkSwitch.vue';
|
import MkSwitch from '@/components/MkSwitch.vue';
|
||||||
import FormSuspense from '@/components/form/suspense.vue';
|
import FormSuspense from '@/components/form/suspense.vue';
|
||||||
import { selectFiles } from '@/scripts/select-file.js';
|
import { selectFile } from '@/scripts/select-file.js';
|
||||||
import * as os from '@/os.js';
|
import * as os from '@/os.js';
|
||||||
import { misskeyApi } from '@/scripts/misskey-api.js';
|
import { misskeyApi } from '@/scripts/misskey-api.js';
|
||||||
import { definePageMetadata } from '@/scripts/page-metadata.js';
|
import { definePageMetadata } from '@/scripts/page-metadata.js';
|
||||||
|
@ -64,8 +64,8 @@ const description = ref<string | null>(null);
|
||||||
const title = ref<string | null>(null);
|
const title = ref<string | null>(null);
|
||||||
const isSensitive = ref(false);
|
const isSensitive = ref(false);
|
||||||
|
|
||||||
function selectFile(evt) {
|
function chooseFile(evt) {
|
||||||
selectFiles(evt.currentTarget ?? evt.target, null).then(selected => {
|
selectFile(evt.currentTarget ?? evt.target, { multiple: true }).then(selected => {
|
||||||
files.value = files.value.concat(selected);
|
files.value = files.value.concat(selected);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -217,7 +217,7 @@ async function add() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function setEyeCatchingImage(img) {
|
function setEyeCatchingImage(img) {
|
||||||
selectFile(img.currentTarget ?? img.target, null).then(file => {
|
selectFile(img.currentTarget ?? img.target).then(file => {
|
||||||
eyeCatchingImageId.value = file.id;
|
eyeCatchingImageId.value = file.id;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -223,7 +223,7 @@ function save() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function changeAvatar(ev) {
|
function changeAvatar(ev) {
|
||||||
selectFile(ev.currentTarget ?? ev.target, i18n.ts.avatar).then(async (file) => {
|
selectFile(ev.currentTarget ?? ev.target, { label: i18n.ts.avatar }).then(async (file) => {
|
||||||
let originalOrCropped = file;
|
let originalOrCropped = file;
|
||||||
|
|
||||||
const { canceled } = await os.confirm({
|
const { canceled } = await os.confirm({
|
||||||
|
@ -250,7 +250,7 @@ function changeAvatar(ev) {
|
||||||
}
|
}
|
||||||
|
|
||||||
function changeBanner(ev) {
|
function changeBanner(ev) {
|
||||||
selectFile(ev.currentTarget ?? ev.target, i18n.ts.banner).then(async (file) => {
|
selectFile(ev.currentTarget ?? ev.target, { label: i18n.ts.banner }).then(async (file) => {
|
||||||
let originalOrCropped = file;
|
let originalOrCropped = file;
|
||||||
|
|
||||||
const { canceled } = await os.confirm({
|
const { canceled } = await os.confirm({
|
||||||
|
|
|
@ -94,7 +94,9 @@ const friendlyFileName = computed<string>(() => {
|
||||||
});
|
});
|
||||||
|
|
||||||
function selectSound(ev) {
|
function selectSound(ev) {
|
||||||
selectFile(ev.currentTarget ?? ev.target, i18n.ts._soundSettings.driveFile).then(async (file) => {
|
selectFile(ev.currentTarget ?? ev.target, {
|
||||||
|
label: i18n.ts._soundSettings.driveFile,
|
||||||
|
}).then(async (file) => {
|
||||||
if (!file.type.startsWith('audio')) {
|
if (!file.type.startsWith('audio')) {
|
||||||
os.alert({
|
os.alert({
|
||||||
type: 'warning',
|
type: 'warning',
|
||||||
|
|
|
@ -158,7 +158,7 @@ fetchThemes().then(() => {
|
||||||
});
|
});
|
||||||
|
|
||||||
function setWallpaper(event) {
|
function setWallpaper(event) {
|
||||||
selectFile(event.currentTarget ?? event.target, null).then(file => {
|
selectFile(event.currentTarget ?? event.target).then(file => {
|
||||||
wallpaper.value = file.url;
|
wallpaper.value = file.url;
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,19 +9,22 @@ import * as os from '@/os.js';
|
||||||
import { misskeyApi } from '@/scripts/misskey-api.js';
|
import { misskeyApi } from '@/scripts/misskey-api.js';
|
||||||
import { useStream } from '@/stream.js';
|
import { useStream } from '@/stream.js';
|
||||||
import { i18n } from '@/i18n.js';
|
import { i18n } from '@/i18n.js';
|
||||||
import { $i } from '@/account.js';
|
|
||||||
import { defaultStore } from '@/store.js';
|
import { defaultStore } from '@/store.js';
|
||||||
import { uploadFile } from '@/scripts/upload.js';
|
import { uploadFile } from '@/scripts/upload.js';
|
||||||
import type { MenuItem } from '@/types/menu.js';
|
import type { MenuItem } from '@/types/menu.js';
|
||||||
|
|
||||||
export function chooseFileFromPc(multiple: boolean, keepOriginal = false, useWatermark = false): Promise<Misskey.entities.DriveFile[]> {
|
export function chooseFileFromPc(opts?: {
|
||||||
|
multiple?: boolean;
|
||||||
|
keepOriginal?: boolean;
|
||||||
|
useWatermark?: boolean;
|
||||||
|
}): Promise<Misskey.entities.DriveFile[]> {
|
||||||
return new Promise((res, rej) => {
|
return new Promise((res, rej) => {
|
||||||
const input = document.createElement('input');
|
const input = document.createElement('input');
|
||||||
input.type = 'file';
|
input.type = 'file';
|
||||||
input.multiple = multiple;
|
input.multiple = opts?.multiple ?? false;
|
||||||
input.onchange = () => {
|
input.onchange = () => {
|
||||||
if (!input.files) return res([]);
|
if (!input.files) return res([]);
|
||||||
const promises = Array.from(input.files, file => uploadFile(file, defaultStore.state.uploadFolder, undefined, keepOriginal, useWatermark));
|
const promises = Array.from(input.files, file => uploadFile(file, defaultStore.state.uploadFolder, undefined, opts?.keepOriginal, opts?.useWatermark));
|
||||||
|
|
||||||
Promise.all(promises).then(driveFiles => {
|
Promise.all(promises).then(driveFiles => {
|
||||||
res(driveFiles);
|
res(driveFiles);
|
||||||
|
@ -41,9 +44,11 @@ export function chooseFileFromPc(multiple: boolean, keepOriginal = false, useWat
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export function chooseFileFromDrive(multiple: boolean): Promise<Misskey.entities.DriveFile[]> {
|
export function chooseFileFromDrive(opts?: {
|
||||||
|
multiple?: boolean;
|
||||||
|
}): Promise<Misskey.entities.DriveFile[]> {
|
||||||
return new Promise((res, rej) => {
|
return new Promise((res, rej) => {
|
||||||
os.selectDriveFile(multiple).then(files => {
|
os.selectDriveFile(opts?.multiple ?? false).then(files => {
|
||||||
res(files);
|
res(files);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -82,42 +87,76 @@ export function chooseFileFromUrl(): Promise<Misskey.entities.DriveFile> {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
function select(src: HTMLElement | EventTarget | null, label: string | null, multiple: boolean): Promise<Misskey.entities.DriveFile[]> {
|
function select(src: HTMLElement | EventTarget | null, opts?: {
|
||||||
|
label?: string;
|
||||||
|
multiple?: boolean;
|
||||||
|
dontUseWatermark?: boolean;
|
||||||
|
}): Promise<Misskey.entities.DriveFile[]> {
|
||||||
return new Promise((res, rej) => {
|
return new Promise((res, rej) => {
|
||||||
const keepOriginal = ref(defaultStore.state.keepOriginalUploading);
|
const keepOriginal = ref(defaultStore.state.keepOriginalUploading);
|
||||||
const useWatermark = ref(defaultStore.state.useWatermark);
|
const useWatermark = ref(opts?.dontUseWatermark ? false : defaultStore.state.useWatermark);
|
||||||
|
|
||||||
os.popupMenu([label ? {
|
const menu: MenuItem[] = [];
|
||||||
text: label,
|
|
||||||
|
if (opts?.label) {
|
||||||
|
menu.push({
|
||||||
|
text: opts.label,
|
||||||
type: 'label',
|
type: 'label',
|
||||||
} : undefined, {
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
menu.push({
|
||||||
type: 'switch',
|
type: 'switch',
|
||||||
text: i18n.ts.keepOriginalUploading,
|
text: i18n.ts.keepOriginalUploading,
|
||||||
ref: keepOriginal,
|
ref: keepOriginal,
|
||||||
}, {
|
});
|
||||||
|
|
||||||
|
if (!opts?.dontUseWatermark) {
|
||||||
|
menu.push({
|
||||||
type: 'switch',
|
type: 'switch',
|
||||||
text: i18n.ts.useWatermark,
|
text: i18n.ts.useWatermark,
|
||||||
ref: useWatermark,
|
ref: useWatermark,
|
||||||
}, {
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
menu.push({
|
||||||
text: i18n.ts.upload,
|
text: i18n.ts.upload,
|
||||||
icon: 'ti ti-upload',
|
icon: 'ti ti-upload',
|
||||||
action: () => chooseFileFromPc(multiple, keepOriginal.value, useWatermark.value).then(files => res(files)),
|
action: () => chooseFileFromPc({
|
||||||
|
multiple: opts?.multiple,
|
||||||
|
keepOriginal: keepOriginal.value,
|
||||||
|
useWatermark: useWatermark.value,
|
||||||
|
}).then(files => res(files)),
|
||||||
}, {
|
}, {
|
||||||
text: i18n.ts.fromDrive,
|
text: i18n.ts.fromDrive,
|
||||||
icon: 'ti ti-cloud',
|
icon: 'ti ti-cloud',
|
||||||
action: () => chooseFileFromDrive(multiple).then(files => res(files)),
|
action: () => chooseFileFromDrive({ multiple: opts?.multiple }).then(files => res(files)),
|
||||||
}, {
|
}, {
|
||||||
text: i18n.ts.fromUrl,
|
text: i18n.ts.fromUrl,
|
||||||
icon: 'ti ti-link',
|
icon: 'ti ti-link',
|
||||||
action: () => chooseFileFromUrl().then(file => res([file])),
|
action: () => chooseFileFromUrl().then(file => res([file])),
|
||||||
}], src);
|
});
|
||||||
|
|
||||||
|
os.popupMenu(menu, src);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export function selectFile(src: HTMLElement | EventTarget | null, label: string | null = null): Promise<Misskey.entities.DriveFile> {
|
export function selectFile(src: HTMLElement | EventTarget | null, opts: {
|
||||||
return select(src, label, false).then(files => files[0]);
|
label?: string;
|
||||||
}
|
multiple: true;
|
||||||
|
dontUseWatermark?: boolean;
|
||||||
export function selectFiles(src: HTMLElement | EventTarget | null, label: string | null = null): Promise<Misskey.entities.DriveFile[]> {
|
}): Promise<Misskey.entities.DriveFile[]>;
|
||||||
return select(src, label, true);
|
export function selectFile(src: HTMLElement | EventTarget | null, opts?: {
|
||||||
|
label?: string;
|
||||||
|
multiple?: false;
|
||||||
|
dontUseWatermark?: boolean;
|
||||||
|
}): Promise<Misskey.entities.DriveFile>;
|
||||||
|
export function selectFile(src: HTMLElement | EventTarget | null, opts?: {
|
||||||
|
label?: string;
|
||||||
|
multiple?: boolean;
|
||||||
|
dontUseWatermark?: boolean;
|
||||||
|
}): Promise<Misskey.entities.DriveFile | Misskey.entities.DriveFile[]> {
|
||||||
|
return select(src, opts).then(files => {
|
||||||
|
return opts?.multiple ? files : files[0];
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue