| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239 |
- /**
- * @fileoverview added by tsickle
- * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
- */
- // @deprecated
- // tslint:disable
- import { Component } from '@angular/core';
- import { isBs3 } from 'ngx-bootstrap/utils';
- import { DatePickerInnerComponent } from './datepicker-inner.component';
- export class DayPickerComponent {
- /**
- * @param {?} datePicker
- */
- constructor(datePicker) {
- this.labels = [];
- this.rows = [];
- this.weekNumbers = [];
- this.datePicker = datePicker;
- }
- /**
- * @return {?}
- */
- get isBs4() {
- return !isBs3();
- }
- /*protected getDaysInMonth(year:number, month:number) {
- return ((month === 1) && (year % 4 === 0) &&
- ((year % 100 !== 0) || (year % 400 === 0))) ? 29 : DAYS_IN_MONTH[month];
- }*/
- /**
- * @return {?}
- */
- ngOnInit() {
- /** @type {?} */
- const self = this;
- this.datePicker.stepDay = { months: 1 };
- this.datePicker.setRefreshViewHandler((/**
- * @return {?}
- */
- function () {
- /** @type {?} */
- const year = this.activeDate.getFullYear();
- /** @type {?} */
- const month = this.activeDate.getMonth();
- /** @type {?} */
- const firstDayOfMonth = new Date(year, month, 1);
- /** @type {?} */
- const difference = this.startingDay - firstDayOfMonth.getDay();
- /** @type {?} */
- const numDisplayedFromPreviousMonth = difference > 0 ? 7 - difference : -difference;
- /** @type {?} */
- const firstDate = new Date(firstDayOfMonth.getTime());
- if (numDisplayedFromPreviousMonth > 0) {
- firstDate.setDate(-numDisplayedFromPreviousMonth + 1);
- }
- // 42 is the number of days on a six-week calendar
- /** @type {?} */
- const _days = self.getDates(firstDate, 42);
- /** @type {?} */
- const days = [];
- for (let i = 0; i < 42; i++) {
- /** @type {?} */
- const _dateObject = this.createDateObject(_days[i], this.formatDay);
- _dateObject.secondary = _days[i].getMonth() !== month;
- _dateObject.uid = this.uniqueId + '-' + i;
- days[i] = _dateObject;
- }
- self.labels = [];
- for (let j = 0; j < 7; j++) {
- self.labels[j] = {};
- self.labels[j].abbr = this.dateFilter(days[j].date, this.formatDayHeader);
- self.labels[j].full = this.dateFilter(days[j].date, 'EEEE');
- }
- self.title = this.dateFilter(this.activeDate, this.formatDayTitle);
- self.rows = this.split(days, 7);
- if (this.showWeeks) {
- self.weekNumbers = [];
- /** @type {?} */
- const thursdayIndex = (4 + 7 - this.startingDay) % 7;
- /** @type {?} */
- const numWeeks = self.rows.length;
- for (let curWeek = 0; curWeek < numWeeks; curWeek++) {
- self.weekNumbers.push(self.getISO8601WeekNumber(self.rows[curWeek][thursdayIndex].date));
- }
- }
- }), 'day');
- this.datePicker.setCompareHandler((/**
- * @param {?} date1
- * @param {?} date2
- * @return {?}
- */
- function (date1, date2) {
- /** @type {?} */
- const d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());
- /** @type {?} */
- const d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());
- return d1.getTime() - d2.getTime();
- }), 'day');
- this.datePicker.refreshView();
- }
- /**
- * @protected
- * @param {?} startDate
- * @param {?} n
- * @return {?}
- */
- getDates(startDate, n) {
- /** @type {?} */
- const dates = new Array(n);
- /** @type {?} */
- let current = new Date(startDate.getTime());
- /** @type {?} */
- let i = 0;
- /** @type {?} */
- let date;
- while (i < n) {
- date = new Date(current.getTime());
- date = this.datePicker.fixTimeZone(date);
- dates[i++] = date;
- current = new Date(date.getFullYear(), date.getMonth(), date.getDate() + 1);
- }
- return dates;
- }
- /**
- * @protected
- * @param {?} date
- * @return {?}
- */
- getISO8601WeekNumber(date) {
- /** @type {?} */
- const checkDate = new Date(date.getTime());
- // Thursday
- checkDate.setDate(checkDate.getDate() + 4 - (checkDate.getDay() || 7));
- /** @type {?} */
- const time = checkDate.getTime();
- // Compare with Jan 1
- checkDate.setMonth(0);
- checkDate.setDate(1);
- return (Math.floor(Math.round((time - checkDate.getTime()) / 86400000) / 7) + 1);
- }
- }
- DayPickerComponent.decorators = [
- { type: Component, args: [{
- selector: 'daypicker',
- template: `
- <table *ngIf="datePicker.datepickerMode === 'day'" role="grid" [attr.aria-labelledby]="datePicker.uniqueId + '-title'" aria-activedescendant="activeDateId">
- <thead>
- <tr>
- <th>
- <button *ngIf="!isBs4"
- type="button"
- class="btn btn-default btn-secondary btn-sm pull-left float-left"
- (click)="datePicker.move(-1)"
- tabindex="-1">‹</button>
- <button *ngIf="isBs4"
- type="button"
- class="btn btn-default btn-secondary btn-sm pull-left float-left"
- (click)="datePicker.move(-1)"
- tabindex="-1"><</button>
- </th>
- <th [attr.colspan]="5 + (datePicker.showWeeks ? 1 : 0)">
- <button [id]="datePicker.uniqueId + '-title'"
- type="button" class="btn btn-default btn-secondary btn-sm"
- (click)="datePicker.toggleMode(0)"
- [disabled]="datePicker.datepickerMode === datePicker.maxMode"
- [ngClass]="{disabled: datePicker.datepickerMode === datePicker.maxMode}" tabindex="-1" style="width:100%;">
- <strong>{{ title }}</strong>
- </button>
- </th>
- <th>
- <button *ngIf="!isBs4"
- type="button"
- class="btn btn-default btn-secondary btn-sm pull-right float-right"
- (click)="datePicker.move(1)"
- tabindex="-1">›</button>
- <button *ngIf="isBs4"
- type="button"
- class="btn btn-default btn-secondary btn-sm pull-right float-right"
- (click)="datePicker.move(1)"
- tabindex="-1">>
- </button>
- </th>
- </tr>
- <tr>
- <th *ngIf="datePicker.showWeeks"></th>
- <th *ngFor="let labelz of labels" class="text-center">
- <small aria-label="labelz.full"><b>{{ labelz.abbr }}</b></small>
- </th>
- </tr>
- </thead>
- <tbody>
- <ng-template ngFor [ngForOf]="rows" let-rowz="$implicit" let-index="index">
- <tr *ngIf="!(datePicker.onlyCurrentMonth && rowz[0].secondary && rowz[6].secondary)">
- <td *ngIf="datePicker.showWeeks" class="h6" class="text-center">
- <em>{{ weekNumbers[index] }}</em>
- </td>
- <td *ngFor="let dtz of rowz" class="text-center" role="gridcell" [id]="dtz.uid">
- <button type="button" style="min-width:100%;" class="btn btn-sm {{dtz.customClass}}"
- *ngIf="!(datePicker.onlyCurrentMonth && dtz.secondary)"
- [ngClass]="{'btn-secondary': isBs4 && !dtz.selected && !datePicker.isActive(dtz), 'btn-info': dtz.selected, disabled: dtz.disabled, active: !isBs4 && datePicker.isActive(dtz), 'btn-default': !isBs4}"
- [disabled]="dtz.disabled"
- (click)="datePicker.select(dtz.date)" tabindex="-1">
- <span [ngClass]="{'text-muted': dtz.secondary || dtz.current, 'text-info': !isBs4 && dtz.current}">{{ dtz.label }}</span>
- </button>
- </td>
- </tr>
- </ng-template>
- </tbody>
- </table>
- `,
- styles: [`
- :host .btn-secondary {
- color: #292b2c;
- background-color: #fff;
- border-color: #ccc;
- }
- :host .btn-info .text-muted {
- color: #292b2c !important;
- }
- `]
- }] }
- ];
- /** @nocollapse */
- DayPickerComponent.ctorParameters = () => [
- { type: DatePickerInnerComponent }
- ];
- if (false) {
- /** @type {?} */
- DayPickerComponent.prototype.labels;
- /** @type {?} */
- DayPickerComponent.prototype.title;
- /** @type {?} */
- DayPickerComponent.prototype.rows;
- /** @type {?} */
- DayPickerComponent.prototype.weekNumbers;
- /** @type {?} */
- DayPickerComponent.prototype.datePicker;
- }
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"daypicker.component.js","sourceRoot":"ng://ngx-bootstrap/datepicker/","sources":["daypicker.component.ts"],"names":[],"mappings":"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","sourcesContent":["// @deprecated\n// tslint:disable\nimport { Component, OnInit } from '@angular/core';\nimport { isBs3 } from 'ngx-bootstrap/utils';\nimport { DatePickerInnerComponent } from './datepicker-inner.component';\n\n@Component({\n  selector: 'daypicker',\n  template: `\n<table *ngIf=\"datePicker.datepickerMode === 'day'\" role=\"grid\" [attr.aria-labelledby]=\"datePicker.uniqueId + '-title'\" aria-activedescendant=\"activeDateId\">\n  <thead>\n    <tr>\n      <th>\n        <button *ngIf=\"!isBs4\"\n                type=\"button\"\n                class=\"btn btn-default btn-secondary btn-sm pull-left float-left\"\n                (click)=\"datePicker.move(-1)\"\n                tabindex=\"-1\">‹</button>\n        <button *ngIf=\"isBs4\"\n                type=\"button\"\n                class=\"btn btn-default btn-secondary btn-sm pull-left float-left\"\n                (click)=\"datePicker.move(-1)\"\n                tabindex=\"-1\">&lt;</button>\n      </th>\n      <th [attr.colspan]=\"5 + (datePicker.showWeeks ? 1 : 0)\">\n        <button [id]=\"datePicker.uniqueId + '-title'\"\n                type=\"button\" class=\"btn btn-default btn-secondary btn-sm\"\n                (click)=\"datePicker.toggleMode(0)\"\n                [disabled]=\"datePicker.datepickerMode === datePicker.maxMode\"\n                [ngClass]=\"{disabled: datePicker.datepickerMode === datePicker.maxMode}\" tabindex=\"-1\" style=\"width:100%;\">\n          <strong>{{ title }}</strong>\n        </button>\n      </th>\n      <th>\n        <button *ngIf=\"!isBs4\"\n                type=\"button\"\n                class=\"btn btn-default btn-secondary btn-sm pull-right float-right\"\n                (click)=\"datePicker.move(1)\"\n                tabindex=\"-1\">›</button>\n        <button *ngIf=\"isBs4\"\n                type=\"button\"\n                class=\"btn btn-default btn-secondary btn-sm pull-right float-right\"\n                (click)=\"datePicker.move(1)\"\n                tabindex=\"-1\">&gt;\n        </button>\n      </th>\n    </tr>\n    <tr>\n      <th *ngIf=\"datePicker.showWeeks\"></th>\n      <th *ngFor=\"let labelz of labels\" class=\"text-center\">\n        <small aria-label=\"labelz.full\"><b>{{ labelz.abbr }}</b></small>\n      </th>\n    </tr>\n  </thead>\n  <tbody>\n    <ng-template ngFor [ngForOf]=\"rows\" let-rowz=\"$implicit\" let-index=\"index\">\n      <tr *ngIf=\"!(datePicker.onlyCurrentMonth && rowz[0].secondary && rowz[6].secondary)\">\n        <td *ngIf=\"datePicker.showWeeks\" class=\"h6\" class=\"text-center\">\n          <em>{{ weekNumbers[index] }}</em>\n        </td>\n        <td *ngFor=\"let dtz of rowz\" class=\"text-center\" role=\"gridcell\" [id]=\"dtz.uid\">\n          <button type=\"button\" style=\"min-width:100%;\" class=\"btn btn-sm {{dtz.customClass}}\"\n                  *ngIf=\"!(datePicker.onlyCurrentMonth && dtz.secondary)\"\n                  [ngClass]=\"{'btn-secondary': isBs4 && !dtz.selected && !datePicker.isActive(dtz), 'btn-info': dtz.selected, disabled: dtz.disabled, active: !isBs4 && datePicker.isActive(dtz), 'btn-default': !isBs4}\"\n                  [disabled]=\"dtz.disabled\"\n                  (click)=\"datePicker.select(dtz.date)\" tabindex=\"-1\">\n            <span [ngClass]=\"{'text-muted': dtz.secondary || dtz.current, 'text-info': !isBs4 && dtz.current}\">{{ dtz.label }}</span>\n          </button>\n        </td>\n      </tr>\n    </ng-template>\n  </tbody>\n</table>\n  `,\n  styles: [\n    `\n    :host .btn-secondary {\n      color: #292b2c;\n      background-color: #fff;\n      border-color: #ccc;\n    }\n    :host .btn-info .text-muted {\n      color: #292b2c !important;\n    }\n  `\n  ]\n})\nexport class DayPickerComponent implements OnInit {\n  labels: any[] = [];\n  title: string;\n  rows: any[] = [];\n  weekNumbers: number[] = [];\n  datePicker: DatePickerInnerComponent;\n\n  constructor(datePicker: DatePickerInnerComponent) {\n    this.datePicker = datePicker;\n  }\n\n  get isBs4(): boolean {\n    return !isBs3();\n  }\n\n  /*protected getDaysInMonth(year:number, month:number) {\n   return ((month === 1) && (year % 4 === 0) &&\n   ((year % 100 !== 0) || (year % 400 === 0))) ? 29 : DAYS_IN_MONTH[month];\n   }*/\n  ngOnInit(): void {\n    const self = this;\n\n    this.datePicker.stepDay = { months: 1 };\n\n    this.datePicker.setRefreshViewHandler(function(): void {\n      const year = this.activeDate.getFullYear();\n      const month = this.activeDate.getMonth();\n      const firstDayOfMonth = new Date(year, month, 1);\n      const difference = this.startingDay - firstDayOfMonth.getDay();\n      const numDisplayedFromPreviousMonth =\n        difference > 0 ? 7 - difference : -difference;\n      const firstDate = new Date(firstDayOfMonth.getTime());\n\n      if (numDisplayedFromPreviousMonth > 0) {\n        firstDate.setDate(-numDisplayedFromPreviousMonth + 1);\n      }\n\n      // 42 is the number of days on a six-week calendar\n      const _days: Date[] = self.getDates(firstDate, 42);\n      const days: any[] = [];\n      for (let i = 0; i < 42; i++) {\n        const _dateObject = this.createDateObject(_days[i], this.formatDay);\n        _dateObject.secondary = _days[i].getMonth() !== month;\n        _dateObject.uid = this.uniqueId + '-' + i;\n        days[i] = _dateObject;\n      }\n\n      self.labels = [];\n      for (let j = 0; j < 7; j++) {\n        self.labels[j] = {};\n        self.labels[j].abbr = this.dateFilter(\n          days[j].date,\n          this.formatDayHeader\n        );\n        self.labels[j].full = this.dateFilter(days[j].date, 'EEEE');\n      }\n\n      self.title = this.dateFilter(this.activeDate, this.formatDayTitle);\n      self.rows = this.split(days, 7);\n\n      if (this.showWeeks) {\n        self.weekNumbers = [];\n        const thursdayIndex = (4 + 7 - this.startingDay) % 7;\n        const numWeeks = self.rows.length;\n        for (let curWeek = 0; curWeek < numWeeks; curWeek++) {\n          self.weekNumbers.push(\n            self.getISO8601WeekNumber(self.rows[curWeek][thursdayIndex].date)\n          );\n        }\n      }\n    }, 'day');\n\n    this.datePicker.setCompareHandler(function(\n      date1: Date,\n      date2: Date\n    ): number {\n      const d1 = new Date(date1.getFullYear(), date1.getMonth(), date1.getDate());\n      const d2 = new Date(date2.getFullYear(), date2.getMonth(), date2.getDate());\n      return d1.getTime() - d2.getTime();\n    }, 'day');\n\n    this.datePicker.refreshView();\n  }\n\n  protected getDates(startDate: Date, n: number): Date[] {\n    const dates: Date[] = new Array(n);\n    let current = new Date(startDate.getTime());\n    let i = 0;\n    let date: Date;\n    while (i < n) {\n      date = new Date(current.getTime());\n      date = this.datePicker.fixTimeZone(date);\n      dates[i++] = date;\n      current = new Date(\n        date.getFullYear(),\n        date.getMonth(),\n        date.getDate() + 1\n      );\n    }\n    return dates;\n  }\n\n  protected getISO8601WeekNumber(date: Date): number {\n    const checkDate = new Date(date.getTime());\n    // Thursday\n    checkDate.setDate(checkDate.getDate() + 4 - (checkDate.getDay() || 7));\n    const time = checkDate.getTime();\n    // Compare with Jan 1\n    checkDate.setMonth(0);\n    checkDate.setDate(1);\n    return (\n      Math.floor(Math.round((time - checkDate.getTime()) / 86400000) / 7) + 1\n    );\n  }\n\n  // todo: key events implementation\n}\n"]}
|