@taiga-ui/kit 4.3.0 → 4.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (74) hide show
  1. package/components/calendar-range/calendar-range.component.d.ts +16 -6
  2. package/components/preview/preview.component.d.ts +1 -1
  3. package/directives/button-close/index.d.ts +0 -1
  4. package/directives/icon-badge/icon-badge.directive.d.ts +9 -0
  5. package/directives/icon-badge/index.d.ts +1 -0
  6. package/directives/index.d.ts +1 -0
  7. package/esm2022/components/calendar-range/calendar-range.component.mjs +37 -41
  8. package/esm2022/components/carousel/carousel.component.mjs +3 -3
  9. package/esm2022/components/checkbox/checkbox.component.mjs +2 -2
  10. package/esm2022/components/files/input-files/input-files.directive.mjs +6 -3
  11. package/esm2022/components/items-with-more/items-with-more.service.mjs +3 -3
  12. package/esm2022/components/pagination/pagination.component.mjs +2 -2
  13. package/esm2022/components/preview/preview.component.mjs +4 -6
  14. package/esm2022/components/push/push-alert.component.mjs +3 -3
  15. package/esm2022/components/radio/radio.component.mjs +2 -2
  16. package/esm2022/components/range/range-change.directive.mjs +5 -5
  17. package/esm2022/components/range/range.component.mjs +3 -3
  18. package/esm2022/components/slider/helpers/key-steps.mjs +3 -2
  19. package/esm2022/components/slider/helpers/slider-key-steps.directive.mjs +2 -2
  20. package/esm2022/components/switch/switch.component.mjs +3 -3
  21. package/esm2022/components/tabs/tabs-with-more.component.mjs +7 -6
  22. package/esm2022/components/tiles/tiles.component.mjs +3 -3
  23. package/esm2022/directives/button-close/button-close.directive.mjs +5 -6
  24. package/esm2022/directives/button-close/index.mjs +1 -2
  25. package/esm2022/directives/icon-badge/icon-badge.directive.mjs +41 -0
  26. package/esm2022/directives/icon-badge/index.mjs +2 -0
  27. package/esm2022/directives/icon-badge/taiga-ui-kit-directives-icon-badge.mjs +5 -0
  28. package/esm2022/directives/index.mjs +2 -1
  29. package/esm2022/directives/lazy-loading/lazy-loading.service.mjs +2 -2
  30. package/esm2022/directives/sensitive/sensitive.directive.mjs +5 -5
  31. package/esm2022/directives/skeleton/skeleton.directive.mjs +2 -2
  32. package/fesm2022/taiga-ui-kit-components-calendar-range.mjs +36 -40
  33. package/fesm2022/taiga-ui-kit-components-calendar-range.mjs.map +1 -1
  34. package/fesm2022/taiga-ui-kit-components-carousel.mjs +2 -2
  35. package/fesm2022/taiga-ui-kit-components-carousel.mjs.map +1 -1
  36. package/fesm2022/taiga-ui-kit-components-checkbox.mjs +1 -1
  37. package/fesm2022/taiga-ui-kit-components-checkbox.mjs.map +1 -1
  38. package/fesm2022/taiga-ui-kit-components-files.mjs +5 -2
  39. package/fesm2022/taiga-ui-kit-components-files.mjs.map +1 -1
  40. package/fesm2022/taiga-ui-kit-components-items-with-more.mjs +2 -2
  41. package/fesm2022/taiga-ui-kit-components-items-with-more.mjs.map +1 -1
  42. package/fesm2022/taiga-ui-kit-components-pagination.mjs +1 -1
  43. package/fesm2022/taiga-ui-kit-components-pagination.mjs.map +1 -1
  44. package/fesm2022/taiga-ui-kit-components-preview.mjs +3 -5
  45. package/fesm2022/taiga-ui-kit-components-preview.mjs.map +1 -1
  46. package/fesm2022/taiga-ui-kit-components-push.mjs +2 -2
  47. package/fesm2022/taiga-ui-kit-components-push.mjs.map +1 -1
  48. package/fesm2022/taiga-ui-kit-components-radio.mjs +1 -1
  49. package/fesm2022/taiga-ui-kit-components-radio.mjs.map +1 -1
  50. package/fesm2022/taiga-ui-kit-components-range.mjs +6 -6
  51. package/fesm2022/taiga-ui-kit-components-range.mjs.map +1 -1
  52. package/fesm2022/taiga-ui-kit-components-slider.mjs +3 -2
  53. package/fesm2022/taiga-ui-kit-components-slider.mjs.map +1 -1
  54. package/fesm2022/taiga-ui-kit-components-switch.mjs +2 -2
  55. package/fesm2022/taiga-ui-kit-components-switch.mjs.map +1 -1
  56. package/fesm2022/taiga-ui-kit-components-tabs.mjs +6 -5
  57. package/fesm2022/taiga-ui-kit-components-tabs.mjs.map +1 -1
  58. package/fesm2022/taiga-ui-kit-components-tiles.mjs +2 -2
  59. package/fesm2022/taiga-ui-kit-components-tiles.mjs.map +1 -1
  60. package/fesm2022/taiga-ui-kit-directives-button-close.mjs +5 -8
  61. package/fesm2022/taiga-ui-kit-directives-button-close.mjs.map +1 -1
  62. package/fesm2022/taiga-ui-kit-directives-icon-badge.mjs +47 -0
  63. package/fesm2022/taiga-ui-kit-directives-icon-badge.mjs.map +1 -0
  64. package/fesm2022/taiga-ui-kit-directives-lazy-loading.mjs +1 -1
  65. package/fesm2022/taiga-ui-kit-directives-lazy-loading.mjs.map +1 -1
  66. package/fesm2022/taiga-ui-kit-directives-sensitive.mjs +4 -4
  67. package/fesm2022/taiga-ui-kit-directives-sensitive.mjs.map +1 -1
  68. package/fesm2022/taiga-ui-kit-directives-skeleton.mjs +1 -1
  69. package/fesm2022/taiga-ui-kit-directives-skeleton.mjs.map +1 -1
  70. package/fesm2022/taiga-ui-kit-directives.mjs +1 -0
  71. package/fesm2022/taiga-ui-kit-directives.mjs.map +1 -1
  72. package/package.json +10 -4
  73. package/directives/button-close/button-close.options.d.ts +0 -1
  74. package/esm2022/directives/button-close/button-close.options.mjs +0 -3
