@natec/mef-dev-ui-kit 16.3.49 → 16.3.54

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 (44) hide show
  1. package/README.md +4 -4
  2. package/esm2022/lib/markup-kit/card/card/card.component.mjs +2 -2
  3. package/esm2022/lib/markup-kit/card/card-long/card-long.component.mjs +2 -2
  4. package/esm2022/lib/markup-kit/card/card-simple/card-simple.component.mjs +2 -2
  5. package/esm2022/lib/markup-kit/collapse/collapse/collapse.component.mjs +2 -2
  6. package/esm2022/lib/markup-kit/executors/step-executor/step-executor.component.mjs +2 -2
  7. package/esm2022/lib/markup-kit/modals/fill/fill.component.mjs +2 -2
  8. package/esm2022/lib/markup-kit/modals/right-filter/right-filter.component.mjs +10 -6
  9. package/esm2022/lib/markup-kit/modals/slide-right/slide-right.component.mjs +2 -2
  10. package/esm2022/lib/markup-kit/modals/slide-up/slide-up.component.mjs +2 -2
  11. package/esm2022/lib/markup-kit/page-layouts/central-page/central-page.component.mjs +2 -2
  12. package/esm2022/lib/markup-kit/page-layouts/manage-page/manage-page.component.mjs +2 -2
  13. package/esm2022/lib/markup-kit/page-layouts/profile/profile.component.mjs +2 -2
  14. package/esm2022/lib/markup-kit/page-layouts/table-page/table-page.component.mjs +2 -2
  15. package/esm2022/lib/markup-kit/slider/slider/slider.component.mjs +2 -2
  16. package/esm2022/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.mjs +2 -2
  17. package/esm2022/lib/markup-kit/utils/filtered-field/filtered-field-container/filtered-field-container.component.mjs +2 -2
  18. package/esm2022/lib/markup-kit/utils/help-block/help-block.component.mjs +2 -2
  19. package/esm2022/lib/pg-components/select/select.component.mjs +2 -2
  20. package/esm2022/lib/pg-components/switch/switch.component.mjs +2 -2
  21. package/esm2022/lib/pg-components/tabs/tabset.component.mjs +2 -2
  22. package/fesm2022/natec-mef-dev-ui-kit.mjs +25 -22
  23. package/fesm2022/natec-mef-dev-ui-kit.mjs.map +1 -1
  24. package/lib/markup-kit/card/card/card.component.d.ts +1 -1
  25. package/lib/markup-kit/card/card-long/card-long.component.d.ts +1 -1
  26. package/lib/markup-kit/card/card-simple/card-simple.component.d.ts +1 -1
  27. package/lib/markup-kit/collapse/collapse/collapse.component.d.ts +1 -1
  28. package/lib/markup-kit/executors/step-executor/step-executor.component.d.ts +1 -1
  29. package/lib/markup-kit/modals/fill/fill.component.d.ts +1 -1
  30. package/lib/markup-kit/modals/right-filter/right-filter.component.d.ts +2 -1
  31. package/lib/markup-kit/modals/slide-right/slide-right.component.d.ts +1 -1
  32. package/lib/markup-kit/modals/slide-up/slide-up.component.d.ts +1 -1
  33. package/lib/markup-kit/page-layouts/central-page/central-page.component.d.ts +1 -1
  34. package/lib/markup-kit/page-layouts/manage-page/manage-page.component.d.ts +1 -1
  35. package/lib/markup-kit/page-layouts/profile/profile.component.d.ts +1 -1
  36. package/lib/markup-kit/page-layouts/table-page/table-page.component.d.ts +1 -1
  37. package/lib/markup-kit/slider/slider/slider.component.d.ts +1 -1
  38. package/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.d.ts +1 -1
  39. package/lib/markup-kit/utils/filtered-field/filtered-field-container/filtered-field-container.component.d.ts +1 -1
  40. package/lib/markup-kit/utils/help-block/help-block.component.d.ts +1 -1
  41. package/lib/pg-components/select/select.component.d.ts +1 -1
  42. package/lib/pg-components/switch/switch.component.d.ts +1 -1
  43. package/lib/pg-components/tabs/tabset.component.d.ts +1 -1
  44. package/package.json +1 -1
@@ -18,7 +18,7 @@ import * as i1 from "@angular/common";
18
18
  * ```
19
19
  *
20
20
  * Example of usage:
21
- * <example-url>https://mef.dev/ui_kit_demo/view/page_layouts/manage_page</example-url>
21
+ * <example-url>https://platform.mef.dev/ui_kit_demo/view/page_layouts/manage_page</example-url>
22
22
  */
23
23
  export class ManagePageComponent {
24
24
  /**
@@ -70,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
70
70
  }], startTabInd: [{
71
71
  type: Input
72
72
  }] } });
73
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFuYWdlLXBhZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0LWxpYi9zcmMvbGliL21hcmt1cC1raXQvcGFnZS1sYXlvdXRzL21hbmFnZS1wYWdlL21hbmFnZS1wYWdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC1saWIvc3JjL2xpYi9tYXJrdXAta2l0L3BhZ2UtbGF5b3V0cy9tYW5hZ2UtcGFnZS9tYW5hZ2UtcGFnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQXVCLE1BQU0sZUFBZSxDQUFDOzs7QUFHbEY7Ozs7Ozs7Ozs7Ozs7Ozs7OztFQWtCRTtBQU1KLE1BQU0sT0FBTyxtQkFBbUI7SUFFOUI7Ozs7Ozs7OztPQVNHO0lBQ3lCLFVBQVUsQ0FBb0I7SUFFMUQ7Ozs7Ozs7OztPQVNHO0lBQ3lCLFVBQVUsQ0FBb0I7SUFFMUQ7Ozs7Ozs7T0FPRztJQUNNLFdBQVcsR0FBRyxDQUFDLENBQUM7SUFFekIsZ0JBQWdCLENBQUM7SUFFakIsUUFBUTtJQUNSLENBQUM7d0dBdkNVLG1CQUFtQjs0RkFBbkIsbUJBQW1CLG1TQzNCaEMsd1ZBVUE7OzRGRGlCYSxtQkFBbUI7a0JBTC9CLFNBQVM7K0JBQ0Usb0JBQW9COzBFQWdCRixVQUFVO3NCQUFyQyxZQUFZO3VCQUFDLFlBQVk7Z0JBWUUsVUFBVTtzQkFBckMsWUFBWTt1QkFBQyxZQUFZO2dCQVVqQixXQUFXO3NCQUFuQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDb250ZW50Q2hpbGQsIElucHV0LCBPbkluaXQsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5cclxuICAvKipcclxuICAqIEEgY29tcG9uZW50IHJlcHJlc2VudGluZyBhIG1hbmFnZSBwYWdlIGxheW91dC5cclxuICAqXHJcbiAgKiBFeGFtcGxlIG9mIHVzYWdlOlxyXG4gICogXHJcbiAgKiBgYGBcclxuICAqIDxtZWZkZXYtbWFuYWdlLXBhZ2UgW3N0YXJ0VGFiSW5kXT1cIjBcIj5cclxuICAqICAgPG5nLXRlbXBsYXRlICNjYXJkX3RpdGxlPlxyXG4gICogICAgIFRpdGxlIG9mIHRoZSBjYXJkXHJcbiAgKiAgIDwvbmctdGVtcGxhdGU+XHJcbiAgKiAgIDxuZy10ZW1wbGF0ZSAjdGFic19ibG9jaz5cclxuICAqICAgICBDb250ZW50IG9mIHRoZSB0YWJzIGJsb2NrXHJcbiAgKiAgIDwvbmctdGVtcGxhdGU+XHJcbiAgKiA8L21lZmRldi1tYW5hZ2UtcGFnZT5cclxuICAqIGBgYFxyXG4gICpcclxuICAqIEV4YW1wbGUgb2YgdXNhZ2U6XHJcbiAgKiA8ZXhhbXBsZS11cmw+aHR0cHM6Ly9tZWYuZGV2L3VpX2tpdF9kZW1vL3ZpZXcvcGFnZV9sYXlvdXRzL21hbmFnZV9wYWdlPC9leGFtcGxlLXVybD5cclxuICAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ21lZmRldi1tYW5hZ2UtcGFnZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL21hbmFnZS1wYWdlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9tYW5hZ2UtcGFnZS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNYW5hZ2VQYWdlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIHRlbXBsYXRlIHJlZmVyZW5jZSB0byB0aGUgY2FyZCB0aXRsZS5cclxuICAgKiBgYGBcclxuICAgKiA8bWVmZGV2LW1hbmFnZS1wYWdlPlxyXG4gICAqICAgPG5nLXRlbXBsYXRlICNjYXJkX3RpdGxlPlxyXG4gICAqICAgICBUaXRsZSBvZiB0aGUgY2FyZFxyXG4gICAqICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgKiA8L21lZmRldi1tYW5hZ2UtcGFnZT5cclxuICAgKiBgYGBcclxuICAgKi9cclxuICBAQ29udGVudENoaWxkKFwiY2FyZF90aXRsZVwiKSBjYXJkX3RpdGxlOiBUZW1wbGF0ZVJlZjx2b2lkPjtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIHRlbXBsYXRlIHJlZmVyZW5jZSB0byB0aGUgdGFicyBibG9jay5cclxuICAgKiBgYGBcclxuICAgKiA8bWVmZGV2LW1hbmFnZS1wYWdlPlxyXG4gICAqICAgPG5nLXRlbXBsYXRlICN0YWJzX2Jsb2NrPlxyXG4gICAqICAgICBDb250ZW50IG9mIHRoZSB0YWJzIGJsb2NrXHJcbiAgICogICA8L25nLXRlbXBsYXRlPlxyXG4gICAqIDwvbWVmZGV2LW1hbmFnZS1wYWdlPlxyXG4gICAqIGBgYFxyXG4gICAqL1xyXG4gIEBDb250ZW50Q2hpbGQoXCJ0YWJzX2Jsb2NrXCIpIHRhYnNfYmxvY2s6IFRlbXBsYXRlUmVmPHZvaWQ+O1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgaW5kZXggb2YgdGhlIHN0YXJ0aW5nIHRhYi5cclxuICAgKiBgYGBcclxuICAgKiA8bWVmZGV2LW1hbmFnZS1wYWdlIFtzdGFydFRhYkluZF09XCIwXCI+XHJcbiAgICogICAgICBDb250ZW50IGdvZXMgaGVyZS4uLlxyXG4gICAqIDwvbWVmZGV2LW1hbmFnZS1wYWdlPlxyXG4gICAqIGBgYFxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHN0YXJ0VGFiSW5kID0gMDtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwiY2FyZC10YWJzXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwicm93IGJvZHktMSBjYXJkLWhlYWRlclwiICpuZ0lmPVwiY2FyZF90aXRsZVwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJtLTJcIj5cclxuICAgICAgICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImNhcmRfdGl0bGVcIj48L25nLXRlbXBsYXRlPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwicm93IHByb2ZpbGUtcGFnZS10YWJzXCI+XHJcbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFuYWdlLXBhZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0LWxpYi9zcmMvbGliL21hcmt1cC1raXQvcGFnZS1sYXlvdXRzL21hbmFnZS1wYWdlL21hbmFnZS1wYWdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC1saWIvc3JjL2xpYi9tYXJrdXAta2l0L3BhZ2UtbGF5b3V0cy9tYW5hZ2UtcGFnZS9tYW5hZ2UtcGFnZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQXVCLE1BQU0sZUFBZSxDQUFDOzs7QUFHbEY7Ozs7Ozs7Ozs7Ozs7Ozs7OztFQWtCRTtBQU1KLE1BQU0sT0FBTyxtQkFBbUI7SUFFOUI7Ozs7Ozs7OztPQVNHO0lBQ3lCLFVBQVUsQ0FBb0I7SUFFMUQ7Ozs7Ozs7OztPQVNHO0lBQ3lCLFVBQVUsQ0FBb0I7SUFFMUQ7Ozs7Ozs7T0FPRztJQUNNLFdBQVcsR0FBRyxDQUFDLENBQUM7SUFFekIsZ0JBQWdCLENBQUM7SUFFakIsUUFBUTtJQUNSLENBQUM7d0dBdkNVLG1CQUFtQjs0RkFBbkIsbUJBQW1CLG1TQzNCaEMsd1ZBVUE7OzRGRGlCYSxtQkFBbUI7a0JBTC9CLFNBQVM7K0JBQ0Usb0JBQW9COzBFQWdCRixVQUFVO3NCQUFyQyxZQUFZO3VCQUFDLFlBQVk7Z0JBWUUsVUFBVTtzQkFBckMsWUFBWTt1QkFBQyxZQUFZO2dCQVVqQixXQUFXO3NCQUFuQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDb250ZW50Q2hpbGQsIElucHV0LCBPbkluaXQsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5cclxuICAvKipcclxuICAqIEEgY29tcG9uZW50IHJlcHJlc2VudGluZyBhIG1hbmFnZSBwYWdlIGxheW91dC5cclxuICAqXHJcbiAgKiBFeGFtcGxlIG9mIHVzYWdlOlxyXG4gICogXHJcbiAgKiBgYGBcclxuICAqIDxtZWZkZXYtbWFuYWdlLXBhZ2UgW3N0YXJ0VGFiSW5kXT1cIjBcIj5cclxuICAqICAgPG5nLXRlbXBsYXRlICNjYXJkX3RpdGxlPlxyXG4gICogICAgIFRpdGxlIG9mIHRoZSBjYXJkXHJcbiAgKiAgIDwvbmctdGVtcGxhdGU+XHJcbiAgKiAgIDxuZy10ZW1wbGF0ZSAjdGFic19ibG9jaz5cclxuICAqICAgICBDb250ZW50IG9mIHRoZSB0YWJzIGJsb2NrXHJcbiAgKiAgIDwvbmctdGVtcGxhdGU+XHJcbiAgKiA8L21lZmRldi1tYW5hZ2UtcGFnZT5cclxuICAqIGBgYFxyXG4gICpcclxuICAqIEV4YW1wbGUgb2YgdXNhZ2U6XHJcbiAgKiA8ZXhhbXBsZS11cmw+aHR0cHM6Ly9wbGF0Zm9ybS5tZWYuZGV2L3VpX2tpdF9kZW1vL3ZpZXcvcGFnZV9sYXlvdXRzL21hbmFnZV9wYWdlPC9leGFtcGxlLXVybD5cclxuICAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ21lZmRldi1tYW5hZ2UtcGFnZScsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL21hbmFnZS1wYWdlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9tYW5hZ2UtcGFnZS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBNYW5hZ2VQYWdlQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIHRlbXBsYXRlIHJlZmVyZW5jZSB0byB0aGUgY2FyZCB0aXRsZS5cclxuICAgKiBgYGBcclxuICAgKiA8bWVmZGV2LW1hbmFnZS1wYWdlPlxyXG4gICAqICAgPG5nLXRlbXBsYXRlICNjYXJkX3RpdGxlPlxyXG4gICAqICAgICBUaXRsZSBvZiB0aGUgY2FyZFxyXG4gICAqICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgKiA8L21lZmRldi1tYW5hZ2UtcGFnZT5cclxuICAgKiBgYGBcclxuICAgKi9cclxuICBAQ29udGVudENoaWxkKFwiY2FyZF90aXRsZVwiKSBjYXJkX3RpdGxlOiBUZW1wbGF0ZVJlZjx2b2lkPjtcclxuXHJcbiAgLyoqXHJcbiAgICogVGhlIHRlbXBsYXRlIHJlZmVyZW5jZSB0byB0aGUgdGFicyBibG9jay5cclxuICAgKiBgYGBcclxuICAgKiA8bWVmZGV2LW1hbmFnZS1wYWdlPlxyXG4gICAqICAgPG5nLXRlbXBsYXRlICN0YWJzX2Jsb2NrPlxyXG4gICAqICAgICBDb250ZW50IG9mIHRoZSB0YWJzIGJsb2NrXHJcbiAgICogICA8L25nLXRlbXBsYXRlPlxyXG4gICAqIDwvbWVmZGV2LW1hbmFnZS1wYWdlPlxyXG4gICAqIGBgYFxyXG4gICAqL1xyXG4gIEBDb250ZW50Q2hpbGQoXCJ0YWJzX2Jsb2NrXCIpIHRhYnNfYmxvY2s6IFRlbXBsYXRlUmVmPHZvaWQ+O1xyXG5cclxuICAvKipcclxuICAgKiBUaGUgaW5kZXggb2YgdGhlIHN0YXJ0aW5nIHRhYi5cclxuICAgKiBgYGBcclxuICAgKiA8bWVmZGV2LW1hbmFnZS1wYWdlIFtzdGFydFRhYkluZF09XCIwXCI+XHJcbiAgICogICAgICBDb250ZW50IGdvZXMgaGVyZS4uLlxyXG4gICAqIDwvbWVmZGV2LW1hbmFnZS1wYWdlPlxyXG4gICAqIGBgYFxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIHN0YXJ0VGFiSW5kID0gMDtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwiY2FyZC10YWJzXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwicm93IGJvZHktMSBjYXJkLWhlYWRlclwiICpuZ0lmPVwiY2FyZF90aXRsZVwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJtLTJcIj5cclxuICAgICAgICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImNhcmRfdGl0bGVcIj48L25nLXRlbXBsYXRlPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwicm93IHByb2ZpbGUtcGFnZS10YWJzXCI+XHJcbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG4iXX0=
@@ -25,7 +25,7 @@ import * as i1 from "@angular/common";
25
25
  * </mefdev-profile>
26
26
  * ```
27
27
  *
28
- * <example-url>https://mef.dev/ui_kit_demo/view/page_layouts/profile</example-url>
28
+ * <example-url>https://platform.mef.dev/ui_kit_demo/view/page_layouts/profile</example-url>
29
29
  */
