This commit is contained in:
@@ -650,6 +650,14 @@ function initNavPanel() {
|
|||||||
key: key++
|
key: key++
|
||||||
});
|
});
|
||||||
|
|
||||||
|
//IMPORT
|
||||||
|
sub.push({
|
||||||
|
title: "Import",
|
||||||
|
icon: "$ayiFileImport",
|
||||||
|
route: "/adm-import",
|
||||||
|
key: key++
|
||||||
|
});
|
||||||
|
|
||||||
// ** ADMINISTRATION (TOP)
|
// ** ADMINISTRATION (TOP)
|
||||||
addNavItem(
|
addNavItem(
|
||||||
"Administration",
|
"Administration",
|
||||||
|
|||||||
@@ -392,6 +392,13 @@ export default new Router({
|
|||||||
import(/* webpackChunkName: "adm" */ "./views/adm-history.vue")
|
import(/* webpackChunkName: "adm" */ "./views/adm-history.vue")
|
||||||
},
|
},
|
||||||
|
|
||||||
|
{
|
||||||
|
path: "/adm-import",
|
||||||
|
name: "adm-import",
|
||||||
|
component: () =>
|
||||||
|
import(/* webpackChunkName: "adm" */ "./views/adm-import.vue")
|
||||||
|
},
|
||||||
|
|
||||||
{
|
{
|
||||||
path: "/ops-backup",
|
path: "/ops-backup",
|
||||||
name: "ops-backup",
|
name: "ops-backup",
|
||||||
|
|||||||
162
ayanova/src/views/adm-import.vue
Normal file
162
ayanova/src/views/adm-import.vue
Normal file
@@ -0,0 +1,162 @@
|
|||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<v-col cols="12" sm="6" lg="4" xl="3">
|
||||||
|
<v-select
|
||||||
|
v-model="ayaType"
|
||||||
|
:items="selectLists.coreAyaTypes"
|
||||||
|
item-text="name"
|
||||||
|
item-value="id"
|
||||||
|
:label="$ay.t('AyaType')"
|
||||||
|
ref="ayaType"
|
||||||
|
data-cy="ayaType"
|
||||||
|
></v-select>
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-file-input
|
||||||
|
v-model="uploadFiles"
|
||||||
|
:label="$ay.t('Import')"
|
||||||
|
accept="application/json"
|
||||||
|
prepend-icon="$ayiFile-upload"
|
||||||
|
multiple
|
||||||
|
chips
|
||||||
|
></v-file-input>
|
||||||
|
<v-btn
|
||||||
|
v-if="uploadFiles.length > 0 && ayaType != 0"
|
||||||
|
:loading="uploading"
|
||||||
|
color="primary"
|
||||||
|
text
|
||||||
|
@click="upload"
|
||||||
|
>{{ $ay.t("Upload") }}</v-btn
|
||||||
|
>
|
||||||
|
</v-col>
|
||||||
|
<v-col>
|
||||||
|
<v-textarea
|
||||||
|
v-model="importResult"
|
||||||
|
full-width
|
||||||
|
readonly
|
||||||
|
auto-grow
|
||||||
|
data-cy="importResult"
|
||||||
|
></v-textarea>
|
||||||
|
</v-col>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
const FORM_KEY = "adm-import";
|
||||||
|
export default {
|
||||||
|
async created() {
|
||||||
|
this.rights = window.$gz.role.getRights(window.$gz.type.Translation);
|
||||||
|
window.$gz.eventBus.$on("menu-click", clickHandler);
|
||||||
|
await fetchTranslatedText(this);
|
||||||
|
await populateSelectionLists(this);
|
||||||
|
generateMenu(this);
|
||||||
|
},
|
||||||
|
beforeDestroy() {
|
||||||
|
window.$gz.eventBus.$off("menu-click", clickHandler);
|
||||||
|
},
|
||||||
|
data() {
|
||||||
|
return {
|
||||||
|
selectLists: {
|
||||||
|
coreAyaTypes: []
|
||||||
|
},
|
||||||
|
uploadFiles: [],
|
||||||
|
ayaType: 0,
|
||||||
|
importResult: "",
|
||||||
|
rights: window.$gz.role.defaultRightsObject(),
|
||||||
|
reload: false,
|
||||||
|
uploading: false
|
||||||
|
};
|
||||||
|
},
|
||||||
|
methods: {
|
||||||
|
async upload() {
|
||||||
|
//similar code in wiki-control
|
||||||
|
let vm = this;
|
||||||
|
let fileData = [];
|
||||||
|
let importResult="";
|
||||||
|
for (let i = 0; i < vm.uploadFiles.length; i++) {
|
||||||
|
let f = vm.uploadFiles[i];
|
||||||
|
fileData.push({ name: f.name, lastModified: f.lastModified });
|
||||||
|
}
|
||||||
|
let at = {
|
||||||
|
ayaType: vm.ayaType,
|
||||||
|
files: vm.uploadFiles,
|
||||||
|
fileData: JSON.stringify(fileData)
|
||||||
|
};
|
||||||
|
try {
|
||||||
|
vm.uploading = true;
|
||||||
|
let res = await window.$gz.api.upload("import/upload", at);
|
||||||
|
if (res.error) {
|
||||||
|
window.$gz.errorHandler.handleFormError(res.error);
|
||||||
|
} else {
|
||||||
|
vm.uploadFiles = [];
|
||||||
|
vm.importResult = res.data;
|
||||||
|
this.reload = !this.reload;
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
window.$gz.errorHandler.handleFormError(error);
|
||||||
|
} finally {
|
||||||
|
vm.uploading = false;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
handleSelected(selectedItems) {
|
||||||
|
console.log(selectedItems);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
/////////////////////////////
|
||||||
|
//
|
||||||
|
//
|
||||||
|
function clickHandler(menuItem) {
|
||||||
|
if (!menuItem) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
let m = window.$gz.menu.parseMenuItem(menuItem);
|
||||||
|
if (m.owner == FORM_KEY && !m.disabled) {
|
||||||
|
switch (m.key) {
|
||||||
|
// case "new":
|
||||||
|
// m.vm.$router.push({
|
||||||
|
// name: "adm-import",
|
||||||
|
// params: { recordid: 0 }
|
||||||
|
// });
|
||||||
|
// break;
|
||||||
|
default:
|
||||||
|
window.$gz.eventBus.$emit(
|
||||||
|
"notify-warning",
|
||||||
|
FORM_KEY + "::context click: [" + m.key + "]"
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//////////////////////
|
||||||
|
//
|
||||||
|
//
|
||||||
|
function generateMenu(vm) {
|
||||||
|
let menuOptions = {
|
||||||
|
isMain: true,
|
||||||
|
icon: "$ayiFileImport",
|
||||||
|
title: "Import",
|
||||||
|
helpUrl: "form-adm-import",
|
||||||
|
menuItems: []
|
||||||
|
};
|
||||||
|
|
||||||
|
window.$gz.eventBus.$emit("menu-change", menuOptions);
|
||||||
|
}
|
||||||
|
|
||||||
|
//////////////////////////////////////////////////////////
|
||||||
|
//
|
||||||
|
// Ensures UI translated text is available
|
||||||
|
//
|
||||||
|
async function fetchTranslatedText(vm) {
|
||||||
|
await window.$gz.translation.cacheTranslations(["AyaType"]);
|
||||||
|
}
|
||||||
|
|
||||||
|
//////////////////////
|
||||||
|
//
|
||||||
|
//
|
||||||
|
async function populateSelectionLists(vm) {
|
||||||
|
await window.$gz.enums.fetchEnumList("core");
|
||||||
|
vm.selectLists.coreAyaTypes = window.$gz.enums.getSelectionList("core");
|
||||||
|
}
|
||||||
|
</script>
|
||||||
@@ -8,7 +8,6 @@
|
|||||||
:showSelect="false"
|
:showSelect="false"
|
||||||
:singleSelect="false"
|
:singleSelect="false"
|
||||||
:reload="reload"
|
:reload="reload"
|
||||||
v-on:selection-change="handleSelected"
|
|
||||||
data-cy="transTable"
|
data-cy="transTable"
|
||||||
>
|
>
|
||||||
</gz-data-table>
|
</gz-data-table>
|
||||||
@@ -85,9 +84,6 @@ export default {
|
|||||||
} finally {
|
} finally {
|
||||||
vm.uploading = false;
|
vm.uploading = false;
|
||||||
}
|
}
|
||||||
},
|
|
||||||
handleSelected(selectedItems) {
|
|
||||||
console.log(selectedItems);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user