@hxui/angular
Version:
* * *
191 lines • 25.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,uselessCode} checked by tsc
*/
import { Component, Input, ViewChild, ElementRef } from '@angular/core';
import { DatepickerFormComponent } from './datepicker-form.component';
import * as moment_ from 'moment';
/** @type {?} */
var moment = moment_;
import { DatepickerConfig } from './datepicker.config';
import { DatepickerComponent } from './datepicker.component';
var DatepickerIntervalComponent = /** @class */ (function () {
function DatepickerIntervalComponent(_datepickerForm, datePickerConfig, _datepickerComponent) {
var _this = this;
this._datepickerForm = _datepickerForm;
this.datePickerConfig = datePickerConfig;
this._datepickerComponent = _datepickerComponent;
this.placement = 'bottom';
this.onCancel = function () {
_this._datepickerComponent.OpenDiv = false;
};
this.onSelect = function () {
if (_this.dropdownNumber && _this.Duration) {
_this.text = moment().add(_this.dropdownNumber, _this.Duration.replace('(s)', 's'));
_this._DueDate = (_this.text).format('ddd DD/MM/YYYY');
_this._dueDatestring = (_this.text).format('DD/MM/YYYY');
/** @type {?} */
var date = _this.text ? new Date(_this.text) : new Date();
_this.presentDate = new Date(date.getFullYear(), date.getMonth(), date.getDate());
_this._datepickerComponent.viewDate = new Date(date.getFullYear(), date.getMonth());
_this._datepickerComponent.renderCalendar();
_this._datepickerForm.dueDateInterval = _this.dropdownNumber + ' ' + _this.Duration;
_this._datepickerForm.onChange(_this._dueDatestring);
return _this._DueDate;
}
};
}
/**
* @return {?}
*/
DatepickerIntervalComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
/** @type {?} */
var selectedDueDateInterval = this.datePickerConfig.selectedDueDateInterval === undefined ?
(this._datepickerComponent.selectedDueDateInterval ? this._datepickerComponent.selectedDueDateInterval.split(' ') : undefined) :
this.datePickerConfig.selectedDueDateInterval.split(' ');
if (selectedDueDateInterval && selectedDueDateInterval.length > 1) {
this.dropdownNumber = selectedDueDateInterval[0];
this.Duration = this.resetDurationText(selectedDueDateInterval[1]);
if (this.datePickerConfig && this.datePickerConfig.tabSelected === 'tab1') {
this.durationText1 = this.SelectElement(this.durationText, this.Duration);
this.numberText1 = this.SelectElement(this.numberText, this.dropdownNumber);
this._DueDate = this.onSelectoptions(this.numberText1, this.durationText1);
}
else if (this.datePickerConfig && this.datePickerConfig.tabSelected === 'tab2') {
this.text = moment().add(this.dropdownNumber, this.Duration.replace('(s)', 's'));
this._DueDate = (this.text).format('ddd DD/MM/YYYY');
}
}
};
/**
* @param {?} numbervalue
* @param {?} durationValue
* @return {?}
*/
DatepickerIntervalComponent.prototype.onSelectoptions = /**
* @param {?} numbervalue
* @param {?} durationValue
* @return {?}
*/
function (numbervalue, durationValue) {
this.text = moment().add(numbervalue, durationValue.replace('(s)', 's'));
this._DueDate = (this.text).format('ddd DD/MM/YYYY');
this._dueDatestring = (this.text).format('DD/MM/YYYY');
this._datepickerForm.onChange(this._dueDatestring);
return this._DueDate;
};
/**
* @return {?}
*/
DatepickerIntervalComponent.prototype.onChoose = /**
* @return {?}
*/
function () {
this._datepickerForm.date = new Date(this.text);
this._datepickerForm.setDate(new Date(this.text));
this._datepickerComponent.OpenDiv = false;
this._datepickerForm.onChange(this._dueDatestring);
this._datepickerComponent.selectedDueDateInterval = undefined;
this._datepickerForm.dueDateInterval = this.dropdownNumber + ' ' + this.Duration;
};
/**
* @param {?} id
* @param {?} valueToSelect
* @return {?}
*/
DatepickerIntervalComponent.prototype.SelectElement = /**
* @param {?} id
* @param {?} valueToSelect
* @return {?}
*/
function (id, valueToSelect) {
(id.nativeElement).value = valueToSelect;
return ((id.nativeElement).value);
};
/**
* @param {?} duration
* @return {?}
*/
DatepickerIntervalComponent.prototype.resetDurationText = /**
* @param {?} duration
* @return {?}
*/
function (duration) {
if (duration === 'day' || duration === 'week' || duration === 'month' || duration === 'year') {
return duration + '(s)';
}
else if (duration === 'days' || duration === 'weeks' || duration === 'months' || duration === 'years') {
return duration.replace('s', '(s)');
}
else {
return duration;
}
};
DatepickerIntervalComponent.decorators = [
{ type: Component, args: [{
selector: 'hxa-datepicker-interval',
template: "<div class=\"hx-datepicker-set-interval is-flex hx-flex-justify-between hx-flex-column\">\n\n <div class=\"hx-datepicker-set-interval-content is-flex hx-flex-column hx-flex-auto hx-flex-align-center hx-flex-justify-center pa-3\">\n\n\n <div class=\"mb-5\">\n <div class=\"hx-datepicker-set-interval-number mr-5\">\n <input type=\"number\" id=\"numberText\" class=\"hx-input\" min=1 [(ngModel)]=\"dropdownNumber\" (change)=\"onSelect()\" #numberText>\n </div>\n\n <span class=\"hx-dropdown month mr-5\" hxaDropdown>\n <select id=\"durationText\" class= \"hx-input\" (change)=\"onSelect()\" [(ngModel)]=\"Duration\" #durationText>\n <option>day(s)</option>\n <option>week(s)</option>\n <option>month(s)</option>\n <option>year(s)</option>\n </select>\n </span>\n\n <span><small>from</small> <span class=\"hx-datepicker-set-interval-today ml-2\">today</span></span>\n </div>\n\n <div class=\"mb-3\">\n <span><small>will be</small></span>\n <span class=\"hx-datepicker-set-interval-selected-date ml-1\">\n {{ _DueDate }}\n </span>\n </div>\n\n </div>\n\n <div class=\"hx-datepicker-set-interval-footer pa-3\">\n <div class=\"hx-columns\">\n <div class=\"hx-column\">\n <button class=\"hx-button\" (click)=\"onCancel()\">Cancel</button>\n </div>\n <div class=\"hx-column is-text-right\">\n <button class=\"hx-button is-primary\" (click)=\"onChoose()\">Select</button>\n </div>\n </div>\n </div>\n\n</div>\n",
styles: [".hx-datepicker-set-interval{max-width:19rem;width:19rem;height:13.86rem;background-color:#fff}.hx-datepicker-set-interval .hx-datepicker-set-interval-content .hx-datepicker-set-interval-number{width:2.5rem;display:inline-block}.hx-datepicker-set-interval .hx-datepicker-set-interval-content .hx-datepicker-set-interval-today{font-size:1rem}.hx-datepicker-set-interval .hx-datepicker-set-interval-content .hx-datepicker-set-interval-selected-date{font-size:1.1rem;font-weight:500}.hx-datepicker-set-interval .hx-datepicker-set-interval-footer{flex:0 0 auto;background-color:rgba(0,0,0,.04)}"]
},] },
];
/** @nocollapse */
DatepickerIntervalComponent.ctorParameters = function () { return [
{ type: DatepickerFormComponent },
{ type: DatepickerConfig },
{ type: DatepickerComponent }
]; };
DatepickerIntervalComponent.propDecorators = {
durationText: [{ type: ViewChild, args: ['durationText',] }],
numberText: [{ type: ViewChild, args: ['numberText',] }],
selectedDateInterval: [{ type: Input }],
placement: [{ type: Input }]
};
return DatepickerIntervalComponent;
}());
export { DatepickerIntervalComponent };
if (false) {
/** @type {?} */
DatepickerIntervalComponent.prototype.durationText;
/** @type {?} */
DatepickerIntervalComponent.prototype.numberText;
/** @type {?} */
DatepickerIntervalComponent.prototype.close;
/** @type {?} */
DatepickerIntervalComponent.prototype.Duration;
/** @type {?} */
DatepickerIntervalComponent.prototype.dropdownNumber;
/** @type {?} */
DatepickerIntervalComponent.prototype.text;
/** @type {?} */
DatepickerIntervalComponent.prototype._DueDate;
/** @type {?} */
DatepickerIntervalComponent.prototype._dueDatestring;
/** @type {?} */
DatepickerIntervalComponent.prototype.durationText1;
/** @type {?} */
DatepickerIntervalComponent.prototype.numberText1;
/** @type {?} */
DatepickerIntervalComponent.prototype.selectedDuration;
/** @type {?} */
DatepickerIntervalComponent.prototype.presentDate;
/** @type {?} */
DatepickerIntervalComponent.prototype.viewDate;
/** @type {?} */
DatepickerIntervalComponent.prototype.selectedDateInterval;
/** @type {?} */
DatepickerIntervalComponent.prototype.placement;
/** @type {?} */
DatepickerIntervalComponent.prototype.onCancel;
/** @type {?} */
DatepickerIntervalComponent.prototype.onSelect;
/** @type {?} */
DatepickerIntervalComponent.prototype._datepickerForm;
/** @type {?} */
DatepickerIntervalComponent.prototype.datePickerConfig;
/** @type {?} */
DatepickerIntervalComponent.prototype._datepickerComponent;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker-interval.component.js","sourceRoot":"ng://@hxui/angular/","sources":["lib/datepicker/datepicker-interval.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, ViewChild, ElementRef} from '@angular/core';\r\nimport {DatepickerFormComponent} from './datepicker-form.component';\r\nimport * as moment_ from 'moment';\r\nconst moment = moment_;\r\nimport {DatepickerConfig} from './datepicker.config';\r\nimport {DatepickerComponent} from './datepicker.component';\r\n\r\n@Component({\r\n  selector: 'hxa-datepicker-interval',\r\n  template: `<div class=\"hx-datepicker-set-interval is-flex hx-flex-justify-between hx-flex-column\">\r\n\r\n  <div class=\"hx-datepicker-set-interval-content is-flex hx-flex-column hx-flex-auto hx-flex-align-center hx-flex-justify-center  pa-3\">\r\n\r\n\r\n      <div class=\"mb-5\">\r\n        <div class=\"hx-datepicker-set-interval-number mr-5\">\r\n          <input type=\"number\" id=\"numberText\" class=\"hx-input\" min=1  [(ngModel)]=\"dropdownNumber\" (change)=\"onSelect()\" #numberText>\r\n        </div>\r\n\r\n        <span class=\"hx-dropdown month mr-5\" hxaDropdown>\r\n          <select id=\"durationText\" class= \"hx-input\"  (change)=\"onSelect()\" [(ngModel)]=\"Duration\" #durationText>\r\n            <option>day(s)</option>\r\n            <option>week(s)</option>\r\n            <option>month(s)</option>\r\n            <option>year(s)</option>\r\n          </select>\r\n        </span>\r\n\r\n        <span><small>from</small> <span class=\"hx-datepicker-set-interval-today ml-2\">today</span></span>\r\n      </div>\r\n\r\n      <div class=\"mb-3\">\r\n        <span><small>will be</small></span>\r\n        <span class=\"hx-datepicker-set-interval-selected-date ml-1\">\r\n        {{ _DueDate }}\r\n        </span>\r\n      </div>\r\n\r\n  </div>\r\n\r\n  <div class=\"hx-datepicker-set-interval-footer pa-3\">\r\n    <div class=\"hx-columns\">\r\n      <div class=\"hx-column\">\r\n        <button class=\"hx-button\" (click)=\"onCancel()\">Cancel</button>\r\n      </div>\r\n      <div class=\"hx-column is-text-right\">\r\n        <button class=\"hx-button is-primary\" (click)=\"onChoose()\">Select</button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n</div>\r\n`,\r\n  styles: [`.hx-datepicker-set-interval{max-width:19rem;width:19rem;height:13.86rem;background-color:#fff}.hx-datepicker-set-interval .hx-datepicker-set-interval-content .hx-datepicker-set-interval-number{width:2.5rem;display:inline-block}.hx-datepicker-set-interval .hx-datepicker-set-interval-content .hx-datepicker-set-interval-today{font-size:1rem}.hx-datepicker-set-interval .hx-datepicker-set-interval-content .hx-datepicker-set-interval-selected-date{font-size:1.1rem;font-weight:500}.hx-datepicker-set-interval .hx-datepicker-set-interval-footer{flex:0 0 auto;background-color:rgba(0,0,0,.04)}`]\r\n})\r\nexport class DatepickerIntervalComponent implements OnInit {\r\n\r\n  @ViewChild('durationText') durationText: ElementRef;\r\n  @ViewChild('numberText') numberText: ElementRef;\r\n  protected close: Function;\r\n  public Duration: any ; // = 'day(s)';\r\n  public dropdownNumber: any ; // = 0;\r\n  public text: any ; // =  moment().add(this.dropdownNumber , this.Duration);\r\n  public _DueDate: string ;\r\n  public _dueDatestring: string;\r\n  public durationText1: any;\r\n  public numberText1: any;\r\n  public selectedDuration: string;\r\n  private presentDate: Date;\r\n  viewDate: Date;\r\n\r\n  @Input()\r\n  selectedDateInterval: Date;\r\n\r\n  @Input()\r\n  placement: 'top' | 'bottom' | 'left' | 'right' = 'bottom';\r\n\r\n  constructor(private _datepickerForm: DatepickerFormComponent, private datePickerConfig: DatepickerConfig,\r\n    private _datepickerComponent: DatepickerComponent) {\r\n     }\r\n\r\n  ngOnInit() {\r\n    const selectedDueDateInterval = this.datePickerConfig.selectedDueDateInterval === undefined ?\r\n     (this._datepickerComponent.selectedDueDateInterval ? this._datepickerComponent.selectedDueDateInterval.split(' ') : undefined) :\r\n      this.datePickerConfig.selectedDueDateInterval.split(' ');\r\n    if (selectedDueDateInterval && selectedDueDateInterval.length > 1) {\r\n      this.dropdownNumber = selectedDueDateInterval[0];\r\n      this.Duration = this.resetDurationText(selectedDueDateInterval[1]);\r\n      if (this.datePickerConfig && this.datePickerConfig.tabSelected === 'tab1') {\r\n        this.durationText1 = this.SelectElement(this.durationText, this.Duration);\r\n        this.numberText1 = this.SelectElement(this.numberText, this.dropdownNumber);\r\n        this._DueDate = this.onSelectoptions(this.numberText1, this.durationText1);\r\n      } else if (this.datePickerConfig && this.datePickerConfig.tabSelected === 'tab2') {\r\n        this.text = moment().add(this.dropdownNumber, this.Duration.replace('(s)', 's'));\r\n        this._DueDate = (this.text).format('ddd DD/MM/YYYY');\r\n      }\r\n    }\r\n  }\r\n\r\n  onCancel = () => {\r\n    this._datepickerComponent.OpenDiv = false;\r\n  }\r\n  onSelect = () => {\r\n    if (this.dropdownNumber && this.Duration) {\r\n      this.text = moment().add(this.dropdownNumber , this.Duration.replace('(s)', 's'));\r\n      this._DueDate = (this.text).format('ddd DD/MM/YYYY');\r\n      this._dueDatestring = (this.text).format('DD/MM/YYYY');\r\n      const date: Date = this.text ? new Date( this.text) : new Date();\r\n      this.presentDate = new Date(date.getFullYear(), date.getMonth(), date.getDate());\r\n      this._datepickerComponent.viewDate =  new Date(date.getFullYear(), date.getMonth());\r\n      this._datepickerComponent.renderCalendar();\r\n      this._datepickerForm.dueDateInterval = this.dropdownNumber + ' ' + this.Duration;\r\n      this._datepickerForm.onChange(this._dueDatestring);\r\n     return this._DueDate;\r\n     }\r\n  }\r\n  onSelectoptions(numbervalue , durationValue) {\r\n      this.text = moment().add(numbervalue , durationValue.replace('(s)', 's'));\r\n      this._DueDate = (this.text).format('ddd DD/MM/YYYY');\r\n      this._dueDatestring = (this.text).format('DD/MM/YYYY');\r\n      this._datepickerForm.onChange(this._dueDatestring);\r\n\r\n      return this._DueDate;\r\n  }\r\n  public onChoose() {\r\n    this._datepickerForm.date =  new Date(this.text);\r\n    this._datepickerForm.setDate(new Date(this.text));\r\n    this._datepickerComponent.OpenDiv = false;\r\n    this._datepickerForm.onChange(this._dueDatestring);\r\n    this._datepickerComponent.selectedDueDateInterval = undefined;\r\n    this._datepickerForm.dueDateInterval = this.dropdownNumber + ' ' + this.Duration;\r\n  }\r\n\r\n  public SelectElement(id , valueToSelect) {\r\n    (id.nativeElement).value = valueToSelect;\r\n    return ((id.nativeElement).value);\r\n  }\r\n  public resetDurationText(duration: string): string {\r\n    if (duration === 'day' || duration === 'week' || duration === 'month' || duration === 'year') {\r\n      return duration + '(s)';\r\n    } else if (duration === 'days' || duration === 'weeks' || duration === 'months' || duration === 'years') {\r\n      return duration.replace('s', '(s)');\r\n    } else {\r\n      return duration;\r\n    }\r\n  }\r\n}\r\n"]}