You've already forked AstralRinth
* Initial unzipping feature * Remove explicit backup provider naming from frontend * CF placeholder * Use regex for CF links * Lint * Add unzip warning for conflicting files, fix hydration error * Adjust conflict modal ui * Fix old queued ops sticking around, remove conflict warning * Add vscode "editor.detectIndentation": true
57 lines
1.6 KiB
Vue
57 lines
1.6 KiB
Vue
<template>
|
|
<ConfirmModal
|
|
ref="modal"
|
|
title="Do you want to overwrite these conflicting files?"
|
|
:proceed-label="`Overwrite`"
|
|
:proceed-icon="CheckIcon"
|
|
@proceed="proceed"
|
|
>
|
|
<div class="flex max-w-[30rem] flex-col gap-4">
|
|
<p class="m-0 font-semibold leading-normal">
|
|
<template v-if="hasMany">
|
|
Over 100 files will be overwritten if you proceed with extraction; here is just some of
|
|
them:
|
|
</template>
|
|
<template v-else>
|
|
The following {{ files.length }} files already exist on your server, and will be
|
|
overwritten if you proceed with extraction:
|
|
</template>
|
|
</p>
|
|
<ul class="m-0 max-h-80 list-none overflow-auto rounded-2xl bg-bg px-4 py-3">
|
|
<li v-for="file in files" :key="file" class="flex items-center gap-1 py-1 font-medium">
|
|
<XIcon class="shrink-0 text-red" /> {{ file }}
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</ConfirmModal>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
import { ConfirmModal } from "@modrinth/ui";
|
|
import { ref } from "vue";
|
|
import { XIcon, CheckIcon } from "@modrinth/assets";
|
|
|
|
const path = ref("");
|
|
const files = ref<string[]>([]);
|
|
|
|
const emit = defineEmits<{
|
|
(e: "proceed", path: string): void;
|
|
}>();
|
|
|
|
const modal = ref<typeof ConfirmModal>();
|
|
|
|
const hasMany = computed(() => files.value.length > 100);
|
|
|
|
const show = (zipPath: string, conflictingFiles: string[]) => {
|
|
path.value = zipPath;
|
|
files.value = conflictingFiles;
|
|
modal.value?.show();
|
|
};
|
|
|
|
const proceed = () => {
|
|
emit("proceed", path.value);
|
|
};
|
|
|
|
defineExpose({ show });
|
|
</script>
|