@@ -24,14 +24,14 @@ class TuiItemsWithMoreService extends Observable {
24
24
  const items = Array.from(children, ({ clientWidth }) => clientWidth);
25
25
  const first = this.directive.required === -1 ? 0 : this.directive.required;
26
26
  const last = items.length - 1;
27
- const more = children[last]?.tagName === 'SPAN' ? items[last] : 0;
27
+ const more = children[last]?.tagName === 'SPAN' ? (items[last] ?? 0) : 0;
28
28
  items.unshift(...items.splice(first, 1));
29
29
  let total = items.reduce((sum, width) => sum + width, 0) - more;
30
30
  if (total <= clientWidth && this.directive.itemsLimit >= items.length) {
31
31
  return this.maxItems;
32
32
  }
33
33
  for (let i = last - 1; i > 0; i--) {
34
- total -= items[i];
34
+ total -= items[i] ?? 0;
35
35
  if (total + more <= clientWidth) {
36
36
  return tuiClamp(i > this.directive.required ? i - 1 : i - 2, -1, this.maxItems);
37
37
  }
@@ -45,4 +45,4 @@ export { TuiItemsWithMoreService };
45
45
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiItemsWithMoreService, decorators: [{
46
46
  type: Injectable
47
47
  }], ctorParameters: function () { return []; } });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbXMtd2l0aC1tb3JlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pdGVtcy13aXRoLW1vcmUvaXRlbXMtd2l0aC1tb3JlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ25FLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQzNELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsb0JBQW9CLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLFlBQVksRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUV2RixPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQzs7QUFFdEUsTUFDYSx1QkFBd0IsU0FBUSxVQUFrQjtJQWdCM0Q7UUFDSSxLQUFLLENBQUMsQ0FBQyxVQUFVLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7UUFoQjdDLE9BQUUsR0FBRyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3hCLGNBQVMsR0FBRyxNQUFNLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUU1QyxZQUFPLEdBQUcsS0FBSyxDQUM5QixJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sRUFDdEIsTUFBTSxDQUFDLHVCQUF1QixFQUFFLEVBQUMsSUFBSSxFQUFFLElBQUksRUFBQyxDQUFDLEVBQzdDLE1BQU0sQ0FBQyxxQkFBcUIsRUFBRSxFQUFDLElBQUksRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUM5QyxDQUFDLElBQUksQ0FDRixZQUFZLENBQUMsQ0FBQyxDQUFDLEVBQ2YsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLEVBQ2xDLG9CQUFvQixFQUFFLEVBQ3RCLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUNoQyxLQUFLLEVBQUUsQ0FDVixDQUFDO0lBSUYsQ0FBQztJQUVELElBQVksUUFBUTtRQUNoQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUTtZQUN0RCxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLEdBQUcsQ0FBQztZQUMvQixDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLEdBQUcsQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFTyxnQkFBZ0I7UUFDcEIsTUFBTSxFQUFDLFdBQVcsRUFBRSxRQUFRLEVBQUMsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDO1FBQ3hDLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsRUFBQyxXQUFXLEVBQUMsRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDbkUsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUM7UUFDM0UsTUFBTSxJQUFJLEdBQUcsS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7UUFDOUIsTUFBTSxJQUFJLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLE9BQU8sS0FBSyxNQUFNLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRWxFLEtBQUssQ0FBQyxPQUFPLENBQUMsR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBRXpDLElBQUksS0FBSyxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxHQUFHLEdBQUcsS0FBSyxFQUFFLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQztRQUVoRSxJQUFJLEtBQUssSUFBSSxXQUFXLElBQUksSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLElBQUksS0FBSyxDQUFDLE1BQU0sRUFBRTtZQUNuRSxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7U0FDeEI7UUFFRCxLQUFLLElBQUksQ0FBQyxHQUFHLElBQUksR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRTtZQUMvQixLQUFLLElBQUksS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBRWxCLElBQUksS0FBSyxHQUFHLElBQUksSUFBSSxXQUFXLEVBQUU7Z0JBQzdCLE9BQU8sUUFBUSxDQUNYLENBQUMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFDM0MsQ0FBQyxDQUFDLEVBQ0YsSUFBSSxDQUFDLFFBQVEsQ0FDaEIsQ0FBQzthQUNMO1NBQ0o7UUFFRCxPQUFPLENBQUMsQ0FBQyxDQUFDO0lBQ2QsQ0FBQzsrR0F0RFEsdUJBQXVCO21IQUF2Qix1QkFBdUI7O1NBQXZCLHVCQUF1Qjs0RkFBdkIsdUJBQXVCO2tCQURuQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtpbmplY3QsIEluamVjdGFibGUsIE5nWm9uZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge011dGF0aW9uT2JzZXJ2ZXJTZXJ2aWNlfSBmcm9tICdAbmctd2ViLWFwaXMvbXV0YXRpb24tb2JzZXJ2ZXInO1xuaW1wb3J0IHtSZXNpemVPYnNlcnZlclNlcnZpY2V9IGZyb20gJ0BuZy13ZWItYXBpcy9yZXNpemUtb2JzZXJ2ZXInO1xuaW1wb3J0IHt0dWlab25lT3B0aW1pemVkfSBmcm9tICdAdGFpZ2EtdWkvY2RrL29ic2VydmFibGVzJztcbmltcG9ydCB7dHVpSW5qZWN0RWxlbWVudH0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9kb20nO1xuaW1wb3J0IHt0dWlDbGFtcH0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9tYXRoJztcbmltcG9ydCB7ZGlzdGluY3RVbnRpbENoYW5nZWQsIG1hcCwgbWVyZ2UsIE9ic2VydmFibGUsIHNoYXJlLCB0aHJvdHRsZVRpbWV9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQge1R1aUl0ZW1zV2l0aE1vcmVEaXJlY3RpdmV9IGZyb20gJy4vaXRlbXMtd2l0aC1tb3JlLmRpcmVjdGl2ZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBUdWlJdGVtc1dpdGhNb3JlU2VydmljZSBleHRlbmRzIE9ic2VydmFibGU8bnVtYmVyPiB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBlbCA9IHR1aUluamVjdEVsZW1lbnQoKTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGRpcmVjdGl2ZSA9IGluamVjdChUdWlJdGVtc1dpdGhNb3JlRGlyZWN0aXZlKTtcblxuICAgIHByb3RlY3RlZCByZWFkb25seSBzdHJlYW0kID0gbWVyZ2UoXG4gICAgICAgIHRoaXMuZGlyZWN0aXZlLmNoYW5nZSQsXG4gICAgICAgIGluamVjdChNdXRhdGlvbk9ic2VydmVyU2VydmljZSwge3NlbGY6IHRydWV9KSxcbiAgICAgICAgaW5qZWN0KFJlc2l6ZU9ic2VydmVyU2VydmljZSwge3NlbGY6IHRydWV9KSxcbiAgICApLnBpcGUoXG4gICAgICAgIHRocm90dGxlVGltZSgwKSxcbiAgICAgICAgbWFwKCgpID0+IHRoaXMuZ2V0T3ZlcmZsb3dJbmRleCgpKSxcbiAgICAgICAgZGlzdGluY3RVbnRpbENoYW5nZWQoKSxcbiAgICAgICAgdHVpWm9uZU9wdGltaXplZChpbmplY3QoTmdab25lKSksXG4gICAgICAgIHNoYXJlKCksXG4gICAgKTtcblxuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcigoc3Vic2NyaWJlcikgPT4gdGhpcy5zdHJlYW0kLnN1YnNjcmliZShzdWJzY3JpYmVyKSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBnZXQgbWF4SXRlbXMoKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZGlyZWN0aXZlLml0ZW1zTGltaXQgPiB0aGlzLmRpcmVjdGl2ZS5yZXF1aXJlZFxuICAgICAgICAgICAgPyB0aGlzLmRpcmVjdGl2ZS5pdGVtc0xpbWl0IC0gMVxuICAgICAgICAgICAgOiB0aGlzLmRpcmVjdGl2ZS5pdGVtc0xpbWl0IC0gMjtcbiAgICB9XG5cbiAgICBwcml2YXRlIGdldE92ZXJmbG93SW5kZXgoKTogbnVtYmVyIHtcbiAgICAgICAgY29uc3Qge2NsaWVudFdpZHRoLCBjaGlsZHJlbn0gPSB0aGlzLmVsO1xuICAgICAgICBjb25zdCBpdGVtcyA9IEFycmF5LmZyb20oY2hpbGRyZW4sICh7Y2xpZW50V2lkdGh9KSA9PiBjbGllbnRXaWR0aCk7XG4gICAgICAgIGNvbnN0IGZpcnN0ID0gdGhpcy5kaXJlY3RpdmUucmVxdWlyZWQgPT09IC0xID8gMCA6IHRoaXMuZGlyZWN0aXZlLnJlcXVpcmVkO1xuICAgICAgICBjb25zdCBsYXN0ID0gaXRlbXMubGVuZ3RoIC0gMTtcbiAgICAgICAgY29uc3QgbW9yZSA9IGNoaWxkcmVuW2xhc3RdPy50YWdOYW1lID09PSAnU1BBTicgPyBpdGVtc1tsYXN0XSA6IDA7XG5cbiAgICAgICAgaXRlbXMudW5zaGlmdCguLi5pdGVtcy5zcGxpY2UoZmlyc3QsIDEpKTtcblxuICAgICAgICBsZXQgdG90YWwgPSBpdGVtcy5yZWR1Y2UoKHN1bSwgd2lkdGgpID0+IHN1bSArIHdpZHRoLCAwKSAtIG1vcmU7XG5cbiAgICAgICAgaWYgKHRvdGFsIDw9IGNsaWVudFdpZHRoICYmIHRoaXMuZGlyZWN0aXZlLml0ZW1zTGltaXQgPj0gaXRlbXMubGVuZ3RoKSB7XG4gICAgICAgICAgICByZXR1cm4gdGhpcy5tYXhJdGVtcztcbiAgICAgICAgfVxuXG4gICAgICAgIGZvciAobGV0IGkgPSBsYXN0IC0gMTsgaSA+IDA7IGktLSkge1xuICAgICAgICAgICAgdG90YWwgLT0gaXRlbXNbaV07XG5cbiAgICAgICAgICAgIGlmICh0b3RhbCArIG1vcmUgPD0gY2xpZW50V2lkdGgpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gdHVpQ2xhbXAoXG4gICAgICAgICAgICAgICAgICAgIGkgPiB0aGlzLmRpcmVjdGl2ZS5yZXF1aXJlZCA/IGkgLSAxIDogaSAtIDIsXG4gICAgICAgICAgICAgICAgICAgIC0xLFxuICAgICAgICAgICAgICAgICAgICB0aGlzLm1heEl0ZW1zLFxuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gLTE7XG4gICAgfVxufVxuIl19
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlbXMtd2l0aC1tb3JlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9pdGVtcy13aXRoLW1vcmUvaXRlbXMtd2l0aC1tb3JlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBQyx1QkFBdUIsRUFBQyxNQUFNLGdDQUFnQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLDhCQUE4QixDQUFDO0FBQ25FLE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQzNELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsb0JBQW9CLEVBQUUsR0FBRyxFQUFFLEtBQUssRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLFlBQVksRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUV2RixPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQzs7QUFFdEUsTUFDYSx1QkFBd0IsU0FBUSxVQUFrQjtJQWdCM0Q7UUFDSSxLQUFLLENBQUMsQ0FBQyxVQUFVLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUM7UUFoQjdDLE9BQUUsR0FBRyxnQkFBZ0IsRUFBRSxDQUFDO1FBQ3hCLGNBQVMsR0FBRyxNQUFNLENBQUMseUJBQXlCLENBQUMsQ0FBQztRQUU1QyxZQUFPLEdBQUcsS0FBSyxDQUM5QixJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sRUFDdEIsTUFBTSxDQUFDLHVCQUF1QixFQUFFLEVBQUMsSUFBSSxFQUFFLElBQUksRUFBQyxDQUFDLEVBQzdDLE1BQU0sQ0FBQyxxQkFBcUIsRUFBRSxFQUFDLElBQUksRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUM5QyxDQUFDLElBQUksQ0FDRixZQUFZLENBQUMsQ0FBQyxDQUFDLEVBQ2YsR0FBRyxDQUFDLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDLEVBQ2xDLG9CQUFvQixFQUFFLEVBQ3RCLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUNoQyxLQUFLLEVBQUUsQ0FDVixDQUFDO0lBSUYsQ0FBQztJQUVELElBQVksUUFBUTtRQUNoQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUTtZQUN0RCxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLEdBQUcsQ0FBQztZQUMvQixDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLEdBQUcsQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFTyxnQkFBZ0I7UUFDcEIsTUFBTSxFQUFDLFdBQVcsRUFBRSxRQUFRLEVBQUMsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDO1FBQ3hDLE1BQU0sS0FBSyxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsRUFBQyxXQUFXLEVBQUMsRUFBRSxFQUFFLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDbkUsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUM7UUFDM0UsTUFBTSxJQUFJLEdBQUcsS0FBSyxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7UUFDOUIsTUFBTSxJQUFJLEdBQUcsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLE9BQU8sS0FBSyxNQUFNLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFFekUsS0FBSyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFFekMsSUFBSSxLQUFLLEdBQUcsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUFDLEdBQUcsR0FBRyxLQUFLLEVBQUUsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDO1FBRWhFLElBQUksS0FBSyxJQUFJLFdBQVcsSUFBSSxJQUFJLENBQUMsU0FBUyxDQUFDLFVBQVUsSUFBSSxLQUFLLENBQUMsTUFBTSxFQUFFO1lBQ25FLE9BQU8sSUFBSSxDQUFDLFFBQVEsQ0FBQztTQUN4QjtRQUVELEtBQUssSUFBSSxDQUFDLEdBQUcsSUFBSSxHQUFHLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFO1lBQy9CLEtBQUssSUFBSSxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDO1lBRXZCLElBQUksS0FBSyxHQUFHLElBQUksSUFBSSxXQUFXLEVBQUU7Z0JBQzdCLE9BQU8sUUFBUSxDQUNYLENBQUMsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsRUFDM0MsQ0FBQyxDQUFDLEVBQ0YsSUFBSSxDQUFDLFFBQVEsQ0FDaEIsQ0FBQzthQUNMO1NBQ0o7UUFFRCxPQUFPLENBQUMsQ0FBQyxDQUFDO0lBQ2QsQ0FBQzsrR0F0RFEsdUJBQXVCO21IQUF2Qix1QkFBdUI7O1NBQXZCLHVCQUF1Qjs0RkFBdkIsdUJBQXVCO2tCQURuQyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtpbmplY3QsIEluamVjdGFibGUsIE5nWm9uZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge011dGF0aW9uT2JzZXJ2ZXJTZXJ2aWNlfSBmcm9tICdAbmctd2ViLWFwaXMvbXV0YXRpb24tb2JzZXJ2ZXInO1xuaW1wb3J0IHtSZXNpemVPYnNlcnZlclNlcnZpY2V9IGZyb20gJ0BuZy13ZWItYXBpcy9yZXNpemUtb2JzZXJ2ZXInO1xuaW1wb3J0IHt0dWlab25lT3B0aW1pemVkfSBmcm9tICdAdGFpZ2EtdWkvY2RrL29ic2VydmFibGVzJztcbmltcG9ydCB7dHVpSW5qZWN0RWxlbWVudH0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9kb20nO1xuaW1wb3J0IHt0dWlDbGFtcH0gZnJvbSAnQHRhaWdhLXVpL2Nkay91dGlscy9tYXRoJztcbmltcG9ydCB7ZGlzdGluY3RVbnRpbENoYW5nZWQsIG1hcCwgbWVyZ2UsIE9ic2VydmFibGUsIHNoYXJlLCB0aHJvdHRsZVRpbWV9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQge1R1aUl0ZW1zV2l0aE1vcmVEaXJlY3RpdmV9IGZyb20gJy4vaXRlbXMtd2l0aC1tb3JlLmRpcmVjdGl2ZSc7XG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBUdWlJdGVtc1dpdGhNb3JlU2VydmljZSBleHRlbmRzIE9ic2VydmFibGU8bnVtYmVyPiB7XG4gICAgcHJpdmF0ZSByZWFkb25seSBlbCA9IHR1aUluamVjdEVsZW1lbnQoKTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGRpcmVjdGl2ZSA9IGluamVjdChUdWlJdGVtc1dpdGhNb3JlRGlyZWN0aXZlKTtcblxuICAgIHByb3RlY3RlZCByZWFkb25seSBzdHJlYW0kID0gbWVyZ2UoXG4gICAgICAgIHRoaXMuZGlyZWN0aXZlLmNoYW5nZSQsXG4gICAgICAgIGluamVjdChNdXRhdGlvbk9ic2VydmVyU2VydmljZSwge3NlbGY6IHRydWV9KSxcbiAgICAgICAgaW5qZWN0KFJlc2l6ZU9ic2VydmVyU2VydmljZSwge3NlbGY6IHRydWV9KSxcbiAgICApLnBpcGUoXG4gICAgICAgIHRocm90dGxlVGltZSgwKSxcbiAgICAgICAgbWFwKCgpID0+IHRoaXMuZ2V0T3ZlcmZsb3dJbmRleCgpKSxcbiAgICAgICAgZGlzdGluY3RVbnRpbENoYW5nZWQoKSxcbiAgICAgICAgdHVpWm9uZU9wdGltaXplZChpbmplY3QoTmdab25lKSksXG4gICAgICAgIHNoYXJlKCksXG4gICAgKTtcblxuICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICBzdXBlcigoc3Vic2NyaWJlcikgPT4gdGhpcy5zdHJlYW0kLnN1YnNjcmliZShzdWJzY3JpYmVyKSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBnZXQgbWF4SXRlbXMoKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuZGlyZWN0aXZlLml0ZW1zTGltaXQgPiB0aGlzLmRpcmVjdGl2ZS5yZXF1aXJlZFxuICAgICAgICAgICAgPyB0aGlzLmRpcmVjdGl2ZS5pdGVtc0xpbWl0IC0gMVxuICAgICAgICAgICAgOiB0aGlzLmRpcmVjdGl2ZS5pdGVtc0xpbWl0IC0gMjtcbiAgICB9XG5cbiAgICBwcml2YXRlIGdldE92ZXJmbG93SW5kZXgoKTogbnVtYmVyIHtcbiAgICAgICAgY29uc3Qge2NsaWVudFdpZHRoLCBjaGlsZHJlbn0gPSB0aGlzLmVsO1xuICAgICAgICBjb25zdCBpdGVtcyA9IEFycmF5LmZyb20oY2hpbGRyZW4sICh7Y2xpZW50V2lkdGh9KSA9PiBjbGllbnRXaWR0aCk7XG4gICAgICAgIGNvbnN0IGZpcnN0ID0gdGhpcy5kaXJlY3RpdmUucmVxdWlyZWQgPT09IC0xID8gMCA6IHRoaXMuZGlyZWN0aXZlLnJlcXVpcmVkO1xuICAgICAgICBjb25zdCBsYXN0ID0gaXRlbXMubGVuZ3RoIC0gMTtcbiAgICAgICAgY29uc3QgbW9yZSA9IGNoaWxkcmVuW2xhc3RdPy50YWdOYW1lID09PSAnU1BBTicgPyAoaXRlbXNbbGFzdF0gPz8gMCkgOiAwO1xuXG4gICAgICAgIGl0ZW1zLnVuc2hpZnQoLi4uaXRlbXMuc3BsaWNlKGZpcnN0LCAxKSk7XG5cbiAgICAgICAgbGV0IHRvdGFsID0gaXRlbXMucmVkdWNlKChzdW0sIHdpZHRoKSA9PiBzdW0gKyB3aWR0aCwgMCkgLSBtb3JlO1xuXG4gICAgICAgIGlmICh0b3RhbCA8PSBjbGllbnRXaWR0aCAmJiB0aGlzLmRpcmVjdGl2ZS5pdGVtc0xpbWl0ID49IGl0ZW1zLmxlbmd0aCkge1xuICAgICAgICAgICAgcmV0dXJuIHRoaXMubWF4SXRlbXM7XG4gICAgICAgIH1cblxuICAgICAgICBmb3IgKGxldCBpID0gbGFzdCAtIDE7IGkgPiAwOyBpLS0pIHtcbiAgICAgICAgICAgIHRvdGFsIC09IGl0ZW1zW2ldID8/IDA7XG5cbiAgICAgICAgICAgIGlmICh0b3RhbCArIG1vcmUgPD0gY2xpZW50V2lkdGgpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gdHVpQ2xhbXAoXG4gICAgICAgICAgICAgICAgICAgIGkgPiB0aGlzLmRpcmVjdGl2ZS5yZXF1aXJlZCA/IGkgLSAxIDogaSAtIDIsXG4gICAgICAgICAgICAgICAgICAgIC0xLFxuICAgICAgICAgICAgICAgICAgICB0aGlzLm1heEl0ZW1zLFxuICAgICAgICAgICAgICAgICk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICByZXR1cm4gLTE7XG4gICAgfVxufVxuIl19
@@ -113,7 +113,7 @@ class TuiPagination {
113
113
  if (element === this.els.first.nativeElement) {
114
114
  return;
115
115
  }
116
- const previous = this.els.find((_, index, array) => array[index + 1].nativeElement === element);
116
+ const previous = this.els.find((_, index, array) => array[index + 1]?.nativeElement === element);
117
117
  previous?.nativeElement.focus();
118
118
  }
119
119
  onElementKeyDownArrowRight(element) {
@@ -210,4 +210,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
210
210
  }], indexChange: [{
211
211
  type: Output
212
212
  }] } });
