@ng-nest/ui 15.0.8 → 15.0.9

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 (69) hide show
  1. package/base-form/base-form.property.d.ts +2 -2
  2. package/core/config/config.d.ts +4 -0
  3. package/date-picker/date-picker.component.d.ts +5 -1
  4. package/date-picker/date-picker.module.d.ts +6 -5
  5. package/date-picker/date-picker.property.d.ts +139 -9
  6. package/date-picker/date-range-portal.component.d.ts +20 -13
  7. package/date-picker/date-range.component.d.ts +14 -4
  8. package/date-picker/picker-month.component.d.ts +15 -4
  9. package/date-picker/picker-year.component.d.ts +15 -5
  10. package/esm2020/base-form/base-form.property.mjs +1 -1
  11. package/esm2020/core/config/config.mjs +1 -1
  12. package/esm2020/date-picker/date-picker-portal.component.mjs +8 -7
  13. package/esm2020/date-picker/date-picker.component.mjs +32 -10
  14. package/esm2020/date-picker/date-picker.module.mjs +5 -1
  15. package/esm2020/date-picker/date-picker.property.mjs +178 -15
  16. package/esm2020/date-picker/date-range-portal.component.mjs +123 -52
  17. package/esm2020/date-picker/date-range.component.mjs +99 -34
  18. package/esm2020/date-picker/picker-date.component.mjs +4 -4
  19. package/esm2020/date-picker/picker-month.component.mjs +151 -11
  20. package/esm2020/date-picker/picker-year.component.mjs +151 -13
  21. package/esm2020/i18n/i18n.property.mjs +1 -1
  22. package/esm2020/i18n/languages/en_GB.mjs +11 -2
  23. package/esm2020/i18n/languages/en_US.mjs +11 -2
  24. package/esm2020/i18n/languages/zh_CN.mjs +11 -2
  25. package/esm2020/i18n/languages/zh_TW.mjs +11 -2
  26. package/esm2020/link/link.component.mjs +19 -5
  27. package/esm2020/link/link.property.mjs +10 -4
  28. package/esm2020/slider/slider.component.mjs +3 -3
  29. package/esm2020/time-picker/time-picker-frame.component.mjs +28 -11
  30. package/esm2020/time-picker/time-picker-portal.component.mjs +2 -2
  31. package/fesm2015/ng-nest-ui-base-form.mjs +0 -1
  32. package/fesm2015/ng-nest-ui-base-form.mjs.map +1 -1
  33. package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
  34. package/fesm2015/ng-nest-ui-date-picker.mjs +726 -124
  35. package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
  36. package/fesm2015/ng-nest-ui-i18n.mjs +40 -5
  37. package/fesm2015/ng-nest-ui-i18n.mjs.map +1 -1
  38. package/fesm2015/ng-nest-ui-link.mjs +28 -9
  39. package/fesm2015/ng-nest-ui-link.mjs.map +1 -1
  40. package/fesm2015/ng-nest-ui-slider.mjs +2 -3
  41. package/fesm2015/ng-nest-ui-slider.mjs.map +1 -1
  42. package/fesm2015/ng-nest-ui-switch.mjs +1 -0
  43. package/fesm2015/ng-nest-ui-table.mjs +1 -0
  44. package/fesm2015/ng-nest-ui-time-picker.mjs +28 -12
  45. package/fesm2015/ng-nest-ui-time-picker.mjs.map +1 -1
  46. package/fesm2020/ng-nest-ui-base-form.mjs +0 -1
  47. package/fesm2020/ng-nest-ui-base-form.mjs.map +1 -1
  48. package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
  49. package/fesm2020/ng-nest-ui-date-picker.mjs +722 -124
  50. package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
  51. package/fesm2020/ng-nest-ui-i18n.mjs +40 -5
  52. package/fesm2020/ng-nest-ui-i18n.mjs.map +1 -1
  53. package/fesm2020/ng-nest-ui-link.mjs +27 -9
  54. package/fesm2020/ng-nest-ui-link.mjs.map +1 -1
  55. package/fesm2020/ng-nest-ui-slider.mjs +2 -3
  56. package/fesm2020/ng-nest-ui-slider.mjs.map +1 -1
  57. package/fesm2020/ng-nest-ui-switch.mjs +1 -0
  58. package/fesm2020/ng-nest-ui-table.mjs +1 -0
  59. package/fesm2020/ng-nest-ui-time-picker.mjs +28 -12
  60. package/fesm2020/ng-nest-ui-time-picker.mjs.map +1 -1
  61. package/i18n/i18n.property.d.ts +9 -0
  62. package/i18n/languages/en_GB.d.ts +9 -0
  63. package/i18n/languages/en_US.d.ts +9 -0
  64. package/i18n/languages/zh_CN.d.ts +9 -0
  65. package/i18n/languages/zh_TW.d.ts +9 -0
  66. package/link/link.component.d.ts +5 -2
  67. package/link/link.property.d.ts +6 -1
  68. package/package.json +1 -1
  69. package/time-picker/time-picker-frame.component.d.ts +8 -6
@@ -65,7 +65,16 @@ export default {
65
65
  sunday: '日',
66
66
  yesterday: '昨天',
67
67
  today: '今天',
68
- tomorrow: '明天'
68
+ tomorrow: '明天',
69
+ selectDate: '請選擇日期',
70
+ selectMonth: '請選擇月份',
71
+ selectYear: '請選擇年份',
72
+ startDate: '開始日期',
73
+ endDate: '結束日期',
74
+ startMonth: '開始月份',
75
+ endMonth: '結束月份',
76
+ startYear: '開始年份',
77
+ endYear: '結束年份'
69
78
  },
70
79
  timePicker: {
71
80
  am: '上午',
@@ -140,4 +149,4 @@ export default {
140
149
  required: '必填'
141
150
  }
142
151
  };
