cps-ui-kit 0.140.0 → 0.141.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (94) hide show
  1. package/esm2020/lib/components/cps-autocomplete/cps-autocomplete.component.mjs +137 -4
  2. package/esm2020/lib/components/cps-button/cps-button.component.mjs +55 -2
  3. package/esm2020/lib/components/cps-button-toggle/cps-button-toggle.component.mjs +63 -2
  4. package/esm2020/lib/components/cps-checkbox/cps-checkbox.component.mjs +50 -1
  5. package/esm2020/lib/components/cps-chip/cps-chip.component.mjs +34 -1
  6. package/esm2020/lib/components/cps-datepicker/cps-datepicker.component.mjs +78 -1
  7. package/esm2020/lib/components/cps-expansion-panel/cps-expansion-panel.component.mjs +51 -1
  8. package/esm2020/lib/components/cps-icon/cps-icon.component.mjs +17 -1
  9. package/esm2020/lib/components/cps-info-circle/cps-info-circle.component.mjs +29 -1
  10. package/esm2020/lib/components/cps-input/cps-input.component.mjs +131 -1
  11. package/esm2020/lib/components/cps-loader/cps-loader.component.mjs +21 -1
  12. package/esm2020/lib/components/cps-menu/cps-menu.component.mjs +58 -2
  13. package/esm2020/lib/components/cps-paginator/cps-paginator.component.mjs +38 -1
  14. package/esm2020/lib/components/cps-paginator/pipes/cps-paginate.pipe.mjs +5 -1
  15. package/esm2020/lib/components/cps-progress-circular/cps-progress-circular.component.mjs +17 -1
  16. package/esm2020/lib/components/cps-progress-linear/cps-progress-linear.component.mjs +29 -1
  17. package/esm2020/lib/components/cps-radio-group/cps-radio/cps-radio.component.mjs +5 -1
  18. package/esm2020/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.mjs +18 -1
  19. package/esm2020/lib/components/cps-radio-group/cps-radio-group.component.mjs +50 -1
  20. package/esm2020/lib/components/cps-select/cps-select.component.mjs +137 -4
  21. package/esm2020/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.mjs +21 -1
  22. package/esm2020/lib/components/cps-tab-group/cps-tab/cps-tab.component.mjs +41 -1
  23. package/esm2020/lib/components/cps-tab-group/cps-tab-group.component.mjs +32 -2
  24. package/esm2020/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.mjs +67 -3
  25. package/esm2020/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.mjs +31 -3
  26. package/esm2020/lib/components/cps-table/components/internal/table-row-menu/table-row-menu.component.mjs +51 -0
  27. package/esm2020/lib/components/cps-table/cps-table.component.mjs +312 -8
  28. package/esm2020/lib/components/cps-table/directives/cps-table-column-filter.directive.mjs +67 -3
  29. package/esm2020/lib/components/cps-table/directives/cps-table-column-sortable.directive.mjs +9 -1
  30. package/esm2020/lib/components/cps-table/directives/cps-table-header-selectable.directive.mjs +5 -1
  31. package/esm2020/lib/components/cps-table/directives/cps-table-row-selectable.directive.mjs +5 -1
  32. package/esm2020/lib/components/cps-tag/cps-tag.component.mjs +35 -2
  33. package/esm2020/lib/components/cps-textarea/cps-textarea.component.mjs +101 -1
  34. package/esm2020/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.mjs +17 -1
  35. package/esm2020/lib/components/cps-tree-select/cps-tree-select.component.mjs +13 -1
  36. package/esm2020/lib/components/cps-tree-table/cps-tree-table.component.mjs +314 -7
  37. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.mjs +63 -3
  38. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.mjs +9 -1
  39. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.mjs +5 -1
  40. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.mjs +5 -1
  41. package/esm2020/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.mjs +5 -1
  42. package/esm2020/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.mjs +118 -1
  43. package/esm2020/lib/directives/cps-tooltip.directive.mjs +37 -1
  44. package/esm2020/lib/services/cps-dialog/cps-dialog.service.mjs +2 -2
  45. package/fesm2015/cps-ui-kit.mjs +2312 -37
  46. package/fesm2015/cps-ui-kit.mjs.map +1 -1
  47. package/fesm2020/cps-ui-kit.mjs +2312 -37
  48. package/fesm2020/cps-ui-kit.mjs.map +1 -1
  49. package/lib/components/cps-autocomplete/cps-autocomplete.component.d.ts +133 -0
  50. package/lib/components/cps-button/cps-button.component.d.ts +53 -0
  51. package/lib/components/cps-button-toggle/cps-button-toggle.component.d.ts +61 -0
  52. package/lib/components/cps-checkbox/cps-checkbox.component.d.ts +49 -0
  53. package/lib/components/cps-chip/cps-chip.component.d.ts +33 -0
  54. package/lib/components/cps-datepicker/cps-datepicker.component.d.ts +85 -0
  55. package/lib/components/cps-expansion-panel/cps-expansion-panel.component.d.ts +50 -0
  56. package/lib/components/cps-icon/cps-icon.component.d.ts +16 -0
  57. package/lib/components/cps-info-circle/cps-info-circle.component.d.ts +28 -0
  58. package/lib/components/cps-input/cps-input.component.d.ts +130 -0
  59. package/lib/components/cps-loader/cps-loader.component.d.ts +20 -0
  60. package/lib/components/cps-menu/cps-menu.component.d.ts +56 -0
  61. package/lib/components/cps-paginator/cps-paginator.component.d.ts +37 -0
  62. package/lib/components/cps-paginator/pipes/cps-paginate.pipe.d.ts +4 -0
  63. package/lib/components/cps-progress-circular/cps-progress-circular.component.d.ts +16 -0
  64. package/lib/components/cps-progress-linear/cps-progress-linear.component.d.ts +28 -0
  65. package/lib/components/cps-radio-group/cps-radio/cps-radio.component.d.ts +8 -0
  66. package/lib/components/cps-radio-group/cps-radio-button/cps-radio-button.component.d.ts +21 -0
  67. package/lib/components/cps-radio-group/cps-radio-group.component.d.ts +49 -0
  68. package/lib/components/cps-select/cps-select.component.d.ts +133 -0
  69. package/lib/components/cps-sidebar-menu/cps-sidebar-menu.component.d.ts +21 -1
  70. package/lib/components/cps-tab-group/cps-tab/cps-tab.component.d.ts +40 -0
  71. package/lib/components/cps-tab-group/cps-tab-group.component.d.ts +30 -0
  72. package/lib/components/cps-table/components/internal/table-column-filter/table-column-filter.component.d.ts +68 -0
  73. package/lib/components/cps-table/components/internal/table-column-filter-constraint/table-column-filter-constraint.component.d.ts +36 -0
  74. package/lib/components/cps-table/{table-row-menu → components/internal/table-row-menu}/table-row-menu.component.d.ts +15 -1
  75. package/lib/components/cps-table/cps-table.component.d.ts +304 -0
  76. package/lib/components/cps-table/directives/cps-table-column-filter.directive.d.ts +68 -0
  77. package/lib/components/cps-table/directives/cps-table-column-sortable.directive.d.ts +8 -0
  78. package/lib/components/cps-table/directives/cps-table-header-selectable.directive.d.ts +4 -0
  79. package/lib/components/cps-table/directives/cps-table-row-selectable.directive.d.ts +8 -0
  80. package/lib/components/cps-tag/cps-tag.component.d.ts +33 -0
  81. package/lib/components/cps-textarea/cps-textarea.component.d.ts +100 -0
  82. package/lib/components/cps-tree-autocomplete/cps-tree-autocomplete.component.d.ts +16 -0
  83. package/lib/components/cps-tree-select/cps-tree-select.component.d.ts +12 -0
  84. package/lib/components/cps-tree-table/cps-tree-table.component.d.ts +307 -0
  85. package/lib/components/cps-tree-table/directives/cps-tree-table-column-filter.directive.d.ts +64 -0
  86. package/lib/components/cps-tree-table/directives/cps-tree-table-column-sortable.directive.d.ts +8 -0
  87. package/lib/components/cps-tree-table/directives/cps-tree-table-header-selectable.directive.d.ts +4 -0
  88. package/lib/components/cps-tree-table/directives/cps-tree-table-row-selectable.directive.d.ts +8 -0
  89. package/lib/components/cps-tree-table/directives/cps-tree-table-row-toggler.directive.d.ts +8 -0
  90. package/lib/components/internal/cps-base-tree-dropdown/cps-base-tree-dropdown.component.d.ts +117 -0
  91. package/lib/directives/cps-tooltip.directive.d.ts +40 -0
  92. package/lib/services/cps-dialog/cps-dialog.service.d.ts +1 -1
  93. package/package.json +1 -1
  94. package/esm2020/lib/components/cps-table/table-row-menu/table-row-menu.component.mjs +0 -37
@@ -8,6 +8,10 @@ import { CpsTooltipDirective } from '../../directives/cps-tooltip.directive';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "@angular/forms";
10
10
  import * as i2 from "@angular/common";