213
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/pagination/pagination.component.ts","../../../../../projects/kit/components/pagination/pagination.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgIf} from '@angular/common';\nimport type {QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    ViewChildren,\n} from '@angular/core';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TuiLet} from '@taiga-ui/cdk/directives/let';\nimport {TuiRepeatTimes} from '@taiga-ui/cdk/directives/repeat-times';\nimport type {TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsNativeFocusedIn} from '@taiga-ui/cdk/utils/focus';\nimport {tuiClamp} from '@taiga-ui/cdk/utils/math';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport {TUI_SPIN_ICONS} from '@taiga-ui/core/tokens';\nimport type {\n    TuiHorizontalDirection,\n    TuiSizeL,\n    TuiSizeS,\n    TuiSizeXS,\n} from '@taiga-ui/core/types';\nimport {TUI_PAGINATION_TEXTS} from '@taiga-ui/kit/tokens';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\nconst DOTS_LENGTH = 1;\nconst ACTIVE_ITEM_LENGTH = 1;\n\n@Component({\n    standalone: true,\n    selector: 'tui-pagination',\n    imports: [NgIf, AsyncPipe, TuiButton, TuiRepeatTimes, TuiLet, PolymorpheusOutlet],\n    templateUrl: './pagination.template.html',\n    styleUrls: ['./pagination.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiPagination {\n    @ViewChildren('element', {read: ElementRef})\n    private readonly els: QueryList<ElementRef<HTMLElement>> = EMPTY_QUERY;\n\n    private readonly el = tuiInjectElement();\n\n    protected readonly texts$ = inject(TUI_PAGINATION_TEXTS);\n    protected readonly icons = inject(TUI_SPIN_ICONS);\n\n    @Input()\n    public length = 1;\n\n    @Input()\n    public focusable = true;\n\n    @Input()\n    public size: TuiSizeL | TuiSizeS = 'l';\n\n    @Input()\n    public readonly disabled = false;\n\n    /**\n     * Amount of visible pages around active page\n     */\n    @Input()\n    public activePadding = 1;\n\n    /**\n     * Amount of visible pages at the edges\n     */\n    @Input()\n    public sidePadding = 1;\n\n    /**\n     * Customization for page number display.\n     */\n    @Input()\n    public content: PolymorpheusContent<TuiContext<number>>;\n\n    /**\n     * Active page index\n     */\n    @Input()\n    public index = 0;\n\n    @Output()\n    public readonly indexChange = new EventEmitter<number>();\n\n    public get nativeFocusableElement(): HTMLElement | null {\n        if (this.disabled) {\n            return null;\n        }\n\n        let activeElementIndex = 0;\n        const {elementsLength} = this;\n\n        for (let i = 0; i < elementsLength; i++) {\n            const itemIndex = this.getItemIndexByElementIndex(i);\n\n            if (itemIndex) {\n                activeElementIndex++;\n            }\n\n            if (itemIndex === this.index) {\n                break;\n            }\n        }\n\n        return (\n            this.els.find((_, index) => index === activeElementIndex)?.nativeElement ??\n            null\n        );\n    }\n\n    public get focused(): boolean {\n        return tuiIsNativeFocusedIn(this.el);\n    }\n\n    public get arrowIsDisabledLeft(): boolean {\n        return this.index === 0;\n    }\n\n    public get arrowIsDisabledRight(): boolean {\n        return this.reverseIndex === 0;\n    }\n\n    /**\n     * Number of items in a container.\n     */\n    protected get elementsLength(): number {\n        return this.itemsFit ? this.length : this.maxElementsLength;\n    }\n\n    protected get buttonSize(): TuiSizeXS {\n        return this.size === 'm' ? 'xs' : 's';\n    }\n\n    protected elementIsFocusable(index: number): boolean {\n        return this.index === index && !this.focused;\n    }\n\n    /**\n     * Get index by element index\n     * @param elementIndex\n     * @returns index or null (for '…')\n     */\n    protected getItemIndexByElementIndex(elementIndex: number): number | null {\n        if (this.size === 's') {\n            return elementIndex;\n        }\n\n        if (elementIndex < this.sidePadding) {\n            return elementIndex;\n        }\n\n        if (elementIndex === this.sidePadding && this.hasCollapsedItems(this.index)) {\n            return null;\n        }\n\n        const reverseElementIndex = this.lastElementIndex - elementIndex;\n\n        if (\n            reverseElementIndex === this.sidePadding &&\n            this.hasCollapsedItems(this.reverseIndex)\n        ) {\n            return null;\n        }\n\n        if (reverseElementIndex < this.sidePadding) {\n            return this.lastIndex - reverseElementIndex;\n        }\n\n        const computedIndex = this.index - this.maxHalfLength + elementIndex;\n\n        return tuiClamp(\n            computedIndex,\n            elementIndex,\n            this.lastIndex - reverseElementIndex,\n        );\n    }\n\n    protected getElementMode(index: number): string {\n        const fallback = this.size === 's' ? 'secondary' : 'flat';\n\n        return this.index === index ? 'primary' : fallback;\n    }\n\n    protected onElementClick(index: number): void {\n        this.updateIndex(index);\n    }\n\n    protected onElementKeyDownArrowLeft(element: HTMLElement): void {\n        if (element === this.els.first.nativeElement) {\n            return;\n        }\n\n        const previous = this.els.find(\n            (_, index, array) => array[index + 1].nativeElement === element,\n        );\n\n        previous?.nativeElement.focus();\n    }\n\n    protected onElementKeyDownArrowRight(element: HTMLElement): void {\n        if (element === this.els.last.nativeElement) {\n            return;\n        }\n\n        const next = this.els.find(\n            (_, index, array) => array[index - 1]?.nativeElement === element,\n        );\n\n        next?.nativeElement.focus();\n    }\n\n    protected onArrowClick(direction: TuiHorizontalDirection): void {\n        this.tryChangeTo(direction);\n        this.focusActive();\n    }\n\n    /**\n     * Active index from the end\n     */\n    private get reverseIndex(): number {\n        return this.lastIndex - this.index;\n    }\n\n    /**\n     * Max number of elements in half (not counting the middle one).\n     */\n    private get maxHalfLength(): number {\n        return this.sidePadding + DOTS_LENGTH + this.activePadding;\n    }\n\n    /**\n     * Is there '...' anywhere\n     */\n    private get itemsFit(): boolean {\n        return this.length <= this.maxElementsLength;\n    }\n\n    /**\n     * Max number of elements\n     */\n    private get maxElementsLength(): number {\n        return this.maxHalfLength * 2 + ACTIVE_ITEM_LENGTH;\n    }\n\n    private get lastIndex(): number {\n        return this.length - 1;\n    }\n\n    private get lastElementIndex(): number {\n        return this.elementsLength - 1;\n    }\n\n    /**\n     * Are there collapsed items at that index\n     * @param index\n     * @returns there are collapsed items\n     */\n    private hasCollapsedItems(index: number): boolean {\n        return !this.itemsFit && index > this.maxHalfLength;\n    }\n\n    private tryChangeTo(direction: TuiHorizontalDirection): void {\n        this.updateIndex(\n            tuiClamp(this.index + (direction === 'right' ? 1 : -1), 0, this.lastIndex),\n        );\n    }\n\n    private focusActive(): void {\n        const {nativeFocusableElement} = this;\n\n        if (nativeFocusableElement) {\n            nativeFocusableElement.focus();\n        }\n    }\n\n    private updateIndex(index: number): void {\n        if (this.index === index) {\n            return;\n        }\n\n        this.index = index;\n        this.indexChange.emit(index);\n    }\n}\n","<div class=\"t-content\">\n    <ng-container *ngIf=\"size !== 's'; else smallButtons\">\n        <ng-container *ngIf=\"texts$ | async as texts\">\n            <button\n                appearance=\"flat\"\n                tabIndex=\"-1\"\n                tuiIconButton\n                type=\"button\"\n                class=\"t-button\"\n                [disabled]=\"arrowIsDisabledLeft\"\n                [iconStart]=\"icons.decrement\"\n                [size]=\"buttonSize\"\n                (click)=\"onArrowClick('left')\"\n                (mousedown.silent.prevent)=\"(0)\"\n            >\n                {{ texts[0] }}\n            </button>\n            <ng-container *tuiRepeatTimes=\"let elementIndex of elementsLength\">\n                <ng-container *tuiLet=\"getItemIndexByElementIndex(elementIndex) as index\">\n                    <button\n                        *ngIf=\"index !== null; else dotsTemplate\"\n                        #element\n                        automation-id=\"tui-pagination__element\"\n                        tuiButton\n                        type=\"button\"\n                        class=\"t-button\"\n                        [appearance]=\"getElementMode(index)\"\n                        [disabled]=\"disabled\"\n                        [size]=\"buttonSize\"\n                        [tabIndex]=\"elementIsFocusable(index) ? 0 : -1\"\n                        (click)=\"onElementClick(index)\"\n                        (keydown.arrowLeft.prevent)=\"onElementKeyDownArrowLeft(element)\"\n                        (keydown.arrowRight.prevent)=\"onElementKeyDownArrowRight(element)\"\n                    >\n                        <ng-container *polymorpheusOutlet=\"content || index + 1 as text; context: {$implicit: index}\">\n                            {{ text }}\n                        </ng-container>\n                    </button>\n                </ng-container>\n            </ng-container>\n            <button\n                appearance=\"flat\"\n                tabIndex=\"-1\"\n                tuiIconButton\n                type=\"button\"\n                class=\"t-button\"\n                [disabled]=\"arrowIsDisabledRight\"\n                [iconStart]=\"icons.increment\"\n                [size]=\"buttonSize\"\n                (click)=\"onArrowClick('right')\"\n                (mousedown.silent.prevent)=\"(0)\"\n            >\n                {{ texts[1] }}\n            </button>\n        </ng-container>\n    </ng-container>\n    <ng-template #smallButtons>\n        <button\n            *tuiRepeatTimes=\"let indexItem of length\"\n            #element\n            tuiButton\n            type=\"button\"\n            class=\"t-button t-button_small\"\n            [appearance]=\"getElementMode(indexItem)\"\n            [disabled]=\"disabled\"\n            [tabIndex]=\"elementIsFocusable(indexItem) ? 0 : -1\"\n            (click)=\"onElementClick(indexItem)\"\n            (keydown.arrowLeft.prevent)=\"onElementKeyDownArrowLeft(element)\"\n            (keydown.arrowRight.prevent)=\"onElementKeyDownArrowRight(element)\"\n        ></button>\n    </ng-template>\n    <ng-template #dotsTemplate>\n        <div\n            automation-id=\"tui-pagination__element\"\n            class=\"t-dots\"\n            [class.t-dots_small]=\"size === 'm'\"\n        ></div>\n    </ng-template>\n</div>\n"]}
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/pagination/pagination.component.ts","../../../../../projects/kit/components/pagination/pagination.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgIf} from '@angular/common';\nimport type {QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    ViewChildren,\n} from '@angular/core';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TuiLet} from '@taiga-ui/cdk/directives/let';\nimport {TuiRepeatTimes} from '@taiga-ui/cdk/directives/repeat-times';\nimport type {TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiIsNativeFocusedIn} from '@taiga-ui/cdk/utils/focus';\nimport {tuiClamp} from '@taiga-ui/cdk/utils/math';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport {TUI_SPIN_ICONS} from '@taiga-ui/core/tokens';\nimport type {\n    TuiHorizontalDirection,\n    TuiSizeL,\n    TuiSizeS,\n    TuiSizeXS,\n} from '@taiga-ui/core/types';\nimport {TUI_PAGINATION_TEXTS} from '@taiga-ui/kit/tokens';\nimport type {PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\n\nconst DOTS_LENGTH = 1;\nconst ACTIVE_ITEM_LENGTH = 1;\n\n@Component({\n    standalone: true,\n    selector: 'tui-pagination',\n    imports: [NgIf, AsyncPipe, TuiButton, TuiRepeatTimes, TuiLet, PolymorpheusOutlet],\n    templateUrl: './pagination.template.html',\n    styleUrls: ['./pagination.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiPagination {\n    @ViewChildren('element', {read: ElementRef})\n    private readonly els: QueryList<ElementRef<HTMLElement>> = EMPTY_QUERY;\n\n    private readonly el = tuiInjectElement();\n\n    protected readonly texts$ = inject(TUI_PAGINATION_TEXTS);\n    protected readonly icons = inject(TUI_SPIN_ICONS);\n\n    @Input()\n    public length = 1;\n\n    @Input()\n    public focusable = true;\n\n    @Input()\n    public size: TuiSizeL | TuiSizeS = 'l';\n\n    @Input()\n    public readonly disabled = false;\n\n    /**\n     * Amount of visible pages around active page\n     */\n    @Input()\n    public activePadding = 1;\n\n    /**\n     * Amount of visible pages at the edges\n     */\n    @Input()\n    public sidePadding = 1;\n\n    /**\n     * Customization for page number display.\n     */\n    @Input()\n    public content: PolymorpheusContent<TuiContext<number>>;\n\n    /**\n     * Active page index\n     */\n    @Input()\n    public index = 0;\n\n    @Output()\n    public readonly indexChange = new EventEmitter<number>();\n\n    public get nativeFocusableElement(): HTMLElement | null {\n        if (this.disabled) {\n            return null;\n        }\n\n        let activeElementIndex = 0;\n        const {elementsLength} = this;\n\n        for (let i = 0; i < elementsLength; i++) {\n            const itemIndex = this.getItemIndexByElementIndex(i);\n\n            if (itemIndex) {\n                activeElementIndex++;\n            }\n\n            if (itemIndex === this.index) {\n                break;\n            }\n        }\n\n        return (\n            this.els.find((_, index) => index === activeElementIndex)?.nativeElement ??\n            null\n        );\n    }\n\n    public get focused(): boolean {\n        return tuiIsNativeFocusedIn(this.el);\n    }\n\n    public get arrowIsDisabledLeft(): boolean {\n        return this.index === 0;\n    }\n\n    public get arrowIsDisabledRight(): boolean {\n        return this.reverseIndex === 0;\n    }\n\n    /**\n     * Number of items in a container.\n     */\n    protected get elementsLength(): number {\n        return this.itemsFit ? this.length : this.maxElementsLength;\n    }\n\n    protected get buttonSize(): TuiSizeXS {\n        return this.size === 'm' ? 'xs' : 's';\n    }\n\n    protected elementIsFocusable(index: number): boolean {\n        return this.index === index && !this.focused;\n    }\n\n    /**\n     * Get index by element index\n     * @param elementIndex\n     * @returns index or null (for '…')\n     */\n    protected getItemIndexByElementIndex(elementIndex: number): number | null {\n        if (this.size === 's') {\n            return elementIndex;\n        }\n\n        if (elementIndex < this.sidePadding) {\n            return elementIndex;\n        }\n\n        if (elementIndex === this.sidePadding && this.hasCollapsedItems(this.index)) {\n            return null;\n        }\n\n        const reverseElementIndex = this.lastElementIndex - elementIndex;\n\n        if (\n            reverseElementIndex === this.sidePadding &&\n            this.hasCollapsedItems(this.reverseIndex)\n        ) {\n            return null;\n        }\n\n        if (reverseElementIndex < this.sidePadding) {\n            return this.lastIndex - reverseElementIndex;\n        }\n\n        const computedIndex = this.index - this.maxHalfLength + elementIndex;\n\n        return tuiClamp(\n            computedIndex,\n            elementIndex,\n            this.lastIndex - reverseElementIndex,\n        );\n    }\n\n    protected getElementMode(index: number): string {\n        const fallback = this.size === 's' ? 'secondary' : 'flat';\n\n        return this.index === index ? 'primary' : fallback;\n    }\n\n    protected onElementClick(index: number): void {\n        this.updateIndex(index);\n    }\n\n    protected onElementKeyDownArrowLeft(element: HTMLElement): void {\n        if (element === this.els.first.nativeElement) {\n            return;\n        }\n\n        const previous = this.els.find(\n            (_, index, array) => array[index + 1]?.nativeElement === element,\n        );\n\n        previous?.nativeElement.focus();\n    }\n\n    protected onElementKeyDownArrowRight(element: HTMLElement): void {\n        if (element === this.els.last.nativeElement) {\n            return;\n        }\n\n        const next = this.els.find(\n            (_, index, array) => array[index - 1]?.nativeElement === element,\n        );\n\n        next?.nativeElement.focus();\n    }\n\n    protected onArrowClick(direction: TuiHorizontalDirection): void {\n        this.tryChangeTo(direction);\n        this.focusActive();\n    }\n\n    /**\n     * Active index from the end\n     */\n    private get reverseIndex(): number {\n        return this.lastIndex - this.index;\n    }\n\n    /**\n     * Max number of elements in half (not counting the middle one).\n     */\n    private get maxHalfLength(): number {\n        return this.sidePadding + DOTS_LENGTH + this.activePadding;\n    }\n\n    /**\n     * Is there '...' anywhere\n     */\n    private get itemsFit(): boolean {\n        return this.length <= this.maxElementsLength;\n    }\n\n    /**\n     * Max number of elements\n     */\n    private get maxElementsLength(): number {\n        return this.maxHalfLength * 2 + ACTIVE_ITEM_LENGTH;\n    }\n\n    private get lastIndex(): number {\n        return this.length - 1;\n    }\n\n    private get lastElementIndex(): number {\n        return this.elementsLength - 1;\n    }\n\n    /**\n     * Are there collapsed items at that index\n     * @param index\n     * @returns there are collapsed items\n     */\n    private hasCollapsedItems(index: number): boolean {\n        return !this.itemsFit && index > this.maxHalfLength;\n    }\n\n    private tryChangeTo(direction: TuiHorizontalDirection): void {\n        this.updateIndex(\n            tuiClamp(this.index + (direction === 'right' ? 1 : -1), 0, this.lastIndex),\n        );\n    }\n\n    private focusActive(): void {\n        const {nativeFocusableElement} = this;\n\n        if (nativeFocusableElement) {\n            nativeFocusableElement.focus();\n        }\n    }\n\n    private updateIndex(index: number): void {\n        if (this.index === index) {\n            return;\n        }\n\n        this.index = index;\n        this.indexChange.emit(index);\n    }\n}\n","<div class=\"t-content\">\n    <ng-container *ngIf=\"size !== 's'; else smallButtons\">\n        <ng-container *ngIf=\"texts$ | async as texts\">\n            <button\n                appearance=\"flat\"\n                tabIndex=\"-1\"\n                tuiIconButton\n                type=\"button\"\n                class=\"t-button\"\n                [disabled]=\"arrowIsDisabledLeft\"\n                [iconStart]=\"icons.decrement\"\n                [size]=\"buttonSize\"\n                (click)=\"onArrowClick('left')\"\n                (mousedown.silent.prevent)=\"(0)\"\n            >\n                {{ texts[0] }}\n            </button>\n            <ng-container *tuiRepeatTimes=\"let elementIndex of elementsLength\">\n                <ng-container *tuiLet=\"getItemIndexByElementIndex(elementIndex) as index\">\n                    <button\n                        *ngIf=\"index !== null; else dotsTemplate\"\n                        #element\n                        automation-id=\"tui-pagination__element\"\n                        tuiButton\n                        type=\"button\"\n                        class=\"t-button\"\n                        [appearance]=\"getElementMode(index)\"\n                        [disabled]=\"disabled\"\n                        [size]=\"buttonSize\"\n                        [tabIndex]=\"elementIsFocusable(index) ? 0 : -1\"\n                        (click)=\"onElementClick(index)\"\n                        (keydown.arrowLeft.prevent)=\"onElementKeyDownArrowLeft(element)\"\n                        (keydown.arrowRight.prevent)=\"onElementKeyDownArrowRight(element)\"\n                    >\n                        <ng-container *polymorpheusOutlet=\"content || index + 1 as text; context: {$implicit: index}\">\n                            {{ text }}\n                        </ng-container>\n                    </button>\n                </ng-container>\n            </ng-container>\n            <button\n                appearance=\"flat\"\n                tabIndex=\"-1\"\n                tuiIconButton\n                type=\"button\"\n                class=\"t-button\"\n                [disabled]=\"arrowIsDisabledRight\"\n                [iconStart]=\"icons.increment\"\n                [size]=\"buttonSize\"\n                (click)=\"onArrowClick('right')\"\n                (mousedown.silent.prevent)=\"(0)\"\n            >\n                {{ texts[1] }}\n            </button>\n        </ng-container>\n    </ng-container>\n    <ng-template #smallButtons>\n        <button\n            *tuiRepeatTimes=\"let indexItem of length\"\n            #element\n            tuiButton\n            type=\"button\"\n            class=\"t-button t-button_small\"\n            [appearance]=\"getElementMode(indexItem)\"\n            [disabled]=\"disabled\"\n            [tabIndex]=\"elementIsFocusable(indexItem) ? 0 : -1\"\n            (click)=\"onElementClick(indexItem)\"\n            (keydown.arrowLeft.prevent)=\"onElementKeyDownArrowLeft(element)\"\n            (keydown.arrowRight.prevent)=\"onElementKeyDownArrowRight(element)\"\n        ></button>\n    </ng-template>\n    <ng-template #dotsTemplate>\n        <div\n            automation-id=\"tui-pagination__element\"\n            class=\"t-dots\"\n            [class.t-dots_small]=\"size === 'm'\"\n        ></div>\n    </ng-template>\n</div>\n"]}
@@ -59,12 +59,10 @@ class TuiPreviewComponent {
59
59
  this.processZoom(clientX, clientY, delta);
60
60
  }
61
61
  }
62
- onResize(contentResizeEntries) {
63
- if (contentResizeEntries.length === 0) {
64
- return;
62
+ onResize([entry]) {
63
+ if (entry?.contentRect) {
64
+ this.refresh(entry.contentRect.width, entry.contentRect.height);
65
65
  }
66
- const { width, height } = contentResizeEntries[0].contentRect;
67
- this.refresh(width, height);
68
66
  }
69
67
  reset() {
70
68
  this.zoom$.next(this.minZoom);
@@ -138,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
138
136
  }], rotatable: [{
139
137
  type: Input
140
138
  }] } });
141
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preview.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/preview/preview.component.ts","../../../../../projects/kit/components/preview/preview.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgIf} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, inject, Input} from '@angular/core';\nimport {WaMutationObserver} from '@ng-web-apis/mutation-observer';\nimport {WaResizeObserver} from '@ng-web-apis/resize-observer';\nimport {TUI_FALSE_HANDLER} from '@taiga-ui/cdk/constants';\nimport {TuiPan} from '@taiga-ui/cdk/directives/pan';\nimport type {TuiZoomEvent} from '@taiga-ui/cdk/directives/zoom';\nimport {TuiZoom} from '@taiga-ui/cdk/directives/zoom';\nimport {tuiDragAndDropFrom, tuiTypedFromEvent} from '@taiga-ui/cdk/observables';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiClamp, tuiRound} from '@taiga-ui/cdk/utils/math';\nimport {tuiPx} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {tuiSlideInTop} from '@taiga-ui/core/animations';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport {TuiHint} from '@taiga-ui/core/directives/hint';\nimport {TUI_PREVIEW_ICONS, TUI_PREVIEW_TEXTS} from '@taiga-ui/kit/tokens';\nimport {BehaviorSubject, combineLatest, map, merge, startWith} from 'rxjs';\n\nimport {TuiPreviewAction} from './preview-action/preview-action.directive';\nimport {TuiPreviewZoom} from './zoom/preview-zoom.component';\n\nconst INITIAL_SCALE_COEF = 0.8;\nconst EMPTY_COORDINATES: [number, number] = [0, 0];\nconst ROTATION_ANGLE = 90;\n\n@Component({\n    standalone: true,\n    selector: 'tui-preview',\n    imports: [\n        TuiZoom,\n        WaMutationObserver,\n        WaResizeObserver,\n        NgIf,\n        AsyncPipe,\n        TuiPan,\n        TuiButton,\n        TuiHint,\n        TuiPreviewAction,\n        TuiPreviewZoom,\n    ],\n    templateUrl: './preview.template.html',\n    styleUrls: ['./preview.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [tuiSlideInTop],\n})\nexport class TuiPreviewComponent {\n    private readonly el = tuiInjectElement();\n\n    protected minZoom = 1;\n    protected width = 0;\n    protected height = 0;\n    protected readonly texts$ = inject(TUI_PREVIEW_TEXTS);\n    protected readonly icons = inject(TUI_PREVIEW_ICONS);\n    protected readonly zoom$ = new BehaviorSubject<number>(this.minZoom);\n    protected readonly rotation$ = new BehaviorSubject<number>(0);\n    protected readonly coordinates$ = new BehaviorSubject<readonly [number, number]>(\n        EMPTY_COORDINATES,\n    );\n\n    protected readonly transitioned$ = merge(\n        tuiDragAndDropFrom(this.el).pipe(map(({stage}) => stage !== 'continues')),\n        tuiTypedFromEvent(this.el, 'touchmove', {\n            passive: true,\n        }).pipe(map(TUI_FALSE_HANDLER)),\n        tuiTypedFromEvent(this.el, 'wheel', {passive: true}).pipe(map(TUI_FALSE_HANDLER)),\n    );\n\n    protected readonly cursor$ = tuiDragAndDropFrom(this.el).pipe(\n        map(({stage}) => (stage === 'continues' ? 'grabbing' : 'initial')),\n        startWith('initial'),\n    );\n\n    protected readonly wrapperTransform$ = combineLatest([\n        this.coordinates$.pipe(map(([x, y]) => `${tuiPx(x)}, ${tuiPx(y)}`)),\n        this.zoom$,\n        this.rotation$,\n    ]).pipe(\n        map(\n            ([translate, zoom, rotation]) =>\n                `translate(${translate}) scale(${zoom}) rotate(${rotation}deg)`,\n        ),\n    );\n\n    @Input()\n    public zoomable = true;\n\n    @Input()\n    public rotatable = false;\n\n    protected rotate(): void {\n        this.rotation$.next(this.rotation$.value - ROTATION_ANGLE);\n    }\n\n    protected onPan(delta: readonly [number, number]): void {\n        this.coordinates$.next(\n            this.getGuardedCoordinates(\n                this.coordinates$.value[0] + delta[0],\n                this.coordinates$.value[1] + delta[1],\n            ),\n        );\n    }\n\n    protected onMutation(contentWrapper: HTMLElement): void {\n        const {clientWidth, clientHeight} = contentWrapper;\n\n        this.refresh(clientWidth, clientHeight);\n    }\n\n    protected onZoom({clientX, clientY, delta}: TuiZoomEvent): void {\n        if (this.zoomable) {\n            this.processZoom(clientX, clientY, delta);\n        }\n    }\n\n    protected onResize(contentResizeEntries: readonly ResizeObserverEntry[]): void {\n        if (contentResizeEntries.length === 0) {\n            return;\n        }\n\n        const {width, height} = contentResizeEntries[0].contentRect;\n\n        this.refresh(width, height);\n    }\n\n    protected reset(): void {\n        this.zoom$.next(this.minZoom);\n        this.coordinates$.next(EMPTY_COORDINATES);\n    }\n\n    protected setZoom(zoom: number): void {\n        this.zoom$.next(zoom);\n        const [x, y] = this.coordinates$.value;\n\n        this.coordinates$.next(this.getGuardedCoordinates(x, y));\n    }\n\n    private get offsets(): {offsetX: number; offsetY: number} {\n        const offsetX = ((this.zoom$.value - this.minZoom) * this.width) / 2;\n        const offsetY = ((this.zoom$.value - this.minZoom) * this.height) / 2;\n\n        return {offsetX, offsetY};\n    }\n\n    private calculateMinZoom(\n        contentHeight: number,\n        contentWidth: number,\n        boxHeight: number,\n        boxWidth: number,\n    ): number {\n        const bigSize =\n            contentHeight > boxHeight * INITIAL_SCALE_COEF ||\n            contentWidth > boxWidth * INITIAL_SCALE_COEF;\n        const {clientHeight, clientWidth} = this.el;\n\n        return bigSize\n            ? tuiRound(\n                  Math.min(\n                      (clientHeight * INITIAL_SCALE_COEF) / contentHeight,\n                      (clientWidth * INITIAL_SCALE_COEF) / contentWidth,\n                  ),\n                  2,\n              )\n            : 1;\n    }\n\n    private refresh(width: number, height: number): void {\n        this.width = width;\n        this.height = height;\n        this.minZoom = this.calculateMinZoom(\n            height,\n            width,\n            this.el.clientHeight,\n            this.el.clientWidth,\n        );\n        this.zoom$.next(this.minZoom);\n        this.coordinates$.next(EMPTY_COORDINATES);\n        this.rotation$.next(0);\n    }\n\n    private processZoom(clientX: number, clientY: number, delta: number): void {\n        const oldScale = this.zoom$.value;\n        const newScale = tuiClamp(oldScale + delta, this.minZoom, 2);\n\n        const center = this.getScaleCenter(\n            {clientX, clientY},\n            this.coordinates$.value,\n            this.zoom$.value,\n        );\n\n        const moveX = center[0] * oldScale - center[0] * newScale;\n        const moveY = center[1] * oldScale - center[1] * newScale;\n\n        this.zoom$.next(newScale);\n        this.coordinates$.next(\n            this.getGuardedCoordinates(\n                this.coordinates$.value[0] + moveX,\n                this.coordinates$.value[1] + moveY,\n            ),\n        );\n    }\n\n    private getGuardedCoordinates(x: number, y: number): readonly [number, number] {\n        const {offsetX, offsetY} = this.offsets;\n\n        return [tuiClamp(x, -offsetX, offsetX), tuiClamp(y, -offsetY, offsetY)];\n    }\n\n    private getScaleCenter(\n        {clientX, clientY}: {clientX: number; clientY: number},\n        [x, y]: readonly [number, number],\n        scale: number,\n    ): [number, number] {\n        return [\n            (clientX - x - this.el.offsetWidth / 2) / scale,\n            (clientY - y - this.el.offsetHeight / 2) / scale,\n        ];\n    }\n}\n","<ng-container *ngIf=\"texts$ | async as texts\">\n    <section\n        #contentWrapper\n        attributeFilter=\"src\"\n        characterData\n        childList\n        subtree\n        class=\"t-wrapper\"\n        [class.t-not-interactive-content]=\"zoomable\"\n        [class.t-transitive]=\"transitioned$ | async\"\n        [style.cursor]=\"cursor$ | async\"\n        [style.transform]=\"wrapperTransform$ | async\"\n        (tuiPan)=\"onPan($event)\"\n        (tuiZoom)=\"onZoom($event)\"\n        (waMutationObserver)=\"onMutation(contentWrapper)\"\n        (waResizeObserver)=\"onResize($event)\"\n    >\n        <ng-content />\n    </section>\n\n    <header class=\"t-header\">\n        <div class=\"t-title\">\n            <ng-content select=\"tui-preview-title\" />\n        </div>\n\n        <ng-content select=\"tui-preview-pagination\" />\n\n        <div class=\"t-actions\">\n            <ng-content select=\"[tuiPreviewAction]\" />\n        </div>\n    </header>\n\n    <footer class=\"t-footer\">\n        <button\n            *ngIf=\"rotatable\"\n            tuiHintAppearance=\"dark\"\n            tuiHintDescribe\n            tuiHintDirection=\"top-right\"\n            tuiIconButton\n            tuiPreviewAction\n            type=\"button\"\n            class=\"t-rotate-button\"\n            [iconStart]=\"icons.rotate\"\n            [tuiHint]=\"texts.rotate\"\n            (click)=\"rotate()\"\n        ></button>\n\n        <tui-preview-zoom\n            *ngIf=\"zoomable\"\n            [min]=\"minZoom\"\n            [value]=\"(zoom$ | async) || 1\"\n            (reset)=\"reset()\"\n            (valueChange)=\"setZoom($event)\"\n        />\n    </footer>\n</ng-container>\n"]}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"preview.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/preview/preview.component.ts","../../../../../projects/kit/components/preview/preview.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe, NgIf} from '@angular/common';\nimport {ChangeDetectionStrategy, Component, inject, Input} from '@angular/core';\nimport {WaMutationObserver} from '@ng-web-apis/mutation-observer';\nimport {WaResizeObserver} from '@ng-web-apis/resize-observer';\nimport {TUI_FALSE_HANDLER} from '@taiga-ui/cdk/constants';\nimport {TuiPan} from '@taiga-ui/cdk/directives/pan';\nimport type {TuiZoomEvent} from '@taiga-ui/cdk/directives/zoom';\nimport {TuiZoom} from '@taiga-ui/cdk/directives/zoom';\nimport {tuiDragAndDropFrom, tuiTypedFromEvent} from '@taiga-ui/cdk/observables';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiClamp, tuiRound} from '@taiga-ui/cdk/utils/math';\nimport {tuiPx} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {tuiSlideInTop} from '@taiga-ui/core/animations';\nimport {TuiButton} from '@taiga-ui/core/components/button';\nimport {TuiHint} from '@taiga-ui/core/directives/hint';\nimport {TUI_PREVIEW_ICONS, TUI_PREVIEW_TEXTS} from '@taiga-ui/kit/tokens';\nimport {BehaviorSubject, combineLatest, map, merge, startWith} from 'rxjs';\n\nimport {TuiPreviewAction} from './preview-action/preview-action.directive';\nimport {TuiPreviewZoom} from './zoom/preview-zoom.component';\n\nconst INITIAL_SCALE_COEF = 0.8;\nconst EMPTY_COORDINATES: [number, number] = [0, 0];\nconst ROTATION_ANGLE = 90;\n\n@Component({\n    standalone: true,\n    selector: 'tui-preview',\n    imports: [\n        TuiZoom,\n        WaMutationObserver,\n        WaResizeObserver,\n        NgIf,\n        AsyncPipe,\n        TuiPan,\n        TuiButton,\n        TuiHint,\n        TuiPreviewAction,\n        TuiPreviewZoom,\n    ],\n    templateUrl: './preview.template.html',\n    styleUrls: ['./preview.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    animations: [tuiSlideInTop],\n})\nexport class TuiPreviewComponent {\n    private readonly el = tuiInjectElement();\n\n    protected minZoom = 1;\n    protected width = 0;\n    protected height = 0;\n    protected readonly texts$ = inject(TUI_PREVIEW_TEXTS);\n    protected readonly icons = inject(TUI_PREVIEW_ICONS);\n    protected readonly zoom$ = new BehaviorSubject<number>(this.minZoom);\n    protected readonly rotation$ = new BehaviorSubject<number>(0);\n    protected readonly coordinates$ = new BehaviorSubject<readonly [number, number]>(\n        EMPTY_COORDINATES,\n    );\n\n    protected readonly transitioned$ = merge(\n        tuiDragAndDropFrom(this.el).pipe(map(({stage}) => stage !== 'continues')),\n        tuiTypedFromEvent(this.el, 'touchmove', {\n            passive: true,\n        }).pipe(map(TUI_FALSE_HANDLER)),\n        tuiTypedFromEvent(this.el, 'wheel', {passive: true}).pipe(map(TUI_FALSE_HANDLER)),\n    );\n\n    protected readonly cursor$ = tuiDragAndDropFrom(this.el).pipe(\n        map(({stage}) => (stage === 'continues' ? 'grabbing' : 'initial')),\n        startWith('initial'),\n    );\n\n    protected readonly wrapperTransform$ = combineLatest([\n        this.coordinates$.pipe(map(([x, y]) => `${tuiPx(x)}, ${tuiPx(y)}`)),\n        this.zoom$,\n        this.rotation$,\n    ]).pipe(\n        map(\n            ([translate, zoom, rotation]) =>\n                `translate(${translate}) scale(${zoom}) rotate(${rotation}deg)`,\n        ),\n    );\n\n    @Input()\n    public zoomable = true;\n\n    @Input()\n    public rotatable = false;\n\n    protected rotate(): void {\n        this.rotation$.next(this.rotation$.value - ROTATION_ANGLE);\n    }\n\n    protected onPan(delta: readonly [number, number]): void {\n        this.coordinates$.next(\n            this.getGuardedCoordinates(\n                this.coordinates$.value[0] + delta[0],\n                this.coordinates$.value[1] + delta[1],\n            ),\n        );\n    }\n\n    protected onMutation(contentWrapper: HTMLElement): void {\n        const {clientWidth, clientHeight} = contentWrapper;\n\n        this.refresh(clientWidth, clientHeight);\n    }\n\n    protected onZoom({clientX, clientY, delta}: TuiZoomEvent): void {\n        if (this.zoomable) {\n            this.processZoom(clientX, clientY, delta);\n        }\n    }\n\n    protected onResize([entry]: readonly ResizeObserverEntry[]): void {\n        if (entry?.contentRect) {\n            this.refresh(entry.contentRect.width, entry.contentRect.height);\n        }\n    }\n\n    protected reset(): void {\n        this.zoom$.next(this.minZoom);\n        this.coordinates$.next(EMPTY_COORDINATES);\n    }\n\n    protected setZoom(zoom: number): void {\n        this.zoom$.next(zoom);\n        const [x, y] = this.coordinates$.value;\n\n        this.coordinates$.next(this.getGuardedCoordinates(x, y));\n    }\n\n    private get offsets(): {offsetX: number; offsetY: number} {\n        const offsetX = ((this.zoom$.value - this.minZoom) * this.width) / 2;\n        const offsetY = ((this.zoom$.value - this.minZoom) * this.height) / 2;\n\n        return {offsetX, offsetY};\n    }\n\n    private calculateMinZoom(\n        contentHeight: number,\n        contentWidth: number,\n        boxHeight: number,\n        boxWidth: number,\n    ): number {\n        const bigSize =\n            contentHeight > boxHeight * INITIAL_SCALE_COEF ||\n            contentWidth > boxWidth * INITIAL_SCALE_COEF;\n        const {clientHeight, clientWidth} = this.el;\n\n        return bigSize\n            ? tuiRound(\n                  Math.min(\n                      (clientHeight * INITIAL_SCALE_COEF) / contentHeight,\n                      (clientWidth * INITIAL_SCALE_COEF) / contentWidth,\n                  ),\n                  2,\n              )\n            : 1;\n    }\n\n    private refresh(width: number, height: number): void {\n        this.width = width;\n        this.height = height;\n        this.minZoom = this.calculateMinZoom(\n            height,\n            width,\n            this.el.clientHeight,\n            this.el.clientWidth,\n        );\n        this.zoom$.next(this.minZoom);\n        this.coordinates$.next(EMPTY_COORDINATES);\n        this.rotation$.next(0);\n    }\n\n    private processZoom(clientX: number, clientY: number, delta: number): void {\n        const oldScale = this.zoom$.value;\n        const newScale = tuiClamp(oldScale + delta, this.minZoom, 2);\n\n        const center = this.getScaleCenter(\n            {clientX, clientY},\n            this.coordinates$.value,\n            this.zoom$.value,\n        );\n\n        const moveX = center[0] * oldScale - center[0] * newScale;\n        const moveY = center[1] * oldScale - center[1] * newScale;\n\n        this.zoom$.next(newScale);\n        this.coordinates$.next(\n            this.getGuardedCoordinates(\n                this.coordinates$.value[0] + moveX,\n                this.coordinates$.value[1] + moveY,\n            ),\n        );\n    }\n\n    private getGuardedCoordinates(x: number, y: number): readonly [number, number] {\n        const {offsetX, offsetY} = this.offsets;\n\n        return [tuiClamp(x, -offsetX, offsetX), tuiClamp(y, -offsetY, offsetY)];\n    }\n\n    private getScaleCenter(\n        {clientX, clientY}: {clientX: number; clientY: number},\n        [x, y]: readonly [number, number],\n        scale: number,\n    ): [number, number] {\n        return [\n            (clientX - x - this.el.offsetWidth / 2) / scale,\n            (clientY - y - this.el.offsetHeight / 2) / scale,\n        ];\n    }\n}\n","<ng-container *ngIf=\"texts$ | async as texts\">\n    <section\n        #contentWrapper\n        attributeFilter=\"src\"\n        characterData\n        childList\n        subtree\n        class=\"t-wrapper\"\n        [class.t-not-interactive-content]=\"zoomable\"\n        [class.t-transitive]=\"transitioned$ | async\"\n        [style.cursor]=\"cursor$ | async\"\n        [style.transform]=\"wrapperTransform$ | async\"\n        (tuiPan)=\"onPan($event)\"\n        (tuiZoom)=\"onZoom($event)\"\n        (waMutationObserver)=\"onMutation(contentWrapper)\"\n        (waResizeObserver)=\"onResize($event)\"\n    >\n        <ng-content />\n    </section>\n\n    <header class=\"t-header\">\n        <div class=\"t-title\">\n            <ng-content select=\"tui-preview-title\" />\n        </div>\n\n        <ng-content select=\"tui-preview-pagination\" />\n\n        <div class=\"t-actions\">\n            <ng-content select=\"[tuiPreviewAction]\" />\n        </div>\n    </header>\n\n    <footer class=\"t-footer\">\n        <button\n            *ngIf=\"rotatable\"\n            tuiHintAppearance=\"dark\"\n            tuiHintDescribe\n            tuiHintDirection=\"top-right\"\n            tuiIconButton\n            tuiPreviewAction\n            type=\"button\"\n            class=\"t-rotate-button\"\n            [iconStart]=\"icons.rotate\"\n            [tuiHint]=\"texts.rotate\"\n            (click)=\"rotate()\"\n        ></button>\n\n        <tui-preview-zoom\n            *ngIf=\"zoomable\"\n            [min]=\"minZoom\"\n            [value]=\"(zoom$ | async) || 1\"\n            (reset)=\"reset()\"\n            (valueChange)=\"setZoom($event)\"\n        />\n    </footer>\n</ng-container>\n"]}
@@ -19,7 +19,7 @@ class TuiPushAlert {
19
19
  return this.context.content instanceof TuiPushDirective;
20
20
  }