143
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiemhfVFcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWIvbmctbmVzdC91aS9pMThuL2xhbmd1YWdlcy96aF9UVy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxlQUFlO0lBQ2IsTUFBTSxFQUFFLE9BQU87SUFDZixPQUFPLEVBQUU7UUFDUCxRQUFRLEVBQUUsSUFBSTtRQUNkLFNBQVMsRUFBRSxJQUFJO1FBQ2YsS0FBSyxFQUFFLElBQUk7UUFDWCxJQUFJLEVBQUUsTUFBTTtRQUNaLElBQUksRUFBRSxJQUFJO1FBQ1YsV0FBVyxFQUFFLE9BQU87S0FDckI7SUFDRCxLQUFLLEVBQUU7UUFDTCxRQUFRLEVBQUUsTUFBTTtRQUNoQixXQUFXLEVBQUUsUUFBUTtRQUNyQixPQUFPLEVBQUUsSUFBSTtRQUNiLE9BQU8sRUFBRSxJQUFJO1FBQ2IsT0FBTyxFQUFFLElBQUk7UUFDYixNQUFNLEVBQUUsSUFBSTtRQUNaLElBQUksRUFBRSxJQUFJO1FBQ1YsVUFBVSxFQUFFLElBQUk7UUFDaEIsTUFBTSxFQUFFLElBQUk7UUFDWixJQUFJLEVBQUUsSUFBSTtLQUNYO0lBQ0QsUUFBUSxFQUFFO1FBQ1IsS0FBSyxFQUFFLEdBQUc7UUFDVixJQUFJLEVBQUUsR0FBRztRQUNULFNBQVMsRUFBRSxJQUFJO1FBQ2YsUUFBUSxFQUFFLElBQUk7UUFDZCxTQUFTLEVBQUUsSUFBSTtRQUNmLFFBQVEsRUFBRSxJQUFJO1FBQ2QsT0FBTyxFQUFFLElBQUk7UUFDYixRQUFRLEVBQUUsSUFBSTtRQUNkLEtBQUssRUFBRSxJQUFJO1FBQ1gsS0FBSyxFQUFFLElBQUk7UUFDWCxHQUFHLEVBQUUsSUFBSTtRQUNULElBQUksRUFBRSxJQUFJO1FBQ1YsSUFBSSxFQUFFLElBQUk7UUFDVixNQUFNLEVBQUUsSUFBSTtRQUNaLFNBQVMsRUFBRSxJQUFJO1FBQ2YsT0FBTyxFQUFFLEtBQUs7UUFDZCxRQUFRLEVBQUUsS0FBSztRQUNmLFFBQVEsRUFBRSxLQUFLO0tBQ2hCO0lBQ0QsVUFBVSxFQUFFO1FBQ1YsSUFBSSxFQUFFLElBQUk7UUFDVixLQUFLLEVBQUUsR0FBRztRQUNWLElBQUksRUFBRSxHQUFHO1FBQ1QsT0FBTyxFQUFFLElBQUk7UUFDYixRQUFRLEVBQUUsSUFBSTtRQUNkLEtBQUssRUFBRSxJQUFJO1FBQ1gsS0FBSyxFQUFFLElBQUk7UUFDWCxHQUFHLEVBQUUsSUFBSTtRQUNULElBQUksRUFBRSxJQUFJO1FBQ1YsSUFBSSxFQUFFLElBQUk7UUFDVixNQUFNLEVBQUUsSUFBSTtRQUNaLFNBQVMsRUFBRSxJQUFJO1FBQ2YsT0FBTyxFQUFFLEtBQUs7UUFDZCxRQUFRLEVBQUUsS0FBSztRQUNmLFFBQVEsRUFBRSxLQUFLO1FBQ2YsTUFBTSxFQUFFLEdBQUc7UUFDWCxPQUFPLEVBQUUsR0FBRztRQUNaLFNBQVMsRUFBRSxHQUFHO1FBQ2QsUUFBUSxFQUFFLEdBQUc7UUFDYixNQUFNLEVBQUUsR0FBRztRQUNYLFFBQVEsRUFBRSxHQUFHO1FBQ2IsTUFBTSxFQUFFLEdBQUc7UUFDWCxTQUFTLEVBQUUsSUFBSTtRQUNmLEtBQUssRUFBRSxJQUFJO1FBQ1gsUUFBUSxFQUFFLElBQUk7S0FDZjtJQUNELFVBQVUsRUFBRTtRQUNWLEVBQUUsRUFBRSxJQUFJO1FBQ1IsRUFBRSxFQUFFLElBQUk7UUFDUixHQUFHLEVBQUUsSUFBSTtLQUNWO0lBQ0QsS0FBSyxFQUFFO1FBQ0wsTUFBTSxFQUFFLE1BQU07S0FDZjtJQUNELEtBQUssRUFBRTtRQUNMLFdBQVcsRUFBRSxJQUFJO0tBQ2xCO0lBQ0QsVUFBVSxFQUFFO1FBQ1YsUUFBUSxFQUFFLEtBQUs7UUFDZixJQUFJLEVBQUUsS0FBSztRQUNYLEtBQUssRUFBRSxHQUFHO1FBQ1YsSUFBSSxFQUFFLEdBQUc7UUFDVCxLQUFLLEVBQUUsSUFBSTtRQUNYLElBQUksRUFBRSxJQUFJO1FBQ1YsSUFBSSxFQUFFLElBQUk7UUFDVixRQUFRLEVBQUUsS0FBSztLQUNoQjtJQUNELFdBQVcsRUFBRTtRQUNYLE1BQU0sRUFBRSxJQUFJO1FBQ1osTUFBTSxFQUFFLElBQUk7S0FDYjtJQUNELE9BQU8sRUFBRTtRQUNQLElBQUksRUFBRSxJQUFJO1FBQ1YsVUFBVSxFQUFFLElBQUk7UUFDaEIsVUFBVSxFQUFFLEtBQUs7UUFDakIsUUFBUSxFQUFFLEtBQUs7S0FDaEI7SUFDRCxRQUFRLEVBQUU7UUFDUixTQUFTLEVBQUUsSUFBSTtRQUNmLFNBQVMsRUFBRSxHQUFHO1FBQ2QsVUFBVSxFQUFFLElBQUk7UUFDaEIsYUFBYSxFQUFFLEtBQUs7UUFDcEIsT0FBTyxFQUFFLElBQUk7S0FDZDtJQUNELFVBQVUsRUFBRTtRQUNWLFVBQVUsRUFBRSxJQUFJO1FBQ2hCLFdBQVcsRUFBRSxJQUFJO0tBQ2xCO0lBQ0QsTUFBTSxFQUFFO1FBQ04sVUFBVSxFQUFFLElBQUk7UUFDaEIsV0FBVyxFQUFFLElBQUk7S0FDbEI7SUFDRCxVQUFVLEVBQUU7UUFDVixVQUFVLEVBQUUsSUFBSTtRQUNoQixXQUFXLEVBQUUsSUFBSTtLQUNsQjtJQUNELE1BQU0sRUFBRTtRQUNOLFVBQVUsRUFBRSxNQUFNO0tBQ25CO0lBQ0QsVUFBVSxFQUFFO1FBQ1YsSUFBSSxFQUFFLElBQUk7S0FDWDtJQUNELElBQUksRUFBRTtRQUNKLGFBQWEsRUFBRSxJQUFJO1FBQ25CLFlBQVksRUFBRSxNQUFNO1FBQ3BCLGVBQWUsRUFBRSxPQUFPO0tBQ3pCO0lBQ0QsTUFBTSxFQUFFO1FBQ04sYUFBYSxFQUFFLElBQUk7UUFDbkIsYUFBYSxFQUFFLGtCQUFrQjtLQUNsQztJQUNELFVBQVUsRUFBRTtRQUNWLGFBQWEsRUFBRSxJQUFJO1FBQ25CLGFBQWEsRUFBRSxrQkFBa0I7S0FDbEM7SUFDRCxJQUFJLEVBQUU7UUFDSixRQUFRLEVBQUUsSUFBSTtLQUNmO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IHtcclxuICBsb2NhbGU6ICd6aF9UVycsXHJcbiAgY29tbWVudDoge1xyXG4gICAgY29tbWVudHM6ICfoqZXoq5YnLFxyXG4gICAgZ2l2ZUFMaWtlOiAn6bue6LSKJyxcclxuICAgIHJlcGx5OiAn5Zue5aSNJyxcclxuICAgIG1vcmU6ICfmn6XnnIvmm7TlpJonLFxyXG4gICAgc3VyZTogJ+eZvOW4gycsXHJcbiAgICBwbGFjZWhvbGRlcjogJ+iri+i8uOWFpeipleirlidcclxuICB9LFxyXG4gIHRoZW1lOiB7XHJcbiAgICBkYXJrTW9kZTogJ+aal+m7keaooeW8jycsXHJcbiAgICBpbml0RGVmYXVsdDogJ+WIneWni+WMlum7mOiqjeWAvCcsXHJcbiAgICBwcmltYXJ5OiAn5Li76ImyJyxcclxuICAgIHN1Y2Nlc3M6ICfmiJDlip8nLFxyXG4gICAgd2FybmluZzogJ+itpuWRiicsXHJcbiAgICBkYW5nZXI6ICfljbHpmqonLFxyXG4gICAgaW5mbzogJ+S/oeaBrycsXHJcbiAgICBiYWNrZ3JvdW5kOiAn6IOM5pmvJyxcclxuICAgIGJvcmRlcjogJ+mCiuahhicsXHJcbiAgICB0ZXh0OiAn5paH5a2XJ1xyXG4gIH0sXHJcbiAgY2FsZW5kYXI6IHtcclxuICAgIG1vbnRoOiAn5pyIJyxcclxuICAgIHllYXI6ICflubQnLFxyXG4gICAgbGFzdE1vbnRoOiAn5LiK5pyIJyxcclxuICAgIGxhc3RZZWFyOiAn5Y675bm0JyxcclxuICAgIG5leHRNb250aDogJ+S4i+aciCcsXHJcbiAgICBuZXh0WWVhcjogJ+aYjuW5tCcsXHJcbiAgICBqYW51YXJ5OiAnMeaciCcsXHJcbiAgICBmZWJydWFyeTogJzLmnIgnLFxyXG4gICAgbWFyY2g6ICcz5pyIJyxcclxuICAgIGFwcmlsOiAnNOaciCcsXHJcbiAgICBtYXk6ICc15pyIJyxcclxuICAgIGp1bmU6ICc25pyIJyxcclxuICAgIGp1bHk6ICc35pyIJyxcclxuICAgIGF1Z3VzdDogJzjmnIgnLFxyXG4gICAgc2VwdGVtYmVyOiAnOeaciCcsXHJcbiAgICBvY3RvYmVyOiAnMTDmnIgnLFxyXG4gICAgbm92ZW1iZXI6ICcxMeaciCcsXHJcbiAgICBkZWNlbWJlcjogJzEy5pyIJ1xyXG4gIH0sXHJcbiAgZGF0ZVBpY2tlcjoge1xyXG4gICAgc3VyZTogJ+eiuuiqjScsXHJcbiAgICBtb250aDogJ+aciCcsXHJcbiAgICB5ZWFyOiAn5bm0JyxcclxuICAgIGphbnVhcnk6ICcx5pyIJyxcclxuICAgIGZlYnJ1YXJ5OiAnMuaciCcsXHJcbiAgICBtYXJjaDogJzPmnIgnLFxyXG4gICAgYXByaWw6ICc05pyIJyxcclxuICAgIG1heTogJzXmnIgnLFxyXG4gICAganVuZTogJzbmnIgnLFxyXG4gICAganVseTogJzfmnIgnLFxyXG4gICAgYXVndXN0OiAnOOaciCcsXHJcbiAgICBzZXB0ZW1iZXI6ICc55pyIJyxcclxuICAgIG9jdG9iZXI6ICcxMOaciCcsXHJcbiAgICBub3ZlbWJlcjogJzEx5pyIJyxcclxuICAgIGRlY2VtYmVyOiAnMTLmnIgnLFxyXG4gICAgbW9uZGF5OiAn5LiAJyxcclxuICAgIHR1ZXNkYXk6ICfkuownLFxyXG4gICAgd2VkbmVzZGF5OiAn5LiJJyxcclxuICAgIHRodXJzZGF5OiAn5ZubJyxcclxuICAgIGZyaWRheTogJ+S6lCcsXHJcbiAgICBzYXR1cmRheTogJ+WFrScsXHJcbiAgICBzdW5kYXk6ICfml6UnLFxyXG4gICAgeWVzdGVyZGF5OiAn5pio5aSpJyxcclxuICAgIHRvZGF5OiAn5LuK5aSpJyxcclxuICAgIHRvbW9ycm93OiAn5piO5aSpJ1xyXG4gIH0sXHJcbiAgdGltZVBpY2tlcjoge1xyXG4gICAgYW06ICfkuIrljYgnLFxyXG4gICAgcG06ICfkuIvljYgnLFxyXG4gICAgbm93OiAn5q2k5Yi7J1xyXG4gIH0sXHJcbiAgZW1wdHk6IHtcclxuICAgIG5vRGF0YTogJ+aaq+eEoeaVuOaTmidcclxuICB9LFxyXG4gIGltYWdlOiB7XHJcbiAgICBwcmV2aWV3VGV4dDogJ+mihOiniCdcclxuICB9LFxyXG4gIHBhZ2luYXRpb246IHtcclxuICAgIHByZXZpb3VzOiAn5LiK5LiA6aCBJyxcclxuICAgIG5leHQ6ICfkuIvkuIDpoIEnLFxyXG4gICAgdG90YWw6ICflhbEnLFxyXG4gICAgaXRlbTogJ+ainScsXHJcbiAgICBmaXJzdDogJ+mmlumggScsXHJcbiAgICBsYXN0OiAn5bC+6aCBJyxcclxuICAgIGp1bXA6ICfot7Poh7MnLFxyXG4gICAgc2l6ZVBhZ2U6ICfmop0v6aCBJ1xyXG4gIH0sXHJcbiAgdGV4dFJldHJhY3Q6IHtcclxuICAgIHVuZm9sZDogJ+WxlemWiycsXHJcbiAgICBwYWNrVXA6ICfmlLbotbcnXHJcbiAgfSxcclxuICB0aW1lQWdvOiB7XHJcbiAgICBqdXN0OiAn5Ymb5YmbJyxcclxuICAgIHNlY29uZHNBZ286ICfnp5LliY0nLFxyXG4gICAgbWludXRlc0FnbzogJ+WIhumQmOWJjScsXHJcbiAgICBob3Vyc0FnbzogJ+Wwj+aZguWJjSdcclxuICB9LFxyXG4gIHRyYW5zZmVyOiB7XHJcbiAgICBsaXN0VGl0bGU6ICfmuIXllq4nLFxyXG4gICAgdHJlZVRpdGxlOiAn5qCRJyxcclxuICAgIHRhYmxlVGl0bGU6ICfooajmoLwnLFxyXG4gICAgc2VsZWN0ZWRUaXRsZTogJ+mBuOS4remghScsXHJcbiAgICBpbnZlcnNlOiAn5Y+N6YG4J1xyXG4gIH0sXHJcbiAgbWVzc2FnZUJveDoge1xyXG4gICAgY2FuY2VsVGV4dDogJ+WPlua2iCcsXHJcbiAgICBjb25maXJtVGV4dDogJ+eiuuiqjSdcclxuICB9LFxyXG4gIGRpYWxvZzoge1xyXG4gICAgY2FuY2VsVGV4dDogJ+WPlua2iCcsXHJcbiAgICBjb25maXJtVGV4dDogJ+eiuuiqjSdcclxuICB9LFxyXG4gIHBvcGNvbmZpcm06IHtcclxuICAgIGNhbmNlbFRleHQ6ICflj5bmtognLFxyXG4gICAgY29uZmlybVRleHQ6ICfnorroqo0nXHJcbiAgfSxcclxuICB1cGxvYWQ6IHtcclxuICAgIHVwbG9hZFRleHQ6ICfkuIrlgrPmlofku7YnXHJcbiAgfSxcclxuICBwYWdlSGVhZGVyOiB7XHJcbiAgICBiYWNrOiAn6L+U5ZueJ1xyXG4gIH0sXHJcbiAgbGlzdDoge1xyXG4gICAgc2VsZWN0QWxsVGV4dDogJ+WFqOmBuCcsXHJcbiAgICBsb2FkTW9yZVRleHQ6ICfliqDovInmm7TlpJonLFxyXG4gICAgbG9hZGluZ01vcmVUZXh0OiAn5q2j5Zyo5Yqg6LyJ5LitJ1xyXG4gIH0sXHJcbiAgc2VsZWN0OiB7XHJcbiAgICBzZWxlY3RBbGxUZXh0OiAn5YWo6YG4JyxcclxuICAgIG1heFRhZ0NvbnRlbnQ6ICfmm7TlpJp7e3N1cnBsdXN9feWAi+mBuOS4rSdcclxuICB9LFxyXG4gIHRyZWVTZWxlY3Q6IHtcclxuICAgIHNlbGVjdEFsbFRleHQ6ICflhajpgbgnLFxyXG4gICAgbWF4VGFnQ29udGVudDogJ+abtOWkmnt7c3VycGx1c3195YCL6YG45LitJ1xyXG4gIH0sXHJcbiAgZm9ybToge1xyXG4gICAgcmVxdWlyZWQ6ICflv4XloasnXHJcbiAgfVxyXG59O1xyXG4iXX0=
152
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"zh_TW.js","sourceRoot":"","sources":["../../../../../../lib/ng-nest/ui/i18n/languages/zh_TW.ts"],"names":[],"mappings":"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","sourcesContent":["export default {\r\n  locale: 'zh_TW',\r\n  comment: {\r\n    comments: '評論',\r\n    giveALike: '點贊',\r\n    reply: '回复',\r\n    more: '查看更多',\r\n    sure: '發布',\r\n    placeholder: '請輸入評論'\r\n  },\r\n  theme: {\r\n    darkMode: '暗黑模式',\r\n    initDefault: '初始化默認值',\r\n    primary: '主色',\r\n    success: '成功',\r\n    warning: '警告',\r\n    danger: '危險',\r\n    info: '信息',\r\n    background: '背景',\r\n    border: '邊框',\r\n    text: '文字'\r\n  },\r\n  calendar: {\r\n    month: '月',\r\n    year: '年',\r\n    lastMonth: '上月',\r\n    lastYear: '去年',\r\n    nextMonth: '下月',\r\n    nextYear: '明年',\r\n    january: '1月',\r\n    february: '2月',\r\n    march: '3月',\r\n    april: '4月',\r\n    may: '5月',\r\n    june: '6月',\r\n    july: '7月',\r\n    august: '8月',\r\n    september: '9月',\r\n    october: '10月',\r\n    november: '11月',\r\n    december: '12月'\r\n  },\r\n  datePicker: {\r\n    sure: '確認',\r\n    month: '月',\r\n    year: '年',\r\n    january: '1月',\r\n    february: '2月',\r\n    march: '3月',\r\n    april: '4月',\r\n    may: '5月',\r\n    june: '6月',\r\n    july: '7月',\r\n    august: '8月',\r\n    september: '9月',\r\n    october: '10月',\r\n    november: '11月',\r\n    december: '12月',\r\n    monday: '一',\r\n    tuesday: '二',\r\n    wednesday: '三',\r\n    thursday: '四',\r\n    friday: '五',\r\n    saturday: '六',\r\n    sunday: '日',\r\n    yesterday: '昨天',\r\n    today: '今天',\r\n    tomorrow: '明天',\r\n    selectDate: '請選擇日期',\r\n    selectMonth: '請選擇月份',\r\n    selectYear: '請選擇年份',\r\n    startDate: '開始日期',\r\n    endDate: '結束日期',\r\n    startMonth: '開始月份',\r\n    endMonth: '結束月份',\r\n    startYear: '開始年份',\r\n    endYear: '結束年份'\r\n  },\r\n  timePicker: {\r\n    am: '上午',\r\n    pm: '下午',\r\n    now: '此刻'\r\n  },\r\n  empty: {\r\n    noData: '暫無數據'\r\n  },\r\n  image: {\r\n    previewText: '预览'\r\n  },\r\n  pagination: {\r\n    previous: '上一頁',\r\n    next: '下一頁',\r\n    total: '共',\r\n    item: '條',\r\n    first: '首頁',\r\n    last: '尾頁',\r\n    jump: '跳至',\r\n    sizePage: '條/頁'\r\n  },\r\n  textRetract: {\r\n    unfold: '展開',\r\n    packUp: '收起'\r\n  },\r\n  timeAgo: {\r\n    just: '剛剛',\r\n    secondsAgo: '秒前',\r\n    minutesAgo: '分鐘前',\r\n    hoursAgo: '小時前'\r\n  },\r\n  transfer: {\r\n    listTitle: '清單',\r\n    treeTitle: '树',\r\n    tableTitle: '表格',\r\n    selectedTitle: '選中項',\r\n    inverse: '反選'\r\n  },\r\n  messageBox: {\r\n    cancelText: '取消',\r\n    confirmText: '確認'\r\n  },\r\n  dialog: {\r\n    cancelText: '取消',\r\n    confirmText: '確認'\r\n  },\r\n  popconfirm: {\r\n    cancelText: '取消',\r\n    confirmText: '確認'\r\n  },\r\n  upload: {\r\n    uploadText: '上傳文件'\r\n  },\r\n  pageHeader: {\r\n    back: '返回'\r\n  },\r\n  list: {\r\n    selectAllText: '全選',\r\n    loadMoreText: '加載更多',\r\n    loadingMoreText: '正在加載中'\r\n  },\r\n  select: {\r\n    selectAllText: '全選',\r\n    maxTagContent: '更多{{surplus}}個選中'\r\n  },\r\n  treeSelect: {\r\n    selectAllText: '全選',\r\n    maxTagContent: '更多{{surplus}}個選中'\r\n  },\r\n  form: {\r\n    required: '必填'\r\n  }\r\n};\r\n"]}
@@ -1,5 +1,6 @@
1
- import { Component, ViewEncapsulation, ChangeDetectionStrategy, HostListener } from '@angular/core';
1
+ import { Component, ViewEncapsulation, ChangeDetectionStrategy, HostListener, ViewChild } from '@angular/core';
2
2
  import { XLinkPrefix, XLinkProperty } from './link.property';