11
+ /**
12
+ * CpsButtonToggleComponent is used to select values using buttons.
13
+ * @group Components
14
+ */
11
15
  export class CpsButtonToggleComponent {
12
16
  set value(value) {
13
17
  this._value = value;
@@ -19,19 +23,76 @@ export class CpsButtonToggleComponent {
19
23
  constructor(_control, renderer) {
20
24
  this._control = _control;
21
25
  this.renderer = renderer;
26
+ /**
27
+ * Label of the toggle buttons.
28
+ * @group Props
29
+ */
22
30
  this.label = '';
31
+ /**
32
+ * An array of options.
33
+ * @group Props
34
+ */
23
35
  this.options = [];
36
+ /**
37
+ * Specifies if multiple values can be selected.
38
+ * @group Props
39
+ */
24
40
  this.multiple = false;
41
+ /**
42
+ * Specifies that the component should be disabled.
43
+ * @group Props
44
+ */
25
45
  this.disabled = false;
26
- this.mandatory = true; // at least one of the options is mandatory
46
+ /**
47
+ * Whether at least one of the options is mandatory.
48
+ * @group Props
49
+ */
50
+ this.mandatory = true;
51
+ /**
52
+ * Whether all buttons should have equal widths.
53
+ * @group Props
54
+ */
27
55
  this.equalWidths = true;
56
+ /**
57
+ * Position of the option tooltip, can be 'top', 'bottom', 'left' or 'right'.
58
+ * @group Props
59
+ */
28
60
  this.optionTooltipPosition = 'bottom';
61
+ /**
62
+ * When it is not an empty string, an info icon is displayed to show text for more info.
63
+ * @group Props
64
+ */
29
65
  this.infoTooltip = '';
66
+ /**
67
+ * Info tooltip class for styling.
68
+ * @group Props
69
+ */
30
70
  this.infoTooltipClass = 'cps-tooltip-content';
71
+ /**
72
+ * Size of infoTooltip, of type number or string.
73
+ * @group Props
74
+ */
31
75
  this.infoTooltipMaxWidth = '100%';
76
+ /**
77
+ * Whether the infoTooltip is persistent.
78
+ * @group Props
79
+ */
32
80
  this.infoTooltipPersistent = false;
81
+ /**
82
+ * Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.
83
+ * @group Props
84
+ */
33
85
  this.infoTooltipPosition = 'top';
86
+ /**
87
+ * Value of the component.
88
+ * @group Props
89
+ */
34
90
  this._value = undefined;
91
+ /**
92
+ * Callback to invoke on value change.
93
+ * @param {any} any - value changed.
94
+ * @group Emits
95
+ */
35
96
  this.valueChanged = new EventEmitter();
36
97
  this.largestButtonWidth = 0;
37
98
  // eslint-disable-next-line @typescript-eslint/no-empty-function
@@ -172,4 +233,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
172
233
  }], valueChanged: [{
173
234
  type: Output
174
235
  }] } });