30
30
  export class ProfileComponent {
31
31
  /**
@@ -134,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
134
134
  }], circleImg: [{
135
135
  type: Input
136
136
  }] } });
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"profile.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/page-layouts/profile/profile.component.ts","../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/page-layouts/profile/profile.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAuB,MAAM,eAAe,CAAC;;;AAGpF;;;;;;;;;;;;;;;;;;;;;;;;;IAyBI;AAMJ,MAAM,OAAO,gBAAgB;IAE3B;;;;;;;MAOE;IAC2B,WAAW,CAAoB;IAE5D;;;;;;;OAOG;IAC2B,YAAY,CAAoB;IAE5D;;;;;;;IAOA;IACsB,MAAM,CAAoB;IAElD;;;;;OAKG;IACM,IAAI,CAAQ;IAEpB;;;;;MAKE;IACM,GAAG,GAAW,EAAE,CAAC;IAE1B;;;;;OAKG;IACM,gBAAgB,CAAS;IAElC;;;;;OAKG;IACM,MAAM,CAAS;IAExB;;;;;OAKG;IACM,SAAS,GAAY,KAAK,CAAC;IAEpC,gBAAgB,CAAC;IAEjB,QAAQ;IACR,CAAC;IAED,IAAI,SAAS;QACX,+DAA+D;QAC/D;;SAEC;QACD,IAAG,CAAC,IAAI,CAAC,SAAS,EAAC;YACjB,OAAO,EAAE,CAAC;SACX;QAED,OAAO;YACL,wBAAwB,EAAE,KAAK;YAC/B,yBAAyB,EAAE,KAAK;YAChC,4BAA4B,EAAE,KAAK;YACnC,2BAA2B,EAAE,KAAK;SACnC,CAAC;IACJ,CAAC;wGA5FU,gBAAgB;4FAAhB,gBAAgB,scClC7B,w6CA0CA;;4FDRa,gBAAgB;kBAL5B,SAAS;+BACE,gBAAgB;0EAcG,WAAW;sBAAvC,YAAY;uBAAC,aAAa;gBAUG,YAAY;sBAAzC,YAAY;uBAAC,cAAc;gBAUJ,MAAM;sBAA7B,YAAY;uBAAC,QAAQ;gBAQb,IAAI;sBAAZ,KAAK;gBAQG,GAAG;sBAAX,KAAK;gBAQG,gBAAgB;sBAAxB,KAAK;gBAQG,MAAM;sBAAd,KAAK;gBAQG,SAAS;sBAAjB,KAAK","sourcesContent":["import { Component, ContentChild, Input, OnInit, TemplateRef } from '@angular/core';\r\n\r\n\r\n/**\r\n * A component representing a user profile.\r\n *\r\n * Example of usage:\r\n * \r\n * ```\r\n * <mefdev-profile\r\n *   [name]=\"'John Doe'\"\r\n *   [img]=\"'assets/profile.png'\"\r\n *   [shortDescription]=\"'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\"\r\n *   [header]=\"'User Profile'\"\r\n *   [circleImg]=\"'true'\">\r\n *   <ng-template #first_colum>\r\n *     <!-- Content for the first column -->\r\n *   </ng-template>\r\n *   <ng-template #second_colum>\r\n *     <!-- Content for the second column -->\r\n *   </ng-template>\r\n *   <ng-template #footer>\r\n *     <!-- Content for the footer -->\r\n *   </ng-template>\r\n * </mefdev-profile>\r\n * ```\r\n *\r\n  * <example-url>https://mef.dev/ui_kit_demo/view/page_layouts/profile</example-url>\r\n  */\r\n@Component({\r\n  selector: 'mefdev-profile',\r\n  templateUrl: './profile.component.html',\r\n  styleUrls: ['./profile.component.scss']\r\n})\r\nexport class ProfileComponent implements OnInit {\r\n\r\n  /**\r\n  * The template reference to the content of the first column.\r\n  *```\r\n  *   <ng-template #first_colum>\r\n  *     <!-- Content for the first column -->\r\n  *   </ng-template>\r\n  *```\r\n  */\r\n  @ContentChild(\"first_colum\") first_colum: TemplateRef<void>;\r\n\r\n  /**\r\n   * The template reference to the content of the second column.\r\n  *```\r\n  *   <ng-template #second_colum>\r\n  *     <!-- Content for the second column -->\r\n  *   </ng-template>\r\n  *```\r\n   */\r\n  @ContentChild(\"second_colum\") second_colum: TemplateRef<void>;\r\n\r\n    /**\r\n  * The template reference to the content of the footer.\r\n  *```\r\n  *   <ng-template #footer>\r\n  *     <!-- Content for the footer -->\r\n  *   </ng-template>\r\n  *```\r\n  */\r\n  @ContentChild(\"footer\") footer: TemplateRef<void>;\r\n\r\n  /**\r\n   * The name of the user.\r\n   * ```\r\n   * <mefdev-profile [name]=\"'John Doe'\"></mefdev-profile>\r\n   * ```\r\n   */\r\n  @Input() name:string;\r\n\r\n   /**\r\n   * The URL of the user's profile image.\r\n   * ```\r\n   * <mefdev-profile [img]=\"'assets/profile.png'\"></mefdev-profile>\r\n   * ```\r\n   */\r\n  @Input() img: string = '';\r\n\r\n  /**\r\n   * A short description of the user.\r\n   * ```\r\n   * <mefdev-profile [shortDescription]=\"'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\"></mefdev-profile>\r\n   * ```\r\n   */\r\n  @Input() shortDescription: string;\r\n\r\n  /**\r\n   * The header title of the profile component.\r\n   * ```\r\n   * <mefdev-profile [header]=\"'User Profile'\"></mefdev-profile>\r\n   * ```\r\n   */\r\n  @Input() header: string;\r\n\r\n  /**\r\n   * A flag indicating whether to display the profile image as a circle. Default \"false\".\r\n   * ```\r\n   * <mefdev-profile [circleImg]=\"'true'\"></mefdev-profile>\r\n   * ```\r\n   */\r\n  @Input() circleImg: boolean = false;\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  get sizeStyle(){\r\n    // return { 'width.px': this.width, 'height.px': this.height };\r\n    /**\r\n   * Returns the CSS style for the profile image size and shape.\r\n   */\r\n    if(!this.circleImg){\r\n      return {};\r\n    }\r\n\r\n    return {\r\n      'border-top-left-radius': `50%`,\r\n      'border-top-right-radius': `50%`,\r\n      'border-bottom-right-radius': `50%`,\r\n      'border-bottom-left-radius': `50%`,\r\n    };\r\n  }\r\n}\r\n","<div class=\"row profile-page\">\r\n    <div class=\"col-12 h3 mt-3\">\r\n        {{header}}\r\n    </div>\r\n    <div class=\"col-xl-3 col-lg-3 col-md-4 col-sm-12\">\r\n        <div *ngIf=\"!img || img == ''\" >\r\n            <img src=\"assets/images/md_icon.png\" height=\"124\" width=\"220\" />\r\n        </div>\r\n        <div *ngIf=\"img\" >\r\n            <img src=\"{{img}}\" alt=\"\" class=\"custom-img\" [ngStyle]=\"sizeStyle\"\r\n            />\r\n        </div>\r\n    </div>\r\n\r\n    <div class=\"col-xl-3 col-lg-4 col-md-5 col-sm-12 mt-4 mt-md-0\" >\r\n        <div class=\"row profile-name\">\r\n            <div class=\"col\">\r\n                {{name}}\r\n            </div>\r\n        </div>\r\n        <div class=\"row\">\r\n            <div class=\"col profile-description\">\r\n                {{shortDescription}}\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n    <div class=\"col-xl-3 col-lg-4 col-md-5 col-sm-12 body-6 mt-4 mt-md-0\">\r\n        <ng-template [ngTemplateOutlet]=\"first_colum\"></ng-template>\r\n    </div>\r\n\r\n    <div class=\"col-xl-3 col-lg-4 col-md-5 col-sm-12 body-6 mt-4 mt-md-0\" >\r\n        <ng-template [ngTemplateOutlet]=\"second_colum\"></ng-template>\r\n    </div>\r\n\r\n</div>\r\n<div style=\"position: relative;\">\r\n    <div class=\"row profile-page-tabs\">\r\n        <ng-template [ngTemplateOutlet]=\"footer\">\r\n        </ng-template>\r\n    </div>\r\n</div>\r\n"]}
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"profile.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/page-layouts/profile/profile.component.ts","../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/page-layouts/profile/profile.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAuB,MAAM,eAAe,CAAC;;;AAGpF;;;;;;;;;;;;;;;;;;;;;;;;;IAyBI;AAMJ,MAAM,OAAO,gBAAgB;IAE3B;;;;;;;MAOE;IAC2B,WAAW,CAAoB;IAE5D;;;;;;;OAOG;IAC2B,YAAY,CAAoB;IAE5D;;;;;;;IAOA;IACsB,MAAM,CAAoB;IAElD;;;;;OAKG;IACM,IAAI,CAAQ;IAEpB;;;;;MAKE;IACM,GAAG,GAAW,EAAE,CAAC;IAE1B;;;;;OAKG;IACM,gBAAgB,CAAS;IAElC;;;;;OAKG;IACM,MAAM,CAAS;IAExB;;;;;OAKG;IACM,SAAS,GAAY,KAAK,CAAC;IAEpC,gBAAgB,CAAC;IAEjB,QAAQ;IACR,CAAC;IAED,IAAI,SAAS;QACX,+DAA+D;QAC/D;;SAEC;QACD,IAAG,CAAC,IAAI,CAAC,SAAS,EAAC;YACjB,OAAO,EAAE,CAAC;SACX;QAED,OAAO;YACL,wBAAwB,EAAE,KAAK;YAC/B,yBAAyB,EAAE,KAAK;YAChC,4BAA4B,EAAE,KAAK;YACnC,2BAA2B,EAAE,KAAK;SACnC,CAAC;IACJ,CAAC;wGA5FU,gBAAgB;4FAAhB,gBAAgB,scClC7B,w6CA0CA;;4FDRa,gBAAgB;kBAL5B,SAAS;+BACE,gBAAgB;0EAcG,WAAW;sBAAvC,YAAY;uBAAC,aAAa;gBAUG,YAAY;sBAAzC,YAAY;uBAAC,cAAc;gBAUJ,MAAM;sBAA7B,YAAY;uBAAC,QAAQ;gBAQb,IAAI;sBAAZ,KAAK;gBAQG,GAAG;sBAAX,KAAK;gBAQG,gBAAgB;sBAAxB,KAAK;gBAQG,MAAM;sBAAd,KAAK;gBAQG,SAAS;sBAAjB,KAAK","sourcesContent":["import { Component, ContentChild, Input, OnInit, TemplateRef } from '@angular/core';\r\n\r\n\r\n/**\r\n * A component representing a user profile.\r\n *\r\n * Example of usage:\r\n * \r\n * ```\r\n * <mefdev-profile\r\n *   [name]=\"'John Doe'\"\r\n *   [img]=\"'assets/profile.png'\"\r\n *   [shortDescription]=\"'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\"\r\n *   [header]=\"'User Profile'\"\r\n *   [circleImg]=\"'true'\">\r\n *   <ng-template #first_colum>\r\n *     <!-- Content for the first column -->\r\n *   </ng-template>\r\n *   <ng-template #second_colum>\r\n *     <!-- Content for the second column -->\r\n *   </ng-template>\r\n *   <ng-template #footer>\r\n *     <!-- Content for the footer -->\r\n *   </ng-template>\r\n * </mefdev-profile>\r\n * ```\r\n *\r\n  * <example-url>https://platform.mef.dev/ui_kit_demo/view/page_layouts/profile</example-url>\r\n  */\r\n@Component({\r\n  selector: 'mefdev-profile',\r\n  templateUrl: './profile.component.html',\r\n  styleUrls: ['./profile.component.scss']\r\n})\r\nexport class ProfileComponent implements OnInit {\r\n\r\n  /**\r\n  * The template reference to the content of the first column.\r\n  *```\r\n  *   <ng-template #first_colum>\r\n  *     <!-- Content for the first column -->\r\n  *   </ng-template>\r\n  *```\r\n  */\r\n  @ContentChild(\"first_colum\") first_colum: TemplateRef<void>;\r\n\r\n  /**\r\n   * The template reference to the content of the second column.\r\n  *```\r\n  *   <ng-template #second_colum>\r\n  *     <!-- Content for the second column -->\r\n  *   </ng-template>\r\n  *```\r\n   */\r\n  @ContentChild(\"second_colum\") second_colum: TemplateRef<void>;\r\n\r\n    /**\r\n  * The template reference to the content of the footer.\r\n  *```\r\n  *   <ng-template #footer>\r\n  *     <!-- Content for the footer -->\r\n  *   </ng-template>\r\n  *```\r\n  */\r\n  @ContentChild(\"footer\") footer: TemplateRef<void>;\r\n\r\n  /**\r\n   * The name of the user.\r\n   * ```\r\n   * <mefdev-profile [name]=\"'John Doe'\"></mefdev-profile>\r\n   * ```\r\n   */\r\n  @Input() name:string;\r\n\r\n   /**\r\n   * The URL of the user's profile image.\r\n   * ```\r\n   * <mefdev-profile [img]=\"'assets/profile.png'\"></mefdev-profile>\r\n   * ```\r\n   */\r\n  @Input() img: string = '';\r\n\r\n  /**\r\n   * A short description of the user.\r\n   * ```\r\n   * <mefdev-profile [shortDescription]=\"'Lorem ipsum dolor sit amet, consectetur adipiscing elit.'\"></mefdev-profile>\r\n   * ```\r\n   */\r\n  @Input() shortDescription: string;\r\n\r\n  /**\r\n   * The header title of the profile component.\r\n   * ```\r\n   * <mefdev-profile [header]=\"'User Profile'\"></mefdev-profile>\r\n   * ```\r\n   */\r\n  @Input() header: string;\r\n\r\n  /**\r\n   * A flag indicating whether to display the profile image as a circle. Default \"false\".\r\n   * ```\r\n   * <mefdev-profile [circleImg]=\"'true'\"></mefdev-profile>\r\n   * ```\r\n   */\r\n  @Input() circleImg: boolean = false;\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  get sizeStyle(){\r\n    // return { 'width.px': this.width, 'height.px': this.height };\r\n    /**\r\n   * Returns the CSS style for the profile image size and shape.\r\n   */\r\n    if(!this.circleImg){\r\n      return {};\r\n    }\r\n\r\n    return {\r\n      'border-top-left-radius': `50%`,\r\n      'border-top-right-radius': `50%`,\r\n      'border-bottom-right-radius': `50%`,\r\n      'border-bottom-left-radius': `50%`,\r\n    };\r\n  }\r\n}\r\n","<div class=\"row profile-page\">\r\n    <div class=\"col-12 h3 mt-3\">\r\n        {{header}}\r\n    </div>\r\n    <div class=\"col-xl-3 col-lg-3 col-md-4 col-sm-12\">\r\n        <div *ngIf=\"!img || img == ''\" >\r\n            <img src=\"assets/images/md_icon.png\" height=\"124\" width=\"220\" />\r\n        </div>\r\n        <div *ngIf=\"img\" >\r\n            <img src=\"{{img}}\" alt=\"\" class=\"custom-img\" [ngStyle]=\"sizeStyle\"\r\n            />\r\n        </div>\r\n    </div>\r\n\r\n    <div class=\"col-xl-3 col-lg-4 col-md-5 col-sm-12 mt-4 mt-md-0\" >\r\n        <div class=\"row profile-name\">\r\n            <div class=\"col\">\r\n                {{name}}\r\n            </div>\r\n        </div>\r\n        <div class=\"row\">\r\n            <div class=\"col profile-description\">\r\n                {{shortDescription}}\r\n            </div>\r\n        </div>\r\n    </div>\r\n\r\n    <div class=\"col-xl-3 col-lg-4 col-md-5 col-sm-12 body-6 mt-4 mt-md-0\">\r\n        <ng-template [ngTemplateOutlet]=\"first_colum\"></ng-template>\r\n    </div>\r\n\r\n    <div class=\"col-xl-3 col-lg-4 col-md-5 col-sm-12 body-6 mt-4 mt-md-0\" >\r\n        <ng-template [ngTemplateOutlet]=\"second_colum\"></ng-template>\r\n    </div>\r\n\r\n</div>\r\n<div style=\"position: relative;\">\r\n    <div class=\"row profile-page-tabs\">\r\n        <ng-template [ngTemplateOutlet]=\"footer\">\r\n        </ng-template>\r\n    </div>\r\n</div>\r\n"]}
@@ -14,7 +14,7 @@ import * as i1 from "@angular/common";
14
14
  * </mefdev-table-page>