3
+ import { XIsEmpty } from '@ng-nest/ui/core';
3
4
  import * as i0 from "@angular/core";
4
5
  import * as i1 from "@ng-nest/ui/core";
5
6
  import * as i2 from "@angular/common";
@@ -24,20 +25,33 @@ export class XLinkComponent extends XLinkProperty {
24
25
  ngOnInit() {
25
26
  this.setClassMap();
26
27
  }
28
+ ngAfterViewInit() {
29
+ if (XIsEmpty(this.href)) {
30
+ this.renderer.removeAttribute(this.link?.nativeElement, 'href');
31
+ }
32
+ }
33
+ onClick(event) {
34
+ if (this.preventDefault) {
35
+ event.preventDefault();
36
+ }
37
+ }
27
38
  setClassMap() {
28
39
  this.classMap[`${XLinkPrefix}-${this.type}`] = this.type ? true : false;
29
40
  }
30
41
  }
31
42
  /** @nocollapse */ XLinkComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XLinkComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.XConfigService }], target: i0.ɵɵFactoryTarget.Component });
32
- /** @nocollapse */ XLinkComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XLinkComponent, selector: "x-link", host: { listeners: { "mouseenter": "mouseenter()", "mouseleave": "mouseleave()" } }, usesInheritance: true, ngImport: i0, template: "<a\r\n class=\"x-link\"\r\n [ngClass]=\"classMap\"\r\n [class.x-link-disabled]=\"disabled\"\r\n [class.x-link-underline]=\"underline && !disabled\"\r\n [class.x-link-icon-right]=\"iconRight\"\r\n [class.x-link-only-icon]=\"icon && !content.innerHTML.trim()\"\r\n [attr.href]=\"href\"\r\n [attr.target]=\"target\"\r\n>\r\n <x-icon *ngIf=\"icon\" [type]=\"icon\"></x-icon>\r\n <span #content><ng-content></ng-content></span>\r\n</a>\r\n", styles: ["x-link{display:inline-flex}.x-link{margin:0;display:inline-flex;flex-direction:row;align-items:center;justify-content:center;vertical-align:middle;position:relative;text-decoration:none;outline:none;cursor:pointer;padding:0;transition:all var(--x-animation-duration-base) ease-in-out}.x-link>x-icon{margin-right:.125rem}.x-link-underline:hover:after{content:\"\";position:absolute;left:0;right:0;height:0;bottom:0;border-bottom:.0625rem solid var(--x-primary)}.x-link-icon-right{flex-direction:row-reverse}.x-link-icon-right>x-icon{margin-right:0;margin-left:.125rem}.x-link-only-icon>x-icon{margin-right:0;margin-left:0}.x-link{color:inherit}.x-link:hover{color:var(--x-primary)}.x-link:hover:after{border-color:var(--x-primary)}.x-link:active{color:var(--x-primary-a100)}.x-link.x-link-disabled{color:var(--x-text-400);cursor:not-allowed}.x-link.x-link-disabled:active{transform:none}.x-link.x-link-disabled:hover:after{border-color:transparent}.x-link-primary{color:var(--x-primary)}.x-link-primary:hover{color:var(--x-primary-100)}.x-link-primary:hover:after{border-color:var(--x-primary-100)}.x-link-primary:active{color:var(--x-primary-300)}.x-link-primary.x-link-disabled{color:var(--x-primary-400);cursor:not-allowed}.x-link-primary.x-link-disabled:active{transform:none}.x-link-primary.x-link-disabled:hover:after{border-color:transparent}.x-link-success{color:var(--x-success)}.x-link-success:hover{color:var(--x-success-100)}.x-link-success:hover:after{border-color:var(--x-success-100)}.x-link-success:active{color:var(--x-success-300)}.x-link-success.x-link-disabled{color:var(--x-success-400);cursor:not-allowed}.x-link-success.x-link-disabled:active{transform:none}.x-link-success.x-link-disabled:hover:after{border-color:transparent}.x-link-warning{color:var(--x-warning)}.x-link-warning:hover{color:var(--x-warning-100)}.x-link-warning:hover:after{border-color:var(--x-warning-100)}.x-link-warning:active{color:var(--x-warning-300)}.x-link-warning.x-link-disabled{color:var(--x-warning-400);cursor:not-allowed}.x-link-warning.x-link-disabled:active{transform:none}.x-link-warning.x-link-disabled:hover:after{border-color:transparent}.x-link-danger{color:var(--x-danger)}.x-link-danger:hover{color:var(--x-danger-100)}.x-link-danger:hover:after{border-color:var(--x-danger-100)}.x-link-danger:active{color:var(--x-danger-300)}.x-link-danger.x-link-disabled{color:var(--x-danger-400);cursor:not-allowed}.x-link-danger.x-link-disabled:active{transform:none}.x-link-danger.x-link-disabled:hover:after{border-color:transparent}.x-link-info{color:var(--x-info)}.x-link-info:hover{color:var(--x-info-100)}.x-link-info:hover:after{border-color:var(--x-info-100)}.x-link-info:active{color:var(--x-info-300)}.x-link-info.x-link-disabled{color:var(--x-info-400);cursor:not-allowed}.x-link-info.x-link-disabled:active{transform:none}.x-link-info.x-link-disabled:hover:after{border-color:transparent}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.XIconComponent, selector: "x-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
43
+ /** @nocollapse */ XLinkComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XLinkComponent, selector: "x-link", host: { listeners: { "mouseenter": "mouseenter()", "mouseleave": "mouseleave()" } }, viewQueries: [{ propertyName: "link", first: true, predicate: ["link"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<a\r\n #link\r\n class=\"x-link\"\r\n [ngClass]=\"classMap\"\r\n [class.x-link-disabled]=\"disabled\"\r\n [class.x-link-underline]=\"underline && !disabled\"\r\n [class.x-link-icon-right]=\"iconRight\"\r\n [class.x-link-only-icon]=\"icon && !content.innerHTML.trim()\"\r\n [attr.href]=\"href\"\r\n [attr.target]=\"target\"\r\n>\r\n <x-icon *ngIf=\"icon\" [type]=\"icon\"></x-icon>\r\n <span #content><ng-content></ng-content></span>\r\n</a>\r\n", styles: ["x-link{display:inline-flex}.x-link{margin:0;display:inline-flex;flex-direction:row;align-items:center;justify-content:center;vertical-align:middle;position:relative;text-decoration:none;outline:none;cursor:pointer;padding:0;transition:all var(--x-animation-duration-base) ease-in-out}.x-link>x-icon{margin-right:.125rem}.x-link-underline:hover:after{content:\"\";position:absolute;left:0;right:0;height:0;bottom:0;border-bottom:.0625rem solid var(--x-primary)}.x-link-icon-right{flex-direction:row-reverse}.x-link-icon-right>x-icon{margin-right:0;margin-left:.125rem}.x-link-only-icon>x-icon{margin-right:0;margin-left:0}.x-link{color:inherit}.x-link:hover{color:var(--x-primary)}.x-link:hover:after{border-color:var(--x-primary)}.x-link:active{color:var(--x-primary-a100)}.x-link.x-link-disabled{color:var(--x-text-400);cursor:not-allowed}.x-link.x-link-disabled:active{transform:none}.x-link.x-link-disabled:hover:after{border-color:transparent}.x-link-primary{color:var(--x-primary)}.x-link-primary:hover{color:var(--x-primary-100)}.x-link-primary:hover:after{border-color:var(--x-primary-100)}.x-link-primary:active{color:var(--x-primary-300)}.x-link-primary.x-link-disabled{color:var(--x-primary-400);cursor:not-allowed}.x-link-primary.x-link-disabled:active{transform:none}.x-link-primary.x-link-disabled:hover:after{border-color:transparent}.x-link-success{color:var(--x-success)}.x-link-success:hover{color:var(--x-success-100)}.x-link-success:hover:after{border-color:var(--x-success-100)}.x-link-success:active{color:var(--x-success-300)}.x-link-success.x-link-disabled{color:var(--x-success-400);cursor:not-allowed}.x-link-success.x-link-disabled:active{transform:none}.x-link-success.x-link-disabled:hover:after{border-color:transparent}.x-link-warning{color:var(--x-warning)}.x-link-warning:hover{color:var(--x-warning-100)}.x-link-warning:hover:after{border-color:var(--x-warning-100)}.x-link-warning:active{color:var(--x-warning-300)}.x-link-warning.x-link-disabled{color:var(--x-warning-400);cursor:not-allowed}.x-link-warning.x-link-disabled:active{transform:none}.x-link-warning.x-link-disabled:hover:after{border-color:transparent}.x-link-danger{color:var(--x-danger)}.x-link-danger:hover{color:var(--x-danger-100)}.x-link-danger:hover:after{border-color:var(--x-danger-100)}.x-link-danger:active{color:var(--x-danger-300)}.x-link-danger.x-link-disabled{color:var(--x-danger-400);cursor:not-allowed}.x-link-danger.x-link-disabled:active{transform:none}.x-link-danger.x-link-disabled:hover:after{border-color:transparent}.x-link-info{color:var(--x-info)}.x-link-info:hover{color:var(--x-info-100)}.x-link-info:hover:after{border-color:var(--x-info-100)}.x-link-info:active{color:var(--x-info-300)}.x-link-info.x-link-disabled{color:var(--x-info-400);cursor:not-allowed}.x-link-info.x-link-disabled:active{transform:none}.x-link-info.x-link-disabled:hover:after{border-color:transparent}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.XIconComponent, selector: "x-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
33
44
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XLinkComponent, decorators: [{
34
45
  type: Component,
35
- args: [{ selector: `${XLinkPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<a\r\n class=\"x-link\"\r\n [ngClass]=\"classMap\"\r\n [class.x-link-disabled]=\"disabled\"\r\n [class.x-link-underline]=\"underline && !disabled\"\r\n [class.x-link-icon-right]=\"iconRight\"\r\n [class.x-link-only-icon]=\"icon && !content.innerHTML.trim()\"\r\n [attr.href]=\"href\"\r\n [attr.target]=\"target\"\r\n>\r\n <x-icon *ngIf=\"icon\" [type]=\"icon\"></x-icon>\r\n <span #content><ng-content></ng-content></span>\r\n</a>\r\n", styles: ["x-link{display:inline-flex}.x-link{margin:0;display:inline-flex;flex-direction:row;align-items:center;justify-content:center;vertical-align:middle;position:relative;text-decoration:none;outline:none;cursor:pointer;padding:0;transition:all var(--x-animation-duration-base) ease-in-out}.x-link>x-icon{margin-right:.125rem}.x-link-underline:hover:after{content:\"\";position:absolute;left:0;right:0;height:0;bottom:0;border-bottom:.0625rem solid var(--x-primary)}.x-link-icon-right{flex-direction:row-reverse}.x-link-icon-right>x-icon{margin-right:0;margin-left:.125rem}.x-link-only-icon>x-icon{margin-right:0;margin-left:0}.x-link{color:inherit}.x-link:hover{color:var(--x-primary)}.x-link:hover:after{border-color:var(--x-primary)}.x-link:active{color:var(--x-primary-a100)}.x-link.x-link-disabled{color:var(--x-text-400);cursor:not-allowed}.x-link.x-link-disabled:active{transform:none}.x-link.x-link-disabled:hover:after{border-color:transparent}.x-link-primary{color:var(--x-primary)}.x-link-primary:hover{color:var(--x-primary-100)}.x-link-primary:hover:after{border-color:var(--x-primary-100)}.x-link-primary:active{color:var(--x-primary-300)}.x-link-primary.x-link-disabled{color:var(--x-primary-400);cursor:not-allowed}.x-link-primary.x-link-disabled:active{transform:none}.x-link-primary.x-link-disabled:hover:after{border-color:transparent}.x-link-success{color:var(--x-success)}.x-link-success:hover{color:var(--x-success-100)}.x-link-success:hover:after{border-color:var(--x-success-100)}.x-link-success:active{color:var(--x-success-300)}.x-link-success.x-link-disabled{color:var(--x-success-400);cursor:not-allowed}.x-link-success.x-link-disabled:active{transform:none}.x-link-success.x-link-disabled:hover:after{border-color:transparent}.x-link-warning{color:var(--x-warning)}.x-link-warning:hover{color:var(--x-warning-100)}.x-link-warning:hover:after{border-color:var(--x-warning-100)}.x-link-warning:active{color:var(--x-warning-300)}.x-link-warning.x-link-disabled{color:var(--x-warning-400);cursor:not-allowed}.x-link-warning.x-link-disabled:active{transform:none}.x-link-warning.x-link-disabled:hover:after{border-color:transparent}.x-link-danger{color:var(--x-danger)}.x-link-danger:hover{color:var(--x-danger-100)}.x-link-danger:hover:after{border-color:var(--x-danger-100)}.x-link-danger:active{color:var(--x-danger-300)}.x-link-danger.x-link-disabled{color:var(--x-danger-400);cursor:not-allowed}.x-link-danger.x-link-disabled:active{transform:none}.x-link-danger.x-link-disabled:hover:after{border-color:transparent}.x-link-info{color:var(--x-info)}.x-link-info:hover{color:var(--x-info-100)}.x-link-info:hover:after{border-color:var(--x-info-100)}.x-link-info:active{color:var(--x-info-300)}.x-link-info.x-link-disabled{color:var(--x-info-400);cursor:not-allowed}.x-link-info.x-link-disabled:active{transform:none}.x-link-info.x-link-disabled:hover:after{border-color:transparent}\n"] }]
36
- }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.XConfigService }]; }, propDecorators: { mouseenter: [{
46
+ args: [{ selector: `${XLinkPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<a\r\n #link\r\n class=\"x-link\"\r\n [ngClass]=\"classMap\"\r\n [class.x-link-disabled]=\"disabled\"\r\n [class.x-link-underline]=\"underline && !disabled\"\r\n [class.x-link-icon-right]=\"iconRight\"\r\n [class.x-link-only-icon]=\"icon && !content.innerHTML.trim()\"\r\n [attr.href]=\"href\"\r\n [attr.target]=\"target\"\r\n>\r\n <x-icon *ngIf=\"icon\" [type]=\"icon\"></x-icon>\r\n <span #content><ng-content></ng-content></span>\r\n</a>\r\n", styles: ["x-link{display:inline-flex}.x-link{margin:0;display:inline-flex;flex-direction:row;align-items:center;justify-content:center;vertical-align:middle;position:relative;text-decoration:none;outline:none;cursor:pointer;padding:0;transition:all var(--x-animation-duration-base) ease-in-out}.x-link>x-icon{margin-right:.125rem}.x-link-underline:hover:after{content:\"\";position:absolute;left:0;right:0;height:0;bottom:0;border-bottom:.0625rem solid var(--x-primary)}.x-link-icon-right{flex-direction:row-reverse}.x-link-icon-right>x-icon{margin-right:0;margin-left:.125rem}.x-link-only-icon>x-icon{margin-right:0;margin-left:0}.x-link{color:inherit}.x-link:hover{color:var(--x-primary)}.x-link:hover:after{border-color:var(--x-primary)}.x-link:active{color:var(--x-primary-a100)}.x-link.x-link-disabled{color:var(--x-text-400);cursor:not-allowed}.x-link.x-link-disabled:active{transform:none}.x-link.x-link-disabled:hover:after{border-color:transparent}.x-link-primary{color:var(--x-primary)}.x-link-primary:hover{color:var(--x-primary-100)}.x-link-primary:hover:after{border-color:var(--x-primary-100)}.x-link-primary:active{color:var(--x-primary-300)}.x-link-primary.x-link-disabled{color:var(--x-primary-400);cursor:not-allowed}.x-link-primary.x-link-disabled:active{transform:none}.x-link-primary.x-link-disabled:hover:after{border-color:transparent}.x-link-success{color:var(--x-success)}.x-link-success:hover{color:var(--x-success-100)}.x-link-success:hover:after{border-color:var(--x-success-100)}.x-link-success:active{color:var(--x-success-300)}.x-link-success.x-link-disabled{color:var(--x-success-400);cursor:not-allowed}.x-link-success.x-link-disabled:active{transform:none}.x-link-success.x-link-disabled:hover:after{border-color:transparent}.x-link-warning{color:var(--x-warning)}.x-link-warning:hover{color:var(--x-warning-100)}.x-link-warning:hover:after{border-color:var(--x-warning-100)}.x-link-warning:active{color:var(--x-warning-300)}.x-link-warning.x-link-disabled{color:var(--x-warning-400);cursor:not-allowed}.x-link-warning.x-link-disabled:active{transform:none}.x-link-warning.x-link-disabled:hover:after{border-color:transparent}.x-link-danger{color:var(--x-danger)}.x-link-danger:hover{color:var(--x-danger-100)}.x-link-danger:hover:after{border-color:var(--x-danger-100)}.x-link-danger:active{color:var(--x-danger-300)}.x-link-danger.x-link-disabled{color:var(--x-danger-400);cursor:not-allowed}.x-link-danger.x-link-disabled:active{transform:none}.x-link-danger.x-link-disabled:hover:after{border-color:transparent}.x-link-info{color:var(--x-info)}.x-link-info:hover{color:var(--x-info-100)}.x-link-info:hover:after{border-color:var(--x-info-100)}.x-link-info:active{color:var(--x-info-300)}.x-link-info.x-link-disabled{color:var(--x-info-400);cursor:not-allowed}.x-link-info.x-link-disabled:active{transform:none}.x-link-info.x-link-disabled:hover:after{border-color:transparent}\n"] }]
47
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.XConfigService }]; }, propDecorators: { link: [{
48
+ type: ViewChild,
49
+ args: ['link', { static: true }]
50
+ }], mouseenter: [{
37
51
  type: HostListener,
38
52
  args: ['mouseenter']
39
53
  }], mouseleave: [{
40
54
  type: HostListener,
41
55
  args: ['mouseleave']
42
56
  }] } });
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWIvbmctbmVzdC91aS9saW5rL2xpbmsuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvbGluay9saW5rLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBRVQsaUJBQWlCLEVBSWpCLHVCQUF1QixFQUN2QixZQUFZLEVBQ2IsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFdBQVcsRUFBRSxhQUFhLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7Ozs7QUFVN0QsTUFBTSxPQUFPLGNBQWUsU0FBUSxhQUFhO0lBYS9DLFlBQ1MsUUFBbUIsRUFDbkIsVUFBbUMsRUFDbkMsR0FBc0IsRUFDdEIsYUFBNkI7UUFFcEMsS0FBSyxFQUFFLENBQUM7UUFMRCxhQUFRLEdBQVIsUUFBUSxDQUFXO1FBQ25CLGVBQVUsR0FBVixVQUFVLENBQXlCO1FBQ25DLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBQ3RCLGtCQUFhLEdBQWIsYUFBYSxDQUFnQjtRQWhCdEMsVUFBSyxHQUFZLEtBQUssQ0FBQztJQW1CdkIsQ0FBQztJQWpCMkIsVUFBVTtRQUNwQyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztRQUNsQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFMkIsVUFBVTtRQUNwQyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFXRCxRQUFRO1FBQ04sSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxXQUFXO1FBQ1QsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLFdBQVcsSUFBSSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQztJQUMxRSxDQUFDOzs4SEE1QlUsY0FBYztrSEFBZCxjQUFjLDBKQ3BCM0IsOGJBYUE7MkZET2EsY0FBYztrQkFQMUIsU0FBUzsrQkFDRSxHQUFHLFdBQVcsRUFBRSxpQkFHWCxpQkFBaUIsQ0FBQyxJQUFJLG1CQUNwQix1QkFBdUIsQ0FBQyxNQUFNO3NMQUtuQixVQUFVO3NCQUFyQyxZQUFZO3VCQUFDLFlBQVk7Z0JBS0UsVUFBVTtzQkFBckMsWUFBWTt1QkFBQyxZQUFZIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDb21wb25lbnQsXHJcbiAgT25Jbml0LFxyXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxyXG4gIFJlbmRlcmVyMixcclxuICBFbGVtZW50UmVmLFxyXG4gIENoYW5nZURldGVjdG9yUmVmLFxyXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gIEhvc3RMaXN0ZW5lclxyXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBYTGlua1ByZWZpeCwgWExpbmtQcm9wZXJ0eSB9IGZyb20gJy4vbGluay5wcm9wZXJ0eSc7XHJcbmltcG9ydCB7IFhDb25maWdTZXJ2aWNlIH0gZnJvbSAnQG5nLW5lc3QvdWkvY29yZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogYCR7WExpbmtQcmVmaXh9YCxcclxuICB0ZW1wbGF0ZVVybDogJy4vbGluay5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vbGluay5jb21wb25lbnQuc2NzcyddLFxyXG4gIGVuY2Fwc3VsYXRpb246IFZpZXdFbmNhcHN1bGF0aW9uLk5vbmUsXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIFhMaW5rQ29tcG9uZW50IGV4dGVuZHMgWExpbmtQcm9wZXJ0eSBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgaG92ZXI6IGJvb2xlYW4gPSBmYWxzZTtcclxuXHJcbiAgQEhvc3RMaXN0ZW5lcignbW91c2VlbnRlcicpIG1vdXNlZW50ZXIoKSB7XHJcbiAgICB0aGlzLmhvdmVyID0gdHJ1ZTtcclxuICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcclxuICB9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ21vdXNlbGVhdmUnKSBtb3VzZWxlYXZlKCkge1xyXG4gICAgdGhpcy5ob3ZlciA9IGZhbHNlO1xyXG4gICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgcmVuZGVyZXI6IFJlbmRlcmVyMixcclxuICAgIHB1YmxpYyBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PixcclxuICAgIHB1YmxpYyBjZHI6IENoYW5nZURldGVjdG9yUmVmLFxyXG4gICAgcHVibGljIGNvbmZpZ1NlcnZpY2U6IFhDb25maWdTZXJ2aWNlXHJcbiAgKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLnNldENsYXNzTWFwKCk7XHJcbiAgfVxyXG5cclxuICBzZXRDbGFzc01hcCgpIHtcclxuICAgIHRoaXMuY2xhc3NNYXBbYCR7WExpbmtQcmVmaXh9LSR7dGhpcy50eXBlfWBdID0gdGhpcy50eXBlID8gdHJ1ZSA6IGZhbHNlO1xyXG4gIH1cclxufVxyXG4iLCI8YVxyXG4gIGNsYXNzPVwieC1saW5rXCJcclxuICBbbmdDbGFzc109XCJjbGFzc01hcFwiXHJcbiAgW2NsYXNzLngtbGluay1kaXNhYmxlZF09XCJkaXNhYmxlZFwiXHJcbiAgW2NsYXNzLngtbGluay11bmRlcmxpbmVdPVwidW5kZXJsaW5lICYmICFkaXNhYmxlZFwiXHJcbiAgW2NsYXNzLngtbGluay1pY29uLXJpZ2h0XT1cImljb25SaWdodFwiXHJcbiAgW2NsYXNzLngtbGluay1vbmx5LWljb25dPVwiaWNvbiAmJiAhY29udGVudC5pbm5lckhUTUwudHJpbSgpXCJcclxuICBbYXR0ci5ocmVmXT1cImhyZWZcIlxyXG4gIFthdHRyLnRhcmdldF09XCJ0YXJnZXRcIlxyXG4+XHJcbiAgPHgtaWNvbiAqbmdJZj1cImljb25cIiBbdHlwZV09XCJpY29uXCI+PC94LWljb24+XHJcbiAgPHNwYW4gI2NvbnRlbnQ+PG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50Pjwvc3Bhbj5cclxuPC9hPlxyXG4iXX0=
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWIvbmctbmVzdC91aS9saW5rL2xpbmsuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vbGliL25nLW5lc3QvdWkvbGluay9saW5rLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBR1QsaUJBQWlCLEVBSWpCLHVCQUF1QixFQUN2QixZQUFZLEVBQ1osU0FBUyxFQUNWLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBRSxXQUFXLEVBQUUsYUFBYSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDN0QsT0FBTyxFQUFrQixRQUFRLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7Ozs7QUFTNUQsTUFBTSxPQUFPLGNBQWUsU0FBUSxhQUFhO0lBZS9DLFlBQ1MsUUFBbUIsRUFDbkIsVUFBbUMsRUFDbkMsR0FBc0IsRUFDdEIsYUFBNkI7UUFFcEMsS0FBSyxFQUFFLENBQUM7UUFMRCxhQUFRLEdBQVIsUUFBUSxDQUFXO1FBQ25CLGVBQVUsR0FBVixVQUFVLENBQXlCO1FBQ25DLFFBQUcsR0FBSCxHQUFHLENBQW1CO1FBQ3RCLGtCQUFhLEdBQWIsYUFBYSxDQUFnQjtRQWxCdEMsVUFBSyxHQUFZLEtBQUssQ0FBQztJQXFCdkIsQ0FBQztJQWpCMkIsVUFBVTtRQUNwQyxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztRQUNsQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFMkIsVUFBVTtRQUNwQyxJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFXRCxRQUFRO1FBQ04sSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFRCxlQUFlO1FBQ2IsSUFBSSxRQUFRLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ3ZCLElBQUksQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxJQUFJLEVBQUUsYUFBYSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1NBQ2pFO0lBQ0gsQ0FBQztJQUVELE9BQU8sQ0FBQyxLQUFZO1FBQ2xCLElBQUksSUFBSSxDQUFDLGNBQWMsRUFBRTtZQUN2QixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7U0FDeEI7SUFDSCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxRQUFRLENBQUMsR0FBRyxXQUFXLElBQUksSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDMUUsQ0FBQzs7OEhBMUNVLGNBQWM7a0hBQWQsY0FBYyxzUUN0QjNCLHljQWNBOzJGRFFhLGNBQWM7a0JBUDFCLFNBQVM7K0JBQ0UsR0FBRyxXQUFXLEVBQUUsaUJBR1gsaUJBQWlCLENBQUMsSUFBSSxtQkFDcEIsdUJBQXVCLENBQUMsTUFBTTtzTEFLVixJQUFJO3NCQUF4QyxTQUFTO3VCQUFDLE1BQU0sRUFBRSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUU7Z0JBRVAsVUFBVTtzQkFBckMsWUFBWTt1QkFBQyxZQUFZO2dCQUtFLFVBQVU7c0JBQXJDLFlBQVk7dUJBQUMsWUFBWSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XHJcbiAgQ29tcG9uZW50LFxyXG4gIE9uSW5pdCxcclxuICBBZnRlclZpZXdJbml0LFxyXG4gIFZpZXdFbmNhcHN1bGF0aW9uLFxyXG4gIFJlbmRlcmVyMixcclxuICBFbGVtZW50UmVmLFxyXG4gIENoYW5nZURldGVjdG9yUmVmLFxyXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gIEhvc3RMaXN0ZW5lcixcclxuICBWaWV3Q2hpbGRcclxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgWExpbmtQcmVmaXgsIFhMaW5rUHJvcGVydHkgfSBmcm9tICcuL2xpbmsucHJvcGVydHknO1xyXG5pbXBvcnQgeyBYQ29uZmlnU2VydmljZSwgWElzRW1wdHkgfSBmcm9tICdAbmctbmVzdC91aS9jb3JlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiBgJHtYTGlua1ByZWZpeH1gLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9saW5rLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9saW5rLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgWExpbmtDb21wb25lbnQgZXh0ZW5kcyBYTGlua1Byb3BlcnR5IGltcGxlbWVudHMgT25Jbml0LCBBZnRlclZpZXdJbml0IHtcclxuICBob3ZlcjogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICBAVmlld0NoaWxkKCdsaW5rJywgeyBzdGF0aWM6IHRydWUgfSkgbGluayE6IEVsZW1lbnRSZWY8SFRNTExpbmtFbGVtZW50PjtcclxuXHJcbiAgQEhvc3RMaXN0ZW5lcignbW91c2VlbnRlcicpIG1vdXNlZW50ZXIoKSB7XHJcbiAgICB0aGlzLmhvdmVyID0gdHJ1ZTtcclxuICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcclxuICB9XHJcblxyXG4gIEBIb3N0TGlzdGVuZXIoJ21vdXNlbGVhdmUnKSBtb3VzZWxlYXZlKCkge1xyXG4gICAgdGhpcy5ob3ZlciA9IGZhbHNlO1xyXG4gICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gIH1cclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgcmVuZGVyZXI6IFJlbmRlcmVyMixcclxuICAgIHB1YmxpYyBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PixcclxuICAgIHB1YmxpYyBjZHI6IENoYW5nZURldGVjdG9yUmVmLFxyXG4gICAgcHVibGljIGNvbmZpZ1NlcnZpY2U6IFhDb25maWdTZXJ2aWNlXHJcbiAgKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLnNldENsYXNzTWFwKCk7XHJcbiAgfVxyXG5cclxuICBuZ0FmdGVyVmlld0luaXQoKSB7XHJcbiAgICBpZiAoWElzRW1wdHkodGhpcy5ocmVmKSkge1xyXG4gICAgICB0aGlzLnJlbmRlcmVyLnJlbW92ZUF0dHJpYnV0ZSh0aGlzLmxpbms/Lm5hdGl2ZUVsZW1lbnQsICdocmVmJyk7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBvbkNsaWNrKGV2ZW50OiBFdmVudCkge1xyXG4gICAgaWYgKHRoaXMucHJldmVudERlZmF1bHQpIHtcclxuICAgICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHNldENsYXNzTWFwKCkge1xyXG4gICAgdGhpcy5jbGFzc01hcFtgJHtYTGlua1ByZWZpeH0tJHt0aGlzLnR5cGV9YF0gPSB0aGlzLnR5cGUgPyB0cnVlIDogZmFsc2U7XHJcbiAgfVxyXG59XHJcbiIsIjxhXHJcbiAgI2xpbmtcclxuICBjbGFzcz1cIngtbGlua1wiXHJcbiAgW25nQ2xhc3NdPVwiY2xhc3NNYXBcIlxyXG4gIFtjbGFzcy54LWxpbmstZGlzYWJsZWRdPVwiZGlzYWJsZWRcIlxyXG4gIFtjbGFzcy54LWxpbmstdW5kZXJsaW5lXT1cInVuZGVybGluZSAmJiAhZGlzYWJsZWRcIlxyXG4gIFtjbGFzcy54LWxpbmstaWNvbi1yaWdodF09XCJpY29uUmlnaHRcIlxyXG4gIFtjbGFzcy54LWxpbmstb25seS1pY29uXT1cImljb24gJiYgIWNvbnRlbnQuaW5uZXJIVE1MLnRyaW0oKVwiXHJcbiAgW2F0dHIuaHJlZl09XCJocmVmXCJcclxuICBbYXR0ci50YXJnZXRdPVwidGFyZ2V0XCJcclxuPlxyXG4gIDx4LWljb24gKm5nSWY9XCJpY29uXCIgW3R5cGVdPVwiaWNvblwiPjwveC1pY29uPlxyXG4gIDxzcGFuICNjb250ZW50PjxuZy1jb250ZW50PjwvbmctY29udGVudD48L3NwYW4+XHJcbjwvYT5cclxuIl19
@@ -15,18 +15,22 @@ const X_CONFIG_NAME = 'link';
15
15
  export class XLinkProperty extends XProperty {
16
16
  }
17
17
  /** @nocollapse */ XLinkProperty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XLinkProperty, deps: null, target: i0.ɵɵFactoryTarget.Component });
18
- /** @nocollapse */ XLinkProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XLinkProperty, selector: "ng-component", inputs: { href: "href", icon: "icon", underline: "underline", disabled: "disabled", iconRight: "iconRight", type: "type", target: "target" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
18
+ /** @nocollapse */ XLinkProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XLinkProperty, selector: "ng-component", inputs: { href: "href", icon: "icon", underline: "underline", disabled: "disabled", iconRight: "iconRight", preventDefault: "preventDefault", type: "type", target: "target" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
19
19
  __decorate([
20
- XWithConfig(X_CONFIG_NAME),
20
+ XWithConfig(X_CONFIG_NAME, false),
21
21
  XInputBoolean()
22
22
  ], XLinkProperty.prototype, "underline", void 0);
23
23
  __decorate([
24
24
  XInputBoolean()
25
25
  ], XLinkProperty.prototype, "disabled", void 0);
26
26
  __decorate([
27
- XWithConfig(X_CONFIG_NAME),
27
+ XWithConfig(X_CONFIG_NAME, false),
28
28
  XInputBoolean()
29
29
  ], XLinkProperty.prototype, "iconRight", void 0);
30
+ __decorate([
31
+ XWithConfig(X_CONFIG_NAME, false),
32
+ XInputBoolean()
33
+ ], XLinkProperty.prototype, "preventDefault", void 0);
30
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XLinkProperty, decorators: [{
31
35
  type: Component,
32
36
  args: [{ template: '' }]
@@ -40,9 +44,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
40
44
  type: Input
41
45
  }], iconRight: [{
42
46
  type: Input
47
+ }], preventDefault: [{
48
+ type: Input
43
49
  }], type: [{
44
50
  type: Input
45
51
  }], target: [{
46
52
  type: Input
47
53
  }] } });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluay5wcm9wZXJ0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL2xpbmsvbGluay5wcm9wZXJ0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQVksV0FBVyxFQUFTLE1BQU0sa0JBQWtCLENBQUM7QUFDMUYsT0FBTyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRWpEOzs7O0dBSUc7QUFDSCxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDO0FBQ3BDLE1BQU0sYUFBYSxHQUFHLE1BQU0sQ0FBQztBQUU3Qjs7R0FFRztBQUVILE1BQU0sT0FBTyxhQUFjLFNBQVEsU0FBUzs7NkhBQS9CLGFBQWE7aUhBQWIsYUFBYSx5TkFESCxFQUFFO0FBZ0J5QztJQUF0RCxXQUFXLENBQVcsYUFBYSxDQUFDO0lBQUUsYUFBYSxFQUFFO2dEQUFzQjtBQUszRDtJQUFoQixhQUFhLEVBQUU7K0NBQXFCO0FBS2tCO0lBQXRELFdBQVcsQ0FBVyxhQUFhLENBQUM7SUFBRSxhQUFhLEVBQUU7Z0RBQXNCOzJGQXpCMUUsYUFBYTtrQkFEekIsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUU7OEJBTWhCLElBQUk7c0JBQVosS0FBSztnQkFLRyxJQUFJO3NCQUFaLEtBQUs7Z0JBSzBELFNBQVM7c0JBQXhFLEtBQUs7Z0JBS29CLFFBQVE7c0JBQWpDLEtBQUs7Z0JBSzBELFNBQVM7c0JBQXhFLEtBQUs7Z0JBS0csSUFBSTtzQkFBWixLQUFLO2dCQUtHLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFhQcm9wZXJ0eSwgWElucHV0Qm9vbGVhbiwgWEJvb2xlYW4sIFhXaXRoQ29uZmlnLCBYVHlwZSB9IGZyb20gJ0BuZy1uZXN0L3VpL2NvcmUnO1xyXG5pbXBvcnQgeyBJbnB1dCwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKipcclxuICogTGlua1xyXG4gKiBAc2VsZWN0b3IgeC1saW5rXHJcbiAqIEBkZWNvcmF0b3IgY29tcG9uZW50XHJcbiAqL1xyXG5leHBvcnQgY29uc3QgWExpbmtQcmVmaXggPSAneC1saW5rJztcclxuY29uc3QgWF9DT05GSUdfTkFNRSA9ICdsaW5rJztcclxuXHJcbi8qKlxyXG4gKiBMaW5rIFByb3BlcnR5XHJcbiAqL1xyXG5AQ29tcG9uZW50KHsgdGVtcGxhdGU6ICcnIH0pXHJcbmV4cG9ydCBjbGFzcyBYTGlua1Byb3BlcnR5IGV4dGVuZHMgWFByb3BlcnR5IHtcclxuICAvKipcclxuICAgKiBAemhfQ04g6ZO+5o6lXHJcbiAgICogQGVuX1VTIExpbmtcclxuICAgKi9cclxuICBASW5wdXQoKSBocmVmPzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlm77moIdcclxuICAgKiBAZW5fVVMgSWNvblxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIGljb24/OiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOS4i+WIkue6v1xyXG4gICAqIEBlbl9VUyBVbmRlcnNjb3JlXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPFhCb29sZWFuPihYX0NPTkZJR19OQU1FKSBAWElucHV0Qm9vbGVhbigpIHVuZGVybGluZT86IFhCb29sZWFuO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDnpoHnlKhcclxuICAgKiBAZW5fVVMgRGlzYWJsZWRcclxuICAgKi9cclxuICBASW5wdXQoKSBAWElucHV0Qm9vbGVhbigpIGRpc2FibGVkPzogWEJvb2xlYW47XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWbvuagh+mdoOWPs+Wvuem9kFxyXG4gICAqIEBlbl9VUyBJY29ucyBhcmUgYWxpZ25lZCB0byB0aGUgcmlnaHRcclxuICAgKi9cclxuICBASW5wdXQoKSBAWFdpdGhDb25maWc8WEJvb2xlYW4+KFhfQ09ORklHX05BTUUpIEBYSW5wdXRCb29sZWFuKCkgaWNvblJpZ2h0PzogWEJvb2xlYW47XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOmTvuaOpeexu+Wei1xyXG4gICAqIEBlbl9VUyBMaW5rIHR5cGVcclxuICAgKi9cclxuICBASW5wdXQoKSB0eXBlPzogWExpbmtUeXBlO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmiZPlvIDmlrnlvI9cclxuICAgKiBAZW5fVVMgT3BlbiBtZXRob2RcclxuICAgKi9cclxuICBASW5wdXQoKSB0YXJnZXQ/OiBzdHJpbmc7XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBAemhfQ04g6ZO+5o6l57G75Z6LXHJcbiAqIEBlbl9VUyBMaW5rIHR5cGVcclxuICovXHJcbmV4cG9ydCB0eXBlIFhMaW5rVHlwZSA9IFhUeXBlO1xyXG4iXX0=
54
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluay5wcm9wZXJ0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL2xpbmsvbGluay5wcm9wZXJ0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxhQUFhLEVBQVksV0FBVyxFQUFTLE1BQU0sa0JBQWtCLENBQUM7QUFDMUYsT0FBTyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBRWpEOzs7O0dBSUc7QUFDSCxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDO0FBQ3BDLE1BQU0sYUFBYSxHQUFHLE1BQU0sQ0FBQztBQUU3Qjs7R0FFRztBQUVILE1BQU0sT0FBTyxhQUFjLFNBQVEsU0FBUzs7NkhBQS9CLGFBQWE7aUhBQWIsYUFBYSwyUEFESCxFQUFFO0FBZ0JnRDtJQUE3RCxXQUFXLENBQVcsYUFBYSxFQUFFLEtBQUssQ0FBQztJQUFFLGFBQWEsRUFBRTtnREFBc0I7QUFLbEU7SUFBaEIsYUFBYSxFQUFFOytDQUFxQjtBQUt5QjtJQUE3RCxXQUFXLENBQVcsYUFBYSxFQUFFLEtBQUssQ0FBQztJQUFFLGFBQWEsRUFBRTtnREFBc0I7QUFLckI7SUFBN0QsV0FBVyxDQUFXLGFBQWEsRUFBRSxLQUFLLENBQUM7SUFBRSxhQUFhLEVBQUU7cURBQTJCOzJGQTlCdEYsYUFBYTtrQkFEekIsU0FBUzttQkFBQyxFQUFFLFFBQVEsRUFBRSxFQUFFLEVBQUU7OEJBTWhCLElBQUk7c0JBQVosS0FBSztnQkFLRyxJQUFJO3NCQUFaLEtBQUs7Z0JBS2lFLFNBQVM7c0JBQS9FLEtBQUs7Z0JBS29CLFFBQVE7c0JBQWpDLEtBQUs7Z0JBS2lFLFNBQVM7c0JBQS9FLEtBQUs7Z0JBS2lFLGNBQWM7c0JBQXBGLEtBQUs7Z0JBS0csSUFBSTtzQkFBWixLQUFLO2dCQUtHLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFhQcm9wZXJ0eSwgWElucHV0Qm9vbGVhbiwgWEJvb2xlYW4sIFhXaXRoQ29uZmlnLCBYVHlwZSB9IGZyb20gJ0BuZy1uZXN0L3VpL2NvcmUnO1xyXG5pbXBvcnQgeyBJbnB1dCwgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKipcclxuICogTGlua1xyXG4gKiBAc2VsZWN0b3IgeC1saW5rXHJcbiAqIEBkZWNvcmF0b3IgY29tcG9uZW50XHJcbiAqL1xyXG5leHBvcnQgY29uc3QgWExpbmtQcmVmaXggPSAneC1saW5rJztcclxuY29uc3QgWF9DT05GSUdfTkFNRSA9ICdsaW5rJztcclxuXHJcbi8qKlxyXG4gKiBMaW5rIFByb3BlcnR5XHJcbiAqL1xyXG5AQ29tcG9uZW50KHsgdGVtcGxhdGU6ICcnIH0pXHJcbmV4cG9ydCBjbGFzcyBYTGlua1Byb3BlcnR5IGV4dGVuZHMgWFByb3BlcnR5IHtcclxuICAvKipcclxuICAgKiBAemhfQ04g6ZO+5o6lXHJcbiAgICogQGVuX1VTIExpbmtcclxuICAgKi9cclxuICBASW5wdXQoKSBocmVmPzogc3RyaW5nO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlm77moIdcclxuICAgKiBAZW5fVVMgSWNvblxyXG4gICAqL1xyXG4gIEBJbnB1dCgpIGljb24/OiBzdHJpbmc7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOS4i+WIkue6v1xyXG4gICAqIEBlbl9VUyBVbmRlcnNjb3JlXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPFhCb29sZWFuPihYX0NPTkZJR19OQU1FLCBmYWxzZSkgQFhJbnB1dEJvb2xlYW4oKSB1bmRlcmxpbmU/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g56aB55SoXHJcbiAgICogQGVuX1VTIERpc2FibGVkXHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhJbnB1dEJvb2xlYW4oKSBkaXNhYmxlZD86IFhCb29sZWFuO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDlm77moIfpnaDlj7Plr7npvZBcclxuICAgKiBAZW5fVVMgSWNvbnMgYXJlIGFsaWduZWQgdG8gdGhlIHJpZ2h0XHJcbiAgICovXHJcbiAgQElucHV0KCkgQFhXaXRoQ29uZmlnPFhCb29sZWFuPihYX0NPTkZJR19OQU1FLCBmYWxzZSkgQFhJbnB1dEJvb2xlYW4oKSBpY29uUmlnaHQ/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g6Zi75q2i6LaF6ZO+5o6l55qE6buY6K6k6KGM5Li6XHJcbiAgICogQGVuX1VTIEJsb2NrIHRoZSBkZWZhdWx0IGJlaGF2aW9yIG9mIGh5cGVybGlua3NcclxuICAgKi9cclxuICBASW5wdXQoKSBAWFdpdGhDb25maWc8WEJvb2xlYW4+KFhfQ09ORklHX05BTUUsIGZhbHNlKSBAWElucHV0Qm9vbGVhbigpIHByZXZlbnREZWZhdWx0PzogWEJvb2xlYW47XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOmTvuaOpeexu+Wei1xyXG4gICAqIEBlbl9VUyBMaW5rIHR5cGVcclxuICAgKi9cclxuICBASW5wdXQoKSB0eXBlPzogWExpbmtUeXBlO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDmiZPlvIDmlrnlvI9cclxuICAgKiBAZW5fVVMgT3BlbiBtZXRob2RcclxuICAgKi9cclxuICBASW5wdXQoKSB0YXJnZXQ/OiBzdHJpbmc7XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBAemhfQ04g6ZO+5o6l57G75Z6LXHJcbiAqIEBlbl9VUyBMaW5rIHR5cGVcclxuICovXHJcbmV4cG9ydCB0eXBlIFhMaW5rVHlwZSA9IFhUeXBlO1xyXG4iXX0=
@@ -228,10 +228,10 @@ export class XSliderComponent extends XSliderProperty {
228
228
  }
229
229
  }
