datepicker.component.js 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. /**
  2. * @fileoverview added by tsickle
  3. * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
  4. */
  5. import { Component, EventEmitter, forwardRef, Input, Output, ViewChild } from '@angular/core';
  6. import { NG_VALUE_ACCESSOR } from '@angular/forms';
  7. import { DatePickerInnerComponent } from './datepicker-inner.component';
  8. import { DatepickerConfig } from './datepicker.config';
  9. /** @type {?} */
  10. export var DATEPICKER_CONTROL_VALUE_ACCESSOR = {
  11. provide: NG_VALUE_ACCESSOR,
  12. /* tslint:disable-next-line: no-use-before-declare */
  13. useExisting: forwardRef((/**
  14. * @return {?}
  15. */
  16. function () { return DatePickerComponent; })),
  17. multi: true
  18. };
  19. /* tslint:disable:component-selector-name component-selector-type */
  20. var DatePickerComponent = /** @class */ (function () {
  21. function DatePickerComponent(config) {
  22. /**
  23. * sets datepicker mode, supports: `day`, `month`, `year`
  24. */
  25. this.datepickerMode = 'day';
  26. /**
  27. * if false week numbers will be hidden
  28. */
  29. this.showWeeks = true;
  30. this.selectionDone = new EventEmitter(undefined);
  31. /**
  32. * callback to invoke when the activeDate is changed.
  33. */
  34. this.activeDateChange = new EventEmitter(undefined);
  35. /* tslint:disable-next-line: no-any*/
  36. this.onChange = Function.prototype;
  37. /* tslint:disable-next-line: no-any*/
  38. this.onTouched = Function.prototype;
  39. this._now = new Date();
  40. this.config = config;
  41. this.configureOptions();
  42. }
  43. Object.defineProperty(DatePickerComponent.prototype, "activeDate", {
  44. /** currently active date */
  45. get: /**
  46. * currently active date
  47. * @return {?}
  48. */
  49. function () {
  50. return this._activeDate || this._now;
  51. },
  52. set: /**
  53. * @param {?} value
  54. * @return {?}
  55. */
  56. function (value) {
  57. this._activeDate = value;
  58. },
  59. enumerable: true,
  60. configurable: true
  61. });
  62. /**
  63. * @return {?}
  64. */
  65. DatePickerComponent.prototype.configureOptions = /**
  66. * @return {?}
  67. */
  68. function () {
  69. Object.assign(this, this.config);
  70. };
  71. /**
  72. * @param {?} event
  73. * @return {?}
  74. */
  75. DatePickerComponent.prototype.onUpdate = /**
  76. * @param {?} event
  77. * @return {?}
  78. */
  79. function (event) {
  80. this.activeDate = event;
  81. this.onChange(event);
  82. };
  83. /**
  84. * @param {?} event
  85. * @return {?}
  86. */
  87. DatePickerComponent.prototype.onSelectionDone = /**
  88. * @param {?} event
  89. * @return {?}
  90. */
  91. function (event) {
  92. this.selectionDone.emit(event);
  93. };
  94. /**
  95. * @param {?} event
  96. * @return {?}
  97. */
  98. DatePickerComponent.prototype.onActiveDateChange = /**
  99. * @param {?} event
  100. * @return {?}
  101. */
  102. function (event) {
  103. this.activeDateChange.emit(event);
  104. };
  105. // todo: support null value
  106. /* tslint:disable-next-line: no-any*/
  107. // todo: support null value
  108. /* tslint:disable-next-line: no-any*/
  109. /**
  110. * @param {?} value
  111. * @return {?}
  112. */
  113. DatePickerComponent.prototype.writeValue =
  114. // todo: support null value
  115. /* tslint:disable-next-line: no-any*/
  116. /**
  117. * @param {?} value
  118. * @return {?}
  119. */
  120. function (value) {
  121. if (this._datePicker.compare(value, this._activeDate) === 0) {
  122. return;
  123. }
  124. if (value && value instanceof Date) {
  125. this.activeDate = value;
  126. this._datePicker.select(value, false);
  127. return;
  128. }
  129. this.activeDate = value ? new Date(value) : void 0;
  130. };
  131. /**
  132. * @param {?} fn
  133. * @return {?}
  134. */
  135. DatePickerComponent.prototype.registerOnChange = /**
  136. * @param {?} fn
  137. * @return {?}
  138. */
  139. function (fn) {
  140. this.onChange = fn;
  141. };
  142. /**
  143. * @param {?} fn
  144. * @return {?}
  145. */
  146. DatePickerComponent.prototype.registerOnTouched = /**
  147. * @param {?} fn
  148. * @return {?}
  149. */
  150. function (fn) {
  151. this.onTouched = fn;
  152. };
  153. DatePickerComponent.decorators = [
  154. { type: Component, args: [{
  155. selector: 'datepicker',
  156. template: "\n <datepicker-inner [activeDate]=\"activeDate\"\n (update)=\"onUpdate($event)\"\n [locale]=\"config.locale\"\n [datepickerMode]=\"datepickerMode\"\n [initDate]=\"initDate\"\n [minDate]=\"minDate\"\n [maxDate]=\"maxDate\"\n [minMode]=\"minMode\"\n [maxMode]=\"maxMode\"\n [showWeeks]=\"showWeeks\"\n [formatDay]=\"formatDay\"\n [formatMonth]=\"formatMonth\"\n [formatYear]=\"formatYear\"\n [formatDayHeader]=\"formatDayHeader\"\n [formatDayTitle]=\"formatDayTitle\"\n [formatMonthTitle]=\"formatMonthTitle\"\n [startingDay]=\"startingDay\"\n [yearRange]=\"yearRange\"\n [customClass]=\"customClass\"\n [dateDisabled]=\"dateDisabled\"\n [dayDisabled]=\"dayDisabled\"\n [onlyCurrentMonth]=\"onlyCurrentMonth\"\n [shortcutPropagation]=\"shortcutPropagation\"\n [monthColLimit]=\"monthColLimit\"\n [yearColLimit]=\"yearColLimit\"\n (selectionDone)=\"onSelectionDone($event)\"\n (activeDateChange)=\"onActiveDateChange($event)\">\n <daypicker tabindex=\"0\"></daypicker>\n <monthpicker tabindex=\"0\"></monthpicker>\n <yearpicker tabindex=\"0\"></yearpicker>\n </datepicker-inner>\n ",
  157. providers: [DATEPICKER_CONTROL_VALUE_ACCESSOR]
  158. }] }
  159. ];
  160. /** @nocollapse */
  161. DatePickerComponent.ctorParameters = function () { return [
  162. { type: DatepickerConfig }
  163. ]; };
  164. DatePickerComponent.propDecorators = {
  165. datepickerMode: [{ type: Input }],
  166. initDate: [{ type: Input }],
  167. minDate: [{ type: Input }],
  168. maxDate: [{ type: Input }],
  169. minMode: [{ type: Input }],
  170. maxMode: [{ type: Input }],
  171. showWeeks: [{ type: Input }],
  172. formatDay: [{ type: Input }],
  173. formatMonth: [{ type: Input }],
  174. formatYear: [{ type: Input }],
  175. formatDayHeader: [{ type: Input }],
  176. formatDayTitle: [{ type: Input }],
  177. formatMonthTitle: [{ type: Input }],
  178. startingDay: [{ type: Input }],
  179. yearRange: [{ type: Input }],
  180. onlyCurrentMonth: [{ type: Input }],
  181. shortcutPropagation: [{ type: Input }],
  182. monthColLimit: [{ type: Input }],
  183. yearColLimit: [{ type: Input }],
  184. customClass: [{ type: Input }],
  185. dateDisabled: [{ type: Input }],
  186. dayDisabled: [{ type: Input }],
  187. activeDate: [{ type: Input }],
  188. selectionDone: [{ type: Output }],
  189. activeDateChange: [{ type: Output }],
  190. _datePicker: [{ type: ViewChild, args: [DatePickerInnerComponent, { static: true },] }]
  191. };
  192. return DatePickerComponent;
  193. }());
  194. export { DatePickerComponent };
  195. if (false) {
  196. /**
  197. * sets datepicker mode, supports: `day`, `month`, `year`
  198. * @type {?}
  199. */
  200. DatePickerComponent.prototype.datepickerMode;
  201. /**
  202. * default date to show if `ng-model` value is not specified
  203. * @type {?}
  204. */
  205. DatePickerComponent.prototype.initDate;
  206. /**
  207. * oldest selectable date
  208. * @type {?}
  209. */
  210. DatePickerComponent.prototype.minDate;
  211. /**
  212. * latest selectable date
  213. * @type {?}
  214. */
  215. DatePickerComponent.prototype.maxDate;
  216. /**
  217. * set lower datepicker mode, supports: `day`, `month`, `year`
  218. * @type {?}
  219. */
  220. DatePickerComponent.prototype.minMode;
  221. /**
  222. * sets upper datepicker mode, supports: `day`, `month`, `year`
  223. * @type {?}
  224. */
  225. DatePickerComponent.prototype.maxMode;
  226. /**
  227. * if false week numbers will be hidden
  228. * @type {?}
  229. */
  230. DatePickerComponent.prototype.showWeeks;
  231. /**
  232. * format of day in month
  233. * @type {?}
  234. */
  235. DatePickerComponent.prototype.formatDay;
  236. /**
  237. * format of month in year
  238. * @type {?}
  239. */
  240. DatePickerComponent.prototype.formatMonth;
  241. /**
  242. * format of year in year range
  243. * @type {?}
  244. */
  245. DatePickerComponent.prototype.formatYear;
  246. /**
  247. * format of day in week header
  248. * @type {?}
  249. */
  250. DatePickerComponent.prototype.formatDayHeader;
  251. /**
  252. * format of title when selecting day
  253. * @type {?}
  254. */
  255. DatePickerComponent.prototype.formatDayTitle;
  256. /**
  257. * format of title when selecting month
  258. * @type {?}
  259. */
  260. DatePickerComponent.prototype.formatMonthTitle;
  261. /**
  262. * starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday)
  263. * @type {?}
  264. */
  265. DatePickerComponent.prototype.startingDay;
  266. /**
  267. * number of years displayed in year selection
  268. * @type {?}
  269. */
  270. DatePickerComponent.prototype.yearRange;
  271. /**
  272. * if true only dates from the currently displayed month will be shown
  273. * @type {?}
  274. */
  275. DatePickerComponent.prototype.onlyCurrentMonth;
  276. /**
  277. * if true shortcut`s event propagation will be disabled
  278. * @type {?}
  279. */
  280. DatePickerComponent.prototype.shortcutPropagation;
  281. /**
  282. * number of months displayed in a single row of month picker
  283. * @type {?}
  284. */
  285. DatePickerComponent.prototype.monthColLimit;
  286. /**
  287. * number of years displayed in a single row of year picker
  288. * @type {?}
  289. */
  290. DatePickerComponent.prototype.yearColLimit;
  291. /**
  292. * array of custom css classes to be applied to targeted dates
  293. * @type {?}
  294. */
  295. DatePickerComponent.prototype.customClass;
  296. /**
  297. * array of disabled dates
  298. * @type {?}
  299. */
  300. DatePickerComponent.prototype.dateDisabled;
  301. /**
  302. * disabled days of the week from 0-6 (0=Sunday, ..., 6=Saturday)
  303. * @type {?}
  304. */
  305. DatePickerComponent.prototype.dayDisabled;
  306. /** @type {?} */
  307. DatePickerComponent.prototype.selectionDone;
  308. /**
  309. * callback to invoke when the activeDate is changed.
  310. * @type {?}
  311. */
  312. DatePickerComponent.prototype.activeDateChange;
  313. /** @type {?} */
  314. DatePickerComponent.prototype._datePicker;
  315. /** @type {?} */
  316. DatePickerComponent.prototype.onChange;
  317. /** @type {?} */
  318. DatePickerComponent.prototype.onTouched;
  319. /** @type {?} */
  320. DatePickerComponent.prototype.config;
  321. /**
  322. * @type {?}
  323. * @protected
  324. */
  325. DatePickerComponent.prototype._now;
  326. /**
  327. * @type {?}
  328. * @protected
  329. */
  330. DatePickerComponent.prototype._activeDate;
  331. }
  332. //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"ng://ngx-bootstrap/datepicker/","sources":["datepicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  forwardRef,\n  Input,\n  Output,\n  Provider,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DatePickerInnerComponent } from './datepicker-inner.component';\nimport { DatepickerConfig } from './datepicker.config';\n\nexport const DATEPICKER_CONTROL_VALUE_ACCESSOR: Provider = {\n  provide: NG_VALUE_ACCESSOR,\n  /* tslint:disable-next-line: no-use-before-declare */\n  useExisting: forwardRef(() => DatePickerComponent),\n  multi: true\n};\n\n/* tslint:disable:component-selector-name component-selector-type */\n@Component({\n  selector: 'datepicker',\n  template: `\n    <datepicker-inner [activeDate]=\"activeDate\"\n                      (update)=\"onUpdate($event)\"\n                      [locale]=\"config.locale\"\n                      [datepickerMode]=\"datepickerMode\"\n                      [initDate]=\"initDate\"\n                      [minDate]=\"minDate\"\n                      [maxDate]=\"maxDate\"\n                      [minMode]=\"minMode\"\n                      [maxMode]=\"maxMode\"\n                      [showWeeks]=\"showWeeks\"\n                      [formatDay]=\"formatDay\"\n                      [formatMonth]=\"formatMonth\"\n                      [formatYear]=\"formatYear\"\n                      [formatDayHeader]=\"formatDayHeader\"\n                      [formatDayTitle]=\"formatDayTitle\"\n                      [formatMonthTitle]=\"formatMonthTitle\"\n                      [startingDay]=\"startingDay\"\n                      [yearRange]=\"yearRange\"\n                      [customClass]=\"customClass\"\n                      [dateDisabled]=\"dateDisabled\"\n                      [dayDisabled]=\"dayDisabled\"\n                      [onlyCurrentMonth]=\"onlyCurrentMonth\"\n                      [shortcutPropagation]=\"shortcutPropagation\"\n                      [monthColLimit]=\"monthColLimit\"\n                      [yearColLimit]=\"yearColLimit\"\n                      (selectionDone)=\"onSelectionDone($event)\"\n                      (activeDateChange)=\"onActiveDateChange($event)\">\n      <daypicker tabindex=\"0\"></daypicker>\n      <monthpicker tabindex=\"0\"></monthpicker>\n      <yearpicker tabindex=\"0\"></yearpicker>\n    </datepicker-inner>\n    `,\n  providers: [DATEPICKER_CONTROL_VALUE_ACCESSOR]\n})\n/* tslint:enable:component-selector-name component-selector-type */\nexport class DatePickerComponent implements ControlValueAccessor {\n  /** sets datepicker mode, supports: `day`, `month`, `year` */\n  @Input() datepickerMode = 'day';\n  /** default date to show if `ng-model` value is not specified */\n  @Input() initDate: Date;\n  /**  oldest selectable date */\n  @Input() minDate: Date;\n  /** latest selectable date */\n  @Input() maxDate: Date;\n  /** set lower datepicker mode, supports: `day`, `month`, `year` */\n  @Input() minMode: string;\n  /** sets upper datepicker mode, supports: `day`, `month`, `year` */\n  @Input() maxMode: string;\n  /** if false week numbers will be hidden */\n  @Input() showWeeks = true;\n  /** format of day in month */\n  @Input() formatDay: string;\n  /** format of month in year */\n  @Input() formatMonth: string;\n  /** format of year in year range */\n  @Input() formatYear: string;\n  /** format of day in week header */\n  @Input() formatDayHeader: string;\n  /** format of title when selecting day */\n  @Input() formatDayTitle: string;\n  /** format of title when selecting month */\n  @Input() formatMonthTitle: string;\n  /** starting day of the week from 0-6 (0=Sunday, ..., 6=Saturday) */\n  @Input() startingDay: number;\n  /** number of years displayed in year selection */\n  @Input() yearRange: number;\n  /** if true only dates from the currently displayed month will be shown */\n  @Input() onlyCurrentMonth: boolean;\n  /** if true shortcut`s event propagation will be disabled */\n  @Input() shortcutPropagation: boolean;\n  /** number of months displayed in a single row of month picker */\n  @Input() monthColLimit: number;\n  /** number of years displayed in a single row of year picker */\n  @Input() yearColLimit: number;\n  /** array of custom css classes to be applied to targeted dates */\n  @Input() customClass: { date: Date; mode: string; clazz: string }[];\n  /** array of disabled dates */\n  @Input() dateDisabled: { date: Date; mode: string }[];\n  /** disabled days of the week from 0-6 (0=Sunday, ..., 6=Saturday) */\n  @Input() dayDisabled: number[];\n\n  /** currently active date */\n  @Input()\n  get activeDate(): Date {\n    return this._activeDate || this._now;\n  }\n\n  set activeDate(value: Date) {\n    this._activeDate = value;\n  }\n\n  @Output()\n  selectionDone: EventEmitter<Date> = new EventEmitter<Date>(undefined);\n\n  /** callback to invoke when the activeDate is changed. */\n  @Output()\n  activeDateChange: EventEmitter<Date> = new EventEmitter<Date>(\n    undefined\n  );\n\n  @ViewChild(DatePickerInnerComponent, { static: true })\n  _datePicker: DatePickerInnerComponent;\n\n  /* tslint:disable-next-line: no-any*/\n  onChange: any = Function.prototype;\n  /* tslint:disable-next-line: no-any*/\n  onTouched: any = Function.prototype;\n\n  config: DatepickerConfig;\n\n  protected _now: Date = new Date();\n  protected _activeDate: Date;\n\n  constructor(config: DatepickerConfig) {\n    this.config = config;\n    this.configureOptions();\n  }\n\n  configureOptions(): void {\n    Object.assign(this, this.config);\n  }\n\n  onUpdate(event: Date): void {\n    this.activeDate = event;\n    this.onChange(event);\n  }\n\n  onSelectionDone(event: Date): void {\n    this.selectionDone.emit(event);\n  }\n\n  onActiveDateChange(event: Date): void {\n    this.activeDateChange.emit(event);\n  }\n  // todo: support null value\n  /* tslint:disable-next-line: no-any*/\n  writeValue(value: any): void {\n    if (this._datePicker.compare(value, this._activeDate) === 0) {\n      return;\n    }\n    if (value && value instanceof Date) {\n      this.activeDate = value;\n      this._datePicker.select(value, false);\n\n      return;\n    }\n\n    this.activeDate = value ? new Date(value) : void 0;\n  }\n\n  registerOnChange(fn: () => void): void {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n}\n"]}