21
21
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiPushAlert, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
22
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiPushAlert, isStandalone: true, selector: "ng-component", host: { attributes: { "role": "alert" }, properties: { "@tuiFadeIn": "options", "@tuiSlideInRight": "options", "@tuiHeightCollapse": "options" } }, ngImport: i0, template: "<tui-push\n *ngIf=\"!isDirective; else directive\"\n [heading]=\"context.heading\"\n [timestamp]=\"context.timestamp\"\n [type]=\"context.type\"\n (close)=\"context.$implicit.complete()\"\n>\n <img\n *ngIf=\"context.image\"\n alt=\"\"\n [src]=\"context.image\"\n />\n <tui-icon\n *ngIf=\"context.icon\"\n [icon]=\"context.icon\"\n [style.color]=\"context.iconColor\"\n />\n <div\n *polymorpheusOutlet=\"context.content as text; context: context\"\n [innerHTML]=\"text\"\n ></div>\n <button\n *ngIf=\"context.buttons.length > 1\"\n tuiButton\n type=\"button\"\n (click)=\"context.$implicit.next(context.buttons[0])\"\n >\n {{ context.buttons[0] }}\n </button>\n <button\n *ngIf=\"context.buttons.length\"\n tuiLink\n type=\"button\"\n (click)=\"context.$implicit.next(context.buttons[context.buttons.length - 1])\"\n >\n {{ context.buttons[context.buttons.length - 1] }}\n </button>\n</tui-push>\n<ng-template #directive>\n <ng-container *polymorpheusOutlet=\"context.content\" />\n</ng-template>\n", styles: [":host{max-width:calc(100% - 2rem);margin:0 1rem 1rem auto}:host:first-child{margin-top:auto}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "component", type: TuiPushComponent, selector: "tui-push", inputs: ["heading", "type", "timestamp"], outputs: ["close"] }, { kind: "component", type: TuiIcon, selector: "tui-icon", inputs: ["icon", "background"] }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "directive", type: TuiLink, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo"] }], animations: [tuiFadeIn, tuiSlideInRight, tuiHeightCollapse], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
22
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiPushAlert, isStandalone: true, selector: "ng-component", host: { attributes: { "role": "alert" }, properties: { "@tuiFadeIn": "options", "@tuiSlideInRight": "options", "@tuiHeightCollapse": "options" } }, ngImport: i0, template: "<tui-push\n *ngIf=\"!isDirective; else directive\"\n [heading]=\"context.heading\"\n [timestamp]=\"context.timestamp\"\n [type]=\"context.type\"\n (close)=\"context.$implicit.complete()\"\n>\n <img\n *ngIf=\"context.image\"\n alt=\"\"\n [src]=\"context.image\"\n />\n <tui-icon\n *ngIf=\"context.icon\"\n [icon]=\"context.icon\"\n [style.color]=\"context.iconColor\"\n />\n <div\n *polymorpheusOutlet=\"context.content as text; context: context\"\n [innerHTML]=\"text\"\n ></div>\n <button\n *ngIf=\"context.buttons.length > 1\"\n tuiButton\n type=\"button\"\n (click)=\"context.$implicit.next(context.buttons[0] || '')\"\n >\n {{ context.buttons[0] }}\n </button>\n <button\n *ngIf=\"context.buttons.length\"\n tuiLink\n type=\"button\"\n (click)=\"context.$implicit.next(context.buttons[context.buttons.length - 1] || '')\"\n >\n {{ context.buttons[context.buttons.length - 1] }}\n </button>\n</tui-push>\n<ng-template #directive>\n <ng-container *polymorpheusOutlet=\"context.content\" />\n</ng-template>\n", styles: [":host{max-width:calc(100% - 2rem);margin:0 1rem 1rem auto}:host:first-child{margin-top:auto}\n"], dependencies: [{ kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "component", type: TuiPushComponent, selector: "tui-push", inputs: ["heading", "type", "timestamp"], outputs: ["close"] }, { kind: "component", type: TuiIcon, selector: "tui-icon", inputs: ["icon", "background"] }, { kind: "directive", type: TuiButton, selector: "a[tuiButton],button[tuiButton],a[tuiIconButton],button[tuiIconButton]", inputs: ["size"] }, { kind: "directive", type: TuiLink, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo"] }], animations: [tuiFadeIn, tuiSlideInRight, tuiHeightCollapse], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
23
23
  }
24
24
  export { TuiPushAlert };
25
25
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiPushAlert, decorators: [{
@@ -37,6 +37,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
37
37
  '[@tuiFadeIn]': 'options',
38
38
  '[@tuiSlideInRight]': 'options',
39
39
  '[@tuiHeightCollapse]': 'options',
40
- }, template: "<tui-push\n *ngIf=\"!isDirective; else directive\"\n [heading]=\"context.heading\"\n [timestamp]=\"context.timestamp\"\n [type]=\"context.type\"\n (close)=\"context.$implicit.complete()\"\n>\n <img\n *ngIf=\"context.image\"\n alt=\"\"\n [src]=\"context.image\"\n />\n <tui-icon\n *ngIf=\"context.icon\"\n [icon]=\"context.icon\"\n [style.color]=\"context.iconColor\"\n />\n <div\n *polymorpheusOutlet=\"context.content as text; context: context\"\n [innerHTML]=\"text\"\n ></div>\n <button\n *ngIf=\"context.buttons.length > 1\"\n tuiButton\n type=\"button\"\n (click)=\"context.$implicit.next(context.buttons[0])\"\n >\n {{ context.buttons[0] }}\n </button>\n <button\n *ngIf=\"context.buttons.length\"\n tuiLink\n type=\"button\"\n (click)=\"context.$implicit.next(context.buttons[context.buttons.length - 1])\"\n >\n {{ context.buttons[context.buttons.length - 1] }}\n </button>\n</tui-push>\n<ng-template #directive>\n <ng-container *polymorpheusOutlet=\"context.content\" />\n</ng-template>\n", styles: [":host{max-width:calc(100% - 2rem);margin:0 1rem 1rem auto}:host:first-child{margin-top:auto}\n"] }]
40
+ }, template: "<tui-push\n *ngIf=\"!isDirective; else directive\"\n [heading]=\"context.heading\"\n [timestamp]=\"context.timestamp\"\n [type]=\"context.type\"\n (close)=\"context.$implicit.complete()\"\n>\n <img\n *ngIf=\"context.image\"\n alt=\"\"\n [src]=\"context.image\"\n />\n <tui-icon\n *ngIf=\"context.icon\"\n [icon]=\"context.icon\"\n [style.color]=\"context.iconColor\"\n />\n <div\n *polymorpheusOutlet=\"context.content as text; context: context\"\n [innerHTML]=\"text\"\n ></div>\n <button\n *ngIf=\"context.buttons.length > 1\"\n tuiButton\n type=\"button\"\n (click)=\"context.$implicit.next(context.buttons[0] || '')\"\n >\n {{ context.buttons[0] }}\n </button>\n <button\n *ngIf=\"context.buttons.length\"\n tuiLink\n type=\"button\"\n (click)=\"context.$implicit.next(context.buttons[context.buttons.length - 1] || '')\"\n >\n {{ context.buttons[context.buttons.length - 1] }}\n </button>\n</tui-push>\n<ng-template #directive>\n <ng-container *polymorpheusOutlet=\"context.content\" />\n</ng-template>\n", styles: [":host{max-width:calc(100% - 2rem);margin:0 1rem 1rem auto}:host:first-child{margin-top:auto}\n"] }]
41
41
  }] });
