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

57 lines
1.3 KiB
Vue
Raw Normal View History

2018-06-27 20:08:27 +05:30
<script>
import Base from './Base';
export default {
extends: Base,
computed: {
inputClass() {
return ['d-none'];
}
},
methods: {
getWrapperElement(h) {
2018-07-14 17:09:42 +05:30
let fileName = this._('Choose a file..');
2018-06-27 20:08:27 +05:30
if (this.$refs.input && this.$refs.input.files.length) {
fileName = this.$refs.input.files[0].name;
}
const fileButton = h('button', {
class: ['btn btn-outline-secondary btn-block'],
domProps: {
textContent: fileName
},
on: {
click: () => this.$refs.input.click()
}
});
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), this.getInputElement(h), fileButton]);
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
};
},
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>