UNPKG

stimulsoft-viewer-angular

Version:

The Viewer component is designed to view reports and dashboards in the web browser.

291 lines (279 loc) 32.3 kB
import { Component, Input } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "../services/model.service"; import * as i2 from "../services/helper.service"; import * as i3 from "@angular/common"; import * as i4 from "../controls/button.component"; import * as i5 from "../controls/text-box.componet"; import * as i6 from "../controls/drop-down-list.component"; import * as i7 from "../controls/date-picker-day-button.component"; export class DatePickerMenuComponent { constructor(model, helper) { this.model = model; this.helper = helper; this.keyTo = false; this.closeOnAction = true; this.monthesForDatePickerItems = []; this.cols = [0, 1, 2, 3, 4, 5, 6]; this.rows = [0, 1, 2, 3, 4, 5]; this.model.months.forEach((m, i) => this.monthesForDatePickerItems.push({ name: 'Month' + i, caption: this.model.loc('Month' + m), key: i })); const firstLetters = {}; this.model.dayOfWeek.forEach((d) => { const dayName = this.model.loc('Day' + d); firstLetters[dayName.toString().substring(0, 1).toUpperCase()] = true; }); this.countLetters = Object.keys(firstLetters).length < 5 ? 2 : 1; } ngOnInit() { } getButtonSelected(col, row) { const firstDay = this.getFirstDay(); const curDay = row * 7 + col; const day = curDay - firstDay + 1; return day === this.key.day; } getButtonCaption(col, row) { const firstDay = this.getFirstDay(); const daysInMonth = this.helper.getCountDaysOfMonth(this.key.year, this.key.month - 1); const curDay = row * 7 + col; const day = curDay - firstDay + 1; if (curDay >= firstDay && day <= daysInMonth) { return day.toString(); } return ''; } getTime() { return this.helper.formatDate(this.helper.getDate(this.key), 'H:mm:ss'); } getFirstDay() { let firstDay = new Date(this.key.year, this.key.month - 1, 1).getDay(); if (firstDay === 0) { firstDay = 7; } if (this.model.options.appearance.datePickerFirstDayOfWeek !== 'Sunday') { firstDay--; } return firstDay; } get showTime() { return this.menu?.params?.dateTimeType !== 'Date'; } get key() { return this.keyTo ? this.menu.params.keyTo : this.menu.params.key; } yearAction(input) { try { this.key.year = parseInt(input.value, 10); } catch { } } timeAction(input) { const time = this.helper.stringToTime(input.value); this.key.seconds = time.seconds; this.key.minutes = time.minutes; this.key.hours = time.hours; } getShortDayName(index) { const dayName = this.model.loc('Day' + this.model.dayOfWeek[index]); if (dayName) { return dayName.toString().substring(0, this.countLetters <= dayName.length ? this.countLetters : 1).toUpperCase(); } return ''; } getShortDayColor(index) { if (index === (this.model.options.appearance.datePickerFirstDayOfWeek === 'Sunday' ? 6 : 5)) { return '#0000ff'; } if (index === (this.model.options.appearance.datePickerFirstDayOfWeek === 'Sunday' ? 0 : 6)) { return '#ff0000'; } return ''; } prevMonthButtonAction() { let month = this.key.month; let year = this.key.year; month--; if (month === 0) { month = 12; year--; } const countDaysInMonth = this.helper.getCountDaysOfMonth(year, month - 1); if (countDaysInMonth < this.key.day) { this.key.day = countDaysInMonth; } this.key.month = month; this.key.year = year; } nextMonthButtonAction() { let month = this.key.month; let year = this.key.year; month++; if (month === 13) { month = 1; year++; } const countDaysInMonth = this.helper.getCountDaysOfMonth(year, month - 1); if (countDaysInMonth < this.key.day) { this.key.day = countDaysInMonth; } this.key.month = month; this.key.year = year; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DatePickerMenuComponent, deps: [{ token: i1.ModelService }, { token: i2.HelperService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.14", type: DatePickerMenuComponent, selector: "sti-date-picker-menu", inputs: { menu: "menu", keyTo: "keyTo", closeOnAction: "closeOnAction" }, ngImport: i0, template: ` <table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles"> <sti-button [imageName]="'Arrows.BigArrowLeft.png'" [margin]="'1px 2px 0 1px'" (action)="prevMonthButtonAction()"> </sti-button> </td> <td class="stiJsViewerClearAllStyles"> <sti-drop-down-list [width]="model.options.isTouchDevice ? 79 : 81" [readOnly]="true" [margin]="'1px 2px 0 0'" [items]="monthesForDatePickerItems" [key]="key.month - 1" (action)="key.month = $event.key + 1"> </sti-drop-down-list> </td> <td class="stiJsViewerClearAllStyles"> <sti-text-box [width]="40" [margin]="'1px 2px 0 0'" [value]="key.year" (onchange)="yearAction($event)"> </sti-text-box> </td> <td class="stiJsViewerClearAllStyles"> <sti-button [imageName]="'Arrows.BigArrowRight.png'" [margin]="'1px 1px 0 0'" (action)="nextMonthButtonAction()"> </sti-button> </td> </tr> </tbody> </table> <div class="stiJsViewerDatePickerSeparator" [style.margin]="'2px 0px'"></div> <table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td *ngFor="let item of model.dayOfWeek; let i = index" class="stiJsViewerDatePickerDayOfWeekCell" [style.fontSize]="countLetters == 2 ? '11px' : ''" [style.color]="getShortDayColor(i)"> {{getShortDayName(i)}} </td> </tr> <tr *ngFor="let row of rows" class="stiJsViewerClearAllStyles"> <td *ngFor="let col of cols" class="stiJsViewerClearAllStyles"> <sti-date-picker-day-button [col]="col" [row]="row" [date]="key" [selected]="getButtonSelected(col, row)" [caption]="getButtonCaption(col, row)" [enabled]="getButtonCaption(col, row) != ''"> [closeOnAction]="closeOnAction" </sti-date-picker-day-button> </td> </tr> </tbody> </table> <div *ngIf="showTime" class="stiJsViewerDatePickerSeparator" [style.margin]="'2px 0px'"></div> <table *ngIf="showTime" class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0" [style.width]="'100%'"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles" [style.padding]="'0 4px 0 4px'" [style.whiteSpace]="'nowrap'"> {{this.model.loc('Time') + ':'}} </td> <td class="stiJsViewerClearAllStyles" [style.textAlign]="'right'"> <sti-text-box [width]="90" [margin]="'1px 2px 2px 2px'" [value]="getTime()" (action)="timeAction($event)"> </sti-text-box> </td> </tr> </tbody> </table> `, isInline: true, dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.ButtonComponent, selector: "sti-button", inputs: ["caption", "caption2", "captionAlign", "captionPadding", "captionPaddingLeft", "captionWhiteSpace", "captionOverflow", "captionTextOverflow", "captionWidth", "captionMaxWidth", "captionLineHeight", "imageName", "arrow", "arrowMarginTop", "margin", "height", "selected", "minWidth", "innerTableWidth", "menuItems", "actionName", "tooltip", "imageCellTextAlign", "imageCellWidth", "imageCellPadding", "imageSizesWidth", "imageSizesHeight", "imageMargin", "width", "display", "closeButton", "resourceButton", "styleColors", "boxSizing", "navagationPanelTooltip", "cursor", "fontSize", "helpLink", "borderColor", "styleName", "enabled"], outputs: ["action", "closeButtonAction"] }, { kind: "component", type: i5.TextBoxComponent, selector: "sti-text-box", inputs: ["width", "actionLostFocus", "tooltip", "enabled", "value", "margin", "focusOnCreate", "maxLength", "color", "type", "padding", "border", "variable", "textAlign", "autocomplete", "readOnly"], outputs: ["action", "onchange", "onblur"] }, { kind: "component", type: i6.DropDownListComponent, selector: "sti-drop-down-list", inputs: ["toolTip", "showImage", "width", "margin", "items", "styleDisplay", "verticalAlign", "readOnly", "enabled", "key"], outputs: ["action"] }, { kind: "component", type: i7.DatePickerDayButtonComponent, selector: "sti-date-picker-day-button", inputs: ["col", "row", "caption", "enabled", "selected", "date", "closeOnAction"] }] }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: DatePickerMenuComponent, decorators: [{ type: Component, args: [{ selector: 'sti-date-picker-menu', template: ` <table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles"> <sti-button [imageName]="'Arrows.BigArrowLeft.png'" [margin]="'1px 2px 0 1px'" (action)="prevMonthButtonAction()"> </sti-button> </td> <td class="stiJsViewerClearAllStyles"> <sti-drop-down-list [width]="model.options.isTouchDevice ? 79 : 81" [readOnly]="true" [margin]="'1px 2px 0 0'" [items]="monthesForDatePickerItems" [key]="key.month - 1" (action)="key.month = $event.key + 1"> </sti-drop-down-list> </td> <td class="stiJsViewerClearAllStyles"> <sti-text-box [width]="40" [margin]="'1px 2px 0 0'" [value]="key.year" (onchange)="yearAction($event)"> </sti-text-box> </td> <td class="stiJsViewerClearAllStyles"> <sti-button [imageName]="'Arrows.BigArrowRight.png'" [margin]="'1px 1px 0 0'" (action)="nextMonthButtonAction()"> </sti-button> </td> </tr> </tbody> </table> <div class="stiJsViewerDatePickerSeparator" [style.margin]="'2px 0px'"></div> <table class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td *ngFor="let item of model.dayOfWeek; let i = index" class="stiJsViewerDatePickerDayOfWeekCell" [style.fontSize]="countLetters == 2 ? '11px' : ''" [style.color]="getShortDayColor(i)"> {{getShortDayName(i)}} </td> </tr> <tr *ngFor="let row of rows" class="stiJsViewerClearAllStyles"> <td *ngFor="let col of cols" class="stiJsViewerClearAllStyles"> <sti-date-picker-day-button [col]="col" [row]="row" [date]="key" [selected]="getButtonSelected(col, row)" [caption]="getButtonCaption(col, row)" [enabled]="getButtonCaption(col, row) != ''"> [closeOnAction]="closeOnAction" </sti-date-picker-day-button> </td> </tr> </tbody> </table> <div *ngIf="showTime" class="stiJsViewerDatePickerSeparator" [style.margin]="'2px 0px'"></div> <table *ngIf="showTime" class="stiJsViewerClearAllStyles" cellpadding="0" cellspacing="0" [style.width]="'100%'"> <tbody> <tr class="stiJsViewerClearAllStyles"> <td class="stiJsViewerClearAllStyles" [style.padding]="'0 4px 0 4px'" [style.whiteSpace]="'nowrap'"> {{this.model.loc('Time') + ':'}} </td> <td class="stiJsViewerClearAllStyles" [style.textAlign]="'right'"> <sti-text-box [width]="90" [margin]="'1px 2px 2px 2px'" [value]="getTime()" (action)="timeAction($event)"> </sti-text-box> </td> </tr> </tbody> </table> ` }] }], ctorParameters: () => [{ type: i1.ModelService }, { type: i2.HelperService }], propDecorators: { menu: [{ type: Input }], keyTo: [{ type: Input }], closeOnAction: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-picker-menu.component.js","sourceRoot":"","sources":["../../../../../projects/stimulsoft-viewer-angular/src/lib/menu/date-picker-menu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input } from '@angular/core';\r\nimport { ModelService } from '../services/model.service';\r\nimport { Menu } from './menu.service';\r\nimport { HelperService } from '../services/helper.service';\r\nimport { Item, DateTimeObject } from '../services/objects';\r\n\r\n@Component({\r\n  selector: 'sti-date-picker-menu',\r\n  template: `\r\n        <table class=\"stiJsViewerClearAllStyles\" cellpadding=\"0\" cellspacing=\"0\">\r\n          <tbody>\r\n            <tr class=\"stiJsViewerClearAllStyles\">\r\n              <td class=\"stiJsViewerClearAllStyles\">\r\n                <sti-button [imageName]=\"'Arrows.BigArrowLeft.png'\" [margin]=\"'1px 2px 0 1px'\" (action)=\"prevMonthButtonAction()\">\r\n                </sti-button>\r\n              </td>\r\n\r\n              <td class=\"stiJsViewerClearAllStyles\">\r\n                <sti-drop-down-list\r\n                  [width]=\"model.options.isTouchDevice ? 79 : 81\"\r\n                  [readOnly]=\"true\"\r\n                  [margin]=\"'1px 2px 0 0'\"\r\n                  [items]=\"monthesForDatePickerItems\"\r\n                  [key]=\"key.month - 1\"\r\n                  (action)=\"key.month = $event.key + 1\">\r\n                </sti-drop-down-list>\r\n              </td>\r\n\r\n              <td class=\"stiJsViewerClearAllStyles\">\r\n                <sti-text-box [width]=\"40\" [margin]=\"'1px 2px 0 0'\" [value]=\"key.year\" (onchange)=\"yearAction($event)\">\r\n                </sti-text-box>\r\n              </td>\r\n\r\n              <td class=\"stiJsViewerClearAllStyles\">\r\n                <sti-button [imageName]=\"'Arrows.BigArrowRight.png'\" [margin]=\"'1px 1px 0 0'\" (action)=\"nextMonthButtonAction()\">\r\n                </sti-button>\r\n              </td>\r\n            </tr>\r\n          </tbody>\r\n        </table>\r\n        <div class=\"stiJsViewerDatePickerSeparator\" [style.margin]=\"'2px 0px'\"></div>\r\n\r\n        <table class=\"stiJsViewerClearAllStyles\" cellpadding=\"0\" cellspacing=\"0\">\r\n          <tbody>\r\n            <tr class=\"stiJsViewerClearAllStyles\">\r\n              <td *ngFor=\"let item of model.dayOfWeek; let i = index\" class=\"stiJsViewerDatePickerDayOfWeekCell\"\r\n                  [style.fontSize]=\"countLetters == 2 ? '11px' : ''\"\r\n                  [style.color]=\"getShortDayColor(i)\">\r\n                  {{getShortDayName(i)}}\r\n              </td>\r\n            </tr>\r\n            <tr *ngFor=\"let row of rows\" class=\"stiJsViewerClearAllStyles\">\r\n                <td *ngFor=\"let col of cols\" class=\"stiJsViewerClearAllStyles\">\r\n                  <sti-date-picker-day-button\r\n                      [col]=\"col\"\r\n                      [row]=\"row\"\r\n                      [date]=\"key\"\r\n                      [selected]=\"getButtonSelected(col, row)\"\r\n                      [caption]=\"getButtonCaption(col, row)\"\r\n                      [enabled]=\"getButtonCaption(col, row) != ''\">\r\n                      [closeOnAction]=\"closeOnAction\"\r\n                  </sti-date-picker-day-button>\r\n                </td>\r\n            </tr>\r\n          </tbody>\r\n        </table>\r\n\r\n        <div *ngIf=\"showTime\" class=\"stiJsViewerDatePickerSeparator\" [style.margin]=\"'2px 0px'\"></div>\r\n        <table *ngIf=\"showTime\" class=\"stiJsViewerClearAllStyles\" cellpadding=\"0\" cellspacing=\"0\" [style.width]=\"'100%'\">\r\n          <tbody>\r\n            <tr class=\"stiJsViewerClearAllStyles\">\r\n              <td class=\"stiJsViewerClearAllStyles\" [style.padding]=\"'0 4px 0 4px'\" [style.whiteSpace]=\"'nowrap'\">\r\n                {{this.model.loc('Time') + ':'}}\r\n              </td>\r\n\r\n              <td class=\"stiJsViewerClearAllStyles\" [style.textAlign]=\"'right'\">\r\n                <sti-text-box [width]=\"90\"\r\n                    [margin]=\"'1px 2px 2px 2px'\"\r\n                    [value]=\"getTime()\"\r\n                    (action)=\"timeAction($event)\">\r\n                </sti-text-box>\r\n              </td>\r\n            </tr>\r\n          </tbody>\r\n        </table>\r\n  `\r\n})\r\n\r\nexport class DatePickerMenuComponent implements OnInit {\r\n\r\n  @Input() menu: Menu;\r\n  @Input() keyTo = false;\r\n  @Input() closeOnAction = true;\r\n\r\n  public monthesForDatePickerItems: Item[] = [];\r\n  public countLetters: number;\r\n  public cols = [0, 1, 2, 3, 4, 5, 6];\r\n  public rows = [0, 1, 2, 3, 4, 5];\r\n\r\n  constructor(public model: ModelService, public helper: HelperService) {\r\n    this.model.months.forEach((m, i) => this.monthesForDatePickerItems.push({ name: 'Month' + i, caption: this.model.loc('Month' + m), key: i }));\r\n\r\n    const firstLetters = {};\r\n    this.model.dayOfWeek.forEach((d) => {\r\n      const dayName = this.model.loc('Day' + d);\r\n      firstLetters[dayName.toString().substring(0, 1).toUpperCase()] = true;\r\n    });\r\n    this.countLetters = Object.keys(firstLetters).length < 5 ? 2 : 1;\r\n  }\r\n\r\n  ngOnInit() { }\r\n\r\n  getButtonSelected(col: number, row: number): boolean {\r\n    const firstDay = this.getFirstDay();\r\n    const curDay = row * 7 + col;\r\n    const day = curDay - firstDay + 1;\r\n\r\n    return day === this.key.day;\r\n  }\r\n\r\n  getButtonCaption(col: number, row: number): string {\r\n    const firstDay = this.getFirstDay();\r\n    const daysInMonth = this.helper.getCountDaysOfMonth(this.key.year, this.key.month - 1);\r\n    const curDay = row * 7 + col;\r\n    const day = curDay - firstDay + 1;\r\n    if (curDay >= firstDay && day <= daysInMonth) {\r\n      return day.toString();\r\n    }\r\n    return '';\r\n  }\r\n\r\n\r\n  getTime(): string {\r\n    return this.helper.formatDate(this.helper.getDate(this.key), 'H:mm:ss');\r\n  }\r\n\r\n  getFirstDay(): number {\r\n    let firstDay = new Date(this.key.year, this.key.month - 1, 1).getDay();\r\n    if (firstDay === 0) {\r\n      firstDay = 7;\r\n    }\r\n    if (this.model.options.appearance.datePickerFirstDayOfWeek !== 'Sunday') {\r\n      firstDay--;\r\n    }\r\n    return firstDay;\r\n  }\r\n\r\n  get showTime(): boolean {\r\n    return this.menu?.params?.dateTimeType !== 'Date';\r\n  }\r\n\r\n  get key(): DateTimeObject {\r\n    return this.keyTo ? this.menu.params.keyTo : this.menu.params.key;\r\n  }\r\n\r\n  yearAction(input: any) {\r\n    try {\r\n      this.key.year = parseInt(input.value, 10);\r\n    } catch { }\r\n  }\r\n\r\n  timeAction(input: any) {\r\n    const time = this.helper.stringToTime(input.value);\r\n    this.key.seconds = time.seconds;\r\n    this.key.minutes = time.minutes;\r\n    this.key.hours = time.hours;\r\n  }\r\n\r\n  getShortDayName(index: number): string {\r\n    const dayName = this.model.loc('Day' + this.model.dayOfWeek[index]);\r\n    if (dayName) {\r\n      return dayName.toString().substring(0, this.countLetters <= dayName.length ? this.countLetters : 1).toUpperCase();\r\n    }\r\n    return '';\r\n  }\r\n\r\n  getShortDayColor(index: number): string {\r\n    if (index === (this.model.options.appearance.datePickerFirstDayOfWeek === 'Sunday' ? 6 : 5)) {\r\n      return '#0000ff';\r\n    }\r\n\r\n    if (index === (this.model.options.appearance.datePickerFirstDayOfWeek === 'Sunday' ? 0 : 6)) {\r\n      return '#ff0000';\r\n    }\r\n    return '';\r\n  }\r\n\r\n  prevMonthButtonAction() {\r\n    let month = this.key.month;\r\n    let year = this.key.year;\r\n    month--;\r\n    if (month === 0) {\r\n      month = 12;\r\n      year--;\r\n    }\r\n    const countDaysInMonth = this.helper.getCountDaysOfMonth(year, month - 1);\r\n    if (countDaysInMonth < this.key.day) {\r\n      this.key.day = countDaysInMonth;\r\n    }\r\n    this.key.month = month;\r\n    this.key.year = year;\r\n  }\r\n\r\n  nextMonthButtonAction() {\r\n    let month = this.key.month;\r\n    let year = this.key.year;\r\n    month++;\r\n    if (month === 13) {\r\n      month = 1;\r\n      year++;\r\n    }\r\n    const countDaysInMonth = this.helper.getCountDaysOfMonth(year, month - 1);\r\n    if (countDaysInMonth < this.key.day) {\r\n      this.key.day = countDaysInMonth;\r\n    }\r\n    this.key.month = month;\r\n    this.key.year = year;\r\n  }\r\n\r\n\r\n}\r\n"]}