42
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVzaC1hbGVydC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9wdXNoL3B1c2gtYWxlcnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvcHVzaC9wdXNoLWFsZXJ0LnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLElBQUksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQ3JDLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXpFLE9BQU8sRUFBQyxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsZUFBZSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDeEYsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQzNELE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN2RCxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDdkQsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFDM0QsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDekUsT0FBTyxFQUNILG9CQUFvQixFQUNwQixrQkFBa0IsRUFDbEIsb0JBQW9CLEdBQ3ZCLE1BQU0sd0JBQXdCLENBQUM7QUFFaEMsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDbEQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7O0FBR2xELE1Bc0JhLFlBQVk7SUF0QnpCO1FBdUJ1QixZQUFPLEdBQUcscUJBQXFCLENBQUMsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUMsQ0FBQztRQUM5RCxZQUFPLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUd2RCxDQUFDO0tBS0w7SUFIRyxJQUFjLFdBQVc7UUFDckIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sWUFBWSxnQkFBZ0IsQ0FBQztJQUM1RCxDQUFDOytHQVRRLFlBQVk7bUdBQVosWUFBWSw0TkN6Q3pCLDJwQ0F5Q0Esd0pEbkJRLElBQUksNkZBQ0osa0JBQWtCLDhIQUVsQixnQkFBZ0IsbUhBQ2hCLE9BQU8scUZBQ1AsU0FBUyxvSUFDVCxPQUFPLDhFQUtDLENBQUMsU0FBUyxFQUFFLGVBQWUsRUFBRSxpQkFBaUIsQ0FBQzs7U0FRbEQsWUFBWTs0RkFBWixZQUFZO2tCQXRCeEIsU0FBUztpQ0FDTSxJQUFJLFdBQ1A7d0JBQ0wsSUFBSTt3QkFDSixrQkFBa0I7d0JBQ2xCLG9CQUFvQjt3QkFDcEIsZ0JBQWdCO3dCQUNoQixPQUFPO3dCQUNQLFNBQVM7d0JBQ1QsT0FBTztxQkFDVixtQkFHZ0IsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxDQUFDLFNBQVMsRUFBRSxlQUFlLEVBQUUsaUJBQWlCLENBQUMsUUFDckQ7d0JBQ0YsSUFBSSxFQUFFLE9BQU87d0JBQ2IsY0FBYyxFQUFFLFNBQVM7d0JBQ3pCLG9CQUFvQixFQUFFLFNBQVM7d0JBQy9CLHNCQUFzQixFQUFFLFNBQVM7cUJBQ3BDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ0lmfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUge1R1aVBvcG92ZXJ9IGZyb20gJ0B0YWlnYS11aS9jZGsvc2VydmljZXMnO1xuaW1wb3J0IHt0dWlGYWRlSW4sIHR1aUhlaWdodENvbGxhcHNlLCB0dWlTbGlkZUluUmlnaHR9IGZyb20gJ0B0YWlnYS11aS9jb3JlL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHtUdWlCdXR0b259IGZyb20gJ0B0YWlnYS11aS9jb3JlL2NvbXBvbmVudHMvYnV0dG9uJztcbmltcG9ydCB7VHVpSWNvbn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9pY29uJztcbmltcG9ydCB7VHVpTGlua30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9saW5rJztcbmltcG9ydCB7VFVJX0FOSU1BVElPTlNfU1BFRUR9IGZyb20gJ0B0YWlnYS11aS9jb3JlL3Rva2Vucyc7XG5pbXBvcnQge3R1aVRvQW5pbWF0aW9uT3B0aW9uc30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdXRpbHMvbWlzY2VsbGFuZW91cyc7XG5pbXBvcnQge1xuICAgIFBPTFlNT1JQSEVVU19DT05URVhULFxuICAgIFBvbHltb3JwaGV1c091dGxldCxcbiAgICBQb2x5bW9ycGhldXNUZW1wbGF0ZSxcbn0gZnJvbSAnQHRhaWdhLXVpL3BvbHltb3JwaGV1cyc7XG5cbmltcG9ydCB7VHVpUHVzaENvbXBvbmVudH0gZnJvbSAnLi9wdXNoLmNvbXBvbmVudCc7XG5pbXBvcnQge1R1aVB1c2hEaXJlY3RpdmV9IGZyb20gJy4vcHVzaC5kaXJlY3RpdmUnO1xuaW1wb3J0IHR5cGUge1R1aVB1c2hPcHRpb25zfSBmcm9tICcuL3B1c2gub3B0aW9ucyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW1xuICAgICAgICBOZ0lmLFxuICAgICAgICBQb2x5bW9ycGhldXNPdXRsZXQsXG4gICAgICAgIFBvbHltb3JwaGV1c1RlbXBsYXRlLFxuICAgICAgICBUdWlQdXNoQ29tcG9uZW50LFxuICAgICAgICBUdWlJY29uLFxuICAgICAgICBUdWlCdXR0b24sXG4gICAgICAgIFR1aUxpbmssXG4gICAgXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vcHVzaC1hbGVydC50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9wdXNoLWFsZXJ0LnN0eWxlLmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBhbmltYXRpb25zOiBbdHVpRmFkZUluLCB0dWlTbGlkZUluUmlnaHQsIHR1aUhlaWdodENvbGxhcHNlXSxcbiAgICBob3N0OiB7XG4gICAgICAgIHJvbGU6ICdhbGVydCcsXG4gICAgICAgICdbQHR1aUZhZGVJbl0nOiAnb3B0aW9ucycsXG4gICAgICAgICdbQHR1aVNsaWRlSW5SaWdodF0nOiAnb3B0aW9ucycsXG4gICAgICAgICdbQHR1aUhlaWdodENvbGxhcHNlXSc6ICdvcHRpb25zJyxcbiAgICB9LFxufSlcbmV4cG9ydCBjbGFzcyBUdWlQdXNoQWxlcnQge1xuICAgIHByb3RlY3RlZCByZWFkb25seSBvcHRpb25zID0gdHVpVG9BbmltYXRpb25PcHRpb25zKGluamVjdChUVUlfQU5JTUFUSU9OU19TUEVFRCkpO1xuICAgIHByb3RlY3RlZCByZWFkb25seSBjb250ZXh0ID0gaW5qZWN0KFBPTFlNT1JQSEVVU19DT05URVhUKSBhcyBUdWlQb3BvdmVyPFxuICAgICAgICBUdWlQdXNoT3B0aW9ucyxcbiAgICAgICAgc3RyaW5nXG4gICAgPjtcblxuICAgIHByb3RlY3RlZCBnZXQgaXNEaXJlY3RpdmUoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmNvbnRleHQuY29udGVudCBpbnN0YW5jZW9mIFR1aVB1c2hEaXJlY3RpdmU7XG4gICAgfVxufVxuIiwiPHR1aS1wdXNoXG4gICAgKm5nSWY9XCIhaXNEaXJlY3RpdmU7IGVsc2UgZGlyZWN0aXZlXCJcbiAgICBbaGVhZGluZ109XCJjb250ZXh0LmhlYWRpbmdcIlxuICAgIFt0aW1lc3RhbXBdPVwiY29udGV4dC50aW1lc3RhbXBcIlxuICAgIFt0eXBlXT1cImNvbnRleHQudHlwZVwiXG4gICAgKGNsb3NlKT1cImNvbnRleHQuJGltcGxpY2l0LmNvbXBsZXRlKClcIlxuPlxuICAgIDxpbWdcbiAgICAgICAgKm5nSWY9XCJjb250ZXh0LmltYWdlXCJcbiAgICAgICAgYWx0PVwiXCJcbiAgICAgICAgW3NyY109XCJjb250ZXh0LmltYWdlXCJcbiAgICAvPlxuICAgIDx0dWktaWNvblxuICAgICAgICAqbmdJZj1cImNvbnRleHQuaWNvblwiXG4gICAgICAgIFtpY29uXT1cImNvbnRleHQuaWNvblwiXG4gICAgICAgIFtzdHlsZS5jb2xvcl09XCJjb250ZXh0Lmljb25Db2xvclwiXG4gICAgLz5cbiAgICA8ZGl2XG4gICAgICAgICpwb2x5bW9ycGhldXNPdXRsZXQ9XCJjb250ZXh0LmNvbnRlbnQgYXMgdGV4dDsgY29udGV4dDogY29udGV4dFwiXG4gICAgICAgIFtpbm5lckhUTUxdPVwidGV4dFwiXG4gICAgPjwvZGl2PlxuICAgIDxidXR0b25cbiAgICAgICAgKm5nSWY9XCJjb250ZXh0LmJ1dHRvbnMubGVuZ3RoID4gMVwiXG4gICAgICAgIHR1aUJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgKGNsaWNrKT1cImNvbnRleHQuJGltcGxpY2l0Lm5leHQoY29udGV4dC5idXR0b25zWzBdKVwiXG4gICAgPlxuICAgICAgICB7eyBjb250ZXh0LmJ1dHRvbnNbMF0gfX1cbiAgICA8L2J1dHRvbj5cbiAgICA8YnV0dG9uXG4gICAgICAgICpuZ0lmPVwiY29udGV4dC5idXR0b25zLmxlbmd0aFwiXG4gICAgICAgIHR1aUxpbmtcbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIChjbGljayk9XCJjb250ZXh0LiRpbXBsaWNpdC5uZXh0KGNvbnRleHQuYnV0dG9uc1tjb250ZXh0LmJ1dHRvbnMubGVuZ3RoIC0gMV0pXCJcbiAgICA+XG4gICAgICAgIHt7IGNvbnRleHQuYnV0dG9uc1tjb250ZXh0LmJ1dHRvbnMubGVuZ3RoIC0gMV0gfX1cbiAgICA8L2J1dHRvbj5cbjwvdHVpLXB1c2g+XG48bmctdGVtcGxhdGUgI2RpcmVjdGl2ZT5cbiAgICA8bmctY29udGFpbmVyICpwb2x5bW9ycGhldXNPdXRsZXQ9XCJjb250ZXh0LmNvbnRlbnRcIiAvPlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
42
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVzaC1hbGVydC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9wdXNoL3B1c2gtYWxlcnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvcHVzaC9wdXNoLWFsZXJ0LnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLElBQUksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQ3JDLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXpFLE9BQU8sRUFBQyxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsZUFBZSxFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFDeEYsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGtDQUFrQyxDQUFDO0FBQzNELE9BQU8sRUFBQyxPQUFPLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN2RCxPQUFPLEVBQUMsT0FBTyxFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDdkQsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFDM0QsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDekUsT0FBTyxFQUNILG9CQUFvQixFQUNwQixrQkFBa0IsRUFDbEIsb0JBQW9CLEdBQ3ZCLE1BQU0sd0JBQXdCLENBQUM7QUFFaEMsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7QUFDbEQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sa0JBQWtCLENBQUM7O0FBR2xELE1Bc0JhLFlBQVk7SUF0QnpCO1FBdUJ1QixZQUFPLEdBQUcscUJBQXFCLENBQUMsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUMsQ0FBQztRQUM5RCxZQUFPLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUd2RCxDQUFDO0tBS0w7SUFIRyxJQUFjLFdBQVc7UUFDckIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE9BQU8sWUFBWSxnQkFBZ0IsQ0FBQztJQUM1RCxDQUFDOytHQVRRLFlBQVk7bUdBQVosWUFBWSw0TkN6Q3pCLHVxQ0F5Q0Esd0pEbkJRLElBQUksNkZBQ0osa0JBQWtCLDhIQUVsQixnQkFBZ0IsbUhBQ2hCLE9BQU8scUZBQ1AsU0FBUyxvSUFDVCxPQUFPLDhFQUtDLENBQUMsU0FBUyxFQUFFLGVBQWUsRUFBRSxpQkFBaUIsQ0FBQzs7U0FRbEQsWUFBWTs0RkFBWixZQUFZO2tCQXRCeEIsU0FBUztpQ0FDTSxJQUFJLFdBQ1A7d0JBQ0wsSUFBSTt3QkFDSixrQkFBa0I7d0JBQ2xCLG9CQUFvQjt3QkFDcEIsZ0JBQWdCO3dCQUNoQixPQUFPO3dCQUNQLFNBQVM7d0JBQ1QsT0FBTztxQkFDVixtQkFHZ0IsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxDQUFDLFNBQVMsRUFBRSxlQUFlLEVBQUUsaUJBQWlCLENBQUMsUUFDckQ7d0JBQ0YsSUFBSSxFQUFFLE9BQU87d0JBQ2IsY0FBYyxFQUFFLFNBQVM7d0JBQ3pCLG9CQUFvQixFQUFFLFNBQVM7d0JBQy9CLHNCQUFzQixFQUFFLFNBQVM7cUJBQ3BDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ0lmfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBpbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUge1R1aVBvcG92ZXJ9IGZyb20gJ0B0YWlnYS11aS9jZGsvc2VydmljZXMnO1xuaW1wb3J0IHt0dWlGYWRlSW4sIHR1aUhlaWdodENvbGxhcHNlLCB0dWlTbGlkZUluUmlnaHR9IGZyb20gJ0B0YWlnYS11aS9jb3JlL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHtUdWlCdXR0b259IGZyb20gJ0B0YWlnYS11aS9jb3JlL2NvbXBvbmVudHMvYnV0dG9uJztcbmltcG9ydCB7VHVpSWNvbn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9pY29uJztcbmltcG9ydCB7VHVpTGlua30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvY29tcG9uZW50cy9saW5rJztcbmltcG9ydCB7VFVJX0FOSU1BVElPTlNfU1BFRUR9IGZyb20gJ0B0YWlnYS11aS9jb3JlL3Rva2Vucyc7XG5pbXBvcnQge3R1aVRvQW5pbWF0aW9uT3B0aW9uc30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdXRpbHMvbWlzY2VsbGFuZW91cyc7XG5pbXBvcnQge1xuICAgIFBPTFlNT1JQSEVVU19DT05URVhULFxuICAgIFBvbHltb3JwaGV1c091dGxldCxcbiAgICBQb2x5bW9ycGhldXNUZW1wbGF0ZSxcbn0gZnJvbSAnQHRhaWdhLXVpL3BvbHltb3JwaGV1cyc7XG5cbmltcG9ydCB7VHVpUHVzaENvbXBvbmVudH0gZnJvbSAnLi9wdXNoLmNvbXBvbmVudCc7XG5pbXBvcnQge1R1aVB1c2hEaXJlY3RpdmV9IGZyb20gJy4vcHVzaC5kaXJlY3RpdmUnO1xuaW1wb3J0IHR5cGUge1R1aVB1c2hPcHRpb25zfSBmcm9tICcuL3B1c2gub3B0aW9ucyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW1xuICAgICAgICBOZ0lmLFxuICAgICAgICBQb2x5bW9ycGhldXNPdXRsZXQsXG4gICAgICAgIFBvbHltb3JwaGV1c1RlbXBsYXRlLFxuICAgICAgICBUdWlQdXNoQ29tcG9uZW50LFxuICAgICAgICBUdWlJY29uLFxuICAgICAgICBUdWlCdXR0b24sXG4gICAgICAgIFR1aUxpbmssXG4gICAgXSxcbiAgICB0ZW1wbGF0ZVVybDogJy4vcHVzaC1hbGVydC50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9wdXNoLWFsZXJ0LnN0eWxlLmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBhbmltYXRpb25zOiBbdHVpRmFkZUluLCB0dWlTbGlkZUluUmlnaHQsIHR1aUhlaWdodENvbGxhcHNlXSxcbiAgICBob3N0OiB7XG4gICAgICAgIHJvbGU6ICdhbGVydCcsXG4gICAgICAgICdbQHR1aUZhZGVJbl0nOiAnb3B0aW9ucycsXG4gICAgICAgICdbQHR1aVNsaWRlSW5SaWdodF0nOiAnb3B0aW9ucycsXG4gICAgICAgICdbQHR1aUhlaWdodENvbGxhcHNlXSc6ICdvcHRpb25zJyxcbiAgICB9LFxufSlcbmV4cG9ydCBjbGFzcyBUdWlQdXNoQWxlcnQge1xuICAgIHByb3RlY3RlZCByZWFkb25seSBvcHRpb25zID0gdHVpVG9BbmltYXRpb25PcHRpb25zKGluamVjdChUVUlfQU5JTUFUSU9OU19TUEVFRCkpO1xuICAgIHByb3RlY3RlZCByZWFkb25seSBjb250ZXh0ID0gaW5qZWN0KFBPTFlNT1JQSEVVU19DT05URVhUKSBhcyBUdWlQb3BvdmVyPFxuICAgICAgICBUdWlQdXNoT3B0aW9ucyxcbiAgICAgICAgc3RyaW5nXG4gICAgPjtcblxuICAgIHByb3RlY3RlZCBnZXQgaXNEaXJlY3RpdmUoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0aGlzLmNvbnRleHQuY29udGVudCBpbnN0YW5jZW9mIFR1aVB1c2hEaXJlY3RpdmU7XG4gICAgfVxufVxuIiwiPHR1aS1wdXNoXG4gICAgKm5nSWY9XCIhaXNEaXJlY3RpdmU7IGVsc2UgZGlyZWN0aXZlXCJcbiAgICBbaGVhZGluZ109XCJjb250ZXh0LmhlYWRpbmdcIlxuICAgIFt0aW1lc3RhbXBdPVwiY29udGV4dC50aW1lc3RhbXBcIlxuICAgIFt0eXBlXT1cImNvbnRleHQudHlwZVwiXG4gICAgKGNsb3NlKT1cImNvbnRleHQuJGltcGxpY2l0LmNvbXBsZXRlKClcIlxuPlxuICAgIDxpbWdcbiAgICAgICAgKm5nSWY9XCJjb250ZXh0LmltYWdlXCJcbiAgICAgICAgYWx0PVwiXCJcbiAgICAgICAgW3NyY109XCJjb250ZXh0LmltYWdlXCJcbiAgICAvPlxuICAgIDx0dWktaWNvblxuICAgICAgICAqbmdJZj1cImNvbnRleHQuaWNvblwiXG4gICAgICAgIFtpY29uXT1cImNvbnRleHQuaWNvblwiXG4gICAgICAgIFtzdHlsZS5jb2xvcl09XCJjb250ZXh0Lmljb25Db2xvclwiXG4gICAgLz5cbiAgICA8ZGl2XG4gICAgICAgICpwb2x5bW9ycGhldXNPdXRsZXQ9XCJjb250ZXh0LmNvbnRlbnQgYXMgdGV4dDsgY29udGV4dDogY29udGV4dFwiXG4gICAgICAgIFtpbm5lckhUTUxdPVwidGV4dFwiXG4gICAgPjwvZGl2PlxuICAgIDxidXR0b25cbiAgICAgICAgKm5nSWY9XCJjb250ZXh0LmJ1dHRvbnMubGVuZ3RoID4gMVwiXG4gICAgICAgIHR1aUJ1dHRvblxuICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgKGNsaWNrKT1cImNvbnRleHQuJGltcGxpY2l0Lm5leHQoY29udGV4dC5idXR0b25zWzBdIHx8ICcnKVwiXG4gICAgPlxuICAgICAgICB7eyBjb250ZXh0LmJ1dHRvbnNbMF0gfX1cbiAgICA8L2J1dHRvbj5cbiAgICA8YnV0dG9uXG4gICAgICAgICpuZ0lmPVwiY29udGV4dC5idXR0b25zLmxlbmd0aFwiXG4gICAgICAgIHR1aUxpbmtcbiAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgIChjbGljayk9XCJjb250ZXh0LiRpbXBsaWNpdC5uZXh0KGNvbnRleHQuYnV0dG9uc1tjb250ZXh0LmJ1dHRvbnMubGVuZ3RoIC0gMV0gfHwgJycpXCJcbiAgICA+XG4gICAgICAgIHt7IGNvbnRleHQuYnV0dG9uc1tjb250ZXh0LmJ1dHRvbnMubGVuZ3RoIC0gMV0gfX1cbiAgICA8L2J1dHRvbj5cbjwvdHVpLXB1c2g+XG48bmctdGVtcGxhdGUgI2RpcmVjdGl2ZT5cbiAgICA8bmctY29udGFpbmVyICpwb2x5bW9ycGhldXNPdXRsZXQ9XCJjb250ZXh0LmNvbnRlbnRcIiAvPlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
@@ -12,7 +12,7 @@ class TuiRadioComponent {
12
12
  this.appearance = inject(TuiAppearance);
13
13
  this.options = inject(TUI_RADIO_OPTIONS);
14
14
  this.el = tuiInjectElement();
15
- this.control = inject(NgControl, { optional: true, self: true });
15
+ this.control = inject(NgControl, { self: true, optional: true });
16
16
  this.size = this.options.size;
17
17
  }