230
230
  /** @nocollapse */ XSliderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XSliderComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.XConfigService }], target: i0.ɵɵFactoryTarget.Component });
231
- /** @nocollapse */ XSliderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XSliderComponent, selector: "x-slider", viewQueries: [{ propertyName: "sliderScroll", first: true, predicate: ["sliderScroll"], descendants: true }, { propertyName: "sliderNodes", first: true, predicate: ["sliderNodes"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li\r\n *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n [class.x-slider-activated]=\"getActivated(i)\"\r\n [class.x-slider-disabled]=\"node.disabled\"\r\n [title]=\"node.label\"\r\n >\r\n <x-link (click)=\"nodeClick($event, node, i)\" [ngClass]=\"nodeClassMap\" [href]=\"showAnchor ? '#' + node.id : ''\">\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n <x-dropdown\r\n *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n class=\"x-slider-all\"\r\n [data]=\"nodes\"\r\n trigger=\"click\"\r\n [(activatedId)]=\"activatedId\"\r\n (nodeClick)=\"dropdownClick($event)\"\r\n [portalMaxHeight]=\"expandMaxHeight\"\r\n >\r\n <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n </x-dropdown>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.XLinkComponent, selector: "x-link" }, { kind: "component", type: i4.XButtonComponent, selector: "x-button" }, { kind: "directive", type: i5.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }, { kind: "component", type: i6.XDropdownComponent, selector: "x-dropdown" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
231
+ /** @nocollapse */ XSliderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.0.0", type: XSliderComponent, selector: "x-slider", viewQueries: [{ propertyName: "sliderScroll", first: true, predicate: ["sliderScroll"], descendants: true }, { propertyName: "sliderNodes", first: true, predicate: ["sliderNodes"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li\r\n *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n [class.x-slider-activated]=\"getActivated(i)\"\r\n [class.x-slider-disabled]=\"node.disabled\"\r\n [title]=\"node.label\"\r\n >\r\n <x-link\r\n (click)=\"nodeClick($event, node, i)\"\r\n [ngClass]=\"nodeClassMap\"\r\n [href]=\"showAnchor ? '#' + node.id : ''\"\r\n [preventDefault]=\"showAnchor\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n <x-dropdown\r\n *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n class=\"x-slider-all\"\r\n [data]=\"nodes\"\r\n trigger=\"click\"\r\n [(activatedId)]=\"activatedId\"\r\n (nodeClick)=\"dropdownClick($event)\"\r\n [portalMaxHeight]=\"expandMaxHeight\"\r\n >\r\n <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n </x-dropdown>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.XLinkComponent, selector: "x-link" }, { kind: "component", type: i4.XButtonComponent, selector: "x-button" }, { kind: "directive", type: i5.XOutletDirective, selector: "[xOutlet]", inputs: ["xOutletContext", "xOutlet"] }, { kind: "component", type: i6.XDropdownComponent, selector: "x-dropdown" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
232
232
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImport: i0, type: XSliderComponent, decorators: [{
233
233
  type: Component,
234
- args: [{ selector: `${XSliderPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li\r\n *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n [class.x-slider-activated]=\"getActivated(i)\"\r\n [class.x-slider-disabled]=\"node.disabled\"\r\n [title]=\"node.label\"\r\n >\r\n <x-link (click)=\"nodeClick($event, node, i)\" [ngClass]=\"nodeClassMap\" [href]=\"showAnchor ? '#' + node.id : ''\">\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n <x-dropdown\r\n *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n class=\"x-slider-all\"\r\n [data]=\"nodes\"\r\n trigger=\"click\"\r\n [(activatedId)]=\"activatedId\"\r\n (nodeClick)=\"dropdownClick($event)\"\r\n [portalMaxHeight]=\"expandMaxHeight\"\r\n >\r\n <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n </x-dropdown>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"] }]
234
+ args: [{ selector: `${XSliderPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n <ul #sliderNodes [style.transform]=\"transform\">\r\n <li\r\n *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n [class.x-slider-activated]=\"getActivated(i)\"\r\n [class.x-slider-disabled]=\"node.disabled\"\r\n [title]=\"node.label\"\r\n >\r\n <x-link\r\n (click)=\"nodeClick($event, node, i)\"\r\n [ngClass]=\"nodeClassMap\"\r\n [href]=\"showAnchor ? '#' + node.id : ''\"\r\n [preventDefault]=\"showAnchor\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n <ng-container *ngIf=\"!nodeTpl\">\r\n <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n </ng-container>\r\n </x-link>\r\n </li>\r\n <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n </ul>\r\n </div>\r\n <x-link\r\n *ngIf=\"showArrow\"\r\n [disabled]=\"offset === maxOffset\"\r\n class=\"x-slider-arrow-right\"\r\n icon=\"fto-chevron-right\"\r\n (click)=\"scrollNext()\"\r\n ></x-link>\r\n <x-dropdown\r\n *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n class=\"x-slider-all\"\r\n [data]=\"nodes\"\r\n trigger=\"click\"\r\n [(activatedId)]=\"activatedId\"\r\n (nodeClick)=\"dropdownClick($event)\"\r\n [portalMaxHeight]=\"expandMaxHeight\"\r\n >\r\n <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n </x-dropdown>\r\n</div>\r\n", styles: [".x-slider{margin:0;padding:0;position:relative;display:flex;align-items:center;height:100%}.x-slider-scroll{overflow:hidden;flex:1;display:inline-flex}.x-slider-scroll.x-justify-start{justify-content:flex-start}.x-slider-scroll.x-justify-center{justify-content:center}.x-slider-scroll.x-justify-end{justify-content:flex-end}.x-slider-scroll.x-justify-space-between{justify-content:space-between}.x-slider-scroll.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul{display:inline-flex;align-items:center;position:relative;transition:transform var(--x-animation-duration-base)}.x-slider-scroll>ul>li{display:inline-flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:2}.x-slider-scroll>ul>li x-link{flex:1}.x-slider-scroll>ul>li x-link.x-justify-start{justify-content:flex-start}.x-slider-scroll>ul>li x-link.x-justify-center{justify-content:center}.x-slider-scroll>ul>li x-link.x-justify-end{justify-content:flex-end}.x-slider-scroll>ul>li x-link.x-justify-space-between{justify-content:space-between}.x-slider-scroll>ul>li x-link.x-justify-space-around{justify-content:space-around}.x-slider-scroll>ul>li x-link.x-size-big{height:var(--x-height-big);line-height:var(--x-height-big);padding:0 var(--x-padding-big)}.x-slider-scroll>ul>li x-link.x-size-large{height:var(--x-height-large);line-height:var(--x-height-large);padding:0 var(--x-padding-large)}.x-slider-scroll>ul>li x-link.x-size-medium{height:var(--x-height-medium);line-height:var(--x-height-medium);padding:0 var(--x-padding-medium)}.x-slider-scroll>ul>li x-link.x-size-small{height:var(--x-height-small);line-height:var(--x-height-small);padding:0 var(--x-padding-small)}.x-slider-scroll>ul>li x-link.x-size-mini{height:var(--x-height-mini);line-height:var(--x-height-mini);padding:0 var(--x-padding-mini)}.x-slider-scroll>ul>li.x-slider-highlight{position:absolute;left:0;top:0;z-index:1;width:0;height:0;border-radius:var(--x-border-radius);background-color:#0000000d;border:.0625rem solid var(--x-border)}.x-slider-scroll>ul>li.x-slider-highlight-animated{transition:width var(--x-animation-duration-base),left var(--x-animation-duration-base),height var(--x-animation-duration-base),top var(--x-animation-duration-base)}.x-slider-activated{color:var(--x-primary)}.x-slider-disabled{color:var(--x-text-400)!important;cursor:not-allowed!important}.x-slider-disabled .x-link{cursor:not-allowed!important}.x-slider-disabled .x-link:hover{color:var(--x-text-400)!important}.x-slider-arrow-left,.x-slider-arrow-right{height:1.675rem;line-height:1.675rem}.x-slider-arrow-left>x-icon,.x-slider-arrow-right>x-icon{margin-right:0}.x-slider-arrow-left .x-link,.x-slider-arrow-right .x-link{padding:.5rem}.x-slider-show-arrow>.x-slider-scroll{justify-content:start!important}.x-slider-row>.x-slider-scroll>ul{flex-direction:row}.x-slider-column{display:inline-flex;flex-direction:column}.x-slider-column>.x-slider-scroll{display:inline-block}.x-slider-column>.x-slider-scroll>ul{flex-direction:column}.x-slider-column>.x-slider-scroll>ul>li{display:flex;width:100%}.x-slider-column>.x-slider-arrow-left,.x-slider-column>.x-slider-arrow-right{transform:rotate(90deg)}\n"] }]
235
235
  }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.XConfigService }]; }, propDecorators: { sliderScroll: [{
236
236
  type: ViewChild,
237
237
  args: ['sliderScroll']
@@ -239,4 +239,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.0.0", ngImpor
239
239
  type: ViewChild,
240
240
  args: ['sliderNodes']
241
241
  }] } });
242
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/slider/slider.component.ts","../../../../../lib/ng-nest/ui/slider/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  OnDestroy,\r\n  SimpleChange\r\n} from '@angular/core';\r\nimport { XSliderPrefix, XSliderNode, XSliderProperty } from './slider.property';\r\nimport { XClassMap, XIsChange, XResize, XPosition, XIsUndefined, XIsEmpty, XSetData, XConfigService } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, debounceTime } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: `${XSliderPrefix}`,\r\n  templateUrl: './slider.component.html',\r\n  styleUrls: ['./slider.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XSliderComponent extends XSliderProperty implements OnInit, OnChanges, OnDestroy, AfterViewInit {\r\n  @ViewChild('sliderScroll') sliderScroll!: ElementRef<HTMLElement>;\r\n  @ViewChild('sliderNodes') sliderNodes!: ElementRef<HTMLElement>;\r\n  nodes: XSliderNode[] = [];\r\n  activated!: XSliderNode;\r\n  scrollClassMap: XClassMap = {};\r\n  nodeClassMap: XClassMap = {};\r\n  showArrow = false;\r\n  activatedId = '';\r\n  private _offset: number = 0;\r\n  get offset(): number {\r\n    return this._offset;\r\n  }\r\n  set offset(value: number) {\r\n    this._offset = Math.floor(value);\r\n    this.transform = `translate${this.dir}(-${this._offset}px)`;\r\n    this.cdr.detectChanges();\r\n  }\r\n  direction: XPosition = 'right';\r\n  maxOffset: number = 0;\r\n  get dir(): 'X' | 'Y' {\r\n    return this.layout === 'row' ? 'X' : 'Y';\r\n  }\r\n  get sizeName() {\r\n    return this.layout === 'row' ? 'Width' : 'Height';\r\n  }\r\n  transform?: string;\r\n  highlightBox = {\r\n    width: '',\r\n    height: '',\r\n    left: '',\r\n    top: ''\r\n  };\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: ResizeObserver;\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef<HTMLElement>,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setClassMap();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const { data, layout, justify, nodeJustify, activatedIndex } = changes;\r\n    XIsChange(data) && this.setData();\r\n    XIsChange(layout) && this.setChange(this.classMap, layout);\r\n    XIsChange(justify) && this.setChange(this.scrollClassMap, justify, 'x-justify');\r\n    XIsChange(nodeJustify) && this.setChange(this.nodeClassMap, nodeJustify, 'x-justify');\r\n    XIsChange(activatedIndex) && this.setDirection(activatedIndex.currentValue, activatedIndex.previousValue) && this.setActivated();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n    this._resizeObserver?.disconnect();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.setSubscribe();\r\n    this.setActivated();\r\n  }\r\n\r\n  setClassMap() {\r\n    this.classMap[`${XSliderPrefix}-${this.layout}`] = !XIsEmpty(this.layout);\r\n    this.scrollClassMap[`x-justify-${this.justify}`] = !XIsEmpty(this.justify);\r\n    this.nodeClassMap = {\r\n      [`x-justify-${this.nodeJustify}`]: !XIsEmpty(this.nodeJustify),\r\n      [`x-size-${this.size}`]: !XIsEmpty(this.size)\r\n    };\r\n  }\r\n\r\n  setChange(map: XClassMap, change: SimpleChange, prefix = XSliderPrefix) {\r\n    map[`${prefix}-${change.previousValue}`] = false;\r\n    map[`${prefix}-${change.currentValue}`] = true;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setSubscribe() {\r\n    XResize(this.sliderScroll.nativeElement, this.sliderNodes.nativeElement)\r\n      .pipe(debounceTime(30), takeUntil(this._unSubject))\r\n      .subscribe((x) => {\r\n        this._resizeObserver = x.resizeObserver;\r\n        this.sizeChecked();\r\n        this.setActivated();\r\n      });\r\n  }\r\n\r\n  nodeClick(event: Event | null, node: XSliderNode, index: number) {\r\n    if (event) {\r\n      event.preventDefault();\r\n      event.stopPropagation();\r\n    }\r\n    if (node.disabled) return;\r\n    this.setDirection(index, Number(this.activatedIndex));\r\n    this.activatedIndex = index;\r\n    this.activated = node;\r\n    this.activatedId = node.id;\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n    this.indexChange.emit(index);\r\n    this.nodeChange.emit(node);\r\n  }\r\n\r\n  dropdownClick(node: XSliderNode) {\r\n    const index = this.nodes.indexOf(node);\r\n    this.nodeClick(null, node, index);\r\n  }\r\n\r\n  scrollPrev() {\r\n    if (this.offset === 0) return;\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (!currentOffset) return;\r\n    const offset = currentOffset > scrollSize ? currentOffset - scrollSize : 0;\r\n    this.offset = offset;\r\n  }\r\n\r\n  scrollNext() {\r\n    if (this.offset === this.maxOffset) return;\r\n    const sliderSize = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (sliderSize - currentOffset <= scrollSize) return;\r\n    const offset = sliderSize - currentOffset > scrollSize * 2 ? currentOffset + scrollSize : sliderSize - scrollSize;\r\n    this.offset = offset;\r\n  }\r\n\r\n  setDirection(index: number, before: number) {\r\n    const increase = index > before;\r\n    this.direction = this.layout === 'row' ? (increase ? 'right' : 'left') : increase ? 'bottom' : 'top';\r\n    return this.direction;\r\n  }\r\n\r\n  setTranslate() {\r\n    if (XIsUndefined(this.sliderScroll) || XIsUndefined(this.sliderNodes)) return;\r\n    const sliderRect = this.sliderScroll.nativeElement?.getBoundingClientRect();\r\n    const sliderNodesRect = this.sliderNodes.nativeElement?.getBoundingClientRect();\r\n    let moveIndex = ['bottom', 'right'].indexOf(this.direction) !== -1 ? Number(this.activatedIndex) + 2 : Number(this.activatedIndex);\r\n    moveIndex = moveIndex > this.nodes.length ? this.nodes.length : moveIndex === 0 ? 1 : moveIndex;\r\n    let moveEle = this.sliderNodes.nativeElement?.querySelector(`li:nth-child(${moveIndex})`);\r\n    let maxOffset = 0;\r\n    if (XIsEmpty(moveEle)) return;\r\n    const moveRect = moveEle!.getBoundingClientRect();\r\n    const currentOffset = this.offset;\r\n    let offset = currentOffset;\r\n    if (this.layout === 'row') {\r\n      maxOffset = sliderNodesRect.width - sliderRect.width;\r\n      if (moveRect.left < sliderRect.left) {\r\n        offset = currentOffset - (sliderRect.left - moveRect.left);\r\n      }\r\n      if (moveRect.right > sliderRect.right) {\r\n        offset = currentOffset + moveRect.right - sliderRect.right;\r\n      }\r\n    } else {\r\n      maxOffset = sliderNodesRect.height - sliderRect.height;\r\n      if (moveRect.top < sliderRect.top) {\r\n        offset = currentOffset - (sliderRect.top - moveRect.top);\r\n      }\r\n      if (moveRect.bottom > sliderRect.bottom) {\r\n        offset = currentOffset + (moveRect.bottom - sliderRect.bottom);\r\n      }\r\n    }\r\n    this.maxOffset = Math.ceil(maxOffset);\r\n    offset = Math.max(Math.ceil(offset), 0);\r\n    if ([this.maxOffset + 1, this.maxOffset - 1].includes(offset)) {\r\n      this.offset = this.maxOffset;\r\n    } else {\r\n      this.offset = Math.min(offset, this.maxOffset);\r\n    }\r\n  }\r\n\r\n  sizeChecked() {\r\n    const size = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const showArrow = this.nodes.length > 1 && size > scrollSize;\r\n    if (this.showArrow !== showArrow) {\r\n      this.showArrow = showArrow;\r\n      this.classMap[`${XSliderPrefix}-show-arrow`] = this.showArrow;\r\n      if (!this.showArrow) {\r\n        this.offset = 0;\r\n      }\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  setActivated() {\r\n    if (this.nodes.length > 0) {\r\n      this.activated = this.nodes[Number(this.activatedIndex)];\r\n      if (this.activated) {\r\n        this.activatedId = this.activated.id;\r\n      }\r\n    }\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n  }\r\n\r\n  setHighlight() {\r\n    if (XIsUndefined(this.sliderNodes)) return;\r\n    const activeEle: HTMLElement = this.sliderNodes.nativeElement.querySelector(`li:nth-child(${Number(this.activatedIndex) + 1})`)!;\r\n    if (!activeEle) return;\r\n    this.highlightBox = {\r\n      width: `${activeEle.offsetWidth}px`,\r\n      height: `${activeEle.offsetHeight}px`,\r\n      left: `${activeEle.offsetLeft}px`,\r\n      top: `${activeEle.offsetTop}px`\r\n    };\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setData() {\r\n    XSetData<XSliderNode>(this.data, this._unSubject).subscribe((x) => {\r\n      this.nodes = x;\r\n      this.cdr.detectChanges();\r\n      setTimeout(() => this.setActivated());\r\n    });\r\n  }\r\n\r\n  getActivated(index: number) {\r\n    return Number(this.activatedIndex) === index;\r\n  }\r\n\r\n  trackByNode(_index: number, item: XSliderNode) {\r\n    return item.id;\r\n  }\r\n}\r\n","<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n  <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n  <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n    <ul #sliderNodes [style.transform]=\"transform\">\r\n      <li\r\n        *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n        [class.x-slider-activated]=\"getActivated(i)\"\r\n        [class.x-slider-disabled]=\"node.disabled\"\r\n        [title]=\"node.label\"\r\n      >\r\n        <x-link (click)=\"nodeClick($event, node, i)\" [ngClass]=\"nodeClassMap\" [href]=\"showAnchor ? '#' + node.id : ''\">\r\n          <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n          <ng-container *ngIf=\"!nodeTpl\">\r\n            <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n          </ng-container>\r\n        </x-link>\r\n      </li>\r\n      <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n    </ul>\r\n  </div>\r\n  <x-link\r\n    *ngIf=\"showArrow\"\r\n    [disabled]=\"offset === maxOffset\"\r\n    class=\"x-slider-arrow-right\"\r\n    icon=\"fto-chevron-right\"\r\n    (click)=\"scrollNext()\"\r\n  ></x-link>\r\n  <x-dropdown\r\n    *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n    class=\"x-slider-all\"\r\n    [data]=\"nodes\"\r\n    trigger=\"click\"\r\n    [(activatedId)]=\"activatedId\"\r\n    (nodeClick)=\"dropdownClick($event)\"\r\n    [portalMaxHeight]=\"expandMaxHeight\"\r\n  >\r\n    <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n  </x-dropdown>\r\n</div>\r\n"]}
242
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/slider/slider.component.ts","../../../../../lib/ng-nest/ui/slider/slider.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewEncapsulation,\r\n  Renderer2,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  ChangeDetectionStrategy,\r\n  SimpleChanges,\r\n  OnChanges,\r\n  ViewChild,\r\n  AfterViewInit,\r\n  OnDestroy,\r\n  SimpleChange\r\n} from '@angular/core';\r\nimport { XSliderPrefix, XSliderNode, XSliderProperty } from './slider.property';\r\nimport { XClassMap, XIsChange, XResize, XPosition, XIsUndefined, XIsEmpty, XSetData, XConfigService } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { takeUntil, debounceTime } from 'rxjs/operators';\r\n\r\n@Component({\r\n  selector: `${XSliderPrefix}`,\r\n  templateUrl: './slider.component.html',\r\n  styleUrls: ['./slider.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XSliderComponent extends XSliderProperty implements OnInit, OnChanges, OnDestroy, AfterViewInit {\r\n  @ViewChild('sliderScroll') sliderScroll!: ElementRef<HTMLElement>;\r\n  @ViewChild('sliderNodes') sliderNodes!: ElementRef<HTMLElement>;\r\n  nodes: XSliderNode[] = [];\r\n  activated!: XSliderNode;\r\n  scrollClassMap: XClassMap = {};\r\n  nodeClassMap: XClassMap = {};\r\n  showArrow = false;\r\n  activatedId = '';\r\n  private _offset: number = 0;\r\n  get offset(): number {\r\n    return this._offset;\r\n  }\r\n  set offset(value: number) {\r\n    this._offset = Math.floor(value);\r\n    this.transform = `translate${this.dir}(-${this._offset}px)`;\r\n    this.cdr.detectChanges();\r\n  }\r\n  direction: XPosition = 'right';\r\n  maxOffset: number = 0;\r\n  get dir(): 'X' | 'Y' {\r\n    return this.layout === 'row' ? 'X' : 'Y';\r\n  }\r\n  get sizeName() {\r\n    return this.layout === 'row' ? 'Width' : 'Height';\r\n  }\r\n  transform?: string;\r\n  highlightBox = {\r\n    width: '',\r\n    height: '',\r\n    left: '',\r\n    top: ''\r\n  };\r\n  private _unSubject = new Subject<void>();\r\n  private _resizeObserver!: ResizeObserver;\r\n\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef<HTMLElement>,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setClassMap();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const { data, layout, justify, nodeJustify, activatedIndex } = changes;\r\n    XIsChange(data) && this.setData();\r\n    XIsChange(layout) && this.setChange(this.classMap, layout);\r\n    XIsChange(justify) && this.setChange(this.scrollClassMap, justify, 'x-justify');\r\n    XIsChange(nodeJustify) && this.setChange(this.nodeClassMap, nodeJustify, 'x-justify');\r\n    XIsChange(activatedIndex) && this.setDirection(activatedIndex.currentValue, activatedIndex.previousValue) && this.setActivated();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n    this._resizeObserver?.disconnect();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.setSubscribe();\r\n    this.setActivated();\r\n  }\r\n\r\n  setClassMap() {\r\n    this.classMap[`${XSliderPrefix}-${this.layout}`] = !XIsEmpty(this.layout);\r\n    this.scrollClassMap[`x-justify-${this.justify}`] = !XIsEmpty(this.justify);\r\n    this.nodeClassMap = {\r\n      [`x-justify-${this.nodeJustify}`]: !XIsEmpty(this.nodeJustify),\r\n      [`x-size-${this.size}`]: !XIsEmpty(this.size)\r\n    };\r\n  }\r\n\r\n  setChange(map: XClassMap, change: SimpleChange, prefix = XSliderPrefix) {\r\n    map[`${prefix}-${change.previousValue}`] = false;\r\n    map[`${prefix}-${change.currentValue}`] = true;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  setSubscribe() {\r\n    XResize(this.sliderScroll.nativeElement, this.sliderNodes.nativeElement)\r\n      .pipe(debounceTime(30), takeUntil(this._unSubject))\r\n      .subscribe((x) => {\r\n        this._resizeObserver = x.resizeObserver;\r\n        this.sizeChecked();\r\n        this.setActivated();\r\n      });\r\n  }\r\n\r\n  nodeClick(event: Event | null, node: XSliderNode, index: number) {\r\n    if (event) {\r\n      event.preventDefault();\r\n      event.stopPropagation();\r\n    }\r\n    if (node.disabled) return;\r\n    this.setDirection(index, Number(this.activatedIndex));\r\n    this.activatedIndex = index;\r\n    this.activated = node;\r\n    this.activatedId = node.id;\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n    this.indexChange.emit(index);\r\n    this.nodeChange.emit(node);\r\n  }\r\n\r\n  dropdownClick(node: XSliderNode) {\r\n    const index = this.nodes.indexOf(node);\r\n    this.nodeClick(null, node, index);\r\n  }\r\n\r\n  scrollPrev() {\r\n    if (this.offset === 0) return;\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (!currentOffset) return;\r\n    const offset = currentOffset > scrollSize ? currentOffset - scrollSize : 0;\r\n    this.offset = offset;\r\n  }\r\n\r\n  scrollNext() {\r\n    if (this.offset === this.maxOffset) return;\r\n    const sliderSize = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const currentOffset = this.offset;\r\n    if (sliderSize - currentOffset <= scrollSize) return;\r\n    const offset = sliderSize - currentOffset > scrollSize * 2 ? currentOffset + scrollSize : sliderSize - scrollSize;\r\n    this.offset = offset;\r\n  }\r\n\r\n  setDirection(index: number, before: number) {\r\n    const increase = index > before;\r\n    this.direction = this.layout === 'row' ? (increase ? 'right' : 'left') : increase ? 'bottom' : 'top';\r\n    return this.direction;\r\n  }\r\n\r\n  setTranslate() {\r\n    if (XIsUndefined(this.sliderScroll) || XIsUndefined(this.sliderNodes)) return;\r\n    const sliderRect = this.sliderScroll.nativeElement?.getBoundingClientRect();\r\n    const sliderNodesRect = this.sliderNodes.nativeElement?.getBoundingClientRect();\r\n    let moveIndex = ['bottom', 'right'].indexOf(this.direction) !== -1 ? Number(this.activatedIndex) + 2 : Number(this.activatedIndex);\r\n    moveIndex = moveIndex > this.nodes.length ? this.nodes.length : moveIndex === 0 ? 1 : moveIndex;\r\n    let moveEle = this.sliderNodes.nativeElement?.querySelector(`li:nth-child(${moveIndex})`);\r\n    let maxOffset = 0;\r\n    if (XIsEmpty(moveEle)) return;\r\n    const moveRect = moveEle!.getBoundingClientRect();\r\n    const currentOffset = this.offset;\r\n    let offset = currentOffset;\r\n    if (this.layout === 'row') {\r\n      maxOffset = sliderNodesRect.width - sliderRect.width;\r\n      if (moveRect.left < sliderRect.left) {\r\n        offset = currentOffset - (sliderRect.left - moveRect.left);\r\n      }\r\n      if (moveRect.right > sliderRect.right) {\r\n        offset = currentOffset + moveRect.right - sliderRect.right;\r\n      }\r\n    } else {\r\n      maxOffset = sliderNodesRect.height - sliderRect.height;\r\n      if (moveRect.top < sliderRect.top) {\r\n        offset = currentOffset - (sliderRect.top - moveRect.top);\r\n      }\r\n      if (moveRect.bottom > sliderRect.bottom) {\r\n        offset = currentOffset + (moveRect.bottom - sliderRect.bottom);\r\n      }\r\n    }\r\n    this.maxOffset = Math.ceil(maxOffset);\r\n    offset = Math.max(Math.ceil(offset), 0);\r\n    if ([this.maxOffset + 1, this.maxOffset - 1].includes(offset)) {\r\n      this.offset = this.maxOffset;\r\n    } else {\r\n      this.offset = Math.min(offset, this.maxOffset);\r\n    }\r\n  }\r\n\r\n  sizeChecked() {\r\n    const size = this.sliderNodes.nativeElement[`offset${this.sizeName}`];\r\n    const scrollSize = this.sliderScroll.nativeElement[`offset${this.sizeName}`];\r\n    const showArrow = this.nodes.length > 1 && size > scrollSize;\r\n    if (this.showArrow !== showArrow) {\r\n      this.showArrow = showArrow;\r\n      this.classMap[`${XSliderPrefix}-show-arrow`] = this.showArrow;\r\n      if (!this.showArrow) {\r\n        this.offset = 0;\r\n      }\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  setActivated() {\r\n    if (this.nodes.length > 0) {\r\n      this.activated = this.nodes[Number(this.activatedIndex)];\r\n      if (this.activated) {\r\n        this.activatedId = this.activated.id;\r\n      }\r\n    }\r\n    this.setHighlight();\r\n    this.setTranslate();\r\n  }\r\n\r\n  setHighlight() {\r\n    if (XIsUndefined(this.sliderNodes)) return;\r\n    const activeEle: HTMLElement = this.sliderNodes.nativeElement.querySelector(`li:nth-child(${Number(this.activatedIndex) + 1})`)!;\r\n    if (!activeEle) return;\r\n    this.highlightBox = {\r\n      width: `${activeEle.offsetWidth}px`,\r\n      height: `${activeEle.offsetHeight}px`,\r\n      left: `${activeEle.offsetLeft}px`,\r\n      top: `${activeEle.offsetTop}px`\r\n    };\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  private setData() {\r\n    XSetData<XSliderNode>(this.data, this._unSubject).subscribe((x) => {\r\n      this.nodes = x;\r\n      this.cdr.detectChanges();\r\n      setTimeout(() => this.setActivated());\r\n    });\r\n  }\r\n\r\n  getActivated(index: number) {\r\n    return Number(this.activatedIndex) === index;\r\n  }\r\n\r\n  trackByNode(_index: number, item: XSliderNode) {\r\n    return item.id;\r\n  }\r\n}\r\n","<div #slider class=\"x-slider\" [ngClass]=\"classMap\">\r\n  <x-link *ngIf=\"showArrow\" [disabled]=\"offset === 0\" class=\"x-slider-arrow-left\" icon=\"fto-chevron-left\" (click)=\"scrollPrev()\"></x-link>\r\n  <div class=\"x-slider-scroll\" #sliderScroll [ngClass]=\"scrollClassMap\">\r\n    <ul #sliderNodes [style.transform]=\"transform\">\r\n      <li\r\n        *ngFor=\"let node of nodes; index as i; trackBy: trackByNode\"\r\n        [class.x-slider-activated]=\"getActivated(i)\"\r\n        [class.x-slider-disabled]=\"node.disabled\"\r\n        [title]=\"node.label\"\r\n      >\r\n        <x-link\r\n          (click)=\"nodeClick($event, node, i)\"\r\n          [ngClass]=\"nodeClassMap\"\r\n          [href]=\"showAnchor ? '#' + node.id : ''\"\r\n          [preventDefault]=\"showAnchor\"\r\n        >\r\n          <ng-container *ngTemplateOutlet=\"nodeTpl; context: { $node: node }\"></ng-container>\r\n          <ng-container *ngIf=\"!nodeTpl\">\r\n            <ng-container *xOutlet=\"node.label\">{{ node.label }}</ng-container>\r\n          </ng-container>\r\n        </x-link>\r\n      </li>\r\n      <li class=\"x-slider-highlight\" [class.x-slider-highlight-animated]=\"animated\" [ngStyle]=\"highlightBox\"></li>\r\n    </ul>\r\n  </div>\r\n  <x-link\r\n    *ngIf=\"showArrow\"\r\n    [disabled]=\"offset === maxOffset\"\r\n    class=\"x-slider-arrow-right\"\r\n    icon=\"fto-chevron-right\"\r\n    (click)=\"scrollNext()\"\r\n  ></x-link>\r\n  <x-dropdown\r\n    *ngIf=\"showExpand && showArrow && layout === 'row'\"\r\n    class=\"x-slider-all\"\r\n    [data]=\"nodes\"\r\n    trigger=\"click\"\r\n    [(activatedId)]=\"activatedId\"\r\n    (nodeClick)=\"dropdownClick($event)\"\r\n    [portalMaxHeight]=\"expandMaxHeight\"\r\n  >\r\n    <x-button icon=\"fto-list\" onlyIcon [size]=\"size\"> </x-button>\r\n  </x-dropdown>\r\n</div>\r\n"]}