175
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-button-toggle.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-button-toggle/cps-button-toggle.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-button-toggle/cps-button-toggle.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n  Renderer2,\n  Self\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { isEqual } from 'lodash-es';\nimport { CheckOptionSelectedPipe } from '../../pipes/internal/check-option-selected.pipe';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport {\n  CpsTooltipDirective,\n  CpsTooltipPosition\n} from '../../directives/cps-tooltip.directive';\n\nexport type CpsButtonToggleOption = {\n  value: any;\n  label?: string;\n  icon?: string;\n  disabled?: boolean;\n  tooltip?: string;\n};\n\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    CheckOptionSelectedPipe,\n    CpsInfoCircleComponent,\n    CpsIconComponent,\n    CpsTooltipDirective\n  ],\n  providers: [CheckOptionSelectedPipe],\n  selector: 'cps-button-toggle',\n  templateUrl: './cps-button-toggle.component.html',\n  styleUrls: ['./cps-button-toggle.component.scss']\n})\nexport class CpsButtonToggleComponent implements ControlValueAccessor, OnInit {\n  @Input() label = '';\n  @Input() options = [] as CpsButtonToggleOption[];\n  @Input() multiple = false;\n  @Input() disabled = false;\n  @Input() mandatory = true; // at least one of the options is mandatory\n  @Input() equalWidths = true;\n  @Input() optionTooltipPosition: CpsTooltipPosition = 'bottom';\n  @Input() infoTooltip = '';\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n  @Input() infoTooltipPersistent = false;\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  @Input('value') _value: any = undefined;\n\n  set value(value: any) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  @Output() valueChanged = new EventEmitter<any>();\n\n  largestButtonWidth = 0;\n\n  constructor(\n    @Self() @Optional() private _control: NgControl,\n    private renderer: Renderer2\n  ) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit() {\n    if (this.multiple && !this._value) {\n      this._value = [];\n    }\n    this._setEqualWidths();\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: any) {\n    this.value = value;\n  }\n\n  updateValueEvent(event: any) {\n    if (this.disabled) return;\n    const check = event?.target?.checked || false;\n\n    if (this.mandatory && this.multiple && !check && this.value.length < 2) {\n      event.target.checked = true;\n      return;\n    }\n\n    const val = event?.target?.value || undefined;\n\n    if (this.multiple) {\n      let res = [] as any;\n      if (!check) {\n        res = this.value.filter((v: any) => !isEqual(v, val));\n      } else {\n        this.options.forEach((o) => {\n          if (\n            this.value.some((v: any) => isEqual(v, o.value)) ||\n            isEqual(val, o.value)\n          ) {\n            res.push(o.value);\n          }\n        });\n      }\n      this._updateValue(res);\n    } else {\n      if (this.mandatory) {\n        this._updateValue(val); // radio\n      } else {\n        this._updateValue(check ? val : undefined);\n      }\n    }\n  }\n\n  private _updateValue(value: any) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  private _setEqualWidths() {\n    if (!this.equalWidths) return;\n\n    const hiddenSpan = this.renderer.createElement('span');\n    this.renderer.setStyle(hiddenSpan, 'visibility', 'hidden');\n    this.renderer.setStyle(hiddenSpan, 'position', 'absolute');\n    this.renderer.setStyle(hiddenSpan, 'left', '-9999px');\n    this.renderer.setStyle(hiddenSpan, 'font-size', '16px');\n    this.renderer.setStyle(hiddenSpan, 'letter-spacing', '0.05em');\n    this.renderer.setStyle(\n      hiddenSpan,\n      'font-family',\n      '\"Source Sans Pro\", sans-serif'\n    );\n\n    this.renderer.appendChild(document.body, hiddenSpan);\n\n    this.largestButtonWidth = 0;\n    this.options.forEach((opt) => {\n      const text = this.renderer.createText(opt.label || '');\n      this.renderer.appendChild(hiddenSpan, text);\n\n      let width = hiddenSpan.offsetWidth || 0;\n      width += 26;\n      if (opt.icon) {\n        width += 16;\n        if (opt.label) width += 8;\n      }\n      if (width > this.largestButtonWidth) {\n        this.largestButtonWidth = width;\n      }\n      this.renderer.removeChild(hiddenSpan, text);\n    });\n\n    this.renderer.removeChild(document.body, hiddenSpan);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n}\n","<div class=\"cps-btn-toggle\">\n  <div class=\"cps-btn-toggle-label\" *ngIf=\"label\">\n    <span>{{ label }}</span>\n    <cps-info-circle\n      *ngIf=\"infoTooltip\"\n      class=\"cps-btn-toggle-label-info-circle\"\n      size=\"xsmall\"\n      [tooltipPosition]=\"infoTooltipPosition\"\n      [tooltipContentClass]=\"infoTooltipClass\"\n      [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n      [tooltipPersistent]=\"infoTooltipPersistent\"\n      [tooltipText]=\"infoTooltip\">\n    </cps-info-circle>\n  </div>\n  <div class=\"cps-btn-toggle-content\">\n    <ng-container *ngFor=\"let option of options\">\n      <ng-container\n        *ngTemplateOutlet=\"\n          optionContainerTemplate;\n          context: {\n            option: option,\n            tooltip: option.tooltip\n          }\n        \"></ng-container>\n    </ng-container>\n  </div>\n</div>\n\n<ng-template #optionContainerTemplate let-option=\"option\" let-tooltip=\"tooltip\">\n  <label\n    class=\"cps-btn-toggle-content-option\"\n    *ngIf=\"tooltip\"\n    [cpsTooltip]=\"option.tooltip\"\n    tooltipCloseDelay=\"0\"\n    [tooltipPosition]=\"optionTooltipPosition\">\n    <ng-container\n      *ngTemplateOutlet=\"\n        optionRadioTemplate;\n        context: {\n          option: option\n        }\n      \"></ng-container>\n  </label>\n  <label class=\"cps-btn-toggle-content-option\" *ngIf=\"!tooltip\">\n    <ng-container\n      *ngTemplateOutlet=\"\n        optionRadioTemplate;\n        context: {\n          option: option\n        }\n      \"></ng-container>\n  </label>\n</ng-template>\n\n<ng-template #optionRadioTemplate let-option=\"option\">\n  <input\n    class=\"cps-btn-toggle-content-option-input\"\n    [type]=\"!multiple && mandatory ? 'radio' : 'checkbox'\"\n    [disabled]=\"option.disabled || disabled\"\n    [value]=\"option.value\"\n    [checked]=\"\n      option.value | checkOptionSelected : value : multiple : true : ''\n    \"\n    (change)=\"updateValueEvent($event)\" />\n  <span\n    class=\"cps-btn-toggle-content-option-content\"\n    [ngStyle]=\"{\n      'min-width': largestButtonWidth ? largestButtonWidth + 'px' : 'none'\n    }\">\n    <cps-icon\n      *ngIf=\"option.icon\"\n      [ngClass]=\"{ 'me-2': !!option.label }\"\n      [icon]=\"option.icon\">\n    </cps-icon>\n    <span *ngIf=\"option.label\">{{ option.label }}</span>\n  </span>\n</ng-template>\n"]}
236
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-button-toggle.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-button-toggle/cps-button-toggle.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-button-toggle/cps-button-toggle.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n  Renderer2,\n  Self\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { isEqual } from 'lodash-es';\nimport { CheckOptionSelectedPipe } from '../../pipes/internal/check-option-selected.pipe';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\nimport { CpsIconComponent } from '../cps-icon/cps-icon.component';\nimport {\n  CpsTooltipDirective,\n  CpsTooltipPosition\n} from '../../directives/cps-tooltip.directive';\n\nexport type CpsButtonToggleOption = {\n  value: any;\n  label?: string;\n  icon?: string;\n  disabled?: boolean;\n  tooltip?: string;\n};\n\n/**\n * CpsButtonToggleComponent is used to select values using buttons.\n * @group Components\n */\n@Component({\n  standalone: true,\n  imports: [\n    CommonModule,\n    CheckOptionSelectedPipe,\n    CpsInfoCircleComponent,\n    CpsIconComponent,\n    CpsTooltipDirective\n  ],\n  providers: [CheckOptionSelectedPipe],\n  selector: 'cps-button-toggle',\n  templateUrl: './cps-button-toggle.component.html',\n  styleUrls: ['./cps-button-toggle.component.scss']\n})\nexport class CpsButtonToggleComponent implements ControlValueAccessor, OnInit {\n  /**\n   * Label of the toggle buttons.\n   * @group Props\n   */\n  @Input() label = '';\n\n  /**\n   * An array of options.\n   * @group Props\n   */\n  @Input() options = [] as CpsButtonToggleOption[];\n\n  /**\n   * Specifies if multiple values can be selected.\n   * @group Props\n   */\n  @Input() multiple = false;\n\n  /**\n   * Specifies that the component should be disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * Whether at least one of the options is mandatory.\n   * @group Props\n   */\n  @Input() mandatory = true;\n\n  /**\n   * Whether all buttons should have equal widths.\n   * @group Props\n   */\n  @Input() equalWidths = true;\n\n  /**\n   * Position of the option tooltip, can be 'top', 'bottom', 'left' or 'right'.\n   * @group Props\n   */\n  @Input() optionTooltipPosition: CpsTooltipPosition = 'bottom';\n\n  /**\n   * When it is not an empty string, an info icon is displayed to show text for more info.\n   * @group Props\n   */\n  @Input() infoTooltip = '';\n\n  /**\n   * Info tooltip class for styling.\n   * @group Props\n   */\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n\n  /**\n   * Size of infoTooltip, of type number or string.\n   * @group Props\n   */\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n\n  /**\n   * Whether the infoTooltip is persistent.\n   * @group Props\n   */\n  @Input() infoTooltipPersistent = false;\n\n  /**\n   * Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.\n   * @group Props\n   */\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * Value of the component.\n   * @group Props\n   */\n  @Input('value') _value: any = undefined;\n\n  set value(value: any) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): any {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {any} any - value changed.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<any>();\n\n  largestButtonWidth = 0;\n\n  constructor(\n    @Self() @Optional() private _control: NgControl,\n    private renderer: Renderer2\n  ) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit() {\n    if (this.multiple && !this._value) {\n      this._value = [];\n    }\n    this._setEqualWidths();\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: any) {\n    this.value = value;\n  }\n\n  updateValueEvent(event: any) {\n    if (this.disabled) return;\n    const check = event?.target?.checked || false;\n\n    if (this.mandatory && this.multiple && !check && this.value.length < 2) {\n      event.target.checked = true;\n      return;\n    }\n\n    const val = event?.target?.value || undefined;\n\n    if (this.multiple) {\n      let res = [] as any;\n      if (!check) {\n        res = this.value.filter((v: any) => !isEqual(v, val));\n      } else {\n        this.options.forEach((o) => {\n          if (\n            this.value.some((v: any) => isEqual(v, o.value)) ||\n            isEqual(val, o.value)\n          ) {\n            res.push(o.value);\n          }\n        });\n      }\n      this._updateValue(res);\n    } else {\n      if (this.mandatory) {\n        this._updateValue(val); // radio\n      } else {\n        this._updateValue(check ? val : undefined);\n      }\n    }\n  }\n\n  private _updateValue(value: any) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  private _setEqualWidths() {\n    if (!this.equalWidths) return;\n\n    const hiddenSpan = this.renderer.createElement('span');\n    this.renderer.setStyle(hiddenSpan, 'visibility', 'hidden');\n    this.renderer.setStyle(hiddenSpan, 'position', 'absolute');\n    this.renderer.setStyle(hiddenSpan, 'left', '-9999px');\n    this.renderer.setStyle(hiddenSpan, 'font-size', '16px');\n    this.renderer.setStyle(hiddenSpan, 'letter-spacing', '0.05em');\n    this.renderer.setStyle(\n      hiddenSpan,\n      'font-family',\n      '\"Source Sans Pro\", sans-serif'\n    );\n\n    this.renderer.appendChild(document.body, hiddenSpan);\n\n    this.largestButtonWidth = 0;\n    this.options.forEach((opt) => {\n      const text = this.renderer.createText(opt.label || '');\n      this.renderer.appendChild(hiddenSpan, text);\n\n      let width = hiddenSpan.offsetWidth || 0;\n      width += 26;\n      if (opt.icon) {\n        width += 16;\n        if (opt.label) width += 8;\n      }\n      if (width > this.largestButtonWidth) {\n        this.largestButtonWidth = width;\n      }\n      this.renderer.removeChild(hiddenSpan, text);\n    });\n\n    this.renderer.removeChild(document.body, hiddenSpan);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n}\n","<div class=\"cps-btn-toggle\">\n  <div class=\"cps-btn-toggle-label\" *ngIf=\"label\">\n    <span>{{ label }}</span>\n    <cps-info-circle\n      *ngIf=\"infoTooltip\"\n      class=\"cps-btn-toggle-label-info-circle\"\n      size=\"xsmall\"\n      [tooltipPosition]=\"infoTooltipPosition\"\n      [tooltipContentClass]=\"infoTooltipClass\"\n      [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n      [tooltipPersistent]=\"infoTooltipPersistent\"\n      [tooltipText]=\"infoTooltip\">\n    </cps-info-circle>\n  </div>\n  <div class=\"cps-btn-toggle-content\">\n    <ng-container *ngFor=\"let option of options\">\n      <ng-container\n        *ngTemplateOutlet=\"\n          optionContainerTemplate;\n          context: {\n            option: option,\n            tooltip: option.tooltip\n          }\n        \"></ng-container>\n    </ng-container>\n  </div>\n</div>\n\n<ng-template #optionContainerTemplate let-option=\"option\" let-tooltip=\"tooltip\">\n  <label\n    class=\"cps-btn-toggle-content-option\"\n    *ngIf=\"tooltip\"\n    [cpsTooltip]=\"option.tooltip\"\n    tooltipCloseDelay=\"0\"\n    [tooltipPosition]=\"optionTooltipPosition\">\n    <ng-container\n      *ngTemplateOutlet=\"\n        optionRadioTemplate;\n        context: {\n          option: option\n        }\n      \"></ng-container>\n  </label>\n  <label class=\"cps-btn-toggle-content-option\" *ngIf=\"!tooltip\">\n    <ng-container\n      *ngTemplateOutlet=\"\n        optionRadioTemplate;\n        context: {\n          option: option\n        }\n      \"></ng-container>\n  </label>\n</ng-template>\n\n<ng-template #optionRadioTemplate let-option=\"option\">\n  <input\n    class=\"cps-btn-toggle-content-option-input\"\n    [type]=\"!multiple && mandatory ? 'radio' : 'checkbox'\"\n    [disabled]=\"option.disabled || disabled\"\n    [value]=\"option.value\"\n    [checked]=\"\n      option.value | checkOptionSelected : value : multiple : true : ''\n    \"\n    (change)=\"updateValueEvent($event)\" />\n  <span\n    class=\"cps-btn-toggle-content-option-content\"\n    [ngStyle]=\"{\n      'min-width': largestButtonWidth ? largestButtonWidth + 'px' : 'none'\n    }\">\n    <cps-icon\n      *ngIf=\"option.icon\"\n      [ngClass]=\"{ 'me-2': !!option.label }\"\n      [icon]=\"option.icon\">\n    </cps-icon>\n    <span *ngIf=\"option.label\">{{ option.label }}</span>\n  </span>\n</ng-template>\n"]}
@@ -6,7 +6,15 @@ import { getCSSColor } from '../../utils/colors-utils';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@angular/forms";
8
8
  import * as i2 from "@angular/common";
9
+ /**
10
+ * CpsCheckboxComponent is a checkbox element.
11
+ * @group Components
12
+ */
9
13
  export class CpsCheckboxComponent {
14
+ /**
15
+ * Value of the checkbox.
16
+ * @group Props
17
+ */
10
18
  set value(value) {
11
19
  this._value = value;
12
20
  this.onChange(value);
@@ -17,15 +25,56 @@ export class CpsCheckboxComponent {
17
25
  constructor(_control, _elementRef) {
18
26
  this._control = _control;
19
27
  this._elementRef = _elementRef;
28
+ /**
29
+ * Label of the checkbox.
30
+ * @group Props
31
+ */
20
32
  this.label = '';
33
+ /**
34
+ * Whether checkbox is disabled.
35
+ * @group Props
36
+ */
21
37
  this.disabled = false;
38
+ /**
39
+ * When it is not an empty string, an info icon is displayed to show text for more info.
40
+ * @group Props
41
+ */
22
42
  this.infoTooltip = '';
43
+ /**
44
+ * InfoTooltip class for styling.
45
+ * @group Props
46
+ */
23
47
  this.infoTooltipClass = 'cps-tooltip-content';
48
+ /**
49
+ * Size of infoTooltip, of type number denoting pixels or string.
50
+ * @group Props
51
+ */
24
52
  this.infoTooltipMaxWidth = '100%';
53
+ /**
54
+ * Whether the infoTooltip is persistent.
55
+ * @group Props
56
+ */
25
57
  this.infoTooltipPersistent = false;
58
+ /**
59
+ * Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.
60
+ * @group Props
61
+ */
26
62
  this.infoTooltipPosition = 'top';
63
+ /**
64
+ * Name of the icon.
65
+ * @group Props
66
+ */
27
67
  this.icon = '';
68
+ /**
69
+ * Color of the icon.
70
+ * @group Props
71
+ */
28
72
  this.iconColor = 'text-dark';
73
+ /**
74
+ * Callback to invoke on value change.
75
+ * @param {boolean} boolean - value changed.
76
+ * @group Emits
77
+ */
29
78
  this.valueChanged = new EventEmitter();
30
79
  this._value = false;
31
80
  // eslint-disable-next-line @typescript-eslint/no-empty-function
@@ -97,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
97
146
  }], valueChanged: [{
98
147
  type: Output
99
148
  }] } });
100
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-checkbox.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-checkbox/cps-checkbox.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-checkbox/cps-checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n  Self\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\nimport { CpsTooltipPosition } from '../../directives/cps-tooltip.directive';\nimport { CpsIconComponent, IconType } from '../cps-icon/cps-icon.component';\nimport { getCSSColor } from '../../utils/colors-utils';\n\n@Component({\n  standalone: true,\n  imports: [CommonModule, CpsInfoCircleComponent, CpsIconComponent],\n  selector: 'cps-checkbox',\n  templateUrl: './cps-checkbox.component.html',\n  styleUrls: ['./cps-checkbox.component.scss']\n})\nexport class CpsCheckboxComponent implements OnInit, ControlValueAccessor {\n  @Input() label = '';\n  @Input() disabled = false;\n  @Input() infoTooltip = '';\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n  @Input() infoTooltipPersistent = false;\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n  @Input() icon: IconType = '';\n  @Input() iconColor = 'text-dark';\n\n  @Input() set value(value: boolean) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): boolean {\n    return this._value;\n  }\n\n  @Output() valueChanged = new EventEmitter<boolean>();\n\n  private _value = false;\n\n  constructor(\n    @Self() @Optional() private _control: NgControl,\n    private _elementRef: ElementRef<HTMLElement>\n  ) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this.iconColor = getCSSColor(this.iconColor);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: boolean) {\n    this.value = value;\n  }\n\n  updateValueEvent(event: any) {\n    event.preventDefault();\n    if (this.disabled) return;\n    this._updateValue(!this.value);\n  }\n\n  private _updateValue(value: boolean) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  focus() {\n    this._elementRef?.nativeElement?.querySelector('input')?.focus();\n  }\n}\n","<div class=\"cps-checkbox-container\">\n  <label\n    class=\"cps-checkbox\"\n    [ngClass]=\"{\n      'cps-checkbox-disabled': disabled\n    }\">\n    <input\n      type=\"checkbox\"\n      [disabled]=\"disabled\"\n      [checked]=\"value\"\n      (change)=\"updateValueEvent($event)\" />\n    <span class=\"cps-checkbox-indicator\"></span>\n    <cps-icon\n      class=\"cps-checkbox-icon\"\n      *ngIf=\"icon\"\n      [icon]=\"icon\"\n      size=\"small\"\n      [color]=\"disabled ? 'text-light' : iconColor\">\n    </cps-icon>\n    <span *ngIf=\"label\" class=\"cps-checkbox-label\">{{ label }}</span>\n  </label>\n  <cps-info-circle\n    *ngIf=\"infoTooltip\"\n    class=\"cps-checkbox-info-circle\"\n    size=\"xsmall\"\n    [tooltipPosition]=\"infoTooltipPosition\"\n    [tooltipContentClass]=\"infoTooltipClass\"\n    [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n    [tooltipPersistent]=\"infoTooltipPersistent\"\n    [tooltipText]=\"infoTooltip\">\n  </cps-info-circle>\n</div>\n"]}
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-checkbox.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-checkbox/cps-checkbox.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-checkbox/cps-checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnInit,\n  Optional,\n  Output,\n  Self\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl } from '@angular/forms';\nimport { CpsInfoCircleComponent } from '../cps-info-circle/cps-info-circle.component';\nimport { CpsTooltipPosition } from '../../directives/cps-tooltip.directive';\nimport { CpsIconComponent, IconType } from '../cps-icon/cps-icon.component';\nimport { getCSSColor } from '../../utils/colors-utils';\n\n/**\n * CpsCheckboxComponent is a checkbox element.\n * @group Components\n */\n@Component({\n  standalone: true,\n  imports: [CommonModule, CpsInfoCircleComponent, CpsIconComponent],\n  selector: 'cps-checkbox',\n  templateUrl: './cps-checkbox.component.html',\n  styleUrls: ['./cps-checkbox.component.scss']\n})\nexport class CpsCheckboxComponent implements OnInit, ControlValueAccessor {\n  /**\n   * Label of the checkbox.\n   * @group Props\n   */\n  @Input() label = '';\n\n  /**\n   * Whether checkbox is disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * When it is not an empty string, an info icon is displayed to show text for more info.\n   * @group Props\n   */\n  @Input() infoTooltip = '';\n\n  /**\n   * InfoTooltip class for styling.\n   * @group Props\n   */\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n\n  /**\n   * Size of infoTooltip, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n\n  /**\n   * Whether the infoTooltip is persistent.\n   * @group Props\n   */\n  @Input() infoTooltipPersistent = false;\n\n  /**\n   * Position of infoTooltip, it can be 'top', 'bottom', 'left' or 'right'.\n   * @group Props\n   */\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * Name of the icon.\n   * @group Props\n   */\n  @Input() icon: IconType = '';\n\n  /**\n   * Color of the icon.\n   * @group Props\n   */\n  @Input() iconColor = 'text-dark';\n\n  /**\n   * Value of the checkbox.\n   * @group Props\n   */\n  @Input() set value(value: boolean) {\n    this._value = value;\n    this.onChange(value);\n  }\n\n  get value(): boolean {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {boolean} boolean - value changed.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<boolean>();\n\n  private _value = false;\n\n  constructor(\n    @Self() @Optional() private _control: NgControl,\n    private _elementRef: ElementRef<HTMLElement>\n  ) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this.iconColor = getCSSColor(this.iconColor);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  writeValue(value: boolean) {\n    this.value = value;\n  }\n\n  updateValueEvent(event: any) {\n    event.preventDefault();\n    if (this.disabled) return;\n    this._updateValue(!this.value);\n  }\n\n  private _updateValue(value: boolean) {\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  setDisabledState(disabled: boolean) {}\n\n  focus() {\n    this._elementRef?.nativeElement?.querySelector('input')?.focus();\n  }\n}\n","<div class=\"cps-checkbox-container\">\n  <label\n    class=\"cps-checkbox\"\n    [ngClass]=\"{\n      'cps-checkbox-disabled': disabled\n    }\">\n    <input\n      type=\"checkbox\"\n      [disabled]=\"disabled\"\n      [checked]=\"value\"\n      (change)=\"updateValueEvent($event)\" />\n    <span class=\"cps-checkbox-indicator\"></span>\n    <cps-icon\n      class=\"cps-checkbox-icon\"\n      *ngIf=\"icon\"\n      [icon]=\"icon\"\n      size=\"small\"\n      [color]=\"disabled ? 'text-light' : iconColor\">\n    </cps-icon>\n    <span *ngIf=\"label\" class=\"cps-checkbox-label\">{{ label }}</span>\n  </label>\n  <cps-info-circle\n    *ngIf=\"infoTooltip\"\n    class=\"cps-checkbox-info-circle\"\n    size=\"xsmall\"\n    [tooltipPosition]=\"infoTooltipPosition\"\n    [tooltipContentClass]=\"infoTooltipClass\"\n    [tooltipMaxWidth]=\"infoTooltipMaxWidth\"\n    [tooltipPersistent]=\"infoTooltipPersistent\"\n    [tooltipText]=\"infoTooltip\">\n  </cps-info-circle>\n</div>\n"]}
@@ -3,14 +3,47 @@ import { CpsIconComponent } from '../cps-icon/cps-icon.component';
3
3
  import { CommonModule } from '@angular/common';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/common";