15
15
  * ```
16
16
  *
17
- * <example-url>https://mef.dev/ui_kit_demo/view/page_layouts/table_page</example-url>
17
+ * <example-url>https://platform.mef.dev/ui_kit_demo/view/page_layouts/table_page</example-url>
18
18
  */
19
19
  export class TablePageComponent {
20
20
  /**
@@ -39,4 +39,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
39
39
  type: ContentChild,
40
40
  args: ["filter_colum"]
41
41
  }] } });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtcGFnZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1raXQtbGliL3NyYy9saWIvbWFya3VwLWtpdC9wYWdlLWxheW91dHMvdGFibGUtcGFnZS90YWJsZS1wYWdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC1saWIvc3JjL2xpYi9tYXJrdXAta2l0L3BhZ2UtbGF5b3V0cy90YWJsZS1wYWdlL3RhYmxlLXBhZ2UuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQXVCLE1BQU0sZUFBZSxDQUFDOzs7QUFHM0U7Ozs7Ozs7Ozs7Ozs7O0VBY0U7QUFNSixNQUFNLE9BQU8sa0JBQWtCO0lBRTdCOzs7Ozs7O01BT0U7SUFDNEIsWUFBWSxDQUFvQjtJQUU5RCxnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO0lBQ1IsQ0FBQzt3R0FmVSxrQkFBa0I7NEZBQWxCLGtCQUFrQixtS0N2Qi9CLDRQQVNBOzs0RkRjYSxrQkFBa0I7a0JBTDlCLFNBQVM7K0JBQ0UsbUJBQW1COzBFQWNDLFlBQVk7c0JBQXpDLFlBQVk7dUJBQUMsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ29udGVudENoaWxkLCBPbkluaXQsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5cclxuICAvKipcclxuICAqIEEgY29tcG9uZW50IHJlcHJlc2VudGluZyBhIHRhYmxlIHBhZ2UgbGF5b3V0LlxyXG4gICpcclxuICAqIEV4YW1wbGUgb2YgdXNhZ2U6XHJcbiAgKiBcclxuICAqIGBgYFxyXG4gICogPG1lZmRldi10YWJsZS1wYWdlPlxyXG4gICogICA8bmctdGVtcGxhdGUgI2ZpbHRlcl9jb2x1bT5cclxuICAqICAgICA8IS0tIENvbnRlbnQgZm9yIHRoZSBmaWx0ZXIgY29sdW1uIC0tPlxyXG4gICogICA8L25nLXRlbXBsYXRlPlxyXG4gICogPC9tZWZkZXYtdGFibGUtcGFnZT5cclxuICAqIGBgYFxyXG4gICogIFxyXG4gICogPGV4YW1wbGUtdXJsPmh0dHBzOi8vbWVmLmRldi91aV9raXRfZGVtby92aWV3L3BhZ2VfbGF5b3V0cy90YWJsZV9wYWdlPC9leGFtcGxlLXVybD5cclxuICAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ21lZmRldi10YWJsZS1wYWdlJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdGFibGUtcGFnZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vdGFibGUtcGFnZS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUYWJsZVBhZ2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICAvKipcclxuICAgICogVGhlIHRlbXBsYXRlIHJlZmVyZW5jZSB0byB0aGUgY29udGVudCBvZiB0aGUgZmlsdGVyIGNvbHVtbi5cclxuICAgICogYGBgXHJcbiAgICAqICAgPG5nLXRlbXBsYXRlICNmaWx0ZXJfY29sdW0+XHJcbiAgICAqICAgICA8IS0tIENvbnRlbnQgZm9yIHRoZSBmaWx0ZXIgY29sdW1uIC0tPlxyXG4gICAgKiAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICAqIGBgYFxyXG4gICovXHJcbiAgQENvbnRlbnRDaGlsZChcImZpbHRlcl9jb2x1bVwiKSBmaWx0ZXJfY29sdW06IFRlbXBsYXRlUmVmPHZvaWQ+O1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICB9XHJcblxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJyb3dcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJjb2wtMTIgZmlsdGVyLWNvbHVtXCI+XHJcbiAgICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImZpbHRlcl9jb2x1bVwiPjwvbmctdGVtcGxhdGU+IFxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG5cclxuPGRpdiBjbGFzcz1cInRhYmxlLXJlc3BvbnNpdmVcIiA+XHJcbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbjwvZGl2PlxyXG4iXX0=
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtcGFnZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1raXQtbGliL3NyYy9saWIvbWFya3VwLWtpdC9wYWdlLWxheW91dHMvdGFibGUtcGFnZS90YWJsZS1wYWdlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC1saWIvc3JjL2xpYi9tYXJrdXAta2l0L3BhZ2UtbGF5b3V0cy90YWJsZS1wYWdlL3RhYmxlLXBhZ2UuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQXVCLE1BQU0sZUFBZSxDQUFDOzs7QUFHM0U7Ozs7Ozs7Ozs7Ozs7O0VBY0U7QUFNSixNQUFNLE9BQU8sa0JBQWtCO0lBRTdCOzs7Ozs7O01BT0U7SUFDNEIsWUFBWSxDQUFvQjtJQUU5RCxnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO0lBQ1IsQ0FBQzt3R0FmVSxrQkFBa0I7NEZBQWxCLGtCQUFrQixtS0N2Qi9CLDRQQVNBOzs0RkRjYSxrQkFBa0I7a0JBTDlCLFNBQVM7K0JBQ0UsbUJBQW1COzBFQWNDLFlBQVk7c0JBQXpDLFlBQVk7dUJBQUMsY0FBYyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ29udGVudENoaWxkLCBPbkluaXQsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5cclxuICAvKipcclxuICAqIEEgY29tcG9uZW50IHJlcHJlc2VudGluZyBhIHRhYmxlIHBhZ2UgbGF5b3V0LlxyXG4gICpcclxuICAqIEV4YW1wbGUgb2YgdXNhZ2U6XHJcbiAgKiBcclxuICAqIGBgYFxyXG4gICogPG1lZmRldi10YWJsZS1wYWdlPlxyXG4gICogICA8bmctdGVtcGxhdGUgI2ZpbHRlcl9jb2x1bT5cclxuICAqICAgICA8IS0tIENvbnRlbnQgZm9yIHRoZSBmaWx0ZXIgY29sdW1uIC0tPlxyXG4gICogICA8L25nLXRlbXBsYXRlPlxyXG4gICogPC9tZWZkZXYtdGFibGUtcGFnZT5cclxuICAqIGBgYFxyXG4gICogIFxyXG4gICogPGV4YW1wbGUtdXJsPmh0dHBzOi8vcGxhdGZvcm0ubWVmLmRldi91aV9raXRfZGVtby92aWV3L3BhZ2VfbGF5b3V0cy90YWJsZV9wYWdlPC9leGFtcGxlLXVybD5cclxuICAqL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ21lZmRldi10YWJsZS1wYWdlJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vdGFibGUtcGFnZS5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vdGFibGUtcGFnZS5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBUYWJsZVBhZ2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICAvKipcclxuICAgICogVGhlIHRlbXBsYXRlIHJlZmVyZW5jZSB0byB0aGUgY29udGVudCBvZiB0aGUgZmlsdGVyIGNvbHVtbi5cclxuICAgICogYGBgXHJcbiAgICAqICAgPG5nLXRlbXBsYXRlICNmaWx0ZXJfY29sdW0+XHJcbiAgICAqICAgICA8IS0tIENvbnRlbnQgZm9yIHRoZSBmaWx0ZXIgY29sdW1uIC0tPlxyXG4gICAgKiAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICAqIGBgYFxyXG4gICovXHJcbiAgQENvbnRlbnRDaGlsZChcImZpbHRlcl9jb2x1bVwiKSBmaWx0ZXJfY29sdW06IFRlbXBsYXRlUmVmPHZvaWQ+O1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICB9XHJcblxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJyb3dcIj5cclxuICAgIDxkaXYgY2xhc3M9XCJjb2wtMTIgZmlsdGVyLWNvbHVtXCI+XHJcbiAgICAgICAgPG5nLXRlbXBsYXRlIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImZpbHRlcl9jb2x1bVwiPjwvbmctdGVtcGxhdGU+IFxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG5cclxuPGRpdiBjbGFzcz1cInRhYmxlLXJlc3BvbnNpdmVcIiA+XHJcbiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbjwvZGl2PlxyXG4iXX0=
@@ -11,7 +11,7 @@ import * as i1 from "@angular/forms";
11
11
  * (valueChange)="onChildValueChange($event)"
12
12
  * ></mefdev-slider>
13
13
  *
14
- * <example-url>https://mef.dev/ui_kit_demo/view/controls/slider</example-url>
14
+ * <example-url>https://platform.mef.dev/ui_kit_demo/view/controls/slider</example-url>
15
15
  */
16
16
  export class MefDevSliderComponent {
17
17
  _range = { min: 1, max: 1000 };
@@ -117,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
117
117
  }], valueChange: [{
118
118
  type: Output
119
119
  }] } });
120
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/slider/slider/slider.component.ts","../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/slider/slider/slider.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;;;AAEvE;;;;;;;;;;;EAWE;AAMF,MAAM,OAAO,qBAAqB;IAExB,MAAM,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;IAEvC;;;;;;MAME;IACO,EAAE,CAAS;IAGpB;;;;;;;MAOE;IACF,IAEI,KAAK,CAAC,KAAmC;QAC3C,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC;QAC1B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC;IAC5B,CAAC;IACD,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED;;MAEE;IACF,QAAQ,GAAU,IAAI,CAAC,KAAK,CAAC,GAAG,CAAA;IAEhC;;MAEE;IACF,QAAQ,GAAU,IAAI,CAAC,KAAK,CAAC,GAAG,CAAA;IAIhC;;;;;;MAME;IACO,QAAQ,GAAY,KAAK,CAAC;IAEnC;;;;;;;;;MASE;IACQ,WAAW,GAAyD,IAAI,YAAY,EAAE,CAAC;IAEjG;;;;MAIE;IACF,aAAa;QACX,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5E,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAA;QAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAA;QACvB,IAAI,CAAC,gBAAgB,EAAE,CAAA;IACzB,CAAC;IAED;;;;;MAKE;IACF,gBAAgB;QACd,MAAM,YAAY,GAAG,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACjF,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;QACvD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5E,MAAM,UAAU,GAAG,QAAQ,CAAC,cAAc,CAAC,cAAc,IAAI,CAAC,EAAE,EAAE,CAAqB,CAAC;IAC1F,CAAC;IAED;;;;;MAKE;IACF,gBAAgB;QACd,MAAM,YAAY,GAAG,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACjF,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,wEAAwE;QAChI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5E,MAAM,QAAQ,GAAG,QAAQ,CAAC,cAAc,CAAC,YAAY,IAAI,CAAC,EAAE,EAAE,CAAqB,CAAC;IACtF,CAAC;wGAtGU,qBAAqB;4FAArB,qBAAqB,0JCnBlC,y5BAWA;;4FDQa,qBAAqB;kBALjC,SAAS;+BACE,eAAe;8BAehB,EAAE;sBAAV,KAAK;gBAaF,KAAK;sBAFR,KAAK;uBAAC,OAAO;gBA8BL,QAAQ;sBAAhB,KAAK;gBAYI,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\r\n\r\n/**\r\n * Component for a slider that allows selecting a range of values.\r\n * @example\r\n * <mefdev-slider\r\n *  [disabled]=\"false\"\r\n *  [range] = \"{min: 1, max: 10000}\"\r\n *  [id]= \"'slider1'\"\r\n *  (valueChange)=\"onChildValueChange($event)\"\r\n *  ></mefdev-slider>\r\n *\r\n * <example-url>https://mef.dev/ui_kit_demo/view/controls/slider</example-url>    \r\n*/\r\n@Component({\r\n  selector: 'mefdev-slider',\r\n  templateUrl: './slider.component.html',\r\n  styleUrls: ['./slider.component.scss']\r\n})\r\nexport class MefDevSliderComponent {\r\n\r\n  private _range = { min: 1, max: 1000 };\r\n\r\n  /**\r\n   * Unique id for each slider. Use it, if u need more than one slider independent from another on the same page. \r\n   * @example\r\n   * <mefdev-slider\r\n   *  [id]= \"'slider1'\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Input() id: string;\r\n\r\n\r\n  /**\r\n   * Input Object {min, max} container of the slider\r\n   * @example\r\n   * @interval\r\n   * <mefdev-slider\r\n   *  [range] = \"{min: 1, max: 10000}\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Input('range')\r\n  \r\n  set range(range: { min: number, max: number }) {\r\n    this._range = range;\r\n    this.minValue = range.min;\r\n    this.maxValue = range.max;\r\n  }\r\n  public get range(): { min: number, max: number } {\r\n    return this._range;\r\n  }\r\n\r\n  /**\r\n   * The minimum value of the slider.\r\n  */\r\n  minValue:number = this.range.min\r\n\r\n  /**\r\n   * The maximum value of the slider.\r\n  */\r\n  maxValue:number = this.range.max\r\n\r\n  \r\n\r\n  /**\r\n   * Property indicating whether the component is disabled.\r\n   * @example\r\n   * <mefdev-slider\r\n   *  [disabled]=\"true\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Input() disabled : boolean= false;\r\n\r\n  /**\r\n   * Event emitted when the values of the slider change.\r\n   * It passes an object with `minValue` and `maxValue` properties.\r\n   * @event MefDevSliderComponent#valueChange\r\n   * @type {EventEmitter<{ minValue: number; maxValue: number }>}\r\n   * @example\r\n   * <mefdev-slider\r\n   *  (valueChange)=\"onChildValueChange($event)\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Output() valueChange: EventEmitter<{ minValue: number; maxValue: number }> = new EventEmitter();\r\n\r\n  /**\r\n   * Method called when the values of the slider change.\r\n   * Emits the `valueChange` event and calls methods to handle changes in the minimum and maximum values.\r\n   * @fires MefDevSliderComponent#valueChange\r\n  */\r\n  onValueChange() {\r\n    this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });\r\n    this.minValue = this.minValue\r\n    this.onMinValueChange()\r\n    this.onMaxValueChange()\r\n  }\r\n\r\n  /**\r\n   * Method to handle changes in the minimum value.\r\n   * Converts a string to a number and removes all non-numeric characters.\r\n   * Then, emits the `valueChange` event and updates the value of the \"fromSlider\" slider.\r\n   * @fires MefDevSliderComponent#valueChange\r\n  */\r\n  onMinValueChange() {\r\n    const numericValue = parseFloat(this.minValue.toString().replace(/[^\\d.]/g, ''));\r\n    this.minValue = isNaN(numericValue) ? 0 : numericValue; \r\n    this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });\r\n    const fromSlider = document.getElementById(`fromSlider-${this.id}`) as HTMLInputElement;\r\n  }\r\n\r\n  /**\r\n   * Method to handle changes in the maximum value.\r\n   * Converts a string to a number and removes all non-numeric characters.\r\n   * Then, emits the `valueChange` event and updates the value of the \"toSlider\" slider.\r\n   * @fires MefDevSliderComponent#valueChange\r\n  */\r\n  onMaxValueChange() {\r\n    const numericValue = parseFloat(this.maxValue.toString().replace(/[^\\d.]/g, ''));\r\n    this.maxValue = isNaN(numericValue) ? 0 : numericValue; // Перевірка на NaN і присвоєння 0, якщо не вдалося конвертувати в число\r\n    this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });\r\n    const toSlider = document.getElementById(`toSlider-${this.id}`) as HTMLInputElement;\r\n  }\r\n}\r\n","<div class=\"range_container row\">\r\n    <div class=\"inputs_control \">\r\n      <input class=\"form_control_container__time__input h3\"  [(ngModel)]=\"'₴'+ minValue\" [disabled]=\"disabled\" (ngModelChange)=\"onMinValueChange()\">\r\n      <input class=\"form_control_container__time__input h3\"  [(ngModel)]=\"'₴'+ maxValue\" [disabled]=\"disabled\" (ngModelChange)=\"onMaxValueChange()\">\r\n    </div>\r\n    <div class=\"sliders_control\">\r\n      <input id=\"fromSlider\" type=\"range\"  [(ngModel)]=\"minValue\" [min]=\"range.min\" [max]=\"range.max\" (ngModelChange)=\"onValueChange()\">\r\n      <input id=\"toSlider\" type=\"range\"  [(ngModel)]=\"maxValue\" [min]=\"range.min\" [max]=\"range.max\" (ngModelChange)=\"onValueChange()\" \r\n          [style]=\"{'--minValue': minValue,  '--maxValue': maxValue, '--minFromValue': range.min, '--maxToValue': range.max}\">\r\n    </div>\r\n</div>\r\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/slider/slider/slider.component.ts","../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/slider/slider/slider.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;;;AAEvE;;;;;;;;;;;EAWE;AAMF,MAAM,OAAO,qBAAqB;IAExB,MAAM,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC;IAEvC;;;;;;MAME;IACO,EAAE,CAAS;IAGpB;;;;;;;MAOE;IACF,IAEI,KAAK,CAAC,KAAmC;QAC3C,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC;QAC1B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC;IAC5B,CAAC;IACD,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAED;;MAEE;IACF,QAAQ,GAAU,IAAI,CAAC,KAAK,CAAC,GAAG,CAAA;IAEhC;;MAEE;IACF,QAAQ,GAAU,IAAI,CAAC,KAAK,CAAC,GAAG,CAAA;IAIhC;;;;;;MAME;IACO,QAAQ,GAAY,KAAK,CAAC;IAEnC;;;;;;;;;MASE;IACQ,WAAW,GAAyD,IAAI,YAAY,EAAE,CAAC;IAEjG;;;;MAIE;IACF,aAAa;QACX,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5E,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAA;QAC7B,IAAI,CAAC,gBAAgB,EAAE,CAAA;QACvB,IAAI,CAAC,gBAAgB,EAAE,CAAA;IACzB,CAAC;IAED;;;;;MAKE;IACF,gBAAgB;QACd,MAAM,YAAY,GAAG,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACjF,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;QACvD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5E,MAAM,UAAU,GAAG,QAAQ,CAAC,cAAc,CAAC,cAAc,IAAI,CAAC,EAAE,EAAE,CAAqB,CAAC;IAC1F,CAAC;IAED;;;;;MAKE;IACF,gBAAgB;QACd,MAAM,YAAY,GAAG,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC;QACjF,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,wEAAwE;QAChI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC5E,MAAM,QAAQ,GAAG,QAAQ,CAAC,cAAc,CAAC,YAAY,IAAI,CAAC,EAAE,EAAE,CAAqB,CAAC;IACtF,CAAC;wGAtGU,qBAAqB;4FAArB,qBAAqB,0JCnBlC,y5BAWA;;4FDQa,qBAAqB;kBALjC,SAAS;+BACE,eAAe;8BAehB,EAAE;sBAAV,KAAK;gBAaF,KAAK;sBAFR,KAAK;uBAAC,OAAO;gBA8BL,QAAQ;sBAAhB,KAAK;gBAYI,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\r\n\r\n/**\r\n * Component for a slider that allows selecting a range of values.\r\n * @example\r\n * <mefdev-slider\r\n *  [disabled]=\"false\"\r\n *  [range] = \"{min: 1, max: 10000}\"\r\n *  [id]= \"'slider1'\"\r\n *  (valueChange)=\"onChildValueChange($event)\"\r\n *  ></mefdev-slider>\r\n *\r\n * <example-url>https://platform.mef.dev/ui_kit_demo/view/controls/slider</example-url>    \r\n*/\r\n@Component({\r\n  selector: 'mefdev-slider',\r\n  templateUrl: './slider.component.html',\r\n  styleUrls: ['./slider.component.scss']\r\n})\r\nexport class MefDevSliderComponent {\r\n\r\n  private _range = { min: 1, max: 1000 };\r\n\r\n  /**\r\n   * Unique id for each slider. Use it, if u need more than one slider independent from another on the same page. \r\n   * @example\r\n   * <mefdev-slider\r\n   *  [id]= \"'slider1'\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Input() id: string;\r\n\r\n\r\n  /**\r\n   * Input Object {min, max} container of the slider\r\n   * @example\r\n   * @interval\r\n   * <mefdev-slider\r\n   *  [range] = \"{min: 1, max: 10000}\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Input('range')\r\n  \r\n  set range(range: { min: number, max: number }) {\r\n    this._range = range;\r\n    this.minValue = range.min;\r\n    this.maxValue = range.max;\r\n  }\r\n  public get range(): { min: number, max: number } {\r\n    return this._range;\r\n  }\r\n\r\n  /**\r\n   * The minimum value of the slider.\r\n  */\r\n  minValue:number = this.range.min\r\n\r\n  /**\r\n   * The maximum value of the slider.\r\n  */\r\n  maxValue:number = this.range.max\r\n\r\n  \r\n\r\n  /**\r\n   * Property indicating whether the component is disabled.\r\n   * @example\r\n   * <mefdev-slider\r\n   *  [disabled]=\"true\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Input() disabled : boolean= false;\r\n\r\n  /**\r\n   * Event emitted when the values of the slider change.\r\n   * It passes an object with `minValue` and `maxValue` properties.\r\n   * @event MefDevSliderComponent#valueChange\r\n   * @type {EventEmitter<{ minValue: number; maxValue: number }>}\r\n   * @example\r\n   * <mefdev-slider\r\n   *  (valueChange)=\"onChildValueChange($event)\"\r\n   * ></mefdev-slider>\r\n  */\r\n  @Output() valueChange: EventEmitter<{ minValue: number; maxValue: number }> = new EventEmitter();\r\n\r\n  /**\r\n   * Method called when the values of the slider change.\r\n   * Emits the `valueChange` event and calls methods to handle changes in the minimum and maximum values.\r\n   * @fires MefDevSliderComponent#valueChange\r\n  */\r\n  onValueChange() {\r\n    this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });\r\n    this.minValue = this.minValue\r\n    this.onMinValueChange()\r\n    this.onMaxValueChange()\r\n  }\r\n\r\n  /**\r\n   * Method to handle changes in the minimum value.\r\n   * Converts a string to a number and removes all non-numeric characters.\r\n   * Then, emits the `valueChange` event and updates the value of the \"fromSlider\" slider.\r\n   * @fires MefDevSliderComponent#valueChange\r\n  */\r\n  onMinValueChange() {\r\n    const numericValue = parseFloat(this.minValue.toString().replace(/[^\\d.]/g, ''));\r\n    this.minValue = isNaN(numericValue) ? 0 : numericValue; \r\n    this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });\r\n    const fromSlider = document.getElementById(`fromSlider-${this.id}`) as HTMLInputElement;\r\n  }\r\n\r\n  /**\r\n   * Method to handle changes in the maximum value.\r\n   * Converts a string to a number and removes all non-numeric characters.\r\n   * Then, emits the `valueChange` event and updates the value of the \"toSlider\" slider.\r\n   * @fires MefDevSliderComponent#valueChange\r\n  */\r\n  onMaxValueChange() {\r\n    const numericValue = parseFloat(this.maxValue.toString().replace(/[^\\d.]/g, ''));\r\n    this.maxValue = isNaN(numericValue) ? 0 : numericValue; // Перевірка на NaN і присвоєння 0, якщо не вдалося конвертувати в число\r\n    this.valueChange.emit({ minValue: this.minValue, maxValue: this.maxValue });\r\n    const toSlider = document.getElementById(`toSlider-${this.id}`) as HTMLInputElement;\r\n  }\r\n}\r\n","<div class=\"range_container row\">\r\n    <div class=\"inputs_control \">\r\n      <input class=\"form_control_container__time__input h3\"  [(ngModel)]=\"'₴'+ minValue\" [disabled]=\"disabled\" (ngModelChange)=\"onMinValueChange()\">\r\n      <input class=\"form_control_container__time__input h3\"  [(ngModel)]=\"'₴'+ maxValue\" [disabled]=\"disabled\" (ngModelChange)=\"onMaxValueChange()\">\r\n    </div>\r\n    <div class=\"sliders_control\">\r\n      <input id=\"fromSlider\" type=\"range\"  [(ngModel)]=\"minValue\" [min]=\"range.min\" [max]=\"range.max\" (ngModelChange)=\"onValueChange()\">\r\n      <input id=\"toSlider\" type=\"range\"  [(ngModel)]=\"maxValue\" [min]=\"range.min\" [max]=\"range.max\" (ngModelChange)=\"onValueChange()\" \r\n          [style]=\"{'--minValue': minValue,  '--maxValue': maxValue, '--minFromValue': range.min, '--maxToValue': range.max}\">\r\n    </div>\r\n</div>\r\n"]}
@@ -22,7 +22,7 @@ import * as i4 from "../../../../pg-components/select/select.component";
22
22
  * [leftOffset]="'10'">
23
23
  * </mefdev-datepicker>
24
24
  *
25
- * <example-url>https://mef.dev/ui_kit_demo/view/utils/datepicker</example-url>
25
+ * <example-url>https://platform.mef.dev/ui_kit_demo/view/utils/datepicker</example-url>
26
26
  */
27
27
  export class DatepickerComponent {
28
28
  datePipe;
@@ -604,4 +604,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
604
604
  type: HostListener,
605
605
  args: ['document:click', ['$event']]
606
606
  }] } });
607
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.ts","../../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  HostListener,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport { DatePipe } from '@angular/common';\r\n\r\n/**\r\n * Datepicker Component for selecting dates.\r\n *\r\n * This component allows users to pick a date from a calendar interface.\r\n * It supports various configuration options such as language, date format, and date range.\r\n *\r\n * @example\r\n * <mefdev-datepicker\r\n *   [labelContentText]=\"'Select your date'\"\r\n *   [lang]=\"'uk'\"\r\n *   [dateFormat]=\"'dd/MM/yyyy'\"\r\n *   [range]=\"{startYear: 1900, toYear: 300}\"\r\n *   [disabled]=\"false\"\r\n *   (dateChanged)=\"onDateChanged($event)\"\r\n *   [topOffset]=\"'20'\"\r\n *   [leftOffset]=\"'10'\">\r\n * </mefdev-datepicker>\r\n *\r\n * <example-url>https://mef.dev/ui_kit_demo/view/utils/datepicker</example-url>\r\n */\r\n\r\n@Component({\r\n  selector: 'mefdev-datepicker',\r\n  templateUrl: './datepicker.component.html',\r\n  styleUrls: ['./datepicker.component.scss']\r\n})\r\n\r\nexport class DatepickerComponent implements  OnChanges, OnInit {\r\n\r\n  /**\r\n   * A flag that checks whether a valid date has been entered and whether the entered date exists.\r\n   * If the two previous conditions are not true, the datepicker will be highlighted in red\r\n   */\r\n  isUserDateValid: boolean = true;\r\n\r\n  /**\r\n   * Flag to determine if the calendar is open or closed.\r\n   * Default value: false (closed).\r\n   */\r\n  isCalendarOpen: boolean = false;\r\n\r\n  /**\r\n   * The currently selected date.\r\n   * Default value: Today's date.\r\n   */\r\n  selectedDate: Date = new Date();\r\n\r\n  /**\r\n   * The formatted date for display in the input.\r\n   * Default value: Formatted representation of the selected date.\r\n   */\r\n  formattedDate: any ;\r\n\r\n  /**\r\n   * Track the edited date separately when in editing mode.\r\n   * Default value: An empty string.\r\n   */\r\n  editedDate: string = '';\r\n\r\n  /**\r\n   * Flag to determine if the month dropdown is open or closed.\r\n   * Default value: true (open).\r\n   */\r\n  isMonthDropdownOpen: boolean = true;\r\n\r\n  /**\r\n   * Flag to determine if the year dropdown is open or closed.\r\n   * Default value: true (open).\r\n   */\r\n  isYearDropdownOpen: boolean = true;\r\n\r\n  /**\r\n   * The selected month (0-11).\r\n   * Default value: The month of the selected date.\r\n   */\r\n  selectedDateMonth: number = this.selectedDate.getMonth();\r\n\r\n  /**\r\n   * The selected year.\r\n   * Default value: The year of the selected date.\r\n   */\r\n  selectedDateYear: number = this.selectedDate.getFullYear();\r\n\r\n  /**\r\n   * An array of years for the year dropdown.\r\n   * Default value: An array of years within the specified range.\r\n   */\r\n  years: number[]\r\n\r\n  /**\r\n   * Label text for the datepicker.\r\n   * Default value: 'en' (English).\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [labelContentText] = \"'Chose your date'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() labelContentText: string;\r\n\r\n  /**\r\n   * The language/locale for the datepicker.\r\n   * Default value: 'en' (English).\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [lang] = \"'uk'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() lang: string = 'en';\r\n\r\n  /**\r\n   * The date format for displaying the selected date.\r\n   * Default value: 'EEE MMM dd yyyy'.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [dateFormat]=\"'dd/MM/yyyy'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() dateFormat: string = 'EEE MMM dd yyyy';\r\n\r\n  /**\r\n   * The range of years available in the year dropdown.\r\n   * Default value: { startYear: 1900, toYear: 300 }.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [range]=\"{startYear: 1900, toYear: 300}\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input('range') yearsRange:{startYear:number, toYear:number} = {startYear:1900, toYear:300};\r\n\r\n  /**\r\n   * Whether the datepicker is disabled or not.\r\n   * Default value: false (enabled).\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [disabled]=\"false\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() disabled: boolean = false;\r\n\r\n  /**\r\n   * The top offset for positioning the datepicker.\r\n   * Default value: '20'.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [topOffset]=\"'20'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() topOffset: string = '20';\r\n\r\n  /**\r\n   * The left offset for positioning the datepicker.\r\n   * Default value: '10'.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [leftOffset]=\"'10'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() leftOffset: string = '10'; //Default value\r\n\r\n  /**\r\n   * Event emitted when the selected date in the datepicker changes.\r\n   * It emits a `Date` object representing the selected date.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   (dateChanged)=\"onDateChanged($event)\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Output() dateChanged: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  /**\r\n   * Regular expression to validate user input for date in the format \"dd/MM/yyyy\".\r\n   * - The day (dd) should be between 01 and 31.\r\n   * - The month (MM) should be between 01 and 12.\r\n   * - The year (yyyy) should be a 4-digit number.\r\n   */\r\n  private dateRegExp: RegExp = /^(0[1-9]|[12][0-9]|3[01])\\/(0[1-9]|1[0-2])\\/\\d{4}$/;\r\n\r\n  /**\r\n   * The string entered by the user for date input.\r\n   * This variable stores the user's input as they type in the date field.\r\n   */\r\n  userInput: string = '';\r\n\r\n  /**\r\n   * Host listener for document click events to handle calendar interaction.\r\n   * This function checks if a click event occurred within the calendar or input elements.\r\n   * - If the click occurred within the calendar, no action is taken.\r\n   * - If the click occurred within the input element and the component is not in editing mode,\r\n   *   it opens the calendar.\r\n   * @param event The MouseEvent object representing the click event.\r\n   */\r\n  @HostListener('document:click', ['$event'])\r\n  onClick(event: MouseEvent) {\r\n    const targetElement = event.target as HTMLElement;\r\n    const datepickerContainer = this.elementRef.nativeElement.querySelector('.datepicker-container');\r\n    const calendar = this.elementRef.nativeElement.querySelector('.calendar');\r\n    const monthDropdown = this.elementRef.nativeElement.querySelector('.monthDropdown');\r\n    const yearDropdown = this.elementRef.nativeElement.querySelector('.yearDropdown');\r\n    const inputElement = this.elementRef.nativeElement.querySelector('input');\r\n\r\n    if (datepickerContainer && datepickerContainer.contains(calendar)) {\r\n      if (calendar && calendar.contains(targetElement)) return;\r\n      if (this.isMonthDropdownOpen && !calendar.contains(targetElement)) return;\r\n      if (this.isYearDropdownOpen && !calendar.contains(targetElement)) return;\r\n      if ((monthDropdown && monthDropdown.contains(targetElement)) && (yearDropdown && yearDropdown.contains(targetElement))) {\r\n        this.toggleMonthDropdown(event)\r\n        this.toggleYearDropdown(event)\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Constructor for the DatepickerComponent class.\r\n   * @param datePipe A service for formatting and parsing dates.\r\n   * @param elementRef A reference to the element on which this component is attached.\r\n   * It is used to access DOM elements.\r\n   */\r\n  constructor(private datePipe: DatePipe, private elementRef: ElementRef) {\r\n    this.updateInputValue()\r\n  }\r\n\r\n  /**\r\n   * Lifecycle hook called after the component is initialized.\r\n   * It initializes the years for the year select dropdown.\r\n   */\r\n  ngOnInit(){\r\n    this.initializeYears();\r\n  }\r\n\r\n  /**\r\n   * Lifecycle hook called whenever the input properties of the component change.\r\n   * It updates the input value.\r\n   */\r\n  ngOnChanges() {\r\n    this.updateInputValue();\r\n  }\r\n\r\n  /**\r\n   * An array of month names based on the selected language.\r\n   * It provides localized month names for display in the datepicker.\r\n   */\r\n  private get months(){\r\n    return this.getMonthList(this.lang);\r\n  }\r\n\r\n  /**\r\n   * An array of weekday names based on the selected language.\r\n   * It provides localized weekday names for display in the datepicker.\r\n   */\r\n  private get weekdays() {\r\n    return this.getWeekdayList(this.lang);\r\n  }\r\n\r\n  /**\r\n   * Initialize the list of years to be displayed in the year dropdown.\r\n   * This method populates the 'years' array with a range of years based on the provided 'yearsRange' configuration.\r\n   * @example\r\n   * ```\r\n   * // Assuming 'yearsRange' is { startYear: 1900, toYear: 300 }\r\n   * // After calling initializeYears(), 'years' might contain [1900, 1901, ..., 300]\r\n   * this.initializeYears();\r\n   * ```\r\n   */\r\n  private initializeYears() {\r\n    this.years = Array.from({ length: this.yearsRange.toYear }, (_, index) => index + this.yearsRange.startYear);\r\n  }\r\n\r\n  /**\r\n   * Toggle the editing mode for the date input. When enabled, the user can edit the date directly in the input field.\r\n   */\r\n  toggleEdit() {\r\n    this.editedDate = this.formatSelectedDate(); // Store the current formatted date for editing\r\n    this.isCalendarOpen = false;\r\n  }\r\n\r\n  /**\r\n   * Get a list of month names in the specified language and format.\r\n   * @param locales - An optional parameter specifying the locale or locales to use for formatting.\r\n   * @param format - The format for month names, either \"long\" (default) or \"short\".\r\n   * @returns An array of month names based on the provided format and locale.\r\n   * ```\r\n   * // Get a list of month names in the default language and long format\r\n   * const months = this.getMonthList(this.lang);\r\n   * ```\r\n   */\r\n  private getMonthList(  locales?: string | string[],  format: \"long\" | \"short\" = \"long\"): string[] {\r\n    const year = new Date().getFullYear();\r\n    const monthList = [...Array(12).keys()];\r\n    const formatter = new Intl.DateTimeFormat(locales, {    month: format  });\r\n    const getMonthName = (monthIndex: number) => formatter.format(new Date(year, monthIndex));\r\n    return monthList.map(getMonthName);\r\n  }\r\n\r\n  /**\r\n   * Get a list of weekday names in the specified language and format.\r\n   * @param locales - An optional parameter specifying the locale or locales to use for formatting.\r\n   * @param format - The format for weekday names, either \"short\" (default) or \"long\".\r\n   * @returns An array of weekday names based on the provided format and locale.\r\n   * ```\r\n   * // Get a list of weekday names in the default language and short format\r\n   * const weekdays = this.getWeekdayList();\r\n   * ```\r\n   */\r\n  private getWeekdayList(locales?: string | string[], format: \"short\" | \"long\" = \"short\"): string[] {\r\n    const weekdays = [...Array(7).keys()];\r\n    const mondayIndex = weekdays.indexOf(0);\r\n    weekdays.splice(mondayIndex, 1);\r\n    weekdays.push(0);\r\n    const formatter = new Intl.DateTimeFormat(locales, { weekday: format });\r\n    const getWeekdayName = (weekdayIndex: number) => {\r\n      return formatter.format(new Date(2023, 9, weekdayIndex + 1));\r\n    };\r\n    return weekdays.map(getWeekdayName);\r\n  }\r\n\r\n  /**\r\n   * Save the edited date input by the user, provided it matches the specified date format.\r\n   * This method checks if the entered date is in a valid format, disables the editing mode, and applies\r\n   * the edited date to the 'selectedDate'. It then reformats the selected date and closes the calendar.\r\n   * ```\r\n   * // Save the edited date and update the selected date\r\n   * this.saveEditedDate();\r\n   * ```\r\n   */\r\n  private saveEditedDate() {\r\n    if (this.isDateValid(this.editedDate)) {\r\n      const [day, month, year] = this.editedDate.split('/');\r\n      this.selectedDate = new Date(+year, +month - 1, +day);\r\n      this.formatDate();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle user input in the editable input field for date editing. This method captures the input value\r\n   * and stores it in the 'editedDate' variable. If the input matches the valid date format, it updates\r\n   * 'selectedDateMonth' and 'selectedDateYear' accordingly.\r\n   * @param event - The input event containing the user's input.\r\n   * ```\r\n   * // Handle user input in the editable input field\r\n   * this.onDateInput(event);\r\n   * ```\r\n   */\r\n  public onDateInput(event: any) {\r\n    const inputDate: string = event.target.value;\r\n    if (this.isDateValid(inputDate)) {\r\n      this.editedDate = inputDate;\r\n      const parsedDate = inputDate.split('/');\r\n      this.selectedDateMonth = +parsedDate[1] - 1;\r\n      this.selectedDateYear = +parsedDate[2];\r\n      this.selectedDate = new Date(+parsedDate[2], +parsedDate[1] - 1, +parsedDate[0]);\r\n      this.calculateFirstDayOfCalendar();\r\n    }\r\n    this.isUserDateValid = this.isDateValid(inputDate);\r\n  }\r\n\r\n  /**\r\n   * Toggle the visibility of the month dropdown in the calendar interface.\r\n   * This method is used to open or close the dropdown for selecting months.\r\n   * @param event - The event triggering the toggle action (e.g., a click event).\r\n   * ```\r\n   * // Toggle the visibility of the month dropdown\r\n   * this.toggleMonthDropdown(event);\r\n   * ```\r\n   */\r\n  private toggleMonthDropdown(event: Event) {\r\n    this.isMonthDropdownOpen = !this.isMonthDropdownOpen;\r\n  }\r\n\r\n  /**\r\n   * Toggle the visibility of the year dropdown in the calendar interface.\r\n   * This method is used to open or close the dropdown for selecting years.\r\n   * @param event - The event triggering the toggle action (e.g., a click event).\r\n   * ```\r\n   * // Toggle the visibility of the year dropdown\r\n   * this.toggleYearDropdown(event);\r\n   * ```\r\n   */\r\n  private toggleYearDropdown(event: Event) {\r\n    this.isYearDropdownOpen = !this.isYearDropdownOpen;\r\n  }\r\n\r\n  /**\r\n   * Handle the change of the selected month in the calendar interface.\r\n   * This method updates the input value, sets the selected date to the first day of the chosen month,\r\n   * and recalculates the calendar display accordingly.\r\n   * ```\r\n   * // Handle the change of the selected month\r\n   * this.onMonthChange();\r\n   * ```\r\n   */\r\n  private onMonthChange() {\r\n    this.updateInputValue();\r\n    this.selectedDate = new Date(this.selectedDateYear, this.selectedDateMonth, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n  /**\r\n   * Handle the change of the selected year in the calendar interface.\r\n   * This method updates the input value, sets the selected date to the first day of the chosen year,\r\n   * reformats the selected date, and recalculates the calendar display.\r\n   * ```\r\n   * // Handle the change of the selected year\r\n   * this.onYearChange();\r\n   * ```\r\n   */\r\n  private onYearChange() {\r\n    this.updateInputValue();\r\n    this.selectedDate = new Date(this.selectedDateYear, this.selectedDateMonth, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n\r\n  /**\r\n   * Select a date in the calendar interface and perform necessary updates.\r\n   * This method sets the selected date, formats it, closes the calendar, and emits a dateChanged event.\r\n   * It also updates the selected month and year dropdown values.\r\n   * @param date - The date to be selected in the calendar.\r\n   */\r\n  selectDate(date: Date) {\r\n    this.selectedDate = date;\r\n    this.formatDate();\r\n    this.isCalendarOpen = false;\r\n    this.dateChanged.next(this.selectedDate);\r\n    this.selectedDateMonth = this.selectedDate.getMonth();\r\n    this.selectedDateYear = this.selectedDate.getFullYear();\r\n  }\r\n\r\n  /**\r\n   * Format the selected date based on the chosen date format and language.\r\n   * This method uses the Angular DatePipe to format the selected date and updates the formattedDate variable.\r\n   * ```\r\n   * // Format the selected date\r\n   * this.formatDate();\r\n   * ```\r\n   */\r\n  private formatDate() {\r\n    this.formattedDate = this.datePipe.transform(this.selectedDate, this.dateFormat) || '';\r\n  }\r\n\r\n  /**\r\n   * Format the selected date based on the chosen date format, language, and locale.\r\n   * This method uses the Angular DatePipe to format the selected date with the specified language and updates the formatted date as a string.\r\n   * @returns A formatted date string.\r\n   * ```\r\n   * // Format the selected date with language\r\n   * const formatted = this.formatSelectedDate();\r\n   * ```\r\n   */\r\n  private formatSelectedDate(): string {\r\n    return this.datePipe.transform(this.selectedDate, this.dateFormat, this.lang) || '';\r\n  }\r\n\r\n  /**\r\n   * Update the input value displayed in the calendar interface.\r\n   * This method updates the input value to either the edited date or the formatted selected date,\r\n   * depending on whether the user is in edit mode or not.\r\n   * ```\r\n   * // Update the input value\r\n   * this.updateInputValue();\r\n   * ```\r\n   */\r\n  private updateInputValue() {\r\n    this.formattedDate = this.isCalendarOpen ? this.editedDate : this.formatSelectedDate();\r\n  }\r\n\r\n  /**\r\n   * Get an array of arrays representing the days of the current month.\r\n   * Each sub-array contains the day data for a week, and each day data object includes the date and whether it belongs to the current month.\r\n   * @returns An array of arrays representing the days of the current month.\r\n   * ```\r\n   * // Get an array of arrays representing the days of the current month\r\n   * const calendar = this.calendarDays;\r\n   * ```\r\n   */\r\n  private get calendarDays() {\r\n    return this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n  /**\r\n   * Get the date of the previous month to display in empty cells of the current month.\r\n   * This method returns the date of the previous month if the provided date is not in the current month.\r\n   * If the provided date is in the current month, it returns the date's day as a string.\r\n   * @param date - The date to evaluate.\r\n   * @returns The date of the previous month or a day string.\r\n   * ```\r\n   * // Get the previous month's date to display in empty cells\r\n   * const previousMonthDate = this.getPreviousMonthDate(new Date(2023, 8, 1));\r\n   * ```\r\n   */\r\n  private getPreviousMonthDate(date: Date): any {\r\n    if (!date) {\r\n      return '';\r\n    }\r\n    const currentDate = new Date();\r\n    if (date.getMonth() === currentDate.getMonth() && date.getFullYear() === currentDate.getFullYear()) {\r\n      return date.getDate().toString();\r\n    } else {\r\n      return this.datePipe.transform(date, 'dd');\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Navigate to the previous month in the calendar interface.\r\n   * This method updates the selectedDate, formats it, and recalculates the first day of the calendar.\r\n   * ```\r\n   * // Navigate to the previous month\r\n   * this.getPreviousMonth();\r\n   * ```\r\n   */\r\n  private getPreviousMonth() {\r\n    const currentMonth = this.selectedDate.getMonth();\r\n    this.selectedDate = new Date(this.selectedDate.getFullYear(), currentMonth - 1, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n  /**\r\n   * Navigate to the next month in the calendar interface.\r\n   * This method updates the selectedDate, formats it, and recalculates the first day of the calendar.\r\n   * ```\r\n   * // Navigate to the next month\r\n   * this.getNextMonth();\r\n   * ```\r\n   */\r\n  private getNextMonth() {\r\n    const currentMonth = this.selectedDate.getMonth();\r\n    this.selectedDate = new Date(this.selectedDate.getFullYear(), currentMonth + 1, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n\r\n  /**\r\n   * Get the number of days in a given month of a specific year.\r\n   * @param year - The year for which you want to determine the number of days.\r\n   * @param month - The month (0-based index) for which you want to determine the number of days.\r\n   * @returns The number of days in the specified month of the given year.\r\n   */\r\n  private daysInMonth(year: number, month: number): number {\r\n    return new Date(year, month + 1, 0).getDate();\r\n  }\r\n\r\n  /**\r\n   * Calculate the structure of days in a month for the calendar display.\r\n   * This method generates a matrix of day data objects representing the days in the calendar.\r\n   * Each day data object contains the date and whether it belongs to the current month.\r\n   * @returns A matrix of day data objects for the calendar display.\r\n   */\r\n  private calculateFirstDayOfCalendar() {\r\n    const year = this.selectedDate.getFullYear();\r\n    const month = this.selectedDate.getMonth();\r\n    const firstDayOfMonth = new Date(year, month, 1);\r\n    const firstWeekday = firstDayOfMonth.getDay();\r\n    const startDay = firstWeekday === 0 ? -5 : 2 - firstWeekday;\r\n    const calendarDays = [];\r\n    let currentDay = startDay;\r\n    for (let i = 0; i < 6; i++) {\r\n      const week = [];\r\n      for (let j = 0; j < 7; j++) {\r\n        const day = new Date(year, month, currentDay);\r\n        const dayData = {\r\n          date: day,\r\n          isCurrentMonth: currentDay >= 1 && currentDay <= this.daysInMonth(year, month),\r\n        };\r\n        week.push(dayData);\r\n        currentDay++;\r\n      }\r\n      calendarDays.push(week);\r\n    }\r\n    return calendarDays;\r\n  }\r\n\r\n  /**\r\n   * Check if a given date is the currently selected date in the calendar.\r\n   * @param date - The date to check.\r\n   * @returns `true` if the provided date matches the selected date, otherwise `false`.\r\n   * ```\r\n   * // Check if a date is selected\r\n   * const isSelected = this.isDateSelected(someDate);\r\n   * ```\r\n   */\r\n  private isDateSelected(date: Date) {\r\n    return date.toDateString() === this.selectedDate.toDateString();\r\n  }\r\n\r\n  /**\r\n   * Check if a date string is valid based on the specified date format.\r\n   * It also checks whether the specified number, month is correct and whether the specified one exists among calendar years\r\n   * @param inputDate - The date string to validate.\r\n   * @returns `true` if the input date string is valid, otherwise `false`.\r\n   * ```\r\n   * // Check if a date string is valid\r\n   * const isValidDate = this.isDateValid('05/25/2023');\r\n   * ```\r\n   */\r\n  private isDateValid(inputDate: string) {\r\n    if (!this.dateRegExp.test(inputDate)) {\r\n      return false;\r\n    }\r\n\r\n    const parts = inputDate.split('/');\r\n    const day = parseInt(parts[0], 10);\r\n    const month = parseInt(parts[1], 10);\r\n    const year = parseInt(parts[2], 10);\r\n\r\n    if (year > this.years[this.years.length - 1] || year < this.years[0]) {\r\n      return false\r\n    }\r\n\r\n    const daysInMonth = new Date(year, month, 0).getDate();\r\n    return day <= daysInMonth;\r\n  }\r\n\r\n  /**\r\n   * Check if a given date is today's date.\r\n   * @param date - The date to check.\r\n   * @returns `true` if the provided date is today's date, otherwise `false`.\r\n   * ```\r\n   * // Check if a date is today's date\r\n   * const isToday = this.isDateToday(someDate);\r\n   * ```\r\n   */\r\n  private isDateToday(date: Date) {\r\n    const today = new Date();\r\n    return date.toDateString() === today.toDateString();\r\n  }\r\n}\r\n","<div class=\"datepicker-container\" [class.disabled]=\"disabled\">\r\n\r\n  <!-- Input, save & edit buttons -->\r\n    <div class=\"input-container form-group\">\r\n        <label *ngIf=\"labelContentText\" class=\"form-label\"> {{ labelContentText }} </label>\r\n        <input\r\n          [ngClass]=\"{ 'calendarNotOpened': !isCalendarOpen }\"\r\n          [ngStyle]=\"{ 'border-color': isUserDateValid ? '' : 'red' }\"\r\n          type=\"text\"\r\n          class=\"form-control\"\r\n          (input)=\"onDateInput($event)\"\r\n          (click)=\"isCalendarOpen = true\"\r\n          [value]=\"formattedDate\"\r\n          [readOnly]=\"!isCalendarOpen\"\r\n        >\r\n    </div>\r\n\r\n  <!-- Calendar(Dropdowns, dates) -->\r\n  <div *ngIf=\"isCalendarOpen\" class=\"calendar\" #calendarContainer\r\n       [style.top]=\"topOffset\"\r\n       [style.left]=\"leftOffset\">\r\n    <div class=\"calendar-header\">\r\n      <div class=\"monthButtonContainer\">\r\n        <!-- Month dropdown -->\r\n        <ng-container *ngIf=\"isMonthDropdownOpen; else monthLabel\">\r\n          <mefdev-select\r\n            class=\"monthDropdown\"\r\n            [(ngModel)]=\"selectedDateMonth\"\r\n            (ngModelChange)=\"onMonthChange()\"\r\n            [PlaceHolder]=\"'month'\"\r\n          >\r\n            <mefdev-option\r\n              *ngFor=\"let month of months; let i = index\"\r\n              [Value]=\"i\"\r\n              [Label]=\"month\"\r\n              style=\"z-index: 1\"\r\n            >{{ month }}</mefdev-option>\r\n          </mefdev-select>\r\n        </ng-container>\r\n        <ng-template #monthLabel>\r\n          <span (click)=\"toggleMonthDropdown($event)\"></span>\r\n        </ng-template>\r\n\r\n        <!-- Year dropdown -->\r\n        <ng-container *ngIf=\"isYearDropdownOpen; else yearLabel\">\r\n          <mefdev-select\r\n            class=\"yearDropdown\"\r\n            [(ngModel)]=\"selectedDateYear\"\r\n            (ngModelChange)=\"onYearChange()\"\r\n            [PlaceHolder]=\"'year'\"\r\n          >\r\n            <mefdev-option\r\n              *ngFor=\"let year of years\"\r\n              [Label]=\"year\"\r\n              [Value]=\"year\"\r\n            >{{year}}</mefdev-option>\r\n          </mefdev-select>\r\n        </ng-container>\r\n        <ng-template #yearLabel>\r\n          <span (click)=\"toggleYearDropdown($event)\">{{ selectedDateYear }}</span>\r\n        </ng-template>\r\n      </div>\r\n      <!-- Calendar exit button -->\r\n      <div>\r\n        <i class=\"fa fa-times toggleCalendarButton\" (click)=\"isCalendarOpen = false\" aria-hidden=\"true\"></i>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"calendar-body\">\r\n      <table>\r\n        <tr>\r\n          <th class=\"text-center\" *ngFor=\"let weekday of weekdays\">{{ weekday }}</th>\r\n        </tr>\r\n        <tr *ngFor=\"let week of calendarDays\">\r\n          <td *ngFor=\"let dayData of week\"\r\n              (click)=\"selectDate(dayData.date)\"\r\n              [ngClass]=\"{ 'selected': isDateSelected(dayData.date), 'prev-month': !dayData.isCurrentMonth }\">\r\n\r\n            <span class=\"date\" [class.prev-month]=\"!dayData.isCurrentMonth\">\r\n              {{ dayData.date.getDate() }}\r\n            </span>\r\n          </td>\r\n        </tr>\r\n      </table>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
607
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.ts","../../../../../../../../projects/ui-kit-lib/src/lib/markup-kit/utils/datepicker/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  HostListener,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  EventEmitter,\r\n} from '@angular/core';\r\nimport { DatePipe } from '@angular/common';\r\n\r\n/**\r\n * Datepicker Component for selecting dates.\r\n *\r\n * This component allows users to pick a date from a calendar interface.\r\n * It supports various configuration options such as language, date format, and date range.\r\n *\r\n * @example\r\n * <mefdev-datepicker\r\n *   [labelContentText]=\"'Select your date'\"\r\n *   [lang]=\"'uk'\"\r\n *   [dateFormat]=\"'dd/MM/yyyy'\"\r\n *   [range]=\"{startYear: 1900, toYear: 300}\"\r\n *   [disabled]=\"false\"\r\n *   (dateChanged)=\"onDateChanged($event)\"\r\n *   [topOffset]=\"'20'\"\r\n *   [leftOffset]=\"'10'\">\r\n * </mefdev-datepicker>\r\n *\r\n * <example-url>https://platform.mef.dev/ui_kit_demo/view/utils/datepicker</example-url>\r\n */\r\n\r\n@Component({\r\n  selector: 'mefdev-datepicker',\r\n  templateUrl: './datepicker.component.html',\r\n  styleUrls: ['./datepicker.component.scss']\r\n})\r\n\r\nexport class DatepickerComponent implements  OnChanges, OnInit {\r\n\r\n  /**\r\n   * A flag that checks whether a valid date has been entered and whether the entered date exists.\r\n   * If the two previous conditions are not true, the datepicker will be highlighted in red\r\n   */\r\n  isUserDateValid: boolean = true;\r\n\r\n  /**\r\n   * Flag to determine if the calendar is open or closed.\r\n   * Default value: false (closed).\r\n   */\r\n  isCalendarOpen: boolean = false;\r\n\r\n  /**\r\n   * The currently selected date.\r\n   * Default value: Today's date.\r\n   */\r\n  selectedDate: Date = new Date();\r\n\r\n  /**\r\n   * The formatted date for display in the input.\r\n   * Default value: Formatted representation of the selected date.\r\n   */\r\n  formattedDate: any ;\r\n\r\n  /**\r\n   * Track the edited date separately when in editing mode.\r\n   * Default value: An empty string.\r\n   */\r\n  editedDate: string = '';\r\n\r\n  /**\r\n   * Flag to determine if the month dropdown is open or closed.\r\n   * Default value: true (open).\r\n   */\r\n  isMonthDropdownOpen: boolean = true;\r\n\r\n  /**\r\n   * Flag to determine if the year dropdown is open or closed.\r\n   * Default value: true (open).\r\n   */\r\n  isYearDropdownOpen: boolean = true;\r\n\r\n  /**\r\n   * The selected month (0-11).\r\n   * Default value: The month of the selected date.\r\n   */\r\n  selectedDateMonth: number = this.selectedDate.getMonth();\r\n\r\n  /**\r\n   * The selected year.\r\n   * Default value: The year of the selected date.\r\n   */\r\n  selectedDateYear: number = this.selectedDate.getFullYear();\r\n\r\n  /**\r\n   * An array of years for the year dropdown.\r\n   * Default value: An array of years within the specified range.\r\n   */\r\n  years: number[]\r\n\r\n  /**\r\n   * Label text for the datepicker.\r\n   * Default value: 'en' (English).\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [labelContentText] = \"'Chose your date'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() labelContentText: string;\r\n\r\n  /**\r\n   * The language/locale for the datepicker.\r\n   * Default value: 'en' (English).\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [lang] = \"'uk'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() lang: string = 'en';\r\n\r\n  /**\r\n   * The date format for displaying the selected date.\r\n   * Default value: 'EEE MMM dd yyyy'.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [dateFormat]=\"'dd/MM/yyyy'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() dateFormat: string = 'EEE MMM dd yyyy';\r\n\r\n  /**\r\n   * The range of years available in the year dropdown.\r\n   * Default value: { startYear: 1900, toYear: 300 }.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [range]=\"{startYear: 1900, toYear: 300}\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input('range') yearsRange:{startYear:number, toYear:number} = {startYear:1900, toYear:300};\r\n\r\n  /**\r\n   * Whether the datepicker is disabled or not.\r\n   * Default value: false (enabled).\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [disabled]=\"false\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() disabled: boolean = false;\r\n\r\n  /**\r\n   * The top offset for positioning the datepicker.\r\n   * Default value: '20'.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [topOffset]=\"'20'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() topOffset: string = '20';\r\n\r\n  /**\r\n   * The left offset for positioning the datepicker.\r\n   * Default value: '10'.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   [leftOffset]=\"'10'\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Input() leftOffset: string = '10'; //Default value\r\n\r\n  /**\r\n   * Event emitted when the selected date in the datepicker changes.\r\n   * It emits a `Date` object representing the selected date.\r\n   * @example\r\n   * <mefdev-datepicker\r\n   *   (dateChanged)=\"onDateChanged($event)\">\r\n   * </mefdev-datepicker>\r\n   */\r\n  @Output() dateChanged: EventEmitter<Date> = new EventEmitter<Date>();\r\n\r\n  /**\r\n   * Regular expression to validate user input for date in the format \"dd/MM/yyyy\".\r\n   * - The day (dd) should be between 01 and 31.\r\n   * - The month (MM) should be between 01 and 12.\r\n   * - The year (yyyy) should be a 4-digit number.\r\n   */\r\n  private dateRegExp: RegExp = /^(0[1-9]|[12][0-9]|3[01])\\/(0[1-9]|1[0-2])\\/\\d{4}$/;\r\n\r\n  /**\r\n   * The string entered by the user for date input.\r\n   * This variable stores the user's input as they type in the date field.\r\n   */\r\n  userInput: string = '';\r\n\r\n  /**\r\n   * Host listener for document click events to handle calendar interaction.\r\n   * This function checks if a click event occurred within the calendar or input elements.\r\n   * - If the click occurred within the calendar, no action is taken.\r\n   * - If the click occurred within the input element and the component is not in editing mode,\r\n   *   it opens the calendar.\r\n   * @param event The MouseEvent object representing the click event.\r\n   */\r\n  @HostListener('document:click', ['$event'])\r\n  onClick(event: MouseEvent) {\r\n    const targetElement = event.target as HTMLElement;\r\n    const datepickerContainer = this.elementRef.nativeElement.querySelector('.datepicker-container');\r\n    const calendar = this.elementRef.nativeElement.querySelector('.calendar');\r\n    const monthDropdown = this.elementRef.nativeElement.querySelector('.monthDropdown');\r\n    const yearDropdown = this.elementRef.nativeElement.querySelector('.yearDropdown');\r\n    const inputElement = this.elementRef.nativeElement.querySelector('input');\r\n\r\n    if (datepickerContainer && datepickerContainer.contains(calendar)) {\r\n      if (calendar && calendar.contains(targetElement)) return;\r\n      if (this.isMonthDropdownOpen && !calendar.contains(targetElement)) return;\r\n      if (this.isYearDropdownOpen && !calendar.contains(targetElement)) return;\r\n      if ((monthDropdown && monthDropdown.contains(targetElement)) && (yearDropdown && yearDropdown.contains(targetElement))) {\r\n        this.toggleMonthDropdown(event)\r\n        this.toggleYearDropdown(event)\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Constructor for the DatepickerComponent class.\r\n   * @param datePipe A service for formatting and parsing dates.\r\n   * @param elementRef A reference to the element on which this component is attached.\r\n   * It is used to access DOM elements.\r\n   */\r\n  constructor(private datePipe: DatePipe, private elementRef: ElementRef) {\r\n    this.updateInputValue()\r\n  }\r\n\r\n  /**\r\n   * Lifecycle hook called after the component is initialized.\r\n   * It initializes the years for the year select dropdown.\r\n   */\r\n  ngOnInit(){\r\n    this.initializeYears();\r\n  }\r\n\r\n  /**\r\n   * Lifecycle hook called whenever the input properties of the component change.\r\n   * It updates the input value.\r\n   */\r\n  ngOnChanges() {\r\n    this.updateInputValue();\r\n  }\r\n\r\n  /**\r\n   * An array of month names based on the selected language.\r\n   * It provides localized month names for display in the datepicker.\r\n   */\r\n  private get months(){\r\n    return this.getMonthList(this.lang);\r\n  }\r\n\r\n  /**\r\n   * An array of weekday names based on the selected language.\r\n   * It provides localized weekday names for display in the datepicker.\r\n   */\r\n  private get weekdays() {\r\n    return this.getWeekdayList(this.lang);\r\n  }\r\n\r\n  /**\r\n   * Initialize the list of years to be displayed in the year dropdown.\r\n   * This method populates the 'years' array with a range of years based on the provided 'yearsRange' configuration.\r\n   * @example\r\n   * ```\r\n   * // Assuming 'yearsRange' is { startYear: 1900, toYear: 300 }\r\n   * // After calling initializeYears(), 'years' might contain [1900, 1901, ..., 300]\r\n   * this.initializeYears();\r\n   * ```\r\n   */\r\n  private initializeYears() {\r\n    this.years = Array.from({ length: this.yearsRange.toYear }, (_, index) => index + this.yearsRange.startYear);\r\n  }\r\n\r\n  /**\r\n   * Toggle the editing mode for the date input. When enabled, the user can edit the date directly in the input field.\r\n   */\r\n  toggleEdit() {\r\n    this.editedDate = this.formatSelectedDate(); // Store the current formatted date for editing\r\n    this.isCalendarOpen = false;\r\n  }\r\n\r\n  /**\r\n   * Get a list of month names in the specified language and format.\r\n   * @param locales - An optional parameter specifying the locale or locales to use for formatting.\r\n   * @param format - The format for month names, either \"long\" (default) or \"short\".\r\n   * @returns An array of month names based on the provided format and locale.\r\n   * ```\r\n   * // Get a list of month names in the default language and long format\r\n   * const months = this.getMonthList(this.lang);\r\n   * ```\r\n   */\r\n  private getMonthList(  locales?: string | string[],  format: \"long\" | \"short\" = \"long\"): string[] {\r\n    const year = new Date().getFullYear();\r\n    const monthList = [...Array(12).keys()];\r\n    const formatter = new Intl.DateTimeFormat(locales, {    month: format  });\r\n    const getMonthName = (monthIndex: number) => formatter.format(new Date(year, monthIndex));\r\n    return monthList.map(getMonthName);\r\n  }\r\n\r\n  /**\r\n   * Get a list of weekday names in the specified language and format.\r\n   * @param locales - An optional parameter specifying the locale or locales to use for formatting.\r\n   * @param format - The format for weekday names, either \"short\" (default) or \"long\".\r\n   * @returns An array of weekday names based on the provided format and locale.\r\n   * ```\r\n   * // Get a list of weekday names in the default language and short format\r\n   * const weekdays = this.getWeekdayList();\r\n   * ```\r\n   */\r\n  private getWeekdayList(locales?: string | string[], format: \"short\" | \"long\" = \"short\"): string[] {\r\n    const weekdays = [...Array(7).keys()];\r\n    const mondayIndex = weekdays.indexOf(0);\r\n    weekdays.splice(mondayIndex, 1);\r\n    weekdays.push(0);\r\n    const formatter = new Intl.DateTimeFormat(locales, { weekday: format });\r\n    const getWeekdayName = (weekdayIndex: number) => {\r\n      return formatter.format(new Date(2023, 9, weekdayIndex + 1));\r\n    };\r\n    return weekdays.map(getWeekdayName);\r\n  }\r\n\r\n  /**\r\n   * Save the edited date input by the user, provided it matches the specified date format.\r\n   * This method checks if the entered date is in a valid format, disables the editing mode, and applies\r\n   * the edited date to the 'selectedDate'. It then reformats the selected date and closes the calendar.\r\n   * ```\r\n   * // Save the edited date and update the selected date\r\n   * this.saveEditedDate();\r\n   * ```\r\n   */\r\n  private saveEditedDate() {\r\n    if (this.isDateValid(this.editedDate)) {\r\n      const [day, month, year] = this.editedDate.split('/');\r\n      this.selectedDate = new Date(+year, +month - 1, +day);\r\n      this.formatDate();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Handle user input in the editable input field for date editing. This method captures the input value\r\n   * and stores it in the 'editedDate' variable. If the input matches the valid date format, it updates\r\n   * 'selectedDateMonth' and 'selectedDateYear' accordingly.\r\n   * @param event - The input event containing the user's input.\r\n   * ```\r\n   * // Handle user input in the editable input field\r\n   * this.onDateInput(event);\r\n   * ```\r\n   */\r\n  public onDateInput(event: any) {\r\n    const inputDate: string = event.target.value;\r\n    if (this.isDateValid(inputDate)) {\r\n      this.editedDate = inputDate;\r\n      const parsedDate = inputDate.split('/');\r\n      this.selectedDateMonth = +parsedDate[1] - 1;\r\n      this.selectedDateYear = +parsedDate[2];\r\n      this.selectedDate = new Date(+parsedDate[2], +parsedDate[1] - 1, +parsedDate[0]);\r\n      this.calculateFirstDayOfCalendar();\r\n    }\r\n    this.isUserDateValid = this.isDateValid(inputDate);\r\n  }\r\n\r\n  /**\r\n   * Toggle the visibility of the month dropdown in the calendar interface.\r\n   * This method is used to open or close the dropdown for selecting months.\r\n   * @param event - The event triggering the toggle action (e.g., a click event).\r\n   * ```\r\n   * // Toggle the visibility of the month dropdown\r\n   * this.toggleMonthDropdown(event);\r\n   * ```\r\n   */\r\n  private toggleMonthDropdown(event: Event) {\r\n    this.isMonthDropdownOpen = !this.isMonthDropdownOpen;\r\n  }\r\n\r\n  /**\r\n   * Toggle the visibility of the year dropdown in the calendar interface.\r\n   * This method is used to open or close the dropdown for selecting years.\r\n   * @param event - The event triggering the toggle action (e.g., a click event).\r\n   * ```\r\n   * // Toggle the visibility of the year dropdown\r\n   * this.toggleYearDropdown(event);\r\n   * ```\r\n   */\r\n  private toggleYearDropdown(event: Event) {\r\n    this.isYearDropdownOpen = !this.isYearDropdownOpen;\r\n  }\r\n\r\n  /**\r\n   * Handle the change of the selected month in the calendar interface.\r\n   * This method updates the input value, sets the selected date to the first day of the chosen month,\r\n   * and recalculates the calendar display accordingly.\r\n   * ```\r\n   * // Handle the change of the selected month\r\n   * this.onMonthChange();\r\n   * ```\r\n   */\r\n  private onMonthChange() {\r\n    this.updateInputValue();\r\n    this.selectedDate = new Date(this.selectedDateYear, this.selectedDateMonth, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n  /**\r\n   * Handle the change of the selected year in the calendar interface.\r\n   * This method updates the input value, sets the selected date to the first day of the chosen year,\r\n   * reformats the selected date, and recalculates the calendar display.\r\n   * ```\r\n   * // Handle the change of the selected year\r\n   * this.onYearChange();\r\n   * ```\r\n   */\r\n  private onYearChange() {\r\n    this.updateInputValue();\r\n    this.selectedDate = new Date(this.selectedDateYear, this.selectedDateMonth, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n\r\n  /**\r\n   * Select a date in the calendar interface and perform necessary updates.\r\n   * This method sets the selected date, formats it, closes the calendar, and emits a dateChanged event.\r\n   * It also updates the selected month and year dropdown values.\r\n   * @param date - The date to be selected in the calendar.\r\n   */\r\n  selectDate(date: Date) {\r\n    this.selectedDate = date;\r\n    this.formatDate();\r\n    this.isCalendarOpen = false;\r\n    this.dateChanged.next(this.selectedDate);\r\n    this.selectedDateMonth = this.selectedDate.getMonth();\r\n    this.selectedDateYear = this.selectedDate.getFullYear();\r\n  }\r\n\r\n  /**\r\n   * Format the selected date based on the chosen date format and language.\r\n   * This method uses the Angular DatePipe to format the selected date and updates the formattedDate variable.\r\n   * ```\r\n   * // Format the selected date\r\n   * this.formatDate();\r\n   * ```\r\n   */\r\n  private formatDate() {\r\n    this.formattedDate = this.datePipe.transform(this.selectedDate, this.dateFormat) || '';\r\n  }\r\n\r\n  /**\r\n   * Format the selected date based on the chosen date format, language, and locale.\r\n   * This method uses the Angular DatePipe to format the selected date with the specified language and updates the formatted date as a string.\r\n   * @returns A formatted date string.\r\n   * ```\r\n   * // Format the selected date with language\r\n   * const formatted = this.formatSelectedDate();\r\n   * ```\r\n   */\r\n  private formatSelectedDate(): string {\r\n    return this.datePipe.transform(this.selectedDate, this.dateFormat, this.lang) || '';\r\n  }\r\n\r\n  /**\r\n   * Update the input value displayed in the calendar interface.\r\n   * This method updates the input value to either the edited date or the formatted selected date,\r\n   * depending on whether the user is in edit mode or not.\r\n   * ```\r\n   * // Update the input value\r\n   * this.updateInputValue();\r\n   * ```\r\n   */\r\n  private updateInputValue() {\r\n    this.formattedDate = this.isCalendarOpen ? this.editedDate : this.formatSelectedDate();\r\n  }\r\n\r\n  /**\r\n   * Get an array of arrays representing the days of the current month.\r\n   * Each sub-array contains the day data for a week, and each day data object includes the date and whether it belongs to the current month.\r\n   * @returns An array of arrays representing the days of the current month.\r\n   * ```\r\n   * // Get an array of arrays representing the days of the current month\r\n   * const calendar = this.calendarDays;\r\n   * ```\r\n   */\r\n  private get calendarDays() {\r\n    return this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n  /**\r\n   * Get the date of the previous month to display in empty cells of the current month.\r\n   * This method returns the date of the previous month if the provided date is not in the current month.\r\n   * If the provided date is in the current month, it returns the date's day as a string.\r\n   * @param date - The date to evaluate.\r\n   * @returns The date of the previous month or a day string.\r\n   * ```\r\n   * // Get the previous month's date to display in empty cells\r\n   * const previousMonthDate = this.getPreviousMonthDate(new Date(2023, 8, 1));\r\n   * ```\r\n   */\r\n  private getPreviousMonthDate(date: Date): any {\r\n    if (!date) {\r\n      return '';\r\n    }\r\n    const currentDate = new Date();\r\n    if (date.getMonth() === currentDate.getMonth() && date.getFullYear() === currentDate.getFullYear()) {\r\n      return date.getDate().toString();\r\n    } else {\r\n      return this.datePipe.transform(date, 'dd');\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Navigate to the previous month in the calendar interface.\r\n   * This method updates the selectedDate, formats it, and recalculates the first day of the calendar.\r\n   * ```\r\n   * // Navigate to the previous month\r\n   * this.getPreviousMonth();\r\n   * ```\r\n   */\r\n  private getPreviousMonth() {\r\n    const currentMonth = this.selectedDate.getMonth();\r\n    this.selectedDate = new Date(this.selectedDate.getFullYear(), currentMonth - 1, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n  /**\r\n   * Navigate to the next month in the calendar interface.\r\n   * This method updates the selectedDate, formats it, and recalculates the first day of the calendar.\r\n   * ```\r\n   * // Navigate to the next month\r\n   * this.getNextMonth();\r\n   * ```\r\n   */\r\n  private getNextMonth() {\r\n    const currentMonth = this.selectedDate.getMonth();\r\n    this.selectedDate = new Date(this.selectedDate.getFullYear(), currentMonth + 1, 1);\r\n    this.formatDate();\r\n    this.calculateFirstDayOfCalendar();\r\n  }\r\n\r\n\r\n  /**\r\n   * Get the number of days in a given month of a specific year.\r\n   * @param year - The year for which you want to determine the number of days.\r\n   * @param month - The month (0-based index) for which you want to determine the number of days.\r\n   * @returns The number of days in the specified month of the given year.\r\n   */\r\n  private daysInMonth(year: number, month: number): number {\r\n    return new Date(year, month + 1, 0).getDate();\r\n  }\r\n\r\n  /**\r\n   * Calculate the structure of days in a month for the calendar display.\r\n   * This method generates a matrix of day data objects representing the days in the calendar.\r\n   * Each day data object contains the date and whether it belongs to the current month.\r\n   * @returns A matrix of day data objects for the calendar display.\r\n   */\r\n  private calculateFirstDayOfCalendar() {\r\n    const year = this.selectedDate.getFullYear();\r\n    const month = this.selectedDate.getMonth();\r\n    const firstDayOfMonth = new Date(year, month, 1);\r\n    const firstWeekday = firstDayOfMonth.getDay();\r\n    const startDay = firstWeekday === 0 ? -5 : 2 - firstWeekday;\r\n    const calendarDays = [];\r\n    let currentDay = startDay;\r\n    for (let i = 0; i < 6; i++) {\r\n      const week = [];\r\n      for (let j = 0; j < 7; j++) {\r\n        const day = new Date(year, month, currentDay);\r\n        const dayData = {\r\n          date: day,\r\n          isCurrentMonth: currentDay >= 1 && currentDay <= this.daysInMonth(year, month),\r\n        };\r\n        week.push(dayData);\r\n        currentDay++;\r\n      }\r\n      calendarDays.push(week);\r\n    }\r\n    return calendarDays;\r\n  }\r\n\r\n  /**\r\n   * Check if a given date is the currently selected date in the calendar.\r\n   * @param date - The date to check.\r\n   * @returns `true` if the provided date matches the selected date, otherwise `false`.\r\n   * ```\r\n   * // Check if a date is selected\r\n   * const isSelected = this.isDateSelected(someDate);\r\n   * ```\r\n   */\r\n  private isDateSelected(date: Date) {\r\n    return date.toDateString() === this.selectedDate.toDateString();\r\n  }\r\n\r\n  /**\r\n   * Check if a date string is valid based on the specified date format.\r\n   * It also checks whether the specified number, month is correct and whether the specified one exists among calendar years\r\n   * @param inputDate - The date string to validate.\r\n   * @returns `true` if the input date string is valid, otherwise `false`.\r\n   * ```\r\n   * // Check if a date string is valid\r\n   * const isValidDate = this.isDateValid('05/25/2023');\r\n   * ```\r\n   */\r\n  private isDateValid(inputDate: string) {\r\n    if (!this.dateRegExp.test(inputDate)) {\r\n      return false;\r\n    }\r\n\r\n    const parts = inputDate.split('/');\r\n    const day = parseInt(parts[0], 10);\r\n    const month = parseInt(parts[1], 10);\r\n    const year = parseInt(parts[2], 10);\r\n\r\n    if (year > this.years[this.years.length - 1] || year < this.years[0]) {\r\n      return false\r\n    }\r\n\r\n    const daysInMonth = new Date(year, month, 0).getDate();\r\n    return day <= daysInMonth;\r\n  }\r\n\r\n  /**\r\n   * Check if a given date is today's date.\r\n   * @param date - The date to check.\r\n   * @returns `true` if the provided date is today's date, otherwise `false`.\r\n   * ```\r\n   * // Check if a date is today's date\r\n   * const isToday = this.isDateToday(someDate);\r\n   * ```\r\n   */\r\n  private isDateToday(date: Date) {\r\n    const today = new Date();\r\n    return date.toDateString() === today.toDateString();\r\n  }\r\n}\r\n","<div class=\"datepicker-container\" [class.disabled]=\"disabled\">\r\n\r\n  <!-- Input, save & edit buttons -->\r\n    <div class=\"input-container form-group\">\r\n        <label *ngIf=\"labelContentText\" class=\"form-label\"> {{ labelContentText }} </label>\r\n        <input\r\n          [ngClass]=\"{ 'calendarNotOpened': !isCalendarOpen }\"\r\n          [ngStyle]=\"{ 'border-color': isUserDateValid ? '' : 'red' }\"\r\n          type=\"text\"\r\n          class=\"form-control\"\r\n          (input)=\"onDateInput($event)\"\r\n          (click)=\"isCalendarOpen = true\"\r\n          [value]=\"formattedDate\"\r\n          [readOnly]=\"!isCalendarOpen\"\r\n        >\r\n    </div>\r\n\r\n  <!-- Calendar(Dropdowns, dates) -->\r\n  <div *ngIf=\"isCalendarOpen\" class=\"calendar\" #calendarContainer\r\n       [style.top]=\"topOffset\"\r\n       [style.left]=\"leftOffset\">\r\n    <div class=\"calendar-header\">\r\n      <div class=\"monthButtonContainer\">\r\n        <!-- Month dropdown -->\r\n        <ng-container *ngIf=\"isMonthDropdownOpen; else monthLabel\">\r\n          <mefdev-select\r\n            class=\"monthDropdown\"\r\n            [(ngModel)]=\"selectedDateMonth\"\r\n            (ngModelChange)=\"onMonthChange()\"\r\n            [PlaceHolder]=\"'month'\"\r\n          >\r\n            <mefdev-option\r\n              *ngFor=\"let month of months; let i = index\"\r\n              [Value]=\"i\"\r\n              [Label]=\"month\"\r\n              style=\"z-index: 1\"\r\n            >{{ month }}</mefdev-option>\r\n          </mefdev-select>\r\n        </ng-container>\r\n        <ng-template #monthLabel>\r\n          <span (click)=\"toggleMonthDropdown($event)\"></span>\r\n        </ng-template>\r\n\r\n        <!-- Year dropdown -->\r\n        <ng-container *ngIf=\"isYearDropdownOpen; else yearLabel\">\r\n          <mefdev-select\r\n            class=\"yearDropdown\"\r\n            [(ngModel)]=\"selectedDateYear\"\r\n            (ngModelChange)=\"onYearChange()\"\r\n            [PlaceHolder]=\"'year'\"\r\n          >\r\n            <mefdev-option\r\n              *ngFor=\"let year of years\"\r\n              [Label]=\"year\"\r\n              [Value]=\"year\"\r\n            >{{year}}</mefdev-option>\r\n          </mefdev-select>\r\n        </ng-container>\r\n        <ng-template #yearLabel>\r\n          <span (click)=\"toggleYearDropdown($event)\">{{ selectedDateYear }}</span>\r\n        </ng-template>\r\n      </div>\r\n      <!-- Calendar exit button -->\r\n      <div>\r\n        <i class=\"fa fa-times toggleCalendarButton\" (click)=\"isCalendarOpen = false\" aria-hidden=\"true\"></i>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"calendar-body\">\r\n      <table>\r\n        <tr>\r\n          <th class=\"text-center\" *ngFor=\"let weekday of weekdays\">{{ weekday }}</th>\r\n        </tr>\r\n        <tr *ngFor=\"let week of calendarDays\">\r\n          <td *ngFor=\"let dayData of week\"\r\n              (click)=\"selectDate(dayData.date)\"\r\n              [ngClass]=\"{ 'selected': isDateSelected(dayData.date), 'prev-month': !dayData.isCurrentMonth }\">\r\n\r\n            <span class=\"date\" [class.prev-month]=\"!dayData.isCurrentMonth\">\r\n              {{ dayData.date.getDate() }}\r\n            </span>\r\n          </td>\r\n        </tr>\r\n      </table>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
@@ -16,7 +16,7 @@ import * as i3 from "../filtered-field-item/filtered-field-item.component";
16
16
  * </mefdev-filtered-field-container>
17
17
  * ```
18
18
  * Example of usage:
19
- * <example-url>https://mef.dev/ui_kit_demo/view/utils/filtered_field</example-url>
19
+ * <example-url>https://platform.mef.dev/ui_kit_demo/view/utils/filtered_field</example-url>
20
20
  */
21
21
  export class FilteredFieldContainerComponent {
22
22
  service;
@@ -69,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
69
69
  type: Component,
70
70
  args: [{ selector: 'mefdev-filtered-field-container', template: "<div class=\"item-container\">\r\n <mefdev-filtered-field-item *ngFor=\"let item of items\" [item]=\"item\" (discard)=\"onDiscard(item)\" (openFilter)=\"onOpenFilter(item)\"></mefdev-filtered-field-item>\r\n</div>\r\n", styles: [".item-container{display:flex;cursor:context-menu}\n"] }]
71
71
  }], ctorParameters: function () { return [{ type: i1.FilteredFieldService }]; } });
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyZWQtZmllbGQtY29udGFpbmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC1saWIvc3JjL2xpYi9tYXJrdXAta2l0L3V0aWxzL2ZpbHRlcmVkLWZpZWxkL2ZpbHRlcmVkLWZpZWxkLWNvbnRhaW5lci9maWx0ZXJlZC1maWVsZC1jb250YWluZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0LWxpYi9zcmMvbGliL21hcmt1cC1raXQvdXRpbHMvZmlsdGVyZWQtZmllbGQvZmlsdGVyZWQtZmllbGQtY29udGFpbmVyL2ZpbHRlcmVkLWZpZWxkLWNvbnRhaW5lci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7OztBQUloRDs7Ozs7Ozs7Ozs7Ozs7RUFjRTtBQU1KLE1BQU0sT0FBTywrQkFBK0I7SUFRaEM7SUFOVjs7T0FFRztJQUNILEtBQUssR0FBdUIsRUFBRSxDQUFDO0lBRS9CLFlBQ1UsT0FBNkI7UUFBN0IsWUFBTyxHQUFQLE9BQU8sQ0FBc0I7SUFDakMsQ0FBQztJQUVQOzs7O09BSUc7SUFDSCxZQUFZLENBQUMsSUFBc0I7UUFDakMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVDOzs7O0tBSUM7SUFDSCxTQUFTLENBQUMsSUFBc0I7UUFDOUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDakMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNuRSxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDL0MsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQTtZQUVsRCxJQUFHLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUM7Z0JBQ2hELElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO2dCQUNyQixJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7Z0JBQ3hCLE9BQU87YUFDUjtZQUVELElBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsYUFBYSxJQUFJLElBQUksQ0FBQyxRQUFRLElBQUksRUFBRSxDQUFDLEVBQUU7Z0JBQzFFLE9BQU87YUFDUjtZQUVELElBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxFQUFDO2dCQUNULElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO2dCQUNyQixPQUFPO2FBQ1I7WUFFRCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUV4QixDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7d0dBcERVLCtCQUErQjs0RkFBL0IsK0JBQStCLHVFQ3hCNUMsOE5BR0E7OzRGRHFCYSwrQkFBK0I7a0JBTDNDLFNBQVM7K0JBQ0UsaUNBQWlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRmlsdGVyZWRGaWVsZFNlcnZpY2UgfSBmcm9tICcuLi9maWx0ZXJlZC1maWVsZC5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRmlsdHJlZEl0ZW1Nb2RlbCB9IGZyb20gJy4uL2ZpbHRyZWQtaXRlbS5tb2RlbCc7XHJcblxyXG4gIC8qKlxyXG4gICogQSBjb250YWluZXIgY29tcG9uZW50IGZvciBmaWx0ZXJlZCBmaWVsZHMuXHJcbiAgKlxyXG4gICogRXhhbXBsZSBvZiB1c2FnZTpcclxuICAqIGBgYFxyXG4gICogPG1lZmRldi1maWx0ZXJlZC1maWVsZC1jb250YWluZXI+XHJcbiAgKiBcclxuICAqIDxtZWZkZXYtZmlsdGVyZWQtZmllbGQtaXRlbSBbaXRlbV09XCJmaWx0ZXJJdGVtXCIgKGRpc2NhcmQpPVwib25EaXNjYXJkRmlsdGVyKCRldmVudClcIiAob3BlbkZpbHRlcik9XCJvbk9wZW5GaWx0ZXIoKVwiPlxyXG4gICogPC9tZWZkZXYtZmlsdGVyZWQtZmllbGQtaXRlbT5cclxuICAqXHJcbiAgKiA8L21lZmRldi1maWx0ZXJlZC1maWVsZC1jb250YWluZXI+XHJcbiAgKiBgYGBcclxuICAqIEV4YW1wbGUgb2YgdXNhZ2U6XHJcbiAgKiA8ZXhhbXBsZS11cmw+aHR0cHM6Ly9tZWYuZGV2L3VpX2tpdF9kZW1vL3ZpZXcvdXRpbHMvZmlsdGVyZWRfZmllbGQ8L2V4YW1wbGUtdXJsPlxyXG4gICovXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbWVmZGV2LWZpbHRlcmVkLWZpZWxkLWNvbnRhaW5lcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2ZpbHRlcmVkLWZpZWxkLWNvbnRhaW5lci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vZmlsdGVyZWQtZmllbGQtY29udGFpbmVyLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIEZpbHRlcmVkRmllbGRDb250YWluZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICAvKipcclxuICAgKiBBbiBhcnJheSBvZiBmaWx0ZXJlZCBpdGVtIG1vZGVscy5cclxuICAgKi9cclxuICBpdGVtczogRmlsdHJlZEl0ZW1Nb2RlbFtdID0gW107XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBzZXJ2aWNlOiBGaWx0ZXJlZEZpZWxkU2VydmljZVxyXG4gICAgKSB7IH1cclxuXHJcbiAgLyoqXHJcbiAgICogRXZlbnQgaGFuZGxlciBmb3Igb3BlbmluZyB0aGUgZmlsdGVyLlxyXG4gICAqXHJcbiAgICogQHBhcmFtIGl0ZW0gVGhlIGZpbHRlcmVkIGl0ZW0gbW9kZWwuXHJcbiAgICovXHJcbiAgb25PcGVuRmlsdGVyKGl0ZW06IEZpbHRyZWRJdGVtTW9kZWwpe1xyXG4gICAgdGhpcy5zZXJ2aWNlLnNlbmRPcGVuRmlsdGVyKGl0ZW0pO1xyXG4gIH1cclxuXHJcbiAgICAvKipcclxuICAgKiBFdmVudCBoYW5kbGVyIGZvciBkaXNjYXJkaW5nIHRoZSBmaWx0ZXIuXHJcbiAgICpcclxuICAgKiBAcGFyYW0gaXRlbSBUaGUgZmlsdGVyZWQgaXRlbSBtb2RlbC5cclxuICAgKi9cclxuICBvbkRpc2NhcmQoaXRlbTogRmlsdHJlZEl0ZW1Nb2RlbCl7XHJcbiAgICBpdGVtLmRpc2NhcmQoaXRlbS5zdGFuZGFydFZhbHVlKTtcclxuICAgIHRoaXMuaXRlbXMuc3BsaWNlKHRoaXMuaXRlbXMuZmluZEluZGV4KHggPT4geC5pZCA9PSBpdGVtLmlkKSwgMSk7XHJcbiAgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMuc2VydmljZS5nZXROZXdGaWx0ZXJJdGVtKCkuc3Vic2NyaWJlKGl0ZW0gPT4ge1xyXG4gICAgICBsZXQgaSA9IHRoaXMuaXRlbXMuZmluZEluZGV4KHggPT4geC5pZCA9PSBpdGVtLmlkKVxyXG5cclxuICAgICAgaWYoaSAhPSAtMSAmJiBpdGVtLm5ld1ZhbHVlID09IGl0ZW0uc3RhbmRhcnRWYWx1ZSl7XHJcbiAgICAgICAgdGhpcy5pdGVtc1tpXSA9IGl0ZW07XHJcbiAgICAgICAgdGhpcy5pdGVtcy5zcGxpY2UoaSwgMSk7XHJcbiAgICAgICAgcmV0dXJuO1xyXG4gICAgICB9XHJcblxyXG4gICAgICBpZihpID09IC0xICYmIChpdGVtLm5ld1ZhbHVlID09IGl0ZW0uc3RhbmRhcnRWYWx1ZSB8fCBpdGVtLm5ld1ZhbHVlID09ICcnKSApe1xyXG4gICAgICAgIHJldHVybjtcclxuICAgICAgfVxyXG5cclxuICAgICAgaWYoaSAhPSAtMSl7XHJcbiAgICAgICAgdGhpcy5pdGVtc1tpXSA9IGl0ZW07XHJcbiAgICAgICAgcmV0dXJuO1xyXG4gICAgICB9XHJcblxyXG4gICAgICB0aGlzLml0ZW1zLnB1c2goaXRlbSk7XHJcblxyXG4gICAgfSlcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cIml0ZW0tY29udGFpbmVyXCI+XHJcbiAgICA8bWVmZGV2LWZpbHRlcmVkLWZpZWxkLWl0ZW0gKm5nRm9yPVwibGV0IGl0ZW0gb2YgaXRlbXNcIiBbaXRlbV09XCJpdGVtXCIgKGRpc2NhcmQpPVwib25EaXNjYXJkKGl0ZW0pXCIgKG9wZW5GaWx0ZXIpPVwib25PcGVuRmlsdGVyKGl0ZW0pXCI+PC9tZWZkZXYtZmlsdGVyZWQtZmllbGQtaXRlbT5cclxuPC9kaXY+XHJcbiJdfQ==
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyZWQtZmllbGQtY29udGFpbmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3VpLWtpdC1saWIvc3JjL2xpYi9tYXJrdXAta2l0L3V0aWxzL2ZpbHRlcmVkLWZpZWxkL2ZpbHRlcmVkLWZpZWxkLWNvbnRhaW5lci9maWx0ZXJlZC1maWVsZC1jb250YWluZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0LWxpYi9zcmMvbGliL21hcmt1cC1raXQvdXRpbHMvZmlsdGVyZWQtZmllbGQvZmlsdGVyZWQtZmllbGQtY29udGFpbmVyL2ZpbHRlcmVkLWZpZWxkLWNvbnRhaW5lci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFVLE1BQU0sZUFBZSxDQUFDOzs7OztBQUloRDs7Ozs7Ozs7Ozs7Ozs7RUFjRTtBQU1KLE1BQU0sT0FBTywrQkFBK0I7SUFRaEM7SUFOVjs7T0FFRztJQUNILEtBQUssR0FBdUIsRUFBRSxDQUFDO0lBRS9CLFlBQ1UsT0FBNkI7UUFBN0IsWUFBTyxHQUFQLE9BQU8sQ0FBc0I7SUFDakMsQ0FBQztJQUVQOzs7O09BSUc7SUFDSCxZQUFZLENBQUMsSUFBc0I7UUFDakMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVDOzs7O0tBSUM7SUFDSCxTQUFTLENBQUMsSUFBc0I7UUFDOUIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDakMsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUNuRSxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxPQUFPLENBQUMsZ0JBQWdCLEVBQUUsQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDL0MsSUFBSSxDQUFDLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQTtZQUVsRCxJQUFHLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxJQUFJLENBQUMsUUFBUSxJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUM7Z0JBQ2hELElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO2dCQUNyQixJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7Z0JBQ3hCLE9BQU87YUFDUjtZQUVELElBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsYUFBYSxJQUFJLElBQUksQ0FBQyxRQUFRLElBQUksRUFBRSxDQUFDLEVBQUU7Z0JBQzFFLE9BQU87YUFDUjtZQUVELElBQUcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxFQUFDO2dCQUNULElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO2dCQUNyQixPQUFPO2FBQ1I7WUFFRCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUV4QixDQUFDLENBQUMsQ0FBQTtJQUNKLENBQUM7d0dBcERVLCtCQUErQjs0RkFBL0IsK0JBQStCLHVFQ3hCNUMsOE5BR0E7OzRGRHFCYSwrQkFBK0I7a0JBTDNDLFNBQVM7K0JBQ0UsaUNBQWlDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgRmlsdGVyZWRGaWVsZFNlcnZpY2UgfSBmcm9tICcuLi9maWx0ZXJlZC1maWVsZC5zZXJ2aWNlJztcclxuaW1wb3J0IHsgRmlsdHJlZEl0ZW1Nb2RlbCB9IGZyb20gJy4uL2ZpbHRyZWQtaXRlbS5tb2RlbCc7XHJcblxyXG4gIC8qKlxyXG4gICogQSBjb250YWluZXIgY29tcG9uZW50IGZvciBmaWx0ZXJlZCBmaWVsZHMuXHJcbiAgKlxyXG4gICogRXhhbXBsZSBvZiB1c2FnZTpcclxuICAqIGBgYFxyXG4gICogPG1lZmRldi1maWx0ZXJlZC1maWVsZC1jb250YWluZXI+XHJcbiAgKiBcclxuICAqIDxtZWZkZXYtZmlsdGVyZWQtZmllbGQtaXRlbSBbaXRlbV09XCJmaWx0ZXJJdGVtXCIgKGRpc2NhcmQpPVwib25EaXNjYXJkRmlsdGVyKCRldmVudClcIiAob3BlbkZpbHRlcik9XCJvbk9wZW5GaWx0ZXIoKVwiPlxyXG4gICogPC9tZWZkZXYtZmlsdGVyZWQtZmllbGQtaXRlbT5cclxuICAqXHJcbiAgKiA8L21lZmRldi1maWx0ZXJlZC1maWVsZC1jb250YWluZXI+XHJcbiAgKiBgYGBcclxuICAqIEV4YW1wbGUgb2YgdXNhZ2U6XHJcbiAgKiA8ZXhhbXBsZS11cmw+aHR0cHM6Ly9wbGF0Zm9ybS5tZWYuZGV2L3VpX2tpdF9kZW1vL3ZpZXcvdXRpbHMvZmlsdGVyZWRfZmllbGQ8L2V4YW1wbGUtdXJsPlxyXG4gICovXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbWVmZGV2LWZpbHRlcmVkLWZpZWxkLWNvbnRhaW5lcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2ZpbHRlcmVkLWZpZWxkLWNvbnRhaW5lci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vZmlsdGVyZWQtZmllbGQtY29udGFpbmVyLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIEZpbHRlcmVkRmllbGRDb250YWluZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG5cclxuICAvKipcclxuICAgKiBBbiBhcnJheSBvZiBmaWx0ZXJlZCBpdGVtIG1vZGVscy5cclxuICAgKi9cclxuICBpdGVtczogRmlsdHJlZEl0ZW1Nb2RlbFtdID0gW107XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHJpdmF0ZSBzZXJ2aWNlOiBGaWx0ZXJlZEZpZWxkU2VydmljZVxyXG4gICAgKSB7IH1cclxuXHJcbiAgLyoqXHJcbiAgICogRXZlbnQgaGFuZGxlciBmb3Igb3BlbmluZyB0aGUgZmlsdGVyLlxyXG4gICAqXHJcbiAgICogQHBhcmFtIGl0ZW0gVGhlIGZpbHRlcmVkIGl0ZW0gbW9kZWwuXHJcbiAgICovXHJcbiAgb25PcGVuRmlsdGVyKGl0ZW06IEZpbHRyZWRJdGVtTW9kZWwpe1xyXG4gICAgdGhpcy5zZXJ2aWNlLnNlbmRPcGVuRmlsdGVyKGl0ZW0pO1xyXG4gIH1cclxuXHJcbiAgICAvKipcclxuICAgKiBFdmVudCBoYW5kbGVyIGZvciBkaXNjYXJkaW5nIHRoZSBmaWx0ZXIuXHJcbiAgICpcclxuICAgKiBAcGFyYW0gaXRlbSBUaGUgZmlsdGVyZWQgaXRlbSBtb2RlbC5cclxuICAgKi9cclxuICBvbkRpc2NhcmQoaXRlbTogRmlsdHJlZEl0ZW1Nb2RlbCl7XHJcbiAgICBpdGVtLmRpc2NhcmQoaXRlbS5zdGFuZGFydFZhbHVlKTtcclxuICAgIHRoaXMuaXRlbXMuc3BsaWNlKHRoaXMuaXRlbXMuZmluZEluZGV4KHggPT4geC5pZCA9PSBpdGVtLmlkKSwgMSk7XHJcbiAgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMuc2VydmljZS5nZXROZXdGaWx0ZXJJdGVtKCkuc3Vic2NyaWJlKGl0ZW0gPT4ge1xyXG4gICAgICBsZXQgaSA9IHRoaXMuaXRlbXMuZmluZEluZGV4KHggPT4geC5pZCA9PSBpdGVtLmlkKVxyXG5cclxuICAgICAgaWYoaSAhPSAtMSAmJiBpdGVtLm5ld1ZhbHVlID09IGl0ZW0uc3RhbmRhcnRWYWx1ZSl7XHJcbiAgICAgICAgdGhpcy5pdGVtc1tpXSA9IGl0ZW07XHJcbiAgICAgICAgdGhpcy5pdGVtcy5zcGxpY2UoaSwgMSk7XHJcbiAgICAgICAgcmV0dXJuO1xyXG4gICAgICB9XHJcblxyXG4gICAgICBpZihpID09IC0xICYmIChpdGVtLm5ld1ZhbHVlID09IGl0ZW0uc3RhbmRhcnRWYWx1ZSB8fCBpdGVtLm5ld1ZhbHVlID09ICcnKSApe1xyXG4gICAgICAgIHJldHVybjtcclxuICAgICAgfVxyXG5cclxuICAgICAgaWYoaSAhPSAtMSl7XHJcbiAgICAgICAgdGhpcy5pdGVtc1tpXSA9IGl0ZW07XHJcbiAgICAgICAgcmV0dXJuO1xyXG4gICAgICB9XHJcblxyXG4gICAgICB0aGlzLml0ZW1zLnB1c2goaXRlbSk7XHJcblxyXG4gICAgfSlcclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cIml0ZW0tY29udGFpbmVyXCI+XHJcbiAgICA8bWVmZGV2LWZpbHRlcmVkLWZpZWxkLWl0ZW0gKm5nRm9yPVwibGV0IGl0ZW0gb2YgaXRlbXNcIiBbaXRlbV09XCJpdGVtXCIgKGRpc2NhcmQpPVwib25EaXNjYXJkKGl0ZW0pXCIgKG9wZW5GaWx0ZXIpPVwib25PcGVuRmlsdGVyKGl0ZW0pXCI+PC9tZWZkZXYtZmlsdGVyZWQtZmllbGQtaXRlbT5cclxuPC9kaXY+XHJcbiJdfQ==
@@ -12,7 +12,7 @@ import * as i1 from "@angular/common";
12
12
  * <ng-content></ng-content>
13
13
  * </mefdev-help-block>
14
14
  *```
15
- * <example-url>https://mef.dev/ui_kit_demo/view/utils/help_block</example-url>
15
+ * <example-url>https://platform.mef.dev/ui_kit_demo/view/utils/help_block</example-url>
16
16
  */
17
17
  export class HelpBlockComponent {
18
18
  /**
@@ -69,4 +69,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
69
69
  type: Input,
70
70
  args: ['title']
71
71
  }] } });
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC1ibG9jay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1raXQtbGliL3NyYy9saWIvbWFya3VwLWtpdC91dGlscy9oZWxwLWJsb2NrL2hlbHAtYmxvY2suY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0LWxpYi9zcmMvbGliL21hcmt1cC1raXQvdXRpbHMvaGVscC1ibG9jay9oZWxwLWJsb2NrLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWdCLEtBQUssRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFDcEYsT0FBTyxFQUNMLE9BQU8sRUFDUCxLQUFLLEVBQ0wsS0FBSyxFQUNMLE9BQU8sRUFDUCxVQUFVLEdBQ1gsTUFBTSxxQkFBcUIsQ0FBQzs7O0FBRzNCOzs7Ozs7Ozs7OztFQVdDO0FBbUJILE1BQU0sT0FBTyxrQkFBa0I7SUFFN0I7O09BRUc7SUFDSCxTQUFTLEdBQVcsSUFBSSxDQUFDO0lBRXpCOztNQUVFO0lBQ0YsUUFBUSxHQUFXLEtBQUssQ0FBQztJQUd6Qjs7Ozs7OztRQU9JO0lBQ1ksS0FBSyxHQUFVLE1BQU0sQ0FBQztJQUV0QyxnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO0lBQ1IsQ0FBQzt3R0ExQlUsa0JBQWtCOzRGQUFsQixrQkFBa0IscUZDeEMvQiwwNUJBa0JNLDQ1Q0RRTztZQUNULE9BQU8sQ0FBQyxhQUFhLEVBQUM7Z0JBQ3BCLEtBQUssQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDO29CQUNuQixNQUFNLEVBQUUsR0FBRztvQkFDWCxNQUFNLEVBQUUsR0FBRztvQkFDWCxPQUFPLEVBQUUsR0FBRztvQkFDWixPQUFPLEVBQUUsR0FBRztvQkFDWixVQUFVLEVBQUUsUUFBUTtpQkFDckIsQ0FBQyxDQUFDO2dCQUNILEtBQUssQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO2dCQUN4QixVQUFVLENBQUMsY0FBYyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUN6QyxDQUFDO1NBQ0g7OzRGQUVVLGtCQUFrQjtrQkFsQjlCLFNBQVM7K0JBQ0UsbUJBQW1CLGNBR2xCO3dCQUNULE9BQU8sQ0FBQyxhQUFhLEVBQUM7NEJBQ3BCLEtBQUssQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDO2dDQUNuQixNQUFNLEVBQUUsR0FBRztnQ0FDWCxNQUFNLEVBQUUsR0FBRztnQ0FDWCxPQUFPLEVBQUUsR0FBRztnQ0FDWixPQUFPLEVBQUUsR0FBRztnQ0FDWixVQUFVLEVBQUUsUUFBUTs2QkFDckIsQ0FBQyxDQUFDOzRCQUNILEtBQUssQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDOzRCQUN4QixVQUFVLENBQUMsY0FBYyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQzt5QkFDekMsQ0FBQztxQkFDSDswRUF1QmUsS0FBSztzQkFBcEIsS0FBSzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDb250ZW50Q2hpbGQsIElucHV0LCBPbkluaXQsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7XHJcbiAgdHJpZ2dlcixcclxuICBzdGF0ZSxcclxuICBzdHlsZSxcclxuICBhbmltYXRlLFxyXG4gIHRyYW5zaXRpb24sXHJcbn0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XHJcblxyXG5cclxuICAvKipcclxuICAqIEEgY29tcG9uZW50IHJlcHJlc2VudGluZyBhIGhlbHAgYmxvY2sgd2l0aCBzbW9vdGggZXhwYW5kIGFuaW1hdGlvbi5cclxuICAqXHJcbiAgKiAgRXhhbXBsZSBvZiB1c2FnZTpcclxuICAqYGBgXHJcbiAgKiA8bWVmZGV2LWhlbHAtYmxvY2sgW3RpdGxlXT1cIidIZWxwJ1wiPlxyXG4gICogIENvbnRlbnQgZ29lcyBoZXJlLi4uXHJcbiAgKiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbiAgKiA8L21lZmRldi1oZWxwLWJsb2NrPlxyXG4gICpgYGBcclxuICAqIDxleGFtcGxlLXVybD5odHRwczovL21lZi5kZXYvdWlfa2l0X2RlbW8vdmlldy91dGlscy9oZWxwX2Jsb2NrPC9leGFtcGxlLXVybD5cclxuICovXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbWVmZGV2LWhlbHAtYmxvY2snLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9oZWxwLWJsb2NrLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9oZWxwLWJsb2NrLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgYW5pbWF0aW9uczpbXHJcbiAgICB0cmlnZ2VyKCdzbW90aEV4cGFuZCcsW1xyXG4gICAgICBzdGF0ZSgnY2xvc2UnLCBzdHlsZSh7XHJcbiAgICAgICAgaGVpZ2h0OiAnMCcsXHJcbiAgICAgICAgbWFyZ2luOiAnMCcsXHJcbiAgICAgICAgcGFkZGluZzogJzAnLFxyXG4gICAgICAgIG9wYWNpdHk6ICcwJyxcclxuICAgICAgICB2aXNpYmlsaXR5OiAnaGlkZGVuJyxcclxuICAgICAgfSkpLFxyXG4gICAgICBzdGF0ZSgnb3BlbicsIHN0eWxlKHt9KSksXHJcbiAgICAgIHRyYW5zaXRpb24oJ2Nsb3NlPD0+b3BlbicsIGFuaW1hdGUoMjAwKSlcclxuICAgIF0pXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgSGVscEJsb2NrQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuXHJcbiAgLyoqXHJcbiAgICogSW5kaWNhdGVzIHdoZXRoZXIgdGhlIGhlbHAgYmxvY2sgaXMgdmlzaWJsZS5cclxuICAgKi9cclxuICBpc1Zpc2libGU6Ym9vbGVhbiA9IHRydWU7XHJcblxyXG4gIC8qKlxyXG4gICAgKiBJbmRpY2F0ZXMgd2hldGhlciB0aGUgaGVscCBibG9jayBpcyBleHBhbmRlZC5cclxuICAqL1xyXG4gIGV4cGFuZGVkOmJvb2xlYW4gPSBmYWxzZTtcclxuXHJcblxyXG4gIC8qKlxyXG4gICAgKiBUaGUgdGl0bGUgb2YgdGhlIGhlbHAgYmxvY2suXHJcbiAgICAqYGBgXHJcbiAgICAqIDxtZWZkZXYtaGVscC1ibG9jayBbdGl0bGVdPVwiJ0hlbHAgQmxvY2snXCI+XHJcbiAgICAqICAgIENvbnRlbnQgZ29lcyBoZXJlLi4uXHJcbiAgICAqIDwvbWVmZGV2LWhlbHAtYmxvY2s+XHJcbiAgICAqYGBgXHJcbiAgICAqL1xyXG4gIEBJbnB1dCgndGl0bGUnKSB0aXRsZTpzdHJpbmcgPSBcIkhlbHBcIjtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwiY2FyZC1zaW1wbGVcIiAqbmdJZj1cImlzVmlzaWJsZVwiPlxyXG4gICAgPGRpdiBjbGFzcz1cInJvdyBtLTEgYm9keS0xXCIgKGNsaWNrKT1cImV4cGFuZGVkID0gIWV4cGFuZGVkXCIgc3R5bGU9XCJjdXJzb3I6IHBvaW50ZXI7XCI+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImNvbC0xMFwiIHN0eWxlPVwiY29sb3I6IHdoaXRlO1wiPlxyXG4gICAgICAgICAgICB7eyB0aXRsZSB9fVxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtMlwiPlxyXG4gICAgICAgICAgICA8aSBjbGFzcz1cImZhIGZhLXdpbmRvdy1jbG9zZVwiIGFyaWEtaGlkZGVuPVwidHJ1ZVwiIHN0eWxlPVwiZmxvYXQ6IHJpZ2h0OyBtYXJnaW4tbGVmdDogMjBweDtcIiAoY2xpY2spPVwiaXNWaXNpYmxlID0gIWlzVmlzaWJsZTtcIj48L2k+XHJcbiAgICAgICAgICAgIFxyXG4gICAgICAgICAgICA8aSBjbGFzcz1cImZhIGZhLWFuZ2xlLWRvd24gXCIgKm5nSWY9XCIhZXhwYW5kZWRcIiBhcmlhLWhpZGRlbj1cInRydWVcIiBzdHlsZT1cImZsb2F0OiByaWdodDtcIj48L2k+XHJcbiAgICAgICAgICAgIDxpIGNsYXNzPVwiZmEgZmEtYW5nbGUtdXBcIiAqbmdJZj1cImV4cGFuZGVkXCIgYXJpYS1oaWRkZW49XCJ0cnVlXCIgc3R5bGU9XCJmbG9hdDogcmlnaHQ7XCI+PC9pPiAgICAgIFxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcblxyXG4gICAgPGRpdiBjbGFzcz1cImNhcmQtYm9keSByb3dcIiBbQHNtb3RoRXhwYW5kXT1cImV4cGFuZGVkID8gJ29wZW4nIDogJ2Nsb3NlJ1wiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtMTJcIj5cclxuICAgICAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PiJdfQ==
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVscC1ibG9jay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy91aS1raXQtbGliL3NyYy9saWIvbWFya3VwLWtpdC91dGlscy9oZWxwLWJsb2NrL2hlbHAtYmxvY2suY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkta2l0LWxpYi9zcmMvbGliL21hcmt1cC1raXQvdXRpbHMvaGVscC1ibG9jay9oZWxwLWJsb2NrLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWdCLEtBQUssRUFBdUIsTUFBTSxlQUFlLENBQUM7QUFDcEYsT0FBTyxFQUNMLE9BQU8sRUFDUCxLQUFLLEVBQ0wsS0FBSyxFQUNMLE9BQU8sRUFDUCxVQUFVLEdBQ1gsTUFBTSxxQkFBcUIsQ0FBQzs7O0FBRzNCOzs7Ozs7Ozs7OztFQVdDO0FBbUJILE1BQU0sT0FBTyxrQkFBa0I7SUFFN0I7O09BRUc7SUFDSCxTQUFTLEdBQVcsSUFBSSxDQUFDO0lBRXpCOztNQUVFO0lBQ0YsUUFBUSxHQUFXLEtBQUssQ0FBQztJQUd6Qjs7Ozs7OztRQU9JO0lBQ1ksS0FBSyxHQUFVLE1BQU0sQ0FBQztJQUV0QyxnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO0lBQ1IsQ0FBQzt3R0ExQlUsa0JBQWtCOzRGQUFsQixrQkFBa0IscUZDeEMvQiwwNUJBa0JNLDQ1Q0RRTztZQUNULE9BQU8sQ0FBQyxhQUFhLEVBQUM7Z0JBQ3BCLEtBQUssQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDO29CQUNuQixNQUFNLEVBQUUsR0FBRztvQkFDWCxNQUFNLEVBQUUsR0FBRztvQkFDWCxPQUFPLEVBQUUsR0FBRztvQkFDWixPQUFPLEVBQUUsR0FBRztvQkFDWixVQUFVLEVBQUUsUUFBUTtpQkFDckIsQ0FBQyxDQUFDO2dCQUNILEtBQUssQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDO2dCQUN4QixVQUFVLENBQUMsY0FBYyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQzthQUN6QyxDQUFDO1NBQ0g7OzRGQUVVLGtCQUFrQjtrQkFsQjlCLFNBQVM7K0JBQ0UsbUJBQW1CLGNBR2xCO3dCQUNULE9BQU8sQ0FBQyxhQUFhLEVBQUM7NEJBQ3BCLEtBQUssQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDO2dDQUNuQixNQUFNLEVBQUUsR0FBRztnQ0FDWCxNQUFNLEVBQUUsR0FBRztnQ0FDWCxPQUFPLEVBQUUsR0FBRztnQ0FDWixPQUFPLEVBQUUsR0FBRztnQ0FDWixVQUFVLEVBQUUsUUFBUTs2QkFDckIsQ0FBQyxDQUFDOzRCQUNILEtBQUssQ0FBQyxNQUFNLEVBQUUsS0FBSyxDQUFDLEVBQUUsQ0FBQyxDQUFDOzRCQUN4QixVQUFVLENBQUMsY0FBYyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQzt5QkFDekMsQ0FBQztxQkFDSDswRUF1QmUsS0FBSztzQkFBcEIsS0FBSzt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBDb250ZW50Q2hpbGQsIElucHV0LCBPbkluaXQsIFRlbXBsYXRlUmVmIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7XHJcbiAgdHJpZ2dlcixcclxuICBzdGF0ZSxcclxuICBzdHlsZSxcclxuICBhbmltYXRlLFxyXG4gIHRyYW5zaXRpb24sXHJcbn0gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XHJcblxyXG5cclxuICAvKipcclxuICAqIEEgY29tcG9uZW50IHJlcHJlc2VudGluZyBhIGhlbHAgYmxvY2sgd2l0aCBzbW9vdGggZXhwYW5kIGFuaW1hdGlvbi5cclxuICAqXHJcbiAgKiAgRXhhbXBsZSBvZiB1c2FnZTpcclxuICAqYGBgXHJcbiAgKiA8bWVmZGV2LWhlbHAtYmxvY2sgW3RpdGxlXT1cIidIZWxwJ1wiPlxyXG4gICogIENvbnRlbnQgZ29lcyBoZXJlLi4uXHJcbiAgKiAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XHJcbiAgKiA8L21lZmRldi1oZWxwLWJsb2NrPlxyXG4gICpgYGBcclxuICAqIDxleGFtcGxlLXVybD5odHRwczovL3BsYXRmb3JtLm1lZi5kZXYvdWlfa2l0X2RlbW8vdmlldy91dGlscy9oZWxwX2Jsb2NrPC9leGFtcGxlLXVybD5cclxuICovXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnbWVmZGV2LWhlbHAtYmxvY2snLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9oZWxwLWJsb2NrLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9oZWxwLWJsb2NrLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgYW5pbWF0aW9uczpbXHJcbiAgICB0cmlnZ2VyKCdzbW90aEV4cGFuZCcsW1xyXG4gICAgICBzdGF0ZSgnY2xvc2UnLCBzdHlsZSh7XHJcbiAgICAgICAgaGVpZ2h0OiAnMCcsXHJcbiAgICAgICAgbWFyZ2luOiAnMCcsXHJcbiAgICAgICAgcGFkZGluZzogJzAnLFxyXG4gICAgICAgIG9wYWNpdHk6ICcwJyxcclxuICAgICAgICB2aXNpYmlsaXR5OiAnaGlkZGVuJyxcclxuICAgICAgfSkpLFxyXG4gICAgICBzdGF0ZSgnb3BlbicsIHN0eWxlKHt9KSksXHJcbiAgICAgIHRyYW5zaXRpb24oJ2Nsb3NlPD0+b3BlbicsIGFuaW1hdGUoMjAwKSlcclxuICAgIF0pXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgSGVscEJsb2NrQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcclxuXHJcbiAgLyoqXHJcbiAgICogSW5kaWNhdGVzIHdoZXRoZXIgdGhlIGhlbHAgYmxvY2sgaXMgdmlzaWJsZS5cclxuICAgKi9cclxuICBpc1Zpc2libGU6Ym9vbGVhbiA9IHRydWU7XHJcblxyXG4gIC8qKlxyXG4gICAgKiBJbmRpY2F0ZXMgd2hldGhlciB0aGUgaGVscCBibG9jayBpcyBleHBhbmRlZC5cclxuICAqL1xyXG4gIGV4cGFuZGVkOmJvb2xlYW4gPSBmYWxzZTtcclxuXHJcblxyXG4gIC8qKlxyXG4gICAgKiBUaGUgdGl0bGUgb2YgdGhlIGhlbHAgYmxvY2suXHJcbiAgICAqYGBgXHJcbiAgICAqIDxtZWZkZXYtaGVscC1ibG9jayBbdGl0bGVdPVwiJ0hlbHAgQmxvY2snXCI+XHJcbiAgICAqICAgIENvbnRlbnQgZ29lcyBoZXJlLi4uXHJcbiAgICAqIDwvbWVmZGV2LWhlbHAtYmxvY2s+XHJcbiAgICAqYGBgXHJcbiAgICAqL1xyXG4gIEBJbnB1dCgndGl0bGUnKSB0aXRsZTpzdHJpbmcgPSBcIkhlbHBcIjtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7IH1cclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgfVxyXG5cclxufVxyXG4iLCI8ZGl2IGNsYXNzPVwiY2FyZC1zaW1wbGVcIiAqbmdJZj1cImlzVmlzaWJsZVwiPlxyXG4gICAgPGRpdiBjbGFzcz1cInJvdyBtLTEgYm9keS0xXCIgKGNsaWNrKT1cImV4cGFuZGVkID0gIWV4cGFuZGVkXCIgc3R5bGU9XCJjdXJzb3I6IHBvaW50ZXI7XCI+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImNvbC0xMFwiIHN0eWxlPVwiY29sb3I6IHdoaXRlO1wiPlxyXG4gICAgICAgICAgICB7eyB0aXRsZSB9fVxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtMlwiPlxyXG4gICAgICAgICAgICA8aSBjbGFzcz1cImZhIGZhLXdpbmRvdy1jbG9zZVwiIGFyaWEtaGlkZGVuPVwidHJ1ZVwiIHN0eWxlPVwiZmxvYXQ6IHJpZ2h0OyBtYXJnaW4tbGVmdDogMjBweDtcIiAoY2xpY2spPVwiaXNWaXNpYmxlID0gIWlzVmlzaWJsZTtcIj48L2k+XHJcbiAgICAgICAgICAgIFxyXG4gICAgICAgICAgICA8aSBjbGFzcz1cImZhIGZhLWFuZ2xlLWRvd24gXCIgKm5nSWY9XCIhZXhwYW5kZWRcIiBhcmlhLWhpZGRlbj1cInRydWVcIiBzdHlsZT1cImZsb2F0OiByaWdodDtcIj48L2k+XHJcbiAgICAgICAgICAgIDxpIGNsYXNzPVwiZmEgZmEtYW5nbGUtdXBcIiAqbmdJZj1cImV4cGFuZGVkXCIgYXJpYS1oaWRkZW49XCJ0cnVlXCIgc3R5bGU9XCJmbG9hdDogcmlnaHQ7XCI+PC9pPiAgICAgIFxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcblxyXG4gICAgPGRpdiBjbGFzcz1cImNhcmQtYm9keSByb3dcIiBbQHNtb3RoRXhwYW5kXT1cImV4cGFuZGVkID8gJ29wZW4nIDogJ2Nsb3NlJ1wiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtMTJcIj5cclxuICAgICAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PiJdfQ==