mirror of
https://github.com/frappe/books.git
synced 2025-01-27 17:18:27 +00:00
- Dynamic doctype hidden prop
- Table UI Fix: Column expands when active.
This commit is contained in:
parent
fd6eeac8cd
commit
6621a2c7af
@ -55,7 +55,12 @@ export default {
|
|||||||
return this.fields.find(df => df.fieldname === fieldname);
|
return this.fields.find(df => df.fieldname === fieldname);
|
||||||
},
|
},
|
||||||
shouldRenderField(fieldname) {
|
shouldRenderField(fieldname) {
|
||||||
const hidden = Boolean(this.getDocField(fieldname).hidden);
|
let hidden;
|
||||||
|
try {
|
||||||
|
hidden = Boolean(this.getDocField(fieldname).hidden(this.doc));
|
||||||
|
} catch (e) {
|
||||||
|
hidden = Boolean(this.getDocField(fieldname).hidden) || false;
|
||||||
|
}
|
||||||
|
|
||||||
if (hidden) {
|
if (hidden) {
|
||||||
return false;
|
return false;
|
||||||
|
@ -4,12 +4,10 @@
|
|||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th scope="col" width="60">
|
<th scope="col" width="60">
|
||||||
<input class="mr-2" type="checkbox" @change="toggleCheckAll">
|
<input class="mr-2" type="checkbox" @change="toggleCheckAll" />
|
||||||
<span>#</span>
|
<span>#</span>
|
||||||
</th>
|
</th>
|
||||||
<th scope="col" v-for="column in columns" :key="column.fieldname">
|
<th scope="col" v-for="column in columns" :key="column.fieldname">{{ column.label }}</th>
|
||||||
{{ column.label }}
|
|
||||||
</th>
|
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody v-if="rows.length">
|
<tbody v-if="rows.length">
|
||||||
@ -20,10 +18,12 @@
|
|||||||
type="checkbox"
|
type="checkbox"
|
||||||
:checked="checkedRows.includes(i)"
|
:checked="checkedRows.includes(i)"
|
||||||
@change="e => onCheck(e, i)"
|
@change="e => onCheck(e, i)"
|
||||||
>
|
/>
|
||||||
<span>{{ i + 1 }}</span>
|
<span>{{ i + 1 }}</span>
|
||||||
</th>
|
</th>
|
||||||
<td v-for="column in columns" :key="column.fieldname"
|
<td
|
||||||
|
v-for="column in columns"
|
||||||
|
:key="column.fieldname"
|
||||||
tabindex="1"
|
tabindex="1"
|
||||||
:ref="column.fieldname + i"
|
:ref="column.fieldname + i"
|
||||||
@click="activateFocus(i, column.fieldname)"
|
@click="activateFocus(i, column.fieldname)"
|
||||||
@ -37,7 +37,10 @@
|
|||||||
@keydown.down="focusBelowCell(i, column.fieldname)"
|
@keydown.down="focusBelowCell(i, column.fieldname)"
|
||||||
@keydown.esc="escOnCell(i, column.fieldname)"
|
@keydown.esc="escOnCell(i, column.fieldname)"
|
||||||
>
|
>
|
||||||
<div class="table-cell" :class="{'active': isFocused(i, column.fieldname)}">
|
<div
|
||||||
|
class="table-cell"
|
||||||
|
:class="{'active': isFocused(i, column.fieldname),'p-1': isEditing(i, column.fieldname)}"
|
||||||
|
>
|
||||||
<frappe-control
|
<frappe-control
|
||||||
v-if="isEditing(i, column.fieldname)"
|
v-if="isEditing(i, column.fieldname)"
|
||||||
:docfield="getDocfield(column.fieldname)"
|
:docfield="getDocfield(column.fieldname)"
|
||||||
@ -47,9 +50,11 @@
|
|||||||
:autofocus="true"
|
:autofocus="true"
|
||||||
@change="onCellChange(i, column.fieldname, $event)"
|
@change="onCellChange(i, column.fieldname, $event)"
|
||||||
/>
|
/>
|
||||||
<div class="text-truncate" v-else>
|
<div
|
||||||
{{ row[column.fieldname] || ' ' }}
|
class="text-truncate"
|
||||||
</div>
|
:data-fieldtype="column.fieldtype"
|
||||||
|
v-else
|
||||||
|
>{{ row[column.fieldname] || ' ' }}</div>
|
||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
@ -57,9 +62,7 @@
|
|||||||
<tbody v-else>
|
<tbody v-else>
|
||||||
<tr>
|
<tr>
|
||||||
<td :colspan="columns.length + 1" class="text-center">
|
<td :colspan="columns.length + 1" class="text-center">
|
||||||
<div class="table-cell">
|
<div class="table-cell">No Data</div>
|
||||||
No Data
|
|
||||||
</div>
|
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
</tbody>
|
</tbody>
|
||||||
@ -104,7 +107,10 @@ export default {
|
|||||||
},
|
},
|
||||||
focusPreviousCell() {
|
focusPreviousCell() {
|
||||||
let { index, fieldname } = this.currentlyFocused;
|
let { index, fieldname } = this.currentlyFocused;
|
||||||
if (this.isFocused(index, fieldname) && !this.isEditing(index, fieldname)) {
|
if (
|
||||||
|
this.isFocused(index, fieldname) &&
|
||||||
|
!this.isEditing(index, fieldname)
|
||||||
|
) {
|
||||||
let pos = this._getColumnIndex(fieldname);
|
let pos = this._getColumnIndex(fieldname);
|
||||||
pos -= 1;
|
pos -= 1;
|
||||||
if (pos < 0) {
|
if (pos < 0) {
|
||||||
@ -120,8 +126,10 @@ export default {
|
|||||||
},
|
},
|
||||||
focusNextCell() {
|
focusNextCell() {
|
||||||
let { index, fieldname } = this.currentlyFocused;
|
let { index, fieldname } = this.currentlyFocused;
|
||||||
if (this.isFocused(index, fieldname) && !this.isEditing(index, fieldname)) {
|
if (
|
||||||
|
this.isFocused(index, fieldname) &&
|
||||||
|
!this.isEditing(index, fieldname)
|
||||||
|
) {
|
||||||
let pos = this._getColumnIndex(fieldname);
|
let pos = this._getColumnIndex(fieldname);
|
||||||
pos += 1;
|
pos += 1;
|
||||||
if (pos > this.columns.length - 1) {
|
if (pos > this.columns.length - 1) {
|
||||||
@ -292,7 +300,7 @@ export default {
|
|||||||
</script>
|
</script>
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
td {
|
td {
|
||||||
padding: 0;
|
padding: 0rem;
|
||||||
outline: none;
|
outline: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -322,4 +330,9 @@ td {
|
|||||||
[data-fieldtype='Link'] .input-group-append {
|
[data-fieldtype='Link'] .input-group-append {
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[data-fieldtype='Currency'],
|
||||||
|
[data-fieldtype='Float'] {
|
||||||
|
text-align: right !important;
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user