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

81 lines
1.9 KiB
Vue
Raw Normal View History

2018-06-27 20:08:27 +05:30
<script>
import Base from './Base';
export default {
extends: Base,
methods: {
getWrapperElement(h) {
2018-07-15 19:20:24 +05:30
let fileName = this.docfield.placeholder || this._('Choose a file..');
let filePath = null;
2018-06-27 20:08:27 +05:30
if (this.value && typeof this.value === 'string') {
filePath = this.value;
}
else if (this.$refs.input && this.$refs.input.files.length) {
2018-06-27 20:08:27 +05:30
fileName = this.$refs.input.files[0].name;
}
const fileLink = h('a', {
attrs: {
href: filePath,
target: '_blank'
},
domProps: {
textContent: this._('View File')
}
});
const helpText = h('small', {
class: 'form-text text-muted'
}, [fileLink]);
const fileNameLabel = h('label', {
class: ['custom-file-label'],
domProps: {
textContent: filePath || fileName
2018-06-27 20:08:27 +05:30
}
});
const fileInputWrapper = h('div', {
class: ['custom-file']
},
[this.getInputElement(h), fileNameLabel, filePath ? helpText : null]
);
return h(
'div',
{
2018-07-14 17:09:42 +05:30
class: ['form-group', ...this.wrapperClass],
attrs: {
2018-06-27 20:08:27 +05:30
'data-fieldname': this.docfield.fieldname
2018-07-14 17:09:42 +05:30
}
},
[this.getLabelElement(h), fileInputWrapper]
);
2018-06-27 20:08:27 +05:30
},
getInputAttrs() {
return {
id: this.id,
type: 'file',
value: this.value,
2018-07-12 16:59:10 +05:30
required: this.docfield.required,
2018-07-14 17:09:42 +05:30
disabled: this.disabled,
webkitdirectory: this.docfield.directory,
directory: this.docfield.directory,
accept: (this.docfield.filetypes || []).join(',')
2018-07-14 17:09:42 +05:30
};
},
getInputClass() {
return 'custom-file-input';
},
2018-07-14 17:09:42 +05:30
getInputListeners() {
return {
change: e => {
this.handleChange(e.target.files);
}
};
2018-06-27 20:08:27 +05:30
}
}
2018-07-14 17:09:42 +05:30
};
2018-06-27 20:08:27 +05:30
</script>