Modify upload function to accept only yml files on folder upload. Adding breadcrumbs, adding feature to create folder

This commit is contained in:
Jorge 2021-09-05 12:59:03 +03:00
parent fe715360a5
commit 16c4455d8d
4 changed files with 137 additions and 117 deletions

View File

@ -2,21 +2,34 @@
<nav :class="{ active }">
<template v-if="isLogged">
<router-link
class="action"
to="/files/"
:aria-label="$t('sidebar.myFiles')"
:title="$t('sidebar.myFiles')"
class="action"
to="/files/"
:aria-label="$t('sidebar.myFiles')"
:title="$t('sidebar.myFiles')"
>
<i class="material-icons">folder</i>
<span>{{ $t("sidebar.myFiles") }}</span>
</router-link>
<div v-if="user.perm.create">
<div v-if="user.perm.create">
<button
@click="$store.commit('showHover', 'newFile')"
class="action"
:aria-label="$t('sidebar.newFile')"
:title="$t('sidebar.newFile')"
@click="$store.commit('showHover', 'newDir')"
class="action"
:aria-label="$t('sidebar.newFolder')"
:title="$t('sidebar.newFolder')"
>
<i class="material-icons">create_new_folder</i>
<span>{{ $t("sidebar.newFolder") }}</span>
</button>
</div>
<div v-if="user.perm.create">
<button
@click="$store.commit('showHover', 'newFile')"
class="action"
:aria-label="$t('sidebar.newFile')"
:title="$t('sidebar.newFile')"
>
<i class="material-icons">note_add</i>
<span>{{ $t("sidebar.newFile") }}</span>
@ -28,9 +41,9 @@
</template>
<script>
import { mapGetters, mapState } from "vuex";
import {mapGetters, mapState} from "vuex";
import * as auth from "@/utils/auth";
import { authMethod, disableExternal, noAuth, signup, version } from "@/utils/constants";
import {authMethod, disableExternal, noAuth, signup, version} from "@/utils/constants";
export default {
name: "sidebar",

View File

@ -112,7 +112,7 @@
width: 100%;
max-width: 100%;
margin: 0;
margin-top: 64px;
margin-top: 0;
}
#listing.list .item {

View File

@ -2,126 +2,132 @@ import store from "@/store";
import url from "@/utils/url";
export function checkConflict(files, items) {
if (typeof items === "undefined" || items === null) {
items = [];
}
let folder_upload = files[0].fullPath !== undefined;
let conflict = false;
for (let i = 0; i < files.length; i++) {
let file = files[i];
let name = file.name;
if (folder_upload) {
let dirs = file.fullPath.split("/");
if (dirs.length > 1) {
name = dirs[0];
}
if (typeof items === "undefined" || items === null) {
items = [];
}
let res = items.findIndex(function hasConflict(element) {
return element.name === this;
}, name);
let folder_upload = files[0].fullPath !== undefined;
if (res >= 0) {
conflict = true;
break;
let conflict = false;
for (let i = 0; i < files.length; i++) {
let file = files[i];
let name = file.name;
if (folder_upload) {
let dirs = file.fullPath.split("/");
if (dirs.length > 1) {
name = dirs[0];
}
}
let res = items.findIndex(function hasConflict(element) {
return element.name === this;
}, name);
if (res >= 0) {
conflict = true;
break;
}
}
}
return conflict;
return conflict;
}
export function scanFiles(dt) {
return new Promise((resolve) => {
let reading = 0;
const contents = [];
return new Promise((resolve) => {
let reading = 0;
const contents = [];
if (dt.items !== undefined) {
for (let item of dt.items) {
if (
item.kind === "file" &&
typeof item.webkitGetAsEntry === "function"
) {
const entry = item.webkitGetAsEntry();
readEntry(entry);
}
}
} else {
resolve(dt.files);
}
function readEntry(entry, directory = "") {
if (entry.isFile) {
reading++;
entry.file((file) => {
reading--;
file.fullPath = `${directory}${file.name}`;
contents.push(file);
if (reading === 0) {
resolve(contents);
}
});
} else if (entry.isDirectory) {
const dir = {
isDir: true,
size: 0,
fullPath: `${directory}${entry.name}`,
};
contents.push(dir);
readReaderContent(entry.createReader(), `${directory}${entry.name}`);
}
}
function readReaderContent(reader, directory) {
reading++;
reader.readEntries(function (entries) {
reading--;
if (entries.length > 0) {
for (const entry of entries) {
readEntry(entry, `${directory}/`);
}
readReaderContent(reader, `${directory}/`);
if (dt.items !== undefined) {
for (let item of dt.items) {
if (
item.kind === "file" &&
typeof item.webkitGetAsEntry === "function"
) {
const entry = item.webkitGetAsEntry();
readEntry(entry);
}
}
} else {
resolve(dt.files);
}
if (reading === 0) {
resolve(contents);
function readEntry(entry, directory = "") {
if (entry.isFile) {
reading++;
entry.file((file) => {
reading--;
file.fullPath = `${directory}${file.name}`;
contents.push(file);
if (reading === 0) {
resolve(contents);
}
});
} else if (entry.isDirectory) {
const dir = {
isDir: true,
size: 0,
fullPath: `${directory}${entry.name}`,
};
contents.push(dir);
readReaderContent(entry.createReader(), `${directory}${entry.name}`);
}
}
});
}
});
function readReaderContent(reader, directory) {
reading++;
reader.readEntries(function (entries) {
reading--;
if (entries.length > 0) {
for (const entry of entries) {
readEntry(entry, `${directory}/`);
}
readReaderContent(reader, `${directory}/`);
}
if (reading === 0) {
resolve(contents);
}
});
}
});
}
export function handleFiles(files, base, overwrite = false) {
for (let i = 0; i < files.length; i++) {
let id = store.state.upload.id;
let path = base;
let file = files[i];
for (let i = 0; i < files.length; i++) {
if (file.fullPath !== undefined) {
path += url.encodePath(file.fullPath);
} else {
path += url.encodeRFC5987ValueChars(file.name);
let id = store.state.upload.id;
let path = base;
let file = files[i];
console.log(file);
var re = /(?:\.([^.]+))?$/;
console.log(re.exec(file.name)[1]);
if (re.exec(file.name)[1] === 'yml') {
console.log('Is yml file')
if (file.fullPath !== undefined) {
path += url.encodePath(file.fullPath);
} else {
path += url.encodeRFC5987ValueChars(file.name);
}
if (file.isDir) {
path += "/";
}
const item = {
id,
path,
file,
overwrite,
};
store.dispatch("upload/upload", item);
}
}
if (file.isDir) {
path += "/";
}
const item = {
id,
path,
file,
overwrite,
};
store.dispatch("upload/upload", item);
}
}

View File

@ -1,6 +1,7 @@
<template>
<div>
<header-bar v-if="error || req.type == null" showMenu showLogo />
<breadcrumbs base="/files" />
<errors v-if="error" :errorCode="error.message" />
<component v-else-if="currentView" :is="currentView"></component>
<div v-else>