18
18
  ngDoCheck() {
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
32
32
  }], propDecorators: { size: [{
33
33
  type: Input
34
34
  }] } });
35
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvcmFkaW8vcmFkaW8uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULE1BQU0sRUFDTixLQUFLLEVBQ0wsaUJBQWlCLEdBQ3BCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6QyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsYUFBYSxFQUFFLGlCQUFpQixFQUFDLE1BQU0sc0NBQXNDLENBQUM7QUFHdEYsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0saUJBQWlCLENBQUM7Ozs7QUFFbEQsTUFjYSxpQkFBaUI7SUFkOUI7UUFlcUIsZUFBVSxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUNuQyxZQUFPLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDcEMsT0FBRSxHQUFHLGdCQUFnQixFQUFvQixDQUFDO1FBRXhDLFlBQU8sR0FBRyxNQUFNLENBQUMsU0FBUyxFQUFFLEVBQUMsUUFBUSxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQztRQUd0RSxTQUFJLEdBQWEsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7S0FLN0M7SUFIVSxTQUFTO1FBQ1osSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3JFLENBQUM7K0dBWlEsaUJBQWlCO21HQUFqQixpQkFBaUIsaVZBWGhCLEVBQUU7O1NBV0gsaUJBQWlCOzRGQUFqQixpQkFBaUI7a0JBZDdCLFNBQVM7aUNBQ00sSUFBSSxZQUNOLCtCQUErQixZQUMvQixFQUFFLGlCQUVHLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0sa0JBQy9CLENBQUMsaUJBQWlCLEVBQUUsa0JBQWtCLENBQUMsUUFDakQ7d0JBQ0YsWUFBWSxFQUFFLDhCQUE4Qjt3QkFDNUMsa0JBQWtCLEVBQUUsTUFBTTt3QkFDMUIsbUJBQW1CLEVBQUUsVUFBVTtxQkFDbEM7OEJBVU0sSUFBSTtzQkFEVixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge0RvQ2hlY2t9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBDb21wb25lbnQsXG4gICAgaW5qZWN0LFxuICAgIElucHV0LFxuICAgIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TmdDb250cm9sfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge1R1aU5hdGl2ZVZhbGlkYXRvcn0gZnJvbSAnQHRhaWdhLXVpL2Nkay9kaXJlY3RpdmVzL25hdGl2ZS12YWxpZGF0b3InO1xuaW1wb3J0IHt0dWlJbmplY3RFbGVtZW50fSBmcm9tICdAdGFpZ2EtdWkvY2RrL3V0aWxzL2RvbSc7XG5pbXBvcnQge1R1aUFwcGVhcmFuY2UsIFR1aVdpdGhBcHBlYXJhbmNlfSBmcm9tICdAdGFpZ2EtdWkvY29yZS9kaXJlY3RpdmVzL2FwcGVhcmFuY2UnO1xuaW1wb3J0IHR5cGUge1R1aVNpemVTfSBmcm9tICdAdGFpZ2EtdWkvY29yZS90eXBlcyc7XG5cbmltcG9ydCB7VFVJX1JBRElPX09QVElPTlN9IGZyb20gJy4vcmFkaW8ub3B0aW9ucyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6ICdpbnB1dFt0eXBlPVwicmFkaW9cIl1bdHVpUmFkaW9dJyxcbiAgICB0ZW1wbGF0ZTogJycsXG4gICAgc3R5bGVzOiBbJ0BpbXBvcnQgXCJAdGFpZ2EtdWkva2l0L3N0eWxlcy9jb21wb25lbnRzL3JhZGlvLmxlc3NcIjsnXSxcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIGhvc3REaXJlY3RpdmVzOiBbVHVpV2l0aEFwcGVhcmFuY2UsIFR1aU5hdGl2ZVZhbGlkYXRvcl0sXG4gICAgaG9zdDoge1xuICAgICAgICAnW2Rpc2FibGVkXSc6ICchY29udHJvbCB8fCBjb250cm9sLmRpc2FibGVkJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtc2l6ZV0nOiAnc2l6ZScsXG4gICAgICAgICdbY2xhc3MuX3JlYWRvbmx5XSc6ICchY29udHJvbCcsXG4gICAgfSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpUmFkaW9Db21wb25lbnQgaW1wbGVtZW50cyBEb0NoZWNrIHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGFwcGVhcmFuY2UgPSBpbmplY3QoVHVpQXBwZWFyYW5jZSk7XG4gICAgcHJpdmF0ZSByZWFkb25seSBvcHRpb25zID0gaW5qZWN0KFRVSV9SQURJT19PUFRJT05TKTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGVsID0gdHVpSW5qZWN0RWxlbWVudDxIVE1MSW5wdXRFbGVtZW50PigpO1xuXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGNvbnRyb2wgPSBpbmplY3QoTmdDb250cm9sLCB7b3B0aW9uYWw6IHRydWUsIHNlbGY6IHRydWV9KTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNpemU6IFR1aVNpemVTID0gdGhpcy5vcHRpb25zLnNpemU7XG5cbiAgICBwdWJsaWMgbmdEb0NoZWNrKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmFwcGVhcmFuY2UudHVpQXBwZWFyYW5jZSA9IHRoaXMub3B0aW9ucy5hcHBlYXJhbmNlKHRoaXMuZWwpO1xuICAgIH1cbn1cbiJdfQ==
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmFkaW8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvcmFkaW8vcmFkaW8uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULE1BQU0sRUFDTixLQUFLLEVBQ0wsaUJBQWlCLEdBQ3BCLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6QyxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSwyQ0FBMkMsQ0FBQztBQUM3RSxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUMsYUFBYSxFQUFFLGlCQUFpQixFQUFDLE1BQU0sc0NBQXNDLENBQUM7QUFHdEYsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0saUJBQWlCLENBQUM7Ozs7QUFFbEQsTUFjYSxpQkFBaUI7SUFkOUI7UUFlcUIsZUFBVSxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUNuQyxZQUFPLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLENBQUM7UUFDcEMsT0FBRSxHQUFHLGdCQUFnQixFQUFvQixDQUFDO1FBRXhDLFlBQU8sR0FBRyxNQUFNLENBQUMsU0FBUyxFQUFFLEVBQUMsSUFBSSxFQUFFLElBQUksRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFDLENBQUMsQ0FBQztRQUd0RSxTQUFJLEdBQWEsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUM7S0FLN0M7SUFIVSxTQUFTO1FBQ1osSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDO0lBQ3JFLENBQUM7K0dBWlEsaUJBQWlCO21HQUFqQixpQkFBaUIsaVZBWGhCLEVBQUU7O1NBV0gsaUJBQWlCOzRGQUFqQixpQkFBaUI7a0JBZDdCLFNBQVM7aUNBQ00sSUFBSSxZQUNOLCtCQUErQixZQUMvQixFQUFFLGlCQUVHLGlCQUFpQixDQUFDLElBQUksbUJBQ3BCLHVCQUF1QixDQUFDLE1BQU0sa0JBQy9CLENBQUMsaUJBQWlCLEVBQUUsa0JBQWtCLENBQUMsUUFDakQ7d0JBQ0YsWUFBWSxFQUFFLDhCQUE4Qjt3QkFDNUMsa0JBQWtCLEVBQUUsTUFBTTt3QkFDMUIsbUJBQW1CLEVBQUUsVUFBVTtxQkFDbEM7OEJBVU0sSUFBSTtzQkFEVixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge0RvQ2hlY2t9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgICBDb21wb25lbnQsXG4gICAgaW5qZWN0LFxuICAgIElucHV0LFxuICAgIFZpZXdFbmNhcHN1bGF0aW9uLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7TmdDb250cm9sfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge1R1aU5hdGl2ZVZhbGlkYXRvcn0gZnJvbSAnQHRhaWdhLXVpL2Nkay9kaXJlY3RpdmVzL25hdGl2ZS12YWxpZGF0b3InO1xuaW1wb3J0IHt0dWlJbmplY3RFbGVtZW50fSBmcm9tICdAdGFpZ2EtdWkvY2RrL3V0aWxzL2RvbSc7XG5pbXBvcnQge1R1aUFwcGVhcmFuY2UsIFR1aVdpdGhBcHBlYXJhbmNlfSBmcm9tICdAdGFpZ2EtdWkvY29yZS9kaXJlY3RpdmVzL2FwcGVhcmFuY2UnO1xuaW1wb3J0IHR5cGUge1R1aVNpemVTfSBmcm9tICdAdGFpZ2EtdWkvY29yZS90eXBlcyc7XG5cbmltcG9ydCB7VFVJX1JBRElPX09QVElPTlN9IGZyb20gJy4vcmFkaW8ub3B0aW9ucyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgc2VsZWN0b3I6ICdpbnB1dFt0eXBlPVwicmFkaW9cIl1bdHVpUmFkaW9dJyxcbiAgICB0ZW1wbGF0ZTogJycsXG4gICAgc3R5bGVzOiBbJ0BpbXBvcnQgXCJAdGFpZ2EtdWkva2l0L3N0eWxlcy9jb21wb25lbnRzL3JhZGlvLmxlc3NcIjsnXSxcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIGhvc3REaXJlY3RpdmVzOiBbVHVpV2l0aEFwcGVhcmFuY2UsIFR1aU5hdGl2ZVZhbGlkYXRvcl0sXG4gICAgaG9zdDoge1xuICAgICAgICAnW2Rpc2FibGVkXSc6ICchY29udHJvbCB8fCBjb250cm9sLmRpc2FibGVkJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtc2l6ZV0nOiAnc2l6ZScsXG4gICAgICAgICdbY2xhc3MuX3JlYWRvbmx5XSc6ICchY29udHJvbCcsXG4gICAgfSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpUmFkaW9Db21wb25lbnQgaW1wbGVtZW50cyBEb0NoZWNrIHtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGFwcGVhcmFuY2UgPSBpbmplY3QoVHVpQXBwZWFyYW5jZSk7XG4gICAgcHJpdmF0ZSByZWFkb25seSBvcHRpb25zID0gaW5qZWN0KFRVSV9SQURJT19PUFRJT05TKTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGVsID0gdHVpSW5qZWN0RWxlbWVudDxIVE1MSW5wdXRFbGVtZW50PigpO1xuXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGNvbnRyb2wgPSBpbmplY3QoTmdDb250cm9sLCB7c2VsZjogdHJ1ZSwgb3B0aW9uYWw6IHRydWV9KTtcblxuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHNpemU6IFR1aVNpemVTID0gdGhpcy5vcHRpb25zLnNpemU7XG5cbiAgICBwdWJsaWMgbmdEb0NoZWNrKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmFwcGVhcmFuY2UudHVpQXBwZWFyYW5jZSA9IHRoaXMub3B0aW9ucy5hcHBlYXJhbmNlKHRoaXMuZWwpO1xuICAgIH1cbn1cbiJdfQ==
@@ -21,7 +21,7 @@ class TuiRangeChange {
21
21
  passive: true,
22
22
  capture: true,
23
23
  });
