mirror of
https://github.com/frappe/books.git
synced 2025-01-12 11:04:12 +00:00
88 lines
1.8 KiB
Vue
88 lines
1.8 KiB
Vue
<template>
|
|
<component
|
|
:is="component"
|
|
:docfield="docfield"
|
|
:value="value"
|
|
:onlyInput="onlyInput"
|
|
:disabled="isDisabled"
|
|
:autofocus="autofocus"
|
|
@change="$emit('change', $event)"
|
|
/>
|
|
</template>
|
|
<script>
|
|
import Base from './Base';
|
|
import Autocomplete from './Autocomplete';
|
|
import Check from './Check';
|
|
import Code from './Code';
|
|
import Currency from './Currency';
|
|
import Data from './Data';
|
|
import Date from './Date';
|
|
import DynamicLink from './DynamicLink';
|
|
import File from './File';
|
|
import Float from './Float';
|
|
import Int from './Int';
|
|
import Link from './Link';
|
|
import Password from './Password';
|
|
import Select from './Select';
|
|
import Table from './Table';
|
|
import Text from './Text';
|
|
import Time from './Time';
|
|
|
|
export default {
|
|
props: ['docfield', 'value', 'onlyInput', 'doc', 'autofocus'],
|
|
computed: {
|
|
component() {
|
|
if (this.docfield.template) {
|
|
// for controls with their own template
|
|
// create a vue object for it
|
|
return {
|
|
extends: Base,
|
|
render: null,
|
|
template: this.docfield.template()
|
|
};
|
|
}
|
|
|
|
return {
|
|
Autocomplete,
|
|
Check,
|
|
Code,
|
|
Currency,
|
|
Data,
|
|
Date,
|
|
DynamicLink,
|
|
File,
|
|
Float,
|
|
Int,
|
|
Link,
|
|
Password,
|
|
Select,
|
|
Table,
|
|
Text,
|
|
Time
|
|
}[this.docfield.fieldtype];
|
|
},
|
|
isDisabled() {
|
|
let disabled = this.docfield.disabled;
|
|
|
|
if (this.doc && this.doc.submitted) {
|
|
disabled = true;
|
|
}
|
|
|
|
return Boolean(disabled);
|
|
}
|
|
},
|
|
provide() {
|
|
return {
|
|
dynamicLinkTarget: reference => {
|
|
return this.doc[reference];
|
|
}
|
|
};
|
|
},
|
|
};
|
|
</script>
|
|
<style scoped>
|
|
.form-group {
|
|
position: relative;
|
|
}
|
|
</style>
|