2020-01-29 20:37:25 +01:00
|
|
|
<template>
|
2023-04-08 02:01:42 +02:00
|
|
|
<div>
|
|
|
|
<MkStickyContainer>
|
|
|
|
<template #header
|
|
|
|
><MkPageHeader :actions="headerActions"
|
|
|
|
/></template>
|
|
|
|
<MkSpacer :content-max="900">
|
|
|
|
<div class="xrmjdkdw">
|
|
|
|
<div>
|
|
|
|
<div
|
|
|
|
class="inputs"
|
|
|
|
style="
|
|
|
|
display: flex;
|
|
|
|
gap: var(--margin);
|
|
|
|
flex-wrap: wrap;
|
|
|
|
"
|
|
|
|
>
|
|
|
|
<MkSelect
|
|
|
|
v-model="origin"
|
|
|
|
style="margin: 0; flex: 1"
|
|
|
|
>
|
|
|
|
<template #label>{{
|
|
|
|
i18n.ts.instance
|
|
|
|
}}</template>
|
|
|
|
<option value="combined">
|
|
|
|
{{ i18n.ts.all }}
|
|
|
|
</option>
|
|
|
|
<option value="local">
|
|
|
|
{{ i18n.ts.local }}
|
|
|
|
</option>
|
|
|
|
<option value="remote">
|
|
|
|
{{ i18n.ts.remote }}
|
|
|
|
</option>
|
|
|
|
</MkSelect>
|
|
|
|
<MkInput
|
|
|
|
v-model="searchHost"
|
|
|
|
:debounce="true"
|
|
|
|
type="search"
|
|
|
|
style="margin: 0; flex: 1"
|
|
|
|
:disabled="pagination.params.origin === 'local'"
|
|
|
|
>
|
|
|
|
<template #label>{{ i18n.ts.host }}</template>
|
|
|
|
</MkInput>
|
|
|
|
</div>
|
|
|
|
<div
|
|
|
|
class="inputs"
|
|
|
|
style="
|
|
|
|
display: flex;
|
|
|
|
gap: var(--margin);
|
|
|
|
flex-wrap: wrap;
|
|
|
|
padding-top: 1.2em;
|
|
|
|
"
|
|
|
|
>
|
|
|
|
<MkInput
|
|
|
|
v-model="userId"
|
|
|
|
:debounce="true"
|
|
|
|
type="search"
|
|
|
|
style="margin: 0; flex: 1"
|
|
|
|
>
|
|
|
|
<template #label>User ID</template>
|
|
|
|
</MkInput>
|
|
|
|
<MkInput
|
|
|
|
v-model="type"
|
|
|
|
:debounce="true"
|
|
|
|
type="search"
|
|
|
|
style="margin: 0; flex: 1"
|
|
|
|
>
|
|
|
|
<template #label>MIME type</template>
|
|
|
|
</MkInput>
|
|
|
|
</div>
|
|
|
|
<MkFileListForAdmin
|
|
|
|
:pagination="pagination"
|
|
|
|
:view-mode="viewMode"
|
|
|
|
/>
|
2022-06-16 09:05:43 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
2023-04-08 02:01:42 +02:00
|
|
|
</MkSpacer>
|
|
|
|
</MkStickyContainer>
|
|
|
|
</div>
|
2020-01-29 20:37:25 +01:00
|
|
|
</template>
|
|
|
|
|
2022-02-09 05:38:54 +01:00
|
|
|
<script lang="ts" setup>
|
2023-04-08 02:01:42 +02:00
|
|
|
import { computed, defineAsyncComponent } from "vue";
|
|
|
|
import * as Acct from "calckey-js/built/acct";
|
|
|
|
import MkButton from "@/components/MkButton.vue";
|
|
|
|
import MkInput from "@/components/form/input.vue";
|
|
|
|
import MkSelect from "@/components/form/select.vue";
|
|
|
|
import MkFileListForAdmin from "@/components/MkFileListForAdmin.vue";
|
|
|
|
import bytes from "@/filters/bytes";
|
|
|
|
import * as os from "@/os";
|
|
|
|
import { i18n } from "@/i18n";
|
|
|
|
import { definePageMetadata } from "@/scripts/page-metadata";
|
2022-02-09 05:38:54 +01:00
|
|
|
|
2023-04-08 02:01:42 +02:00
|
|
|
let origin = $ref("local");
|
2022-02-09 05:38:54 +01:00
|
|
|
let type = $ref(null);
|
2023-04-08 02:01:42 +02:00
|
|
|
let searchHost = $ref("");
|
|
|
|
let userId = $ref("");
|
|
|
|
let viewMode = $ref("grid");
|
2022-02-09 05:38:54 +01:00
|
|
|
const pagination = {
|
2023-04-08 02:01:42 +02:00
|
|
|
endpoint: "admin/drive/files" as const,
|
2022-02-09 05:38:54 +01:00
|
|
|
limit: 10,
|
|
|
|
params: computed(() => ({
|
2023-04-08 02:01:42 +02:00
|
|
|
type: type && type !== "" ? type : null,
|
|
|
|
userId: userId && userId !== "" ? userId : null,
|
2022-02-09 05:38:54 +01:00
|
|
|
origin: origin,
|
2023-04-08 02:01:42 +02:00
|
|
|
hostname: searchHost && searchHost !== "" ? searchHost : null,
|
2022-02-09 05:38:54 +01:00
|
|
|
})),
|
|
|
|
};
|
|
|
|
|
|
|
|
function clear() {
|
|
|
|
os.confirm({
|
2023-04-08 02:01:42 +02:00
|
|
|
type: "warning",
|
2022-02-09 05:38:54 +01:00
|
|
|
text: i18n.ts.clearCachedFilesConfirm,
|
|
|
|
}).then(({ canceled }) => {
|
|
|
|
if (canceled) return;
|
|
|
|
|
2023-04-08 02:01:42 +02:00
|
|
|
os.apiWithDialog("admin/drive/clean-remote-files", {});
|
2022-02-09 05:38:54 +01:00
|
|
|
});
|
|
|
|
}
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2022-02-09 05:38:54 +01:00
|
|
|
function show(file) {
|
2022-06-20 10:38:49 +02:00
|
|
|
os.pageWindow(`/admin/file/${file.id}`);
|
2022-02-09 05:38:54 +01:00
|
|
|
}
|
2020-01-29 20:37:25 +01:00
|
|
|
|
2022-06-16 09:05:43 +02:00
|
|
|
async function find() {
|
|
|
|
const { canceled, result: q } = await os.inputText({
|
|
|
|
title: i18n.ts.fileIdOrUrl,
|
|
|
|
allowEmpty: false,
|
|
|
|
});
|
|
|
|
if (canceled) return;
|
|
|
|
|
2023-04-08 02:01:42 +02:00
|
|
|
os.api(
|
|
|
|
"admin/drive/show-file",
|
|
|
|
q.startsWith("http://") || q.startsWith("https://")
|
|
|
|
? { url: q.trim() }
|
|
|
|
: { fileId: q.trim() }
|
|
|
|
)
|
|
|
|
.then((file) => {
|
|
|
|
show(file);
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
if (err.code === "NO_SUCH_FILE") {
|
|
|
|
os.alert({
|
|
|
|
type: "error",
|
|
|
|
text: i18n.ts.notFound,
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
2022-02-09 05:38:54 +01:00
|
|
|
}
|
2020-10-17 13:12:00 +02:00
|
|
|
|
2023-04-08 02:01:42 +02:00
|
|
|
const headerActions = $computed(() => [
|
|
|
|
{
|
|
|
|
text: i18n.ts.lookup,
|
|
|
|
icon: "ph-magnifying-glass ph-bold ph-lg",
|
|
|
|
handler: find,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: i18n.ts.clearCachedFiles,
|
|
|
|
icon: "ph-trash ph-bold ph-lg",
|
|
|
|
handler: clear,
|
|
|
|
},
|
|
|
|
]);
|
2022-06-20 10:38:49 +02:00
|
|
|
|
|
|
|
const headerTabs = $computed(() => []);
|
|
|
|
|
2023-04-08 02:01:42 +02:00
|
|
|
definePageMetadata(
|
|
|
|
computed(() => ({
|
|
|
|
title: i18n.ts.files,
|
|
|
|
icon: "ph-cloud ph-bold ph-lg",
|
|
|
|
}))
|
|
|
|
);
|
2020-01-29 20:37:25 +01:00
|
|
|
</script>
|
2020-10-17 13:12:00 +02:00
|
|
|
|
|
|
|
<style lang="scss" scoped>
|
|
|
|
.xrmjdkdw {
|
2021-04-22 15:29:33 +02:00
|
|
|
margin: var(--margin);
|
2021-10-02 16:11:21 +02:00
|
|
|
}
|
2020-10-17 13:12:00 +02:00
|
|
|
</style>
|