24
- this.pointerMove$ = merge(tuiTypedFromEvent(this.doc, 'touchmove').pipe(filter(({ touches }) => touches.length === 1), map(({ touches }) => touches[0])), tuiTypedFromEvent(this.doc, 'mousemove'));
24
+ this.pointerMove$ = merge(tuiTypedFromEvent(this.doc, 'touchmove').pipe(filter(({ touches }) => touches.length === 1), map(({ touches }) => touches[0]), filter((event) => !!event)), tuiTypedFromEvent(this.doc, 'mousemove'));
25
25
  this.pointerUp$ = merge(tuiTypedFromEvent(this.doc, 'touchend', { passive: true }), tuiTypedFromEvent(this.doc, 'mouseup', { passive: true }));
26
26
  this.activeThumbChange = new EventEmitter();
27
27
  let activeThumb;
@@ -32,7 +32,7 @@ class TuiRangeChange {
32
32
  if (this.range.focusable) {
33
33
  this.el.focus();
34
34
  }
35
- }), switchMap((event) => this.pointerMove$.pipe(startWith(event))), map(({ clientX }) => this.getFractionFromEvents(clientX)), takeUntil(this.pointerUp$), repeat(), takeUntilDestroyed())
35
+ }), switchMap((event) => this.pointerMove$.pipe(startWith(event))), map(({ clientX }) => this.getFractionFromEvents(clientX ?? 0)), takeUntil(this.pointerUp$), repeat(), takeUntilDestroyed())
36
36
  .subscribe((fraction) => {
37
37
  const value = this.range.toValue(fraction);
38
38
  this.range.processValue(value, activeThumb === 'right');
@@ -47,9 +47,9 @@ class TuiRangeChange {
47
47
  detectActiveThumb(clientX, target) {
48
48
  const [leftSliderRef, rightSliderRef] = this.range.slidersRefs;
49
49
  switch (target) {
50
- case leftSliderRef.nativeElement:
50
+ case leftSliderRef?.nativeElement:
51
51
  return 'left';
52
- case rightSliderRef.nativeElement:
52
+ case rightSliderRef?.nativeElement:
53
53
  return 'right';
54
54
  default:
55
55
  return this.findNearestActiveThumb(clientX);
@@ -77,4 +77,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
77
77
  }], ctorParameters: function () { return []; }, propDecorators: { activeThumbChange: [{
78
78
  type: Output
79
79
  }] } });
80
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-change.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/range/range-change.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport {Directive, EventEmitter, inject, Output} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {tuiTypedFromEvent} from '@taiga-ui/cdk/observables';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiClamp, tuiRound} from '@taiga-ui/cdk/utils/math';\nimport {TUI_FLOATING_PRECISION} from '@taiga-ui/kit/components/slider';\nimport {filter, map, merge, repeat, startWith, switchMap, takeUntil, tap} from 'rxjs';\n\nimport {TuiRange} from './range.component';\n\n@Directive({\n    standalone: true,\n})\nexport class TuiRangeChange {\n    private readonly doc = inject(DOCUMENT);\n    private readonly el = tuiInjectElement();\n    private readonly range = inject(TuiRange);\n\n    /**\n     * TODO replace with pointer events (when all supported browsers can handle them).\n     * Don't forget to use setPointerCapture instead of listening all doc events\n     */\n    private readonly pointerDown$ = tuiTypedFromEvent(this.el, 'pointerdown', {\n        passive: true,\n        capture: true,\n    });\n\n    private readonly pointerMove$ = merge(\n        tuiTypedFromEvent(this.doc, 'touchmove').pipe(\n            filter(({touches}) => touches.length === 1),\n            map(({touches}) => touches[0]),\n        ),\n        tuiTypedFromEvent(this.doc, 'mousemove'),\n    );\n\n    private readonly pointerUp$ = merge(\n        tuiTypedFromEvent(this.doc, 'touchend', {passive: true}),\n        tuiTypedFromEvent(this.doc, 'mouseup', {passive: true}),\n    );\n\n    @Output()\n    public readonly activeThumbChange = new EventEmitter<'left' | 'right'>();\n\n    constructor() {\n        let activeThumb: 'left' | 'right';\n\n        this.pointerDown$\n            .pipe(\n                tap(({clientX, target}) => {\n                    activeThumb = this.detectActiveThumb(clientX, target);\n                    this.activeThumbChange.emit(activeThumb);\n\n                    if (this.range.focusable) {\n                        this.el.focus();\n                    }\n                }),\n                switchMap((event) => this.pointerMove$.pipe(startWith(event))),\n                map(({clientX}) => this.getFractionFromEvents(clientX)),\n                takeUntil(this.pointerUp$),\n                repeat(),\n                takeUntilDestroyed(),\n            )\n            .subscribe((fraction) => {\n                const value = this.range.toValue(fraction);\n\n                this.range.processValue(value, activeThumb === 'right');\n            });\n    }\n\n    private getFractionFromEvents(clickClientX: number): number {\n        const hostRect = this.el.getBoundingClientRect();\n        const value = clickClientX - hostRect.left;\n        const total = hostRect.width;\n\n        return tuiClamp(tuiRound(value / total, TUI_FLOATING_PRECISION), 0, 1);\n    }\n\n    private detectActiveThumb(\n        clientX: number,\n        target: EventTarget | null,\n    ): 'left' | 'right' {\n        const [leftSliderRef, rightSliderRef] = this.range.slidersRefs;\n\n        switch (target) {\n            case leftSliderRef.nativeElement:\n                return 'left';\n            case rightSliderRef.nativeElement:\n                return 'right';\n            default:\n                return this.findNearestActiveThumb(clientX);\n        }\n    }\n\n    private findNearestActiveThumb(clientX: number): 'left' | 'right' {\n        const fraction = this.getFractionFromEvents(clientX);\n        const deltaLeft = fraction * 100 - this.range.left();\n        const deltaRight = fraction * 100 - 100 + this.range.right();\n\n        return Math.abs(deltaLeft) > Math.abs(deltaRight) ||\n            deltaRight > 0 ||\n            (this.range.left() === 0 && this.range.right() === 100)\n            ? 'right'\n            : 'left';\n    }\n}\n"]}
80
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-change.directive.js","sourceRoot":"","sources":["../../../../../projects/kit/components/range/range-change.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport {Directive, EventEmitter, inject, Output} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {tuiTypedFromEvent} from '@taiga-ui/cdk/observables';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiClamp, tuiRound} from '@taiga-ui/cdk/utils/math';\nimport {TUI_FLOATING_PRECISION} from '@taiga-ui/kit/components/slider';\nimport {filter, map, merge, repeat, startWith, switchMap, takeUntil, tap} from 'rxjs';\n\nimport {TuiRange} from './range.component';\n\n@Directive({\n    standalone: true,\n})\nexport class TuiRangeChange {\n    private readonly doc = inject(DOCUMENT);\n    private readonly el = tuiInjectElement();\n    private readonly range = inject(TuiRange);\n\n    /**\n     * TODO replace with pointer events (when all supported browsers can handle them).\n     * Don't forget to use setPointerCapture instead of listening all doc events\n     */\n    private readonly pointerDown$ = tuiTypedFromEvent(this.el, 'pointerdown', {\n        passive: true,\n        capture: true,\n    });\n\n    private readonly pointerMove$ = merge(\n        tuiTypedFromEvent(this.doc, 'touchmove').pipe(\n            filter(({touches}) => touches.length === 1),\n            map(({touches}) => touches[0]),\n            filter((event): event is Touch => !!event),\n        ),\n        tuiTypedFromEvent(this.doc, 'mousemove'),\n    );\n\n    private readonly pointerUp$ = merge(\n        tuiTypedFromEvent(this.doc, 'touchend', {passive: true}),\n        tuiTypedFromEvent(this.doc, 'mouseup', {passive: true}),\n    );\n\n    @Output()\n    public readonly activeThumbChange = new EventEmitter<'left' | 'right'>();\n\n    constructor() {\n        let activeThumb: 'left' | 'right';\n\n        this.pointerDown$\n            .pipe(\n                tap(({clientX, target}) => {\n                    activeThumb = this.detectActiveThumb(clientX, target);\n                    this.activeThumbChange.emit(activeThumb);\n\n                    if (this.range.focusable) {\n                        this.el.focus();\n                    }\n                }),\n                switchMap((event) => this.pointerMove$.pipe(startWith(event))),\n                map(({clientX}) => this.getFractionFromEvents(clientX ?? 0)),\n                takeUntil(this.pointerUp$),\n                repeat(),\n                takeUntilDestroyed(),\n            )\n            .subscribe((fraction) => {\n                const value = this.range.toValue(fraction);\n\n                this.range.processValue(value, activeThumb === 'right');\n            });\n    }\n\n    private getFractionFromEvents(clickClientX: number): number {\n        const hostRect = this.el.getBoundingClientRect();\n        const value = clickClientX - hostRect.left;\n        const total = hostRect.width;\n\n        return tuiClamp(tuiRound(value / total, TUI_FLOATING_PRECISION), 0, 1);\n    }\n\n    private detectActiveThumb(\n        clientX: number,\n        target: EventTarget | null,\n    ): 'left' | 'right' {\n        const [leftSliderRef, rightSliderRef] = this.range.slidersRefs;\n\n        switch (target) {\n            case leftSliderRef?.nativeElement:\n                return 'left';\n            case rightSliderRef?.nativeElement:\n                return 'right';\n            default:\n                return this.findNearestActiveThumb(clientX);\n        }\n    }\n\n    private findNearestActiveThumb(clientX: number): 'left' | 'right' {\n        const fraction = this.getFractionFromEvents(clientX);\n        const deltaLeft = fraction * 100 - this.range.left();\n        const deltaRight = fraction * 100 - 100 + this.range.right();\n\n        return Math.abs(deltaLeft) > Math.abs(deltaRight) ||\n            deltaRight > 0 ||\n            (this.range.left() === 0 && this.range.right() === 100)\n            ? 'right'\n            : 'left';\n    }\n}\n"]}
@@ -60,8 +60,8 @@ class TuiRange extends TuiControl {
60
60
  }
61
61
  changeByStep(coefficient, target) {
62
62
  const [sliderLeftRef, sliderRightRef] = this.slidersRefs;
63
- const leftThumbElement = sliderLeftRef.nativeElement;
64
- const rightThumbElement = sliderRightRef.nativeElement;
63
+ const leftThumbElement = sliderLeftRef?.nativeElement;
64
+ const rightThumbElement = sliderRightRef?.nativeElement;
65
65
  const isRightThumb = target === this.el
66
66
  ? this.lastActiveThumb === 'right'
67
67
  : target === rightThumbElement;
@@ -151,4 +151,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
151
151
  type: ViewChildren,
152
152
  args: [TuiSliderComponent, { read: ElementRef }]
153
153
  }], computePureKeySteps: [] } });
154
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/range/range.component.ts","../../../../../projects/kit/components/range/range.template.html"],"names":[],"mappings":"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","sourcesContent":["import type {OnChanges, QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    ElementRef,\n    inject,\n    Input,\n    signal,\n    ViewChildren,\n} from '@angular/core';\nimport {FormsModule} from '@angular/forms';\nimport {TuiControl} from '@taiga-ui/cdk/classes';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {tuiFallbackValueProvider} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiClamp, tuiQuantize} from '@taiga-ui/cdk/utils/math';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiSizeS} from '@taiga-ui/core/types';\nimport type {TuiKeySteps} from '@taiga-ui/kit/components/slider';\nimport {\n    TUI_SLIDER_OPTIONS,\n    tuiKeyStepValueToPercentage,\n    tuiPercentageToKeyStepValue,\n    TuiSlider,\n    TuiSliderComponent,\n} from '@taiga-ui/kit/components/slider';\n\nimport {TuiRangeChange} from './range-change.directive';\n\n@Component({\n    standalone: true,\n    selector: 'tui-range',\n    imports: [TuiSlider, FormsModule],\n    templateUrl: './range.template.html',\n    styleUrls: ['./range.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiFallbackValueProvider([0, 0])],\n    hostDirectives: [\n        {\n            directive: TuiRangeChange,\n            outputs: ['activeThumbChange'],\n        },\n    ],\n    host: {\n        '[attr.data-size]': 'size',\n        '[attr.tabindex]': '-1',\n        '[attr.aria-disabled]': 'disabled()',\n        '[style.--left.%]': 'left()',\n        '[style.--right.%]': 'right()',\n        '[style.background]': 'options.trackColor',\n        '[class._disabled]': 'disabled()',\n        '(focusout)': 'onTouched()',\n        '(keydown.arrowUp.prevent)': 'changeByStep(1, $event.target)',\n        '(keydown.arrowRight.prevent)': 'changeByStep(1, $event.target)',\n        '(keydown.arrowLeft.prevent)': 'changeByStep(-1, $event.target)',\n        '(keydown.arrowDown.prevent)': 'changeByStep(-1, $event.target)',\n    },\n})\nexport class TuiRange extends TuiControl<[number, number]> implements OnChanges {\n    // TODO: refactor to signal inputs after Angular update\n    private readonly changes = signal(1);\n    private readonly el = tuiInjectElement();\n\n    protected readonly options = inject(TUI_SLIDER_OPTIONS);\n    protected lastActiveThumb: 'left' | 'right' = 'right';\n\n    @Input()\n    public min = 0;\n\n    @Input()\n    public max = 100;\n\n    @Input()\n    public step = 1;\n\n    @Input()\n    public size: TuiSizeS = this.options.size;\n\n    @Input()\n    public segments = 1;\n\n    @Input()\n    public keySteps: TuiKeySteps | null = null;\n\n    @Input()\n    public focusable = true;\n\n    @Input()\n    public margin = 0;\n\n    @Input()\n    public limit = Infinity;\n\n    @ViewChildren(TuiSliderComponent, {read: ElementRef})\n    public readonly slidersRefs: QueryList<ElementRef<HTMLInputElement>> = EMPTY_QUERY;\n\n    public readonly left = computed(() => this.toPercent(this.value()[0]));\n    public readonly right = computed(() => 100 - this.toPercent(this.value()[1]));\n\n    public ngOnChanges(): void {\n        this.changes.set(this.changes() + 1);\n    }\n\n    public processValue(value: number, right: boolean): void {\n        if (right) {\n            this.updateEnd(value);\n        } else {\n            this.updateStart(value);\n        }\n\n        this.lastActiveThumb = right ? 'right' : 'left';\n    }\n\n    public toValue(fraction: number): number {\n        return tuiPercentageToKeyStepValue(\n            tuiClamp(tuiQuantize(fraction, this.fractionStep), 0, 1) * 100,\n            this.computedKeySteps,\n        );\n    }\n\n    protected get fractionStep(): number {\n        return this.step / (this.max - this.min);\n    }\n\n    protected get computedKeySteps(): TuiKeySteps {\n        return this.computePureKeySteps(this.keySteps, this.min, this.max);\n    }\n\n    protected get segmentWidthRatio(): number {\n        return 1 / this.segments;\n    }\n\n    protected changeByStep(coefficient: number, target: HTMLElement): void {\n        const [sliderLeftRef, sliderRightRef] = this.slidersRefs;\n        const leftThumbElement = sliderLeftRef.nativeElement;\n        const rightThumbElement = sliderRightRef.nativeElement;\n\n        const isRightThumb =\n            target === this.el\n                ? this.lastActiveThumb === 'right'\n                : target === rightThumbElement;\n        const activeThumbElement = isRightThumb ? rightThumbElement : leftThumbElement;\n        const previousValue = isRightThumb ? this.value()[1] : this.value()[0];\n        /** @bad TODO think about a solution without twice conversion */\n        const previousFraction = this.toPercent(previousValue) / 100;\n        const newFractionValue = previousFraction + coefficient * this.fractionStep;\n\n        this.processValue(this.toValue(newFractionValue), isRightThumb);\n        activeThumbElement?.focus();\n    }\n\n    protected toPercent(value: number): number {\n        return (\n            this.changes() && tuiKeyStepValueToPercentage(value, this.computedKeySteps)\n        );\n    }\n\n    @tuiPure\n    private computePureKeySteps(\n        keySteps: TuiKeySteps | null,\n        min: number,\n        max: number,\n    ): TuiKeySteps {\n        return (\n            keySteps || [\n                [0, min],\n                [100, max],\n            ]\n        );\n    }\n\n    private updateStart(value: number): void {\n        const newValue = Math.min(value, this.value()[1]);\n        const distance = this.value()[1] - newValue;\n\n        if (!this.checkDistance(distance)) {\n            return;\n        }\n\n        this.onChange([newValue, this.value()[1]]);\n    }\n\n    private updateEnd(value: number): void {\n        const newValue = Math.max(value, this.value()[0]);\n        const distance = newValue - this.value()[0];\n\n        if (!this.checkDistance(distance)) {\n            return;\n        }\n\n        this.onChange([this.value()[0], newValue]);\n    }\n\n    private checkDistance(distance: number): boolean {\n        return tuiClamp(distance, this.margin, this.limit) === distance;\n    }\n}\n","<div\n    class=\"t-track\"\n    [style.--bg-size-ratio]=\"1 - segmentWidthRatio\"\n    [style.--segment-width.%]=\"segmentWidthRatio * 100\"\n>\n    <input\n        automation-id=\"tui-range__left\"\n        readonly\n        step=\"any\"\n        tuiSlider\n        type=\"range\"\n        class=\"t-thumb\"\n        [disabled]=\"disabled()\"\n        [keySteps]=\"computedKeySteps\"\n        [max]=\"max\"\n        [min]=\"min\"\n        [ngModel]=\"value()[0]\"\n        [ngModelOptions]=\"{standalone: true}\"\n        [size]=\"size\"\n        [tabIndex]=\"focusable ? 0 : -1\"\n    />\n    <input\n        automation-id=\"tui-range__right\"\n        readonly\n        step=\"any\"\n        tuiSlider\n        type=\"range\"\n        class=\"t-thumb\"\n        [disabled]=\"disabled()\"\n        [keySteps]=\"computedKeySteps\"\n        [max]=\"max\"\n        [min]=\"min\"\n        [ngModel]=\"value()[1]\"\n        [ngModelOptions]=\"{standalone: true}\"\n        [size]=\"size\"\n        [tabIndex]=\"focusable ? 0 : -1\"\n    />\n</div>\n"]}
154
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/range/range.component.ts","../../../../../projects/kit/components/range/range.template.html"],"names":[],"mappings":"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","sourcesContent":["import type {OnChanges, QueryList} from '@angular/core';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    ElementRef,\n    inject,\n    Input,\n    signal,\n    ViewChildren,\n} from '@angular/core';\nimport {FormsModule} from '@angular/forms';\nimport {TuiControl} from '@taiga-ui/cdk/classes';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {tuiFallbackValueProvider} from '@taiga-ui/cdk/tokens';\nimport {tuiInjectElement} from '@taiga-ui/cdk/utils/dom';\nimport {tuiClamp, tuiQuantize} from '@taiga-ui/cdk/utils/math';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport type {TuiSizeS} from '@taiga-ui/core/types';\nimport type {TuiKeySteps} from '@taiga-ui/kit/components/slider';\nimport {\n    TUI_SLIDER_OPTIONS,\n    tuiKeyStepValueToPercentage,\n    tuiPercentageToKeyStepValue,\n    TuiSlider,\n    TuiSliderComponent,\n} from '@taiga-ui/kit/components/slider';\n\nimport {TuiRangeChange} from './range-change.directive';\n\n@Component({\n    standalone: true,\n    selector: 'tui-range',\n    imports: [TuiSlider, FormsModule],\n    templateUrl: './range.template.html',\n    styleUrls: ['./range.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [tuiFallbackValueProvider([0, 0])],\n    hostDirectives: [\n        {\n            directive: TuiRangeChange,\n            outputs: ['activeThumbChange'],\n        },\n    ],\n    host: {\n        '[attr.data-size]': 'size',\n        '[attr.tabindex]': '-1',\n        '[attr.aria-disabled]': 'disabled()',\n        '[style.--left.%]': 'left()',\n        '[style.--right.%]': 'right()',\n        '[style.background]': 'options.trackColor',\n        '[class._disabled]': 'disabled()',\n        '(focusout)': 'onTouched()',\n        '(keydown.arrowUp.prevent)': 'changeByStep(1, $event.target)',\n        '(keydown.arrowRight.prevent)': 'changeByStep(1, $event.target)',\n        '(keydown.arrowLeft.prevent)': 'changeByStep(-1, $event.target)',\n        '(keydown.arrowDown.prevent)': 'changeByStep(-1, $event.target)',\n    },\n})\nexport class TuiRange extends TuiControl<[number, number]> implements OnChanges {\n    // TODO: refactor to signal inputs after Angular update\n    private readonly changes = signal(1);\n    private readonly el = tuiInjectElement();\n\n    protected readonly options = inject(TUI_SLIDER_OPTIONS);\n    protected lastActiveThumb: 'left' | 'right' = 'right';\n\n    @Input()\n    public min = 0;\n\n    @Input()\n    public max = 100;\n\n    @Input()\n    public step = 1;\n\n    @Input()\n    public size: TuiSizeS = this.options.size;\n\n    @Input()\n    public segments = 1;\n\n    @Input()\n    public keySteps: TuiKeySteps | null = null;\n\n    @Input()\n    public focusable = true;\n\n    @Input()\n    public margin = 0;\n\n    @Input()\n    public limit = Infinity;\n\n    @ViewChildren(TuiSliderComponent, {read: ElementRef})\n    public readonly slidersRefs: QueryList<ElementRef<HTMLInputElement>> = EMPTY_QUERY;\n\n    public readonly left = computed(() => this.toPercent(this.value()[0]));\n    public readonly right = computed(() => 100 - this.toPercent(this.value()[1]));\n\n    public ngOnChanges(): void {\n        this.changes.set(this.changes() + 1);\n    }\n\n    public processValue(value: number, right: boolean): void {\n        if (right) {\n            this.updateEnd(value);\n        } else {\n            this.updateStart(value);\n        }\n\n        this.lastActiveThumb = right ? 'right' : 'left';\n    }\n\n    public toValue(fraction: number): number {\n        return tuiPercentageToKeyStepValue(\n            tuiClamp(tuiQuantize(fraction, this.fractionStep), 0, 1) * 100,\n            this.computedKeySteps,\n        );\n    }\n\n    protected get fractionStep(): number {\n        return this.step / (this.max - this.min);\n    }\n\n    protected get computedKeySteps(): TuiKeySteps {\n        return this.computePureKeySteps(this.keySteps, this.min, this.max);\n    }\n\n    protected get segmentWidthRatio(): number {\n        return 1 / this.segments;\n    }\n\n    protected changeByStep(coefficient: number, target: HTMLElement): void {\n        const [sliderLeftRef, sliderRightRef] = this.slidersRefs;\n        const leftThumbElement = sliderLeftRef?.nativeElement;\n        const rightThumbElement = sliderRightRef?.nativeElement;\n\n        const isRightThumb =\n            target === this.el\n                ? this.lastActiveThumb === 'right'\n                : target === rightThumbElement;\n        const activeThumbElement = isRightThumb ? rightThumbElement : leftThumbElement;\n        const previousValue = isRightThumb ? this.value()[1] : this.value()[0];\n        /** @bad TODO think about a solution without twice conversion */\n        const previousFraction = this.toPercent(previousValue) / 100;\n        const newFractionValue = previousFraction + coefficient * this.fractionStep;\n\n        this.processValue(this.toValue(newFractionValue), isRightThumb);\n        activeThumbElement?.focus();\n    }\n\n    protected toPercent(value: number): number {\n        return (\n            this.changes() && tuiKeyStepValueToPercentage(value, this.computedKeySteps)\n        );\n    }\n\n    @tuiPure\n    private computePureKeySteps(\n        keySteps: TuiKeySteps | null,\n        min: number,\n        max: number,\n    ): TuiKeySteps {\n        return (\n            keySteps || [\n                [0, min],\n                [100, max],\n            ]\n        );\n    }\n\n    private updateStart(value: number): void {\n        const newValue = Math.min(value, this.value()[1]);\n        const distance = this.value()[1] - newValue;\n\n        if (!this.checkDistance(distance)) {\n            return;\n        }\n\n        this.onChange([newValue, this.value()[1]]);\n    }\n\n    private updateEnd(value: number): void {\n        const newValue = Math.max(value, this.value()[0]);\n        const distance = newValue - this.value()[0];\n\n        if (!this.checkDistance(distance)) {\n            return;\n        }\n\n        this.onChange([this.value()[0], newValue]);\n    }\n\n    private checkDistance(distance: number): boolean {\n        return tuiClamp(distance, this.margin, this.limit) === distance;\n    }\n}\n","<div\n    class=\"t-track\"\n    [style.--bg-size-ratio]=\"1 - segmentWidthRatio\"\n    [style.--segment-width.%]=\"segmentWidthRatio * 100\"\n>\n    <input\n        automation-id=\"tui-range__left\"\n        readonly\n        step=\"any\"\n        tuiSlider\n        type=\"range\"\n        class=\"t-thumb\"\n        [disabled]=\"disabled()\"\n        [keySteps]=\"computedKeySteps\"\n        [max]=\"max\"\n        [min]=\"min\"\n        [ngModel]=\"value()[0]\"\n        [ngModelOptions]=\"{standalone: true}\"\n        [size]=\"size\"\n        [tabIndex]=\"focusable ? 0 : -1\"\n    />\n    <input\n        automation-id=\"tui-range__right\"\n        readonly\n        step=\"any\"\n        tuiSlider\n        type=\"range\"\n        class=\"t-thumb\"\n        [disabled]=\"disabled()\"\n        [keySteps]=\"computedKeySteps\"\n        [max]=\"max\"\n        [min]=\"min\"\n        [ngModel]=\"value()[1]\"\n        [ngModelOptions]=\"{standalone: true}\"\n        [size]=\"size\"\n        [tabIndex]=\"focusable ? 0 : -1\"\n    />\n</div>\n"]}