salix/front/core/components/input-time/index.js

73 lines
1.6 KiB
JavaScript
Raw Normal View History

2018-09-19 13:05:07 +00:00
import ngModule from '../../module';
import Textfield from '../textfield/textfield';
import './style.scss';
export default class InputTime extends Textfield {
get value() {
return this._value;
}
get model() {
return this._model;
}
set model(value) {
this.value = value;
}
2018-09-19 13:05:07 +00:00
set value(value) {
2018-09-24 08:43:54 +00:00
if (!value) return;
let newDate = new Date(value);
newDate.setSeconds(0);
newDate.setMilliseconds(0);
this._model = newDate;
this.hasValue = this._model !== null;
let date = new Date(value);
date.setSeconds(0);
date.setMilliseconds(0);
let offset = date.getTimezoneOffset() * 60000;
date.setTime(date.getTime() - offset);
this._value = date;
2018-09-24 08:43:54 +00:00
2018-09-19 13:05:07 +00:00
this.hasValue = this._value !== null;
if (this.hasValue) this.element.classList.add('not-empty');
this.element.querySelector('.infix').classList.remove('invalid', 'validated');
}
get step() {
2018-09-24 08:43:54 +00:00
return parseInt(this.input.step);
2018-09-19 13:05:07 +00:00
}
set step(value) {
this.input.step = value;
}
}
2018-09-24 08:43:54 +00:00
InputTime.$inject = ['$element', '$scope', '$attrs', 'vnTemplate', '$transclude'];
2018-09-19 13:05:07 +00:00
ngModule.component('vnInputTime', {
template: require('./index.html'),
controller: InputTime,
transclude: {
leftIcons: '?tLeftIcons',
rightIcons: '?tRightIcons'
},
bindings: {
label: '@?',
disabled: '<?',
readonly: '<?',
step: '<?',
rule: '@?',
value: '=model',
vnTabIndex: '@?',
onChange: '&',
onClear: '&'
}
});