6
+ /**
7
+ * CpsChipComponent represents a chip element.
8
+ * @group Components
9
+ */
6
10
  export class CpsChipComponent {
7
11
  constructor() {
12
+ /**
13
+ * Label of the chip element.
14
+ * @group Props
15
+ */
8
16
  this.label = '';
17
+ /**
18
+ * Name of the icon.
19
+ * @group Props
20
+ */
9
21
  this.icon = '';
22
+ /**
23
+ * Color of the icon.
24
+ * @group Props
25
+ */
10
26
  this.iconColor = 'text-darkest';
27
+ /**
28
+ * Position of the icon, it can be 'before' or 'after'. Defaults to 'before'.
29
+ * @group Props
30
+ */
11
31
  this.iconPosition = 'before';
32
+ /**
33
+ * Option for closing a chip element.
34
+ * @group Props
35
+ */
12
36
  this.closable = false;
37
+ /**
38
+ * Whether chip is disabled.
39
+ * @group Props
40
+ */
13
41
  this.disabled = false;
42
+ /**
43
+ * Callback to invoke on chip close.
44
+ * @param {string} string - Chip closed.
45
+ * @group Emits
46
+ */
14
47
  this.closed = new EventEmitter();
15
48
  this.classesList = ['cps-chip'];
16
49
  }
@@ -58,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
58
91
  }], closed: [{
59
92
  type: Output
60
93
  }] } });
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLWNoaXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY3BzLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY3BzLWNoaXAvY3BzLWNoaXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY3BzLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY3BzLWNoaXAvY3BzLWNoaXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUVMLE1BQU0sRUFDUCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsZ0JBQWdCLEVBQVksTUFBTSxnQ0FBZ0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7OztBQVMvQyxNQUFNLE9BQU8sZ0JBQWdCO0lBUDdCO1FBUVcsVUFBSyxHQUFHLEVBQUUsQ0FBQztRQUNYLFNBQUksR0FBYSxFQUFFLENBQUM7UUFDcEIsY0FBUyxHQUFHLGNBQWMsQ0FBQztRQUMzQixpQkFBWSxHQUF1QixRQUFRLENBQUM7UUFDNUMsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUNqQixhQUFRLEdBQUcsS0FBSyxDQUFDO1FBRWhCLFdBQU0sR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBRTlDLGdCQUFXLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQztLQTJCNUI7SUF6QkMsV0FBVztRQUNULElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztJQUNwQixDQUFDO0lBRUQsVUFBVTtRQUNSLElBQUksSUFBSSxDQUFDLFFBQVE7WUFBRSxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO1FBRTlELElBQUksSUFBSSxDQUFDLElBQUksSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFO1lBQzNCLFFBQVEsSUFBSSxDQUFDLFlBQVksRUFBRTtnQkFDekIsS0FBSyxRQUFRLENBQUMsQ0FBQztvQkFDYixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyx1QkFBdUIsQ0FBQyxDQUFDO29CQUMvQyxNQUFNO2lCQUNQO2dCQUNELEtBQUssT0FBTyxDQUFDLENBQUM7b0JBQ1osSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsc0JBQXNCLENBQUMsQ0FBQztvQkFDOUMsTUFBTTtpQkFDUDthQUNGO1NBQ0Y7SUFDSCxDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQVU7UUFDckIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3hCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUMvQixDQUFDOzs2R0FwQ1UsZ0JBQWdCO2lHQUFoQixnQkFBZ0Isb1FDakI3QiwyWkFlQSxzbkNESFksWUFBWSxpT0FBRSxnQkFBZ0I7MkZBSzdCLGdCQUFnQjtrQkFQNUIsU0FBUztpQ0FDSSxJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsZ0JBQWdCLENBQUMsWUFDL0IsVUFBVTs4QkFLWCxLQUFLO3NCQUFiLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csWUFBWTtzQkFBcEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFFBQVE7c0JBQWhCLEtBQUs7Z0JBRUksTUFBTTtzQkFBZixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQ29tcG9uZW50LFxuICBFdmVudEVtaXR0ZXIsXG4gIElucHV0LFxuICBPbkNoYW5nZXMsXG4gIE91dHB1dFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENwc0ljb25Db21wb25lbnQsIEljb25UeXBlIH0gZnJvbSAnLi4vY3BzLWljb24vY3BzLWljb24uY29tcG9uZW50JztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5cbkBDb21wb25lbnQoe1xuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBDcHNJY29uQ29tcG9uZW50XSxcbiAgc2VsZWN0b3I6ICdjcHMtY2hpcCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9jcHMtY2hpcC5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2Nwcy1jaGlwLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgQ3BzQ2hpcENvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gIEBJbnB1dCgpIGxhYmVsID0gJyc7XG4gIEBJbnB1dCgpIGljb246IEljb25UeXBlID0gJyc7XG4gIEBJbnB1dCgpIGljb25Db2xvciA9ICd0ZXh0LWRhcmtlc3QnO1xuICBASW5wdXQoKSBpY29uUG9zaXRpb246ICdiZWZvcmUnIHwgJ2FmdGVyJyA9ICdiZWZvcmUnO1xuICBASW5wdXQoKSBjbG9zYWJsZSA9IGZhbHNlO1xuICBASW5wdXQoKSBkaXNhYmxlZCA9IGZhbHNlO1xuXG4gIEBPdXRwdXQoKSBjbG9zZWQgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICBjbGFzc2VzTGlzdCA9IFsnY3BzLWNoaXAnXTtcblxuICBuZ09uQ2hhbmdlcygpIHtcbiAgICB0aGlzLnNldENsYXNzZXMoKTtcbiAgfVxuXG4gIHNldENsYXNzZXMoKSB7XG4gICAgaWYgKHRoaXMuZGlzYWJsZWQpIHRoaXMuY2xhc3Nlc0xpc3QucHVzaCgnY3BzLWNoaXAtZGlzYWJsZWQnKTtcblxuICAgIGlmICh0aGlzLmljb24gJiYgdGhpcy5sYWJlbCkge1xuICAgICAgc3dpdGNoICh0aGlzLmljb25Qb3NpdGlvbikge1xuICAgICAgICBjYXNlICdiZWZvcmUnOiB7XG4gICAgICAgICAgdGhpcy5jbGFzc2VzTGlzdC5wdXNoKCdjcHMtY2hpcC0taWNvbi1iZWZvcmUnKTtcbiAgICAgICAgICBicmVhaztcbiAgICAgICAgfVxuICAgICAgICBjYXNlICdhZnRlcic6IHtcbiAgICAgICAgICB0aGlzLmNsYXNzZXNMaXN0LnB1c2goJ2Nwcy1jaGlwLS1pY29uLWFmdGVyJyk7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9XG4gIH1cblxuICBvbkNsb3NlQ2xpY2soZXZlbnQ6IGFueSkge1xuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgIHRoaXMuY2xvc2VkLmVtaXQodGhpcy5sYWJlbCk7XG4gIH1cbn1cbiIsIjxkaXYgW25nQ2xhc3NdPVwiY2xhc3Nlc0xpc3RcIj5cbiAgPGNwcy1pY29uXG4gICAgKm5nSWY9XCJpY29uXCJcbiAgICBjbGFzcz1cImNwcy1jaGlwLWljb25cIlxuICAgIFtpY29uXT1cImljb25cIlxuICAgIFtjb2xvcl09XCJpY29uQ29sb3JcIj48L2Nwcy1pY29uPlxuICA8c3BhbiBjbGFzcz1cImNwcy1jaGlwLWxhYmVsXCI+e3sgbGFiZWwgfX08L3NwYW4+XG4gIDxjcHMtaWNvblxuICAgICpuZ0lmPVwiY2xvc2FibGVcIlxuICAgIGNsYXNzPVwiY3BzLWNoaXAtY2xvc2UtaWNvblwiXG4gICAgaWNvbj1cImNsb3NlLXhcIlxuICAgIHNpemU9XCJ4c21hbGxcIlxuICAgIGNvbG9yPVwidGV4dC1kYXJrZXN0XCJcbiAgICAoY2xpY2spPVwib25DbG9zZUNsaWNrKCRldmVudClcIj48L2Nwcy1pY29uPlxuPC9kaXY+XG4iXX0=
94
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3BzLWNoaXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY3BzLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY3BzLWNoaXAvY3BzLWNoaXAuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY3BzLXVpLWtpdC9zcmMvbGliL2NvbXBvbmVudHMvY3BzLWNoaXAvY3BzLWNoaXAuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUVMLE1BQU0sRUFDUCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsZ0JBQWdCLEVBQVksTUFBTSxnQ0FBZ0MsQ0FBQztBQUM1RSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7OztBQUUvQzs7O0dBR0c7QUFRSCxNQUFNLE9BQU8sZ0JBQWdCO0lBUDdCO1FBUUU7OztXQUdHO1FBQ00sVUFBSyxHQUFHLEVBQUUsQ0FBQztRQUVwQjs7O1dBR0c7UUFDTSxTQUFJLEdBQWEsRUFBRSxDQUFDO1FBRTdCOzs7V0FHRztRQUNNLGNBQVMsR0FBRyxjQUFjLENBQUM7UUFFcEM7OztXQUdHO1FBQ00saUJBQVksR0FBdUIsUUFBUSxDQUFDO1FBRXJEOzs7V0FHRztRQUNNLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFFMUI7OztXQUdHO1FBQ00sYUFBUSxHQUFHLEtBQUssQ0FBQztRQUUxQjs7OztXQUlHO1FBQ08sV0FBTSxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFFOUMsZ0JBQVcsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDO0tBMkI1QjtJQXpCQyxXQUFXO1FBQ1QsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ3BCLENBQUM7SUFFRCxVQUFVO1FBQ1IsSUFBSSxJQUFJLENBQUMsUUFBUTtZQUFFLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLENBQUM7UUFFOUQsSUFBSSxJQUFJLENBQUMsSUFBSSxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDM0IsUUFBUSxJQUFJLENBQUMsWUFBWSxFQUFFO2dCQUN6QixLQUFLLFFBQVEsQ0FBQyxDQUFDO29CQUNiLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLHVCQUF1QixDQUFDLENBQUM7b0JBQy9DLE1BQU07aUJBQ1A7Z0JBQ0QsS0FBSyxPQUFPLENBQUMsQ0FBQztvQkFDWixJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO29CQUM5QyxNQUFNO2lCQUNQO2FBQ0Y7U0FDRjtJQUNILENBQUM7SUFFRCxZQUFZLENBQUMsS0FBVTtRQUNyQixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDeEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQy9CLENBQUM7OzZHQXRFVSxnQkFBZ0I7aUdBQWhCLGdCQUFnQixvUUNyQjdCLDJaQWVBLHNuQ0RDWSxZQUFZLGlPQUFFLGdCQUFnQjsyRkFLN0IsZ0JBQWdCO2tCQVA1QixTQUFTO2lDQUNJLElBQUksV0FDUCxDQUFDLFlBQVksRUFBRSxnQkFBZ0IsQ0FBQyxZQUMvQixVQUFVOzhCQVNYLEtBQUs7c0JBQWIsS0FBSztnQkFNRyxJQUFJO3NCQUFaLEtBQUs7Z0JBTUcsU0FBUztzQkFBakIsS0FBSztnQkFNRyxZQUFZO3NCQUFwQixLQUFLO2dCQU1HLFFBQVE7c0JBQWhCLEtBQUs7Z0JBTUcsUUFBUTtzQkFBaEIsS0FBSztnQkFPSSxNQUFNO3NCQUFmLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBDb21wb25lbnQsXG4gIEV2ZW50RW1pdHRlcixcbiAgSW5wdXQsXG4gIE9uQ2hhbmdlcyxcbiAgT3V0cHV0XG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ3BzSWNvbkNvbXBvbmVudCwgSWNvblR5cGUgfSBmcm9tICcuLi9jcHMtaWNvbi9jcHMtaWNvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuLyoqXG4gKiBDcHNDaGlwQ29tcG9uZW50IHJlcHJlc2VudHMgYSBjaGlwIGVsZW1lbnQuXG4gKiBAZ3JvdXAgQ29tcG9uZW50c1xuICovXG5AQ29tcG9uZW50KHtcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgQ3BzSWNvbkNvbXBvbmVudF0sXG4gIHNlbGVjdG9yOiAnY3BzLWNoaXAnLFxuICB0ZW1wbGF0ZVVybDogJy4vY3BzLWNoaXAuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jcHMtY2hpcC5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIENwc0NoaXBDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xuICAvKipcbiAgICogTGFiZWwgb2YgdGhlIGNoaXAgZWxlbWVudC5cbiAgICogQGdyb3VwIFByb3BzXG4gICAqL1xuICBASW5wdXQoKSBsYWJlbCA9ICcnO1xuXG4gIC8qKlxuICAgKiBOYW1lIG9mIHRoZSBpY29uLlxuICAgKiBAZ3JvdXAgUHJvcHNcbiAgICovXG4gIEBJbnB1dCgpIGljb246IEljb25UeXBlID0gJyc7XG5cbiAgLyoqXG4gICAqIENvbG9yIG9mIHRoZSBpY29uLlxuICAgKiBAZ3JvdXAgUHJvcHNcbiAgICovXG4gIEBJbnB1dCgpIGljb25Db2xvciA9ICd0ZXh0LWRhcmtlc3QnO1xuXG4gIC8qKlxuICAgKiBQb3NpdGlvbiBvZiB0aGUgaWNvbiwgaXQgY2FuIGJlICdiZWZvcmUnIG9yICdhZnRlcicuIERlZmF1bHRzIHRvICdiZWZvcmUnLlxuICAgKiBAZ3JvdXAgUHJvcHNcbiAgICovXG4gIEBJbnB1dCgpIGljb25Qb3NpdGlvbjogJ2JlZm9yZScgfCAnYWZ0ZXInID0gJ2JlZm9yZSc7XG5cbiAgLyoqXG4gICAqIE9wdGlvbiBmb3IgY2xvc2luZyBhIGNoaXAgZWxlbWVudC5cbiAgICogQGdyb3VwIFByb3BzXG4gICAqL1xuICBASW5wdXQoKSBjbG9zYWJsZSA9IGZhbHNlO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIGNoaXAgaXMgZGlzYWJsZWQuXG4gICAqIEBncm91cCBQcm9wc1xuICAgKi9cbiAgQElucHV0KCkgZGlzYWJsZWQgPSBmYWxzZTtcblxuICAvKipcbiAgICogQ2FsbGJhY2sgdG8gaW52b2tlIG9uIGNoaXAgY2xvc2UuXG4gICAqIEBwYXJhbSB7c3RyaW5nfSBzdHJpbmcgLSBDaGlwIGNsb3NlZC5cbiAgICogQGdyb3VwIEVtaXRzXG4gICAqL1xuICBAT3V0cHV0KCkgY2xvc2VkID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgY2xhc3Nlc0xpc3QgPSBbJ2Nwcy1jaGlwJ107XG5cbiAgbmdPbkNoYW5nZXMoKSB7XG4gICAgdGhpcy5zZXRDbGFzc2VzKCk7XG4gIH1cblxuICBzZXRDbGFzc2VzKCkge1xuICAgIGlmICh0aGlzLmRpc2FibGVkKSB0aGlzLmNsYXNzZXNMaXN0LnB1c2goJ2Nwcy1jaGlwLWRpc2FibGVkJyk7XG5cbiAgICBpZiAodGhpcy5pY29uICYmIHRoaXMubGFiZWwpIHtcbiAgICAgIHN3aXRjaCAodGhpcy5pY29uUG9zaXRpb24pIHtcbiAgICAgICAgY2FzZSAnYmVmb3JlJzoge1xuICAgICAgICAgIHRoaXMuY2xhc3Nlc0xpc3QucHVzaCgnY3BzLWNoaXAtLWljb24tYmVmb3JlJyk7XG4gICAgICAgICAgYnJlYWs7XG4gICAgICAgIH1cbiAgICAgICAgY2FzZSAnYWZ0ZXInOiB7XG4gICAgICAgICAgdGhpcy5jbGFzc2VzTGlzdC5wdXNoKCdjcHMtY2hpcC0taWNvbi1hZnRlcicpO1xuICAgICAgICAgIGJyZWFrO1xuICAgICAgICB9XG4gICAgICB9XG4gICAgfVxuICB9XG5cbiAgb25DbG9zZUNsaWNrKGV2ZW50OiBhbnkpIHtcbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcbiAgICB0aGlzLmNsb3NlZC5lbWl0KHRoaXMubGFiZWwpO1xuICB9XG59XG4iLCI8ZGl2IFtuZ0NsYXNzXT1cImNsYXNzZXNMaXN0XCI+XG4gIDxjcHMtaWNvblxuICAgICpuZ0lmPVwiaWNvblwiXG4gICAgY2xhc3M9XCJjcHMtY2hpcC1pY29uXCJcbiAgICBbaWNvbl09XCJpY29uXCJcbiAgICBbY29sb3JdPVwiaWNvbkNvbG9yXCI+PC9jcHMtaWNvbj5cbiAgPHNwYW4gY2xhc3M9XCJjcHMtY2hpcC1sYWJlbFwiPnt7IGxhYmVsIH19PC9zcGFuPlxuICA8Y3BzLWljb25cbiAgICAqbmdJZj1cImNsb3NhYmxlXCJcbiAgICBjbGFzcz1cImNwcy1jaGlwLWNsb3NlLWljb25cIlxuICAgIGljb249XCJjbG9zZS14XCJcbiAgICBzaXplPVwieHNtYWxsXCJcbiAgICBjb2xvcj1cInRleHQtZGFya2VzdFwiXG4gICAgKGNsaWNrKT1cIm9uQ2xvc2VDbGljaygkZXZlbnQpXCI+PC9jcHMtaWNvbj5cbjwvZGl2PlxuIl19
@@ -10,7 +10,15 @@ import * as i0 from "@angular/core";
10
10
  import * as i1 from "@angular/forms";
11
11
  import * as i2 from "primeng/calendar";
12
12
  import * as i3 from "@angular/common";
13
+ /**
14
+ * CpsDatepickerComponent is an input component to provide date input.
15
+ * @group Components
16
+ */
13
17
  export class CpsDatepickerComponent {
18
+ /**
19
+ * Value of the datepicker.
20
+ * @group Props
21
+ */
14
22
  set value(value) {
15
23
  this._value = value;
16
24
  this.stringDate = this._dateToString(value);
@@ -21,22 +29,91 @@ export class CpsDatepickerComponent {
21
29
  }
22
30
  constructor(_control) {
23
31
  this._control = _control;
32
+ /**
33
+ * Label of the datepicker element.
34
+ * @group Props
35
+ */
24
36
  this.label = '';
37
+ /**
38
+ * Whether datepicker is disabled.
39
+ * @group Props
40
+ */
25
41
  this.disabled = false;
42
+ /**
43
+ * Width of the datepicker of type number denoting pixels or string.
44
+ * @group Props
45
+ */
26
46
  this.width = '100%';
47
+ /**
48
+ * Placeholder text.
49
+ * @group Props
50
+ */
27
51
  this.placeholder = 'MM/DD/YYYY';
52
+ /**
53
+ * Bottom hint text for the input field.
54
+ * @group Props
55
+ */
28
56
  this.hint = '';
57
+ /**
58
+ * When enabled, a clear icon is displayed to clear the value.
59
+ * @group Props
60
+ */
29
61
  this.clearable = false;
62
+ /**
63
+ * Hides hint and validation errors.
64
+ * @group Props
65
+ */
30
66
  this.hideDetails = false;
67
+ /**
68
+ * Whether the component should have persistent clear icon.
69
+ * @group Props
70
+ */
31
71
  this.persistentClear = false;
72
+ /**
73
+ * Whether to show button to be able to select today's date.
74
+ * @group Props
75
+ */
32
76
  this.showTodayButton = true;
77
+ /**
78
+ * Whether the datepicker dropdown should open on input focus.
79
+ * @group Props
80
+ */
33
81
  this.openOnInputFocus = false;
82
+ /**
83
+ * When it is not an empty string, an info icon is displayed to show text for more info.
84
+ * @group Props
85
+ */
34
86
  this.infoTooltip = '';
87
+ /**
88
+ * InfoTooltip class for styling.
89
+ * @group Props
90
+ */
35
91
  this.infoTooltipClass = 'cps-tooltip-content';
92
+ /**
93
+ * Size of infoTooltip, of type number denoting pixels or string.
94
+ * @group Props
95
+ */
36
96
  this.infoTooltipMaxWidth = '100%';
97
+ /**
98
+ * Whether the infoTooltip is persistent.
99
+ * @group Props
100
+ */
37
101
  this.infoTooltipPersistent = false;
102
+ /**
103
+ * Position of infoTooltip, it can be "top", "bottom", "left" or "right".
104
+ * @group Props
105
+ */
38
106
  this.infoTooltipPosition = 'top';
107
+ /**
108
+ * Styling appearance of datepicker input, it can be 'outlined', 'underlined' or 'borderless.
109
+ * @group Props
110
+ */
39
111
  this.appearance = 'outlined';
112
+ /**
113
+ * Callback to invoke on value change.
114
+ * @param {Date | null} value - value change.
115
+ * @group Emits
116
+ */
40
117
  this.valueChanged = new EventEmitter();
41
118
  this.stringDate = '';
42
119
  this.isOpened = false;
@@ -302,4 +379,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
302
379
  type: ViewChild,
303
380
  args: ['calendarMenu']
304
381
  }] } });
305
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-datepicker.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-datepicker/cps-datepicker.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-datepicker/cps-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\nimport { CalendarModule } from 'primeng/calendar';\nimport { CpsInputComponent } from '../cps-input/cps-input.component';\nimport { Subscription } from 'rxjs';\nimport { convertSize } from '../../utils/internal/size-utils';\nimport { CpsTooltipPosition } from '../../directives/cps-tooltip.directive';\nimport { CpsMenuComponent } from '../cps-menu/cps-menu.component';\n\nexport type CpsDatepickerAppearanceType =\n  | 'outlined'\n  | 'underlined'\n  | 'borderless';\n\n@Component({\n  standalone: true,\n  imports: [\n    CpsInputComponent,\n    CalendarModule,\n    CommonModule,\n    FormsModule,\n    CpsMenuComponent\n  ],\n  selector: 'cps-datepicker',\n  templateUrl: './cps-datepicker.component.html',\n  styleUrls: ['./cps-datepicker.component.scss']\n})\nexport class CpsDatepickerComponent\n  implements ControlValueAccessor, OnInit, OnDestroy\n{\n  @Input() label = '';\n  @Input() disabled = false;\n  @Input() width: number | string = '100%';\n  @Input() placeholder = 'MM/DD/YYYY';\n  @Input() hint = '';\n  @Input() clearable = false;\n  @Input() hideDetails = false;\n  @Input() persistentClear = false;\n  @Input() showTodayButton = true;\n  @Input() openOnInputFocus = false;\n  @Input() infoTooltip = '';\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n  @Input() infoTooltipPersistent = false;\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n  @Input() appearance: CpsDatepickerAppearanceType = 'outlined';\n\n  @Input()\n  minDate!: Date;\n\n  @Input()\n  maxDate!: Date;\n\n  @Input() set value(value: Date | null) {\n    this._value = value;\n    this.stringDate = this._dateToString(value);\n    this.onChange(value);\n  }\n\n  get value(): Date | null {\n    return this._value;\n  }\n\n  @Output() valueChanged = new EventEmitter<Date | null>();\n\n  @ViewChild('datepickerInput')\n  datepickerInput!: CpsInputComponent;\n\n  @ViewChild('calendarMenu')\n  calendarMenu!: CpsMenuComponent;\n\n  stringDate = '';\n  isOpened = false;\n  error = '';\n  cvtWidth = '';\n\n  private _statusChangesSubscription: Subscription = new Subscription();\n  private _value!: Date | null;\n\n  constructor(@Self() @Optional() private _control: NgControl) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this.cvtWidth = convertSize(this.width);\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    ) as Subscription;\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  onInputValueChanged(val: string) {\n    this.stringDate = val;\n    if (!val) {\n      this._updateValue(null);\n      return;\n    }\n    const dt = this._stringToDate(val);\n    if (dt) this._updateValue(dt);\n  }\n\n  writeValue(value: Date | null) {\n    this.value = value;\n  }\n\n  private _updateValue(value: Date | null) {\n    if (this.value === value) return;\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  private _updateValueFromInputString() {\n    if (!this.stringDate) {\n      this._updateValue(null);\n    } else {\n      this._updateValue(this._stringToDate(this.stringDate));\n    }\n  }\n\n  private _checkDateFormat(dateString: string): boolean {\n    if (!/^\\d\\d\\/\\d\\d\\/\\d\\d\\d\\d$/.test(dateString)) {\n      return false;\n    }\n    const parts = dateString.split('/').map((p) => parseInt(p, 10));\n    parts[0] -= 1;\n    const d = new Date(parts[2], parts[0], parts[1]);\n    return (\n      d.getMonth() === parts[0] &&\n      d.getDate() === parts[1] &&\n      d.getFullYear() === parts[2]\n    );\n  }\n\n  private _checkDateInRange(date: Date, minDate: Date, maxDate: Date): boolean {\n    if (!minDate && !maxDate) return true;\n    if (minDate && maxDate) {\n      return (\n        date.getTime() >= minDate.getTime() &&\n        date.getTime() <= maxDate.getTime()\n      );\n    }\n    if (minDate) {\n      return date.getTime() >= minDate.getTime();\n    }\n    return date.getTime() <= maxDate.getTime();\n  }\n\n  private _dateToString(dateVal: Date | null): string {\n    if (!dateVal) return '';\n    let month = '' + (dateVal.getMonth() + 1);\n    if (month.length < 2) month = '0' + month;\n    let day = '' + dateVal.getDate();\n    if (day.length < 2) day = '0' + day;\n    const year = dateVal.getFullYear();\n    return `${month}/${day}/${year}`;\n  }\n\n  private _stringToDate(dateString: string): Date | null {\n    if (!this._checkDateFormat(dateString)) return null;\n    const [month, day, year] = dateString.split('/');\n    const dt = new Date(`${year}-${month}-${day}`);\n    const inRange = this._checkDateInRange(dt, this.minDate, this.maxDate);\n    return inRange ? dt : null;\n  }\n\n  private _checkErrors() {\n    if (this.stringDate && !this._stringToDate(this.stringDate)) {\n      this.error = 'Date is invalid';\n      return;\n    }\n\n    const errors = this._control?.errors;\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this.error = message || 'Unknown error';\n  }\n\n  onClearCalendarDate() {\n    this.onSelectCalendarDate(null);\n  }\n\n  onSelectCalendarDate(dateVal: Date | null) {\n    this.toggleCalendar(false);\n    this.writeValue(dateVal);\n    this.onChange(dateVal);\n    this.valueChanged.emit(dateVal);\n  }\n\n  onInputBlur() {\n    if (this.isOpened) return;\n    this._control?.control?.markAsTouched();\n    this._updateValueFromInputString();\n    this._checkErrors();\n  }\n\n  onInputEnterClicked() {\n    if (!this.isOpened) return;\n    this._control?.control?.markAsTouched();\n    this._updateValueFromInputString();\n    this._checkErrors();\n    this.toggleCalendar(false);\n  }\n\n  onClickCalendarIcon() {\n    if (this.disabled) return;\n    if (this.isOpened) this._updateValueFromInputString();\n    this.toggleCalendar();\n  }\n\n  onBeforeCalendarHidden() {\n    if (this.disabled || !this.isOpened) return;\n    this._updateValueFromInputString();\n    this.toggleCalendar(false);\n  }\n\n  onInputFocus() {\n    if (this.openOnInputFocus) this.toggleCalendar(true);\n  }\n\n  onInputClear() {\n    if (this.isOpened) this.focusInput();\n  }\n\n  onCalendarContentClick() {\n    if (this.isOpened) this.focusInput();\n  }\n\n  focusInput() {\n    this.datepickerInput.focus();\n  }\n\n  toggleCalendar(show?: boolean) {\n    if (this.disabled || this.isOpened === show) return;\n\n    const target =\n      this.datepickerInput.elementRef.nativeElement.querySelector(\n        '.cps-input-wrap'\n      );\n\n    if (typeof show === 'boolean') {\n      if (show) {\n        this.calendarMenu.show({\n          target\n        });\n      } else {\n        this.calendarMenu.hide();\n      }\n    } else {\n      this.calendarMenu.toggle({\n        target\n      });\n    }\n\n    this.isOpened = this.calendarMenu.isVisible();\n\n    if (!this.isOpened) {\n      this._control?.control?.markAsTouched();\n      this._checkErrors();\n    } else {\n      this.focusInput();\n    }\n  }\n}\n","<div\n  class=\"cps-datepicker\"\n  [ngStyle]=\"{ width: cvtWidth }\"\n  [class.focused]=\"isOpened\">\n  <cps-input\n    #datepickerInput\n    [disabled]=\"disabled\"\n    [value]=\"stringDate\"\n    [label]=\"label\"\n    prefixIcon=\"datepicker\"\n    [placeholder]=\"placeholder\"\n    (prefixIconClicked)=\"onClickCalendarIcon()\"\n    [prefixIconClickable]=\"true\"\n    (focused)=\"onInputFocus()\"\n    (valueChanged)=\"onInputValueChanged($event)\"\n    [clearable]=\"clearable\"\n    (blurred)=\"onInputBlur()\"\n    (cleared)=\"onInputClear()\"\n    (enterClicked)=\"onInputEnterClicked()\"\n    [width]=\"width\"\n    [hint]=\"hint\"\n    [hideDetails]=\"hideDetails\"\n    [infoTooltip]=\"infoTooltip\"\n    [infoTooltipClass]=\"infoTooltipClass\"\n    [infoTooltipMaxWidth]=\"infoTooltipMaxWidth\"\n    [infoTooltipPersistent]=\"infoTooltipPersistent\"\n    [persistentClear]=\"persistentClear\"\n    [appearance]=\"appearance\"\n    [error]=\"error\"></cps-input>\n  <cps-menu\n    #calendarMenu\n    [withArrow]=\"false\"\n    (beforeMenuHidden)=\"onBeforeCalendarHidden()\"\n    (contentClicked)=\"onCalendarContentClick()\"\n    [focusOnShow]=\"false\"\n    hideTransitionOptions=\"0s linear\"\n    containerClass=\"cps-datepicker-calendar-menu\">\n    <div class=\"cps-datepicker-calendar\">\n      <p-calendar\n        [(ngModel)]=\"value\"\n        [showIcon]=\"true\"\n        [showButtonBar]=\"showTodayButton\"\n        [inline]=\"true\"\n        (onSelect)=\"onSelectCalendarDate($event)\"\n        (onClearClick)=\"onClearCalendarDate()\"\n        [showOtherMonths]=\"false\"\n        [minDate]=\"minDate\"\n        [maxDate]=\"maxDate\">\n      </p-calendar>\n    </div>\n  </cps-menu>\n</div>\n"]}
382
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cps-datepicker.component.js","sourceRoot":"","sources":["../../../../../../projects/cps-ui-kit/src/lib/components/cps-datepicker/cps-datepicker.component.ts","../../../../../../projects/cps-ui-kit/src/lib/components/cps-datepicker/cps-datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  Self,\n  ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, FormsModule, NgControl } from '@angular/forms';\nimport { CalendarModule } from 'primeng/calendar';\nimport { CpsInputComponent } from '../cps-input/cps-input.component';\nimport { Subscription } from 'rxjs';\nimport { convertSize } from '../../utils/internal/size-utils';\nimport { CpsTooltipPosition } from '../../directives/cps-tooltip.directive';\nimport { CpsMenuComponent } from '../cps-menu/cps-menu.component';\n\nexport type CpsDatepickerAppearanceType =\n  | 'outlined'\n  | 'underlined'\n  | 'borderless';\n\n/**\n * CpsDatepickerComponent is an input component to provide date input.\n * @group Components\n */\n@Component({\n  standalone: true,\n  imports: [\n    CpsInputComponent,\n    CalendarModule,\n    CommonModule,\n    FormsModule,\n    CpsMenuComponent\n  ],\n  selector: 'cps-datepicker',\n  templateUrl: './cps-datepicker.component.html',\n  styleUrls: ['./cps-datepicker.component.scss']\n})\nexport class CpsDatepickerComponent\n  implements ControlValueAccessor, OnInit, OnDestroy\n{\n  /**\n   * Label of the datepicker element.\n   * @group Props\n   */\n  @Input() label = '';\n\n  /**\n   * Whether datepicker is disabled.\n   * @group Props\n   */\n  @Input() disabled = false;\n\n  /**\n   * Width of the datepicker of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() width: number | string = '100%';\n\n  /**\n   * Placeholder text.\n   * @group Props\n   */\n  @Input() placeholder = 'MM/DD/YYYY';\n\n  /**\n   * Bottom hint text for the input field.\n   * @group Props\n   */\n  @Input() hint = '';\n\n  /**\n   * When enabled, a clear icon is displayed to clear the value.\n   * @group Props\n   */\n  @Input() clearable = false;\n\n  /**\n   * Hides hint and validation errors.\n   * @group Props\n   */\n  @Input() hideDetails = false;\n\n  /**\n   * Whether the component should have persistent clear icon.\n   * @group Props\n   */\n  @Input() persistentClear = false;\n\n  /**\n   * Whether to show button to be able to select today's date.\n   * @group Props\n   */\n  @Input() showTodayButton = true;\n\n  /**\n   * Whether the datepicker dropdown should open on input focus.\n   * @group Props\n   */\n  @Input() openOnInputFocus = false;\n\n  /**\n   * When it is not an empty string, an info icon is displayed to show text for more info.\n   * @group Props\n   */\n  @Input() infoTooltip = '';\n\n  /**\n   * InfoTooltip class for styling.\n   * @group Props\n   */\n  @Input() infoTooltipClass = 'cps-tooltip-content';\n\n  /**\n   * Size of infoTooltip, of type number denoting pixels or string.\n   * @group Props\n   */\n  @Input() infoTooltipMaxWidth: number | string = '100%';\n\n  /**\n   * Whether the infoTooltip is persistent.\n   * @group Props\n   */\n  @Input() infoTooltipPersistent = false;\n\n  /**\n   * Position of infoTooltip, it can be \"top\", \"bottom\", \"left\" or \"right\".\n   * @group Props\n   */\n  @Input() infoTooltipPosition: CpsTooltipPosition = 'top';\n\n  /**\n   * Styling appearance of datepicker input, it can be 'outlined', 'underlined' or 'borderless.\n   * @group Props\n   */\n  @Input() appearance: CpsDatepickerAppearanceType = 'outlined';\n\n  /**\n   * Minimal date availalbe for selection.\n   * @group Props\n   */\n  @Input()\n  minDate!: Date;\n\n  /**\n   * Maximal date availalbe for selection.\n   * @group Props\n   */\n  @Input()\n  maxDate!: Date;\n\n  /**\n   * Value of the datepicker.\n   * @group Props\n   */\n  @Input() set value(value: Date | null) {\n    this._value = value;\n    this.stringDate = this._dateToString(value);\n    this.onChange(value);\n  }\n\n  get value(): Date | null {\n    return this._value;\n  }\n\n  /**\n   * Callback to invoke on value change.\n   * @param {Date | null} value - value change.\n   * @group Emits\n   */\n  @Output() valueChanged = new EventEmitter<Date | null>();\n\n  @ViewChild('datepickerInput')\n  datepickerInput!: CpsInputComponent;\n\n  @ViewChild('calendarMenu')\n  calendarMenu!: CpsMenuComponent;\n\n  stringDate = '';\n  isOpened = false;\n  error = '';\n  cvtWidth = '';\n\n  private _statusChangesSubscription: Subscription = new Subscription();\n  private _value!: Date | null;\n\n  constructor(@Self() @Optional() private _control: NgControl) {\n    if (this._control) {\n      this._control.valueAccessor = this;\n    }\n  }\n\n  ngOnInit(): void {\n    this.cvtWidth = convertSize(this.width);\n\n    this._statusChangesSubscription = this._control?.statusChanges?.subscribe(\n      () => {\n        this._checkErrors();\n      }\n    ) as Subscription;\n  }\n\n  ngOnDestroy() {\n    this._statusChangesSubscription?.unsubscribe();\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onChange = (event: any) => {};\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  onTouched = () => {};\n\n  registerOnChange(fn: any) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: any) {\n    this.onTouched = fn;\n  }\n\n  onInputValueChanged(val: string) {\n    this.stringDate = val;\n    if (!val) {\n      this._updateValue(null);\n      return;\n    }\n    const dt = this._stringToDate(val);\n    if (dt) this._updateValue(dt);\n  }\n\n  writeValue(value: Date | null) {\n    this.value = value;\n  }\n\n  private _updateValue(value: Date | null) {\n    if (this.value === value) return;\n    this.writeValue(value);\n    this.onChange(value);\n    this.valueChanged.emit(value);\n  }\n\n  private _updateValueFromInputString() {\n    if (!this.stringDate) {\n      this._updateValue(null);\n    } else {\n      this._updateValue(this._stringToDate(this.stringDate));\n    }\n  }\n\n  private _checkDateFormat(dateString: string): boolean {\n    if (!/^\\d\\d\\/\\d\\d\\/\\d\\d\\d\\d$/.test(dateString)) {\n      return false;\n    }\n    const parts = dateString.split('/').map((p) => parseInt(p, 10));\n    parts[0] -= 1;\n    const d = new Date(parts[2], parts[0], parts[1]);\n    return (\n      d.getMonth() === parts[0] &&\n      d.getDate() === parts[1] &&\n      d.getFullYear() === parts[2]\n    );\n  }\n\n  private _checkDateInRange(date: Date, minDate: Date, maxDate: Date): boolean {\n    if (!minDate && !maxDate) return true;\n    if (minDate && maxDate) {\n      return (\n        date.getTime() >= minDate.getTime() &&\n        date.getTime() <= maxDate.getTime()\n      );\n    }\n    if (minDate) {\n      return date.getTime() >= minDate.getTime();\n    }\n    return date.getTime() <= maxDate.getTime();\n  }\n\n  private _dateToString(dateVal: Date | null): string {\n    if (!dateVal) return '';\n    let month = '' + (dateVal.getMonth() + 1);\n    if (month.length < 2) month = '0' + month;\n    let day = '' + dateVal.getDate();\n    if (day.length < 2) day = '0' + day;\n    const year = dateVal.getFullYear();\n    return `${month}/${day}/${year}`;\n  }\n\n  private _stringToDate(dateString: string): Date | null {\n    if (!this._checkDateFormat(dateString)) return null;\n    const [month, day, year] = dateString.split('/');\n    const dt = new Date(`${year}-${month}-${day}`);\n    const inRange = this._checkDateInRange(dt, this.minDate, this.maxDate);\n    return inRange ? dt : null;\n  }\n\n  private _checkErrors() {\n    if (this.stringDate && !this._stringToDate(this.stringDate)) {\n      this.error = 'Date is invalid';\n      return;\n    }\n\n    const errors = this._control?.errors;\n    if (!this._control?.control?.touched || !errors) {\n      this.error = '';\n      return;\n    }\n\n    if ('required' in errors) {\n      this.error = 'Field is required';\n      return;\n    }\n\n    const errArr = Object.values(errors);\n    if (errArr.length < 1) {\n      this.error = '';\n      return;\n    }\n    const message = errArr.find((msg) => typeof msg === 'string');\n\n    this.error = message || 'Unknown error';\n  }\n\n  onClearCalendarDate() {\n    this.onSelectCalendarDate(null);\n  }\n\n  onSelectCalendarDate(dateVal: Date | null) {\n    this.toggleCalendar(false);\n    this.writeValue(dateVal);\n    this.onChange(dateVal);\n    this.valueChanged.emit(dateVal);\n  }\n\n  onInputBlur() {\n    if (this.isOpened) return;\n    this._control?.control?.markAsTouched();\n    this._updateValueFromInputString();\n    this._checkErrors();\n  }\n\n  onInputEnterClicked() {\n    if (!this.isOpened) return;\n    this._control?.control?.markAsTouched();\n    this._updateValueFromInputString();\n    this._checkErrors();\n    this.toggleCalendar(false);\n  }\n\n  onClickCalendarIcon() {\n    if (this.disabled) return;\n    if (this.isOpened) this._updateValueFromInputString();\n    this.toggleCalendar();\n  }\n\n  onBeforeCalendarHidden() {\n    if (this.disabled || !this.isOpened) return;\n    this._updateValueFromInputString();\n    this.toggleCalendar(false);\n  }\n\n  onInputFocus() {\n    if (this.openOnInputFocus) this.toggleCalendar(true);\n  }\n\n  onInputClear() {\n    if (this.isOpened) this.focusInput();\n  }\n\n  onCalendarContentClick() {\n    if (this.isOpened) this.focusInput();\n  }\n\n  focusInput() {\n    this.datepickerInput.focus();\n  }\n\n  toggleCalendar(show?: boolean) {\n    if (this.disabled || this.isOpened === show) return;\n\n    const target =\n      this.datepickerInput.elementRef.nativeElement.querySelector(\n        '.cps-input-wrap'\n      );\n\n    if (typeof show === 'boolean') {\n      if (show) {\n        this.calendarMenu.show({\n          target\n        });\n      } else {\n        this.calendarMenu.hide();\n      }\n    } else {\n      this.calendarMenu.toggle({\n        target\n      });\n    }\n\n    this.isOpened = this.calendarMenu.isVisible();\n\n    if (!this.isOpened) {\n      this._control?.control?.markAsTouched();\n      this._checkErrors();\n    } else {\n      this.focusInput();\n    }\n  }\n}\n","<div\n  class=\"cps-datepicker\"\n  [ngStyle]=\"{ width: cvtWidth }\"\n  [class.focused]=\"isOpened\">\n  <cps-input\n    #datepickerInput\n    [disabled]=\"disabled\"\n    [value]=\"stringDate\"\n    [label]=\"label\"\n    prefixIcon=\"datepicker\"\n    [placeholder]=\"placeholder\"\n    (prefixIconClicked)=\"onClickCalendarIcon()\"\n    [prefixIconClickable]=\"true\"\n    (focused)=\"onInputFocus()\"\n    (valueChanged)=\"onInputValueChanged($event)\"\n    [clearable]=\"clearable\"\n    (blurred)=\"onInputBlur()\"\n    (cleared)=\"onInputClear()\"\n    (enterClicked)=\"onInputEnterClicked()\"\n    [width]=\"width\"\n    [hint]=\"hint\"\n    [hideDetails]=\"hideDetails\"\n    [infoTooltip]=\"infoTooltip\"\n    [infoTooltipClass]=\"infoTooltipClass\"\n    [infoTooltipMaxWidth]=\"infoTooltipMaxWidth\"\n    [infoTooltipPersistent]=\"infoTooltipPersistent\"\n    [persistentClear]=\"persistentClear\"\n    [appearance]=\"appearance\"\n    [error]=\"error\"></cps-input>\n  <cps-menu\n    #calendarMenu\n    [withArrow]=\"false\"\n    (beforeMenuHidden)=\"onBeforeCalendarHidden()\"\n    (contentClicked)=\"onCalendarContentClick()\"\n    [focusOnShow]=\"false\"\n    hideTransitionOptions=\"0s linear\"\n    containerClass=\"cps-datepicker-calendar-menu\">\n    <div class=\"cps-datepicker-calendar\">\n      <p-calendar\n        [(ngModel)]=\"value\"\n        [showIcon]=\"true\"\n        [showButtonBar]=\"showTodayButton\"\n        [inline]=\"true\"\n        (onSelect)=\"onSelectCalendarDate($event)\"\n        (onClearClick)=\"onClearCalendarDate()\"\n        [showOtherMonths]=\"false\"\n        [minDate]=\"minDate\"\n        [maxDate]=\"maxDate\">\n      </p-calendar>\n    </div>\n  </cps-menu>\n</div>\n"]}