ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
381 lines • 24.4 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: time-holder.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @license
* Copyright Alibaba.com All Rights Reserved.
*
* Use of this source code is governed by an MIT-style license that can be
* found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE
*/
import { Subject } from 'rxjs';
import { isNil, isNotNil } from 'ng-zorro-antd/core/util';
var TimeHolder = /** @class */ (function () {
function TimeHolder() {
this.selected12Hours = undefined;
this._use12Hours = false;
this._changes = new Subject();
}
/**
* @template THIS
* @this {THIS}
* @param {?} value
* @param {?} disabled
* @return {THIS}
*/
TimeHolder.prototype.setMinutes = /**
* @template THIS
* @this {THIS}
* @param {?} value
* @param {?} disabled
* @return {THIS}
*/
function (value, disabled) {
if (value !== (/** @type {?} */ (this)).minutes && !disabled) {
(/** @type {?} */ (this)).initValue();
(/** @type {?} */ (this)).value.setMinutes(value);
(/** @type {?} */ (this)).update();
}
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @param {?} value
* @param {?} disabled
* @return {THIS}
*/
TimeHolder.prototype.setHours = /**
* @template THIS
* @this {THIS}
* @param {?} value
* @param {?} disabled
* @return {THIS}
*/
function (value, disabled) {
if (value !== (/** @type {?} */ (this)).hours && !disabled) {
(/** @type {?} */ (this)).initValue();
if ((/** @type {?} */ (this))._use12Hours) {
if ((/** @type {?} */ (this)).selected12Hours === 'PM' && value !== 12) {
(/** @type {?} */ (this)).value.setHours(((/** @type {?} */ (value))) + 12);
}
else if ((/** @type {?} */ (this)).selected12Hours === 'AM' && value === 12) {
(/** @type {?} */ (this)).value.setHours(0);
}
else {
(/** @type {?} */ (this)).value.setHours(value);
}
}
else {
(/** @type {?} */ (this)).value.setHours(value);
}
(/** @type {?} */ (this)).update();
}
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @param {?} value
* @param {?} disabled
* @return {THIS}
*/
TimeHolder.prototype.setSeconds = /**
* @template THIS
* @this {THIS}
* @param {?} value
* @param {?} disabled
* @return {THIS}
*/
function (value, disabled) {
if (value !== (/** @type {?} */ (this)).seconds && !disabled) {
(/** @type {?} */ (this)).initValue();
(/** @type {?} */ (this)).value.setSeconds(value);
(/** @type {?} */ (this)).update();
}
return (/** @type {?} */ (this));
};
/**
* @template THIS
* @this {THIS}
* @param {?} value
* @return {THIS}
*/
TimeHolder.prototype.setUse12Hours = /**
* @template THIS
* @this {THIS}
* @param {?} value
* @return {THIS}
*/
function (value) {
(/** @type {?} */ (this))._use12Hours = value;
return (/** @type {?} */ (this));
};
Object.defineProperty(TimeHolder.prototype, "changes", {
get: /**
* @return {?}
*/
function () {
return this._changes.asObservable();
},
enumerable: true,
configurable: true
});
/**
* @template THIS
* @this {THIS}
* @param {?} value
* @param {?=} use12Hours
* @return {THIS}
*/
TimeHolder.prototype.setValue = /**
* @template THIS
* @this {THIS}
* @param {?} value
* @param {?=} use12Hours
* @return {THIS}
*/
function (value, use12Hours) {
if (isNotNil(use12Hours)) {
(/** @type {?} */ (this))._use12Hours = (/** @type {?} */ (use12Hours));
}
if (value !== (/** @type {?} */ (this)).value) {
(/** @type {?} */ (this))._value = value;
if (isNotNil((/** @type {?} */ (this)).value)) {
if ((/** @type {?} */ (this))._use12Hours && isNotNil((/** @type {?} */ (this)).hours)) {
(/** @type {?} */ (this)).selected12Hours = (/** @type {?} */ (this)).hours >= 12 ? 'PM' : 'AM';
}
}
else {
(/** @type {?} */ (this))._clear();
}
}
return (/** @type {?} */ (this));
};
/**
* @return {?}
*/
TimeHolder.prototype.initValue = /**
* @return {?}
*/
function () {
if (isNil(this.value)) {
this.setValue(new Date(), this._use12Hours);
}
};
/**
* @return {?}
*/
TimeHolder.prototype.clear = /**
* @return {?}
*/
function () {
this._clear();
this.update();
};
Object.defineProperty(TimeHolder.prototype, "isEmpty", {
get: /**
* @return {?}
*/
function () {
return !(isNotNil(this.hours) || isNotNil(this.minutes) || isNotNil(this.seconds));
},
enumerable: true,
configurable: true
});
/**
* @private
* @return {?}
*/
TimeHolder.prototype._clear = /**
* @private
* @return {?}
*/
function () {
this._value = undefined;
this.selected12Hours = undefined;
};
/**
* @private
* @return {?}
*/
TimeHolder.prototype.update = /**
* @private
* @return {?}
*/
function () {
if (this.isEmpty) {
this._value = undefined;
}
else {
if (isNotNil(this.hours)) {
(/** @type {?} */ (this.value)).setHours((/** @type {?} */ (this.hours)));
}
if (isNotNil(this.minutes)) {
(/** @type {?} */ (this.value)).setMinutes((/** @type {?} */ (this.minutes)));
}
if (isNotNil(this.seconds)) {
(/** @type {?} */ (this.value)).setSeconds((/** @type {?} */ (this.seconds)));
}
if (this._use12Hours) {
if (this.selected12Hours === 'PM' && (/** @type {?} */ (this.hours)) < 12) {
(/** @type {?} */ (this.value)).setHours((/** @type {?} */ (this.hours)) + 12);
}
if (this.selected12Hours === 'AM' && (/** @type {?} */ (this.hours)) >= 12) {
(/** @type {?} */ (this.value)).setHours((/** @type {?} */ (this.hours)) - 12);
}
}
}
this.changed();
};
/**
* @return {?}
*/
TimeHolder.prototype.changed = /**
* @return {?}
*/
function () {
this._changes.next(this.value);
};
Object.defineProperty(TimeHolder.prototype, "viewHours", {
/**
* @description
* UI view hours
* Get viewHours which is selected in `time-picker-panel` and its range is [12, 1, 2, ..., 11]
*/
get: /**
* \@description
* UI view hours
* Get viewHours which is selected in `time-picker-panel` and its range is [12, 1, 2, ..., 11]
* @return {?}
*/
function () {
return this._use12Hours && isNotNil(this.hours) ? this.calculateViewHour((/** @type {?} */ (this.hours))) : this.hours;
},
enumerable: true,
configurable: true
});
/**
* @param {?} value
* @return {?}
*/
TimeHolder.prototype.setSelected12Hours = /**
* @param {?} value
* @return {?}
*/
function (value) {
if ((/** @type {?} */ (value)).toUpperCase() !== this.selected12Hours) {
this.selected12Hours = (/** @type {?} */ (value)).toUpperCase();
this.update();
}
};
Object.defineProperty(TimeHolder.prototype, "value", {
get: /**
* @return {?}
*/
function () {
return this._value || this._defaultOpenValue;
},
enumerable: true,
configurable: true
});
Object.defineProperty(TimeHolder.prototype, "hours", {
get: /**
* @return {?}
*/
function () {
var _a;
return (_a = this.value) === null || _a === void 0 ? void 0 : _a.getHours();
},
enumerable: true,
configurable: true
});
Object.defineProperty(TimeHolder.prototype, "minutes", {
get: /**
* @return {?}
*/
function () {
var _a;
return (_a = this.value) === null || _a === void 0 ? void 0 : _a.getMinutes();
},
enumerable: true,
configurable: true
});
Object.defineProperty(TimeHolder.prototype, "seconds", {
get: /**
* @return {?}
*/
function () {
var _a;
return (_a = this.value) === null || _a === void 0 ? void 0 : _a.getSeconds();
},
enumerable: true,
configurable: true
});
/**
* @template THIS
* @this {THIS}
* @param {?} value
* @return {THIS}
*/
TimeHolder.prototype.setDefaultOpenValue = /**
* @template THIS
* @this {THIS}
* @param {?} value
* @return {THIS}
*/
function (value) {
(/** @type {?} */ (this))._defaultOpenValue = value;
return (/** @type {?} */ (this));
};
/**
* @private
* @param {?} value
* @return {?}
*/
TimeHolder.prototype.calculateViewHour = /**
* @private
* @param {?} value
* @return {?}
*/
function (value) {
/** @type {?} */
var selected12Hours = this.selected12Hours;
if (selected12Hours === 'PM' && value > 12) {
return value - 12;
}
if (selected12Hours === 'AM' && value === 0) {
return 12;
}
return value;
};
return TimeHolder;
}());
export { TimeHolder };
if (false) {
/** @type {?} */
TimeHolder.prototype.selected12Hours;
/**
* @type {?}
* @private
*/
TimeHolder.prototype._value;
/**
* @type {?}
* @private
*/
TimeHolder.prototype._use12Hours;
/**
* @type {?}
* @private
*/
TimeHolder.prototype._defaultOpenValue;
/**
* @type {?}
* @private
*/
TimeHolder.prototype._changes;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-holder.js","sourceRoot":"ng://ng-zorro-antd/time-picker/","sources":["time-holder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport { Observable, Subject } from 'rxjs';\n\nimport { isNil, isNotNil } from 'ng-zorro-antd/core/util';\n\nexport class TimeHolder {\n  selected12Hours: string | undefined = undefined;\n  private _value: Date | undefined;\n  private _use12Hours: boolean = false;\n  private _defaultOpenValue: Date;\n  private _changes = new Subject<Date>();\n\n  setMinutes(value: number, disabled: boolean): this {\n    if (value !== this.minutes && !disabled) {\n      this.initValue();\n      this.value.setMinutes(value);\n      this.update();\n    }\n    return this;\n  }\n\n  setHours(value: number, disabled: boolean): this {\n    if (value !== this.hours && !disabled) {\n      this.initValue();\n      if (this._use12Hours) {\n        if (this.selected12Hours === 'PM' && value !== 12) {\n          this.value.setHours((value as number) + 12);\n        } else if (this.selected12Hours === 'AM' && value === 12) {\n          this.value.setHours(0);\n        } else {\n          this.value.setHours(value);\n        }\n      } else {\n        this.value.setHours(value);\n      }\n      this.update();\n    }\n    return this;\n  }\n\n  setSeconds(value: number, disabled: boolean): this {\n    if (value !== this.seconds && !disabled) {\n      this.initValue();\n      this.value.setSeconds(value);\n      this.update();\n    }\n    return this;\n  }\n\n  setUse12Hours(value: boolean): this {\n    this._use12Hours = value;\n    return this;\n  }\n\n  get changes(): Observable<Date> {\n    return this._changes.asObservable();\n  }\n\n  setValue(value: Date | undefined, use12Hours?: boolean): this {\n    if (isNotNil(use12Hours)) {\n      this._use12Hours = use12Hours as boolean;\n    }\n    if (value !== this.value) {\n      this._value = value;\n      if (isNotNil(this.value)) {\n        if (this._use12Hours && isNotNil(this.hours)) {\n          this.selected12Hours = this.hours >= 12 ? 'PM' : 'AM';\n        }\n      } else {\n        this._clear();\n      }\n    }\n\n    return this;\n  }\n\n  initValue(): void {\n    if (isNil(this.value)) {\n      this.setValue(new Date(), this._use12Hours);\n    }\n  }\n\n  clear(): void {\n    this._clear();\n    this.update();\n  }\n\n  get isEmpty(): boolean {\n    return !(isNotNil(this.hours) || isNotNil(this.minutes) || isNotNil(this.seconds));\n  }\n\n  private _clear(): void {\n    this._value = undefined;\n    this.selected12Hours = undefined;\n  }\n\n  private update(): void {\n    if (this.isEmpty) {\n      this._value = undefined;\n    } else {\n      if (isNotNil(this.hours)) {\n        this.value!.setHours(this.hours!);\n      }\n\n      if (isNotNil(this.minutes)) {\n        this.value!.setMinutes(this.minutes!);\n      }\n\n      if (isNotNil(this.seconds)) {\n        this.value!.setSeconds(this.seconds!);\n      }\n\n      if (this._use12Hours) {\n        if (this.selected12Hours === 'PM' && this.hours! < 12) {\n          this.value!.setHours(this.hours! + 12);\n        }\n        if (this.selected12Hours === 'AM' && this.hours! >= 12) {\n          this.value!.setHours(this.hours! - 12);\n        }\n      }\n    }\n    this.changed();\n  }\n\n  changed(): void {\n    this._changes.next(this.value);\n  }\n\n  /**\n   * @description\n   * UI view hours\n   * Get viewHours which is selected in `time-picker-panel` and its range is [12, 1, 2, ..., 11]\n   */\n  get viewHours(): number | undefined {\n    return this._use12Hours && isNotNil(this.hours) ? this.calculateViewHour(this.hours!) : this.hours;\n  }\n\n  setSelected12Hours(value: string | undefined): void {\n    if (value!.toUpperCase() !== this.selected12Hours) {\n      this.selected12Hours = value!.toUpperCase();\n      this.update();\n    }\n  }\n\n  get value(): Date {\n    return this._value || this._defaultOpenValue;\n  }\n\n  get hours(): number | undefined {\n    return this.value?.getHours();\n  }\n\n  get minutes(): number | undefined {\n    return this.value?.getMinutes();\n  }\n\n  get seconds(): number | undefined {\n    return this.value?.getSeconds();\n  }\n\n  setDefaultOpenValue(value: Date): this {\n    this._defaultOpenValue = value;\n    return this;\n  }\n\n  constructor() {}\n\n  private calculateViewHour(value: number): number {\n    const selected12Hours = this.selected12Hours;\n    if (selected12Hours === 'PM' && value > 12) {\n      return value - 12;\n    }\n    if (selected12Hours === 'AM' && value === 0) {\n      return 12;\n    }\n    return value;\n  }\n}\n"]}