2
0
mirror of https://github.com/frappe/books.git synced 2025-01-25 16:18:33 +00:00

fix: rewrite the data entry grid

This commit is contained in:
18alantom 2023-02-15 13:29:06 +05:30
parent ff49958e5f
commit 9d3ae6adfd

View File

@ -87,67 +87,37 @@
class="text-base ms-2" class="text-base ms-2"
:class="fileName ? 'text-gray-900 font-semibold' : 'text-gray-700'" :class="fileName ? 'text-gray-900 font-semibold' : 'text-gray-700'"
> >
<span v-if="fileName" class="font-normal" <span v-if="fileName" class="font-normal">{{ t`Selected` }} </span>
>{{ t`Selected file` }}
</span>
{{ helperMessage }}{{ fileName ? ',' : '' }} {{ helperMessage }}{{ fileName ? ',' : '' }}
<span v-if="fileName" class="font-normal"> <span v-if="fileName" class="font-normal">
{{ t`verify data and click on` }} </span {{ t`check values and click on` }} </span
>{{ ' ' }}<span v-if="fileName">{{ t`Import Data.` }}</span> >{{ ' ' }}<span v-if="fileName">{{ t`Import Data.` }}</span>
<span <span
v-if="hasImporter && importer.valueMatrix.length > 0" v-if="hasImporter && importer.valueMatrix.length > 0"
class="font-normal" class="font-normal"
>{{ ' ' + t`${importer.valueMatrix.length} rows added.` }}</span >{{
' ' +
(importer.valueMatrix.length === 2
? t`${importer.valueMatrix.length} row added.`
: t`${importer.valueMatrix.length} rows added.`)
}}</span
> >
</p> </p>
</div> </div>
<!-- Bulk Entries Grid --> <!-- Assignment Row and Value Grid container -->
<div v-if="hasImporter">
<div <div
class="flex justify-start" v-if="hasImporter"
class="overflow-auto custom-scroll"
style="max-height: calc(100vh - (2 * var(--h-row-largest)) - 2px)" style="max-height: calc(100vh - (2 * var(--h-row-largest)) - 2px)"
> >
<!-- Index Column --> <!-- Column Assignment Row -->
<div <div
class=" class="grid sticky top-0 py-4 pe-4 bg-white border-b gap-4"
w-12 style="z-index: 1; width: fit-content"
p-4 :style="gridTemplateColumn"
border-e
flex-shrink-0
text-gray-600
grid grid-cols-1
items-center
justify-items-center
gap-4
"
> >
<div class="flex items-center h-7 flex-shrink-0">#</div> <div class="index-cell">#</div>
<div
v-for="(_, i) of importer.valueMatrix"
:key="i"
class="flex items-center group h-7 flex-shrink-0"
>
<span class="hidden group-hover:inline-block">
<feather-icon
name="x"
class="w-4 h-4 -ms-1 cursor-pointer"
:button="true"
@click="importer.removeRow(i)"
/>
</span>
<span class="group-hover:hidden">
{{ i + 1 }}
</span>
</div>
</div>
<!-- Grid -->
<div
class="overflow-auto gap-4 p-4 grid"
:style="`grid-template-columns: repeat(${columnCount}, 10rem)`"
>
<!-- Grid Title Row Cells, Allow Column Selection -->
<AutoComplete <AutoComplete
v-for="index in columnIterator" v-for="index in columnIterator"
class="flex-shrink-0" class="flex-shrink-0"
@ -158,9 +128,31 @@
:value="importer.assignedTemplateFields[index]" :value="importer.assignedTemplateFields[index]"
@change="(value: string | null) => importer.setTemplateField(index, value)" @change="(value: string | null) => importer.setTemplateField(index, value)"
/> />
</div>
<!-- Values Grid -->
<div
v-if="importer.valueMatrix.length"
class="grid py-4 pe-4 bg-white gap-4"
style="width: fit-content"
:style="gridTemplateColumn"
>
<!-- Grid Value Row Cells, Allow Editing Values --> <!-- Grid Value Row Cells, Allow Editing Values -->
<template v-for="(row, ridx) of importer.valueMatrix"> <template v-for="(row, ridx) of importer.valueMatrix" :key="ridx">
<div
class="index-cell group cursor-pointer"
@click="importer.removeRow(ridx)"
>
<feather-icon
name="x"
class="w-4 h-4 hidden group-hover:inline-block -me-1"
:button="true"
/>
<span class="group-hover:hidden">
{{ ridx + 1 }}
</span>
</div>
<template <template
v-for="(val, cidx) of row.slice(0, columnCount)" v-for="(val, cidx) of row.slice(0, columnCount)"
:key="`cell-${ridx}-${cidx}`" :key="`cell-${ridx}-${cidx}`"
@ -208,23 +200,11 @@
</template> </template>
</template> </template>
</div> </div>
</div>
<hr />
</div>
</div>
<!-- How to Use Link --> <div v-else class="p-4 text-gray-700 sticky left-0">
<!-- Not shown cause video is outdated --> {{ t`No rows added. Select a file or add rows.` }}
<div </div>
v-if="false" </div>
class="flex justify-center h-full w-full items-center mb-16"
>
<HowTo
link="https://youtu.be/ukHAgcnVxTQ"
class="text-gray-900 rounded-lg text-base border px-3 py-2"
>
{{ t`How to Use the Import Wizard` }}
</HowTo>
</div> </div>
<!-- Loading Bar when Saving Docs --> <!-- Loading Bar when Saving Docs -->
@ -397,7 +377,6 @@ import Data from 'src/components/Controls/Data.vue';
import FormControl from 'src/components/Controls/FormControl.vue'; import FormControl from 'src/components/Controls/FormControl.vue';
import DropdownWithActions from 'src/components/DropdownWithActions.vue'; import DropdownWithActions from 'src/components/DropdownWithActions.vue';
import FormHeader from 'src/components/FormHeader.vue'; import FormHeader from 'src/components/FormHeader.vue';
import HowTo from 'src/components/HowTo.vue';
import Modal from 'src/components/Modal.vue'; import Modal from 'src/components/Modal.vue';
import PageHeader from 'src/components/PageHeader.vue'; import PageHeader from 'src/components/PageHeader.vue';
import { getColumnLabel, Importer, TemplateField } from 'src/importer'; import { getColumnLabel, Importer, TemplateField } from 'src/importer';
@ -433,7 +412,6 @@ export default defineComponent({
FormControl, FormControl,
Button, Button,
DropdownWithActions, DropdownWithActions,
HowTo,
Loading, Loading,
AutoComplete, AutoComplete,
Data, Data,
@ -464,6 +442,9 @@ export default defineComponent({
} }
}, },
computed: { computed: {
gridTemplateColumn(): string {
return `grid-template-columns: 4rem repeat(${this.columnCount}, 10rem)`;
},
duplicates(): string[] { duplicates(): string[] {
if (!this.hasImporter) { if (!this.hasImporter) {
return []; return [];
@ -637,7 +618,7 @@ export default defineComponent({
if (!this.importType) { if (!this.importType) {
return this.t`Set an Import Type`; return this.t`Set an Import Type`;
} else if (!this.fileName) { } else if (!this.fileName) {
return this.t`Select a file or add rows.`; return '';
} }
return this.fileName; return this.fileName;
@ -935,3 +916,8 @@ export default defineComponent({
}, },
}); });
</script> </script>
<style scoped>
.index-cell {
@apply flex pe-4 justify-end items-center border-e bg-white sticky left-0 -my-4 text-gray-600;
}
</style>