igniteui-angular 17.2.5 → 17.2.7

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 (61) hide show
  1. package/esm2022/lib/calendar/month-picker/month-picker.component.mjs +9 -1
  2. package/esm2022/lib/core/density.mjs +2 -1
  3. package/esm2022/lib/directives/for-of/for_of.directive.mjs +13 -2
  4. package/esm2022/lib/directives/for-of/for_of.sync.service.mjs +6 -1
  5. package/esm2022/lib/directives/tooltip/tooltip-target.directive.mjs +3 -2
  6. package/esm2022/lib/grids/common/events.mjs +1 -1
  7. package/esm2022/lib/grids/common/grid.interface.mjs +1 -1
  8. package/esm2022/lib/grids/common/strategy.mjs +2 -2
  9. package/esm2022/lib/grids/common/types.mjs +1 -1
  10. package/esm2022/lib/grids/grid-base.directive.mjs +45 -45
  11. package/esm2022/lib/grids/hierarchical-grid/hierarchical-grid.component.mjs +2 -2
  12. package/esm2022/lib/grids/selection/selection.service.mjs +12 -16
  13. package/esm2022/lib/simple-combo/simple-combo.component.mjs +7 -6
  14. package/esm2022/lib/slider/slider.component.mjs +10 -8
  15. package/esm2022/lib/slider/thumb/thumb-slider.component.mjs +6 -2
  16. package/fesm2022/igniteui-angular.mjs +104 -75
  17. package/fesm2022/igniteui-angular.mjs.map +1 -1
  18. package/lib/core/density.d.ts +1 -0
  19. package/lib/core/styles/components/bottom-nav/_bottom-nav-theme.scss +24 -12
  20. package/lib/core/styles/components/button/_button-theme.scss +9 -3
  21. package/lib/core/styles/components/grid/_excel-filtering-theme.scss +20 -0
  22. package/lib/core/styles/components/overlay/_overlay-theme.scss +6 -0
  23. package/lib/directives/for-of/for_of.directive.d.ts +5 -0
  24. package/lib/grids/common/events.d.ts +30 -30
  25. package/lib/grids/common/grid.interface.d.ts +48 -48
  26. package/lib/grids/common/strategy.d.ts +1 -1
  27. package/lib/grids/common/types.d.ts +2 -2
  28. package/lib/grids/grid-base.directive.d.ts +2 -1
  29. package/lib/slider/slider.component.d.ts +1 -1
  30. package/lib/slider/thumb/thumb-slider.component.d.ts +2 -1
  31. package/migrations/migration-collection.json +5 -0
  32. package/migrations/update-17_2_6/changes/theme-changes.json +11 -0
  33. package/migrations/update-17_2_6/index.d.ts +3 -0
  34. package/migrations/update-17_2_6/index.js +31 -0
  35. package/package.json +1 -1
  36. package/styles/igniteui-angular-dark.css +1 -1
  37. package/styles/igniteui-angular.css +1 -1
  38. package/styles/igniteui-bootstrap-dark.css +1 -1
  39. package/styles/igniteui-bootstrap-light.css +1 -1
  40. package/styles/igniteui-dark-green.css +1 -1
  41. package/styles/igniteui-fluent-dark-excel.css +1 -1
  42. package/styles/igniteui-fluent-dark-word.css +1 -1
  43. package/styles/igniteui-fluent-dark.css +1 -1
  44. package/styles/igniteui-fluent-light-excel.css +1 -1
  45. package/styles/igniteui-fluent-light-word.css +1 -1
  46. package/styles/igniteui-fluent-light.css +1 -1
  47. package/styles/igniteui-indigo-dark.css +1 -1
  48. package/styles/igniteui-indigo-light.css +1 -1
  49. package/styles/maps/igniteui-angular-dark.css.map +1 -1
  50. package/styles/maps/igniteui-angular.css.map +1 -1
  51. package/styles/maps/igniteui-bootstrap-dark.css.map +1 -1
  52. package/styles/maps/igniteui-bootstrap-light.css.map +1 -1
  53. package/styles/maps/igniteui-dark-green.css.map +1 -1
  54. package/styles/maps/igniteui-fluent-dark-excel.css.map +1 -1
  55. package/styles/maps/igniteui-fluent-dark-word.css.map +1 -1
  56. package/styles/maps/igniteui-fluent-dark.css.map +1 -1
  57. package/styles/maps/igniteui-fluent-light-excel.css.map +1 -1
  58. package/styles/maps/igniteui-fluent-light-word.css.map +1 -1
  59. package/styles/maps/igniteui-fluent-light.css.map +1 -1
  60. package/styles/maps/igniteui-indigo-dark.css.map +1 -1
  61. package/styles/maps/igniteui-indigo-light.css.map +1 -1
@@ -15,6 +15,11 @@ export class IgxForOfSyncService {
15
15
  */
16
16
  setMaster(directive, forced = false) {
17
17
  const orientation = directive.igxForScrollOrientation;
18
+ // in case master is not in dom, set a new master
19
+ const isMasterInDom = this._master.get(orientation)?.dc?.instance?._viewContainer.element.nativeElement.isConnected;
20
+ if (!isMasterInDom) {
21
+ forced = true;
22
+ }
18
23
  if (orientation && (forced || !this._master.has(orientation))) {
19
24
  this._master.set(orientation, directive);
20
25
  }
@@ -65,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
65
70
  providedIn: 'root',
66
71
  }]
67
72
  }] });
68
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9yX29mLnN5bmMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2lnbml0ZXVpLWFuZ3VsYXIvc3JjL2xpYi9kaXJlY3RpdmVzL2Zvci1vZi9mb3Jfb2Yuc3luYy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTzNDLE1BQU0sT0FBTyxtQkFBbUI7SUFIaEM7UUFLWSxZQUFPLEdBQW1ELElBQUksR0FBRyxFQUE2QyxDQUFDO0tBdUMxSDtJQXJDRzs7T0FFRztJQUNJLFFBQVEsQ0FBQyxTQUE0QztRQUN4RCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyx1QkFBdUIsQ0FBQyxLQUFLLFNBQVMsQ0FBQztJQUM3RSxDQUFDO0lBRUQ7O09BRUc7SUFDSSxTQUFTLENBQUMsU0FBNEMsRUFBRSxNQUFNLEdBQUcsS0FBSztRQUN6RSxNQUFNLFdBQVcsR0FBRyxTQUFTLENBQUMsdUJBQXVCLENBQUM7UUFDdEQsSUFBSSxXQUFXLElBQUksQ0FBQyxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLENBQUMsQ0FBQyxFQUFFO1lBQzNELElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFdBQVcsRUFBRSxTQUFTLENBQUMsQ0FBQztTQUM1QztJQUNMLENBQUM7SUFFRDs7T0FFRztJQUNJLFdBQVc7UUFDZCxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFRDs7T0FFRztJQUNJLFVBQVUsQ0FBQyxHQUFXO1FBQ3pCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsVUFBVSxDQUFDO0lBQzVDLENBQUM7SUFFRDs7T0FFRztJQUNJLFNBQVMsQ0FBQyxHQUFXO1FBQ3hCLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDLFNBQVMsQ0FBQztJQUNqRCxDQUFDOzhHQXhDUSxtQkFBbUI7a0hBQW5CLG1CQUFtQixjQUZoQixNQUFNOzsyRkFFVCxtQkFBbUI7a0JBSC9CLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCOztBQStDRCxNQUFNLE9BQU8seUJBQXlCO0lBSHRDO1FBSVksa0JBQWEsR0FBNEMsSUFBSSxHQUFHLEVBQWUsQ0FBQztLQVEzRjtJQVBVLGVBQWUsQ0FBQyxHQUFXLEVBQUUsTUFBa0M7UUFDbEUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFTSxlQUFlLENBQUMsR0FBVztRQUM5QixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7OEdBUlEseUJBQXlCO2tIQUF6Qix5QkFBeUIsY0FGdEIsTUFBTTs7MkZBRVQseUJBQXlCO2tCQUhyQyxVQUFVO21CQUFDO29CQUNSLFVBQVUsRUFBRSxNQUFNO2lCQUNyQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElneEdyaWRGb3JPZkRpcmVjdGl2ZSB9IGZyb20gJy4vZm9yX29mLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBWaXJ0dWFsSGVscGVyQmFzZURpcmVjdGl2ZSB9IGZyb20gJy4vYmFzZS5oZWxwZXIuY29tcG9uZW50JztcblxuQEluamVjdGFibGUoe1xuICAgIHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgSWd4Rm9yT2ZTeW5jU2VydmljZSB7XG5cbiAgICBwcml2YXRlIF9tYXN0ZXI6IE1hcDxzdHJpbmcsIElneEdyaWRGb3JPZkRpcmVjdGl2ZTxhbnksIGFueVtdPj4gPSBuZXcgTWFwPHN0cmluZywgSWd4R3JpZEZvck9mRGlyZWN0aXZlPGFueSwgYW55W10+PigpO1xuXG4gICAgLyoqXG4gICAgICogQGhpZGRlblxuICAgICAqL1xuICAgIHB1YmxpYyBpc01hc3RlcihkaXJlY3RpdmU6IElneEdyaWRGb3JPZkRpcmVjdGl2ZTxhbnksIGFueVtdPik6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5fbWFzdGVyLmdldChkaXJlY3RpdmUuaWd4Rm9yU2Nyb2xsT3JpZW50YXRpb24pID09PSBkaXJlY3RpdmU7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQGhpZGRlblxuICAgICAqL1xuICAgIHB1YmxpYyBzZXRNYXN0ZXIoZGlyZWN0aXZlOiBJZ3hHcmlkRm9yT2ZEaXJlY3RpdmU8YW55LCBhbnlbXT4sIGZvcmNlZCA9IGZhbHNlKSB7XG4gICAgICAgIGNvbnN0IG9yaWVudGF0aW9uID0gZGlyZWN0aXZlLmlneEZvclNjcm9sbE9yaWVudGF0aW9uO1xuICAgICAgICBpZiAob3JpZW50YXRpb24gJiYgKGZvcmNlZCB8fCAhdGhpcy5fbWFzdGVyLmhhcyhvcmllbnRhdGlvbikpKSB7XG4gICAgICAgICAgICB0aGlzLl9tYXN0ZXIuc2V0KG9yaWVudGF0aW9uLCBkaXJlY3RpdmUpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQGhpZGRlblxuICAgICAqL1xuICAgIHB1YmxpYyByZXNldE1hc3RlcigpIHtcbiAgICAgICAgdGhpcy5fbWFzdGVyLmNsZWFyKCk7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQGhpZGRlblxuICAgICAqL1xuICAgIHB1YmxpYyBzaXplc0NhY2hlKGRpcjogc3RyaW5nKTogbnVtYmVyW10ge1xuICAgICAgICByZXR1cm4gdGhpcy5fbWFzdGVyLmdldChkaXIpLnNpemVzQ2FjaGU7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogQGhpZGRlblxuICAgICAqL1xuICAgIHB1YmxpYyBjaHVua1NpemUoZGlyOiBzdHJpbmcpOiBudW1iZXIge1xuICAgICAgICByZXR1cm4gdGhpcy5fbWFzdGVyLmdldChkaXIpLnN0YXRlLmNodW5rU2l6ZTtcbiAgICB9XG59XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIElneEZvck9mU2Nyb2xsU3luY1NlcnZpY2Uge1xuICAgIHByaXZhdGUgX21hc3RlclNjcm9sbDogTWFwPHN0cmluZywgVmlydHVhbEhlbHBlckJhc2VEaXJlY3RpdmU+ID0gbmV3IE1hcDxzdHJpbmcsIGFueT4oKTtcbiAgICBwdWJsaWMgc2V0U2Nyb2xsTWFzdGVyKGRpcjogc3RyaW5nLCBzY3JvbGw6IFZpcnR1YWxIZWxwZXJCYXNlRGlyZWN0aXZlKSB7XG4gICAgICAgIHRoaXMuX21hc3RlclNjcm9sbC5zZXQoZGlyLCBzY3JvbGwpO1xuICAgIH1cblxuICAgIHB1YmxpYyBnZXRTY3JvbGxNYXN0ZXIoZGlyOiBzdHJpbmcpIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX21hc3RlclNjcm9sbC5nZXQoZGlyKTtcbiAgICB9XG59XG4iXX0=
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9yX29mLnN5bmMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2lnbml0ZXVpLWFuZ3VsYXIvc3JjL2xpYi9kaXJlY3RpdmVzL2Zvci1vZi9mb3Jfb2Yuc3luYy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTzNDLE1BQU0sT0FBTyxtQkFBbUI7SUFIaEM7UUFLWSxZQUFPLEdBQW1ELElBQUksR0FBRyxFQUE2QyxDQUFDO0tBNEMxSDtJQTFDRzs7T0FFRztJQUNJLFFBQVEsQ0FBQyxTQUE0QztRQUN4RCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFNBQVMsQ0FBQyx1QkFBdUIsQ0FBQyxLQUFLLFNBQVMsQ0FBQztJQUM3RSxDQUFDO0lBRUQ7O09BRUc7SUFDSSxTQUFTLENBQUMsU0FBNEMsRUFBRSxNQUFNLEdBQUcsS0FBSztRQUN6RSxNQUFNLFdBQVcsR0FBRyxTQUFTLENBQUMsdUJBQXVCLENBQUM7UUFDdEQsaURBQWlEO1FBQ2pELE1BQU0sYUFBYSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxFQUFFLEVBQUUsRUFBRSxRQUFRLEVBQUUsY0FBYyxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQUMsV0FBVyxDQUFDO1FBQ3BILElBQUksQ0FBQyxhQUFhLEVBQUU7WUFDaEIsTUFBTSxHQUFHLElBQUksQ0FBQztTQUNqQjtRQUNELElBQUksV0FBVyxJQUFJLENBQUMsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsV0FBVyxDQUFDLENBQUMsRUFBRTtZQUMzRCxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLEVBQUUsU0FBUyxDQUFDLENBQUM7U0FDNUM7SUFDTCxDQUFDO0lBRUQ7O09BRUc7SUFDSSxXQUFXO1FBQ2QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQ7O09BRUc7SUFDSSxVQUFVLENBQUMsR0FBVztRQUN6QixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLFVBQVUsQ0FBQztJQUM1QyxDQUFDO0lBRUQ7O09BRUc7SUFDSSxTQUFTLENBQUMsR0FBVztRQUN4QixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUM7SUFDakQsQ0FBQzs4R0E3Q1EsbUJBQW1CO2tIQUFuQixtQkFBbUIsY0FGaEIsTUFBTTs7MkZBRVQsbUJBQW1CO2tCQUgvQixVQUFVO21CQUFDO29CQUNSLFVBQVUsRUFBRSxNQUFNO2lCQUNyQjs7QUFvREQsTUFBTSxPQUFPLHlCQUF5QjtJQUh0QztRQUlZLGtCQUFhLEdBQTRDLElBQUksR0FBRyxFQUFlLENBQUM7S0FRM0Y7SUFQVSxlQUFlLENBQUMsR0FBVyxFQUFFLE1BQWtDO1FBQ2xFLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQUMsQ0FBQztJQUN4QyxDQUFDO0lBRU0sZUFBZSxDQUFDLEdBQVc7UUFDOUIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUN2QyxDQUFDOzhHQVJRLHlCQUF5QjtrSEFBekIseUJBQXlCLGNBRnRCLE1BQU07OzJGQUVULHlCQUF5QjtrQkFIckMsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJZ3hHcmlkRm9yT2ZEaXJlY3RpdmUgfSBmcm9tICcuL2Zvcl9vZi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgVmlydHVhbEhlbHBlckJhc2VEaXJlY3RpdmUgfSBmcm9tICcuL2Jhc2UuaGVscGVyLmNvbXBvbmVudCc7XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCcsXG59KVxuZXhwb3J0IGNsYXNzIElneEZvck9mU3luY1NlcnZpY2Uge1xuXG4gICAgcHJpdmF0ZSBfbWFzdGVyOiBNYXA8c3RyaW5nLCBJZ3hHcmlkRm9yT2ZEaXJlY3RpdmU8YW55LCBhbnlbXT4+ID0gbmV3IE1hcDxzdHJpbmcsIElneEdyaWRGb3JPZkRpcmVjdGl2ZTxhbnksIGFueVtdPj4oKTtcblxuICAgIC8qKlxuICAgICAqIEBoaWRkZW5cbiAgICAgKi9cbiAgICBwdWJsaWMgaXNNYXN0ZXIoZGlyZWN0aXZlOiBJZ3hHcmlkRm9yT2ZEaXJlY3RpdmU8YW55LCBhbnlbXT4pOiBib29sZWFuIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX21hc3Rlci5nZXQoZGlyZWN0aXZlLmlneEZvclNjcm9sbE9yaWVudGF0aW9uKSA9PT0gZGlyZWN0aXZlO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEBoaWRkZW5cbiAgICAgKi9cbiAgICBwdWJsaWMgc2V0TWFzdGVyKGRpcmVjdGl2ZTogSWd4R3JpZEZvck9mRGlyZWN0aXZlPGFueSwgYW55W10+LCBmb3JjZWQgPSBmYWxzZSkge1xuICAgICAgICBjb25zdCBvcmllbnRhdGlvbiA9IGRpcmVjdGl2ZS5pZ3hGb3JTY3JvbGxPcmllbnRhdGlvbjtcbiAgICAgICAgLy8gaW4gY2FzZSBtYXN0ZXIgaXMgbm90IGluIGRvbSwgc2V0IGEgbmV3IG1hc3RlclxuICAgICAgICBjb25zdCBpc01hc3RlckluRG9tID0gdGhpcy5fbWFzdGVyLmdldChvcmllbnRhdGlvbik/LmRjPy5pbnN0YW5jZT8uX3ZpZXdDb250YWluZXIuZWxlbWVudC5uYXRpdmVFbGVtZW50LmlzQ29ubmVjdGVkO1xuICAgICAgICBpZiAoIWlzTWFzdGVySW5Eb20pIHtcbiAgICAgICAgICAgIGZvcmNlZCA9IHRydWU7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKG9yaWVudGF0aW9uICYmIChmb3JjZWQgfHwgIXRoaXMuX21hc3Rlci5oYXMob3JpZW50YXRpb24pKSkge1xuICAgICAgICAgICAgdGhpcy5fbWFzdGVyLnNldChvcmllbnRhdGlvbiwgZGlyZWN0aXZlKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEBoaWRkZW5cbiAgICAgKi9cbiAgICBwdWJsaWMgcmVzZXRNYXN0ZXIoKSB7XG4gICAgICAgIHRoaXMuX21hc3Rlci5jbGVhcigpO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEBoaWRkZW5cbiAgICAgKi9cbiAgICBwdWJsaWMgc2l6ZXNDYWNoZShkaXI6IHN0cmluZyk6IG51bWJlcltdIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX21hc3Rlci5nZXQoZGlyKS5zaXplc0NhY2hlO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIEBoaWRkZW5cbiAgICAgKi9cbiAgICBwdWJsaWMgY2h1bmtTaXplKGRpcjogc3RyaW5nKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuX21hc3Rlci5nZXQoZGlyKS5zdGF0ZS5jaHVua1NpemU7XG4gICAgfVxufVxuXG5ASW5qZWN0YWJsZSh7XG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxufSlcbmV4cG9ydCBjbGFzcyBJZ3hGb3JPZlNjcm9sbFN5bmNTZXJ2aWNlIHtcbiAgICBwcml2YXRlIF9tYXN0ZXJTY3JvbGw6IE1hcDxzdHJpbmcsIFZpcnR1YWxIZWxwZXJCYXNlRGlyZWN0aXZlPiA9IG5ldyBNYXA8c3RyaW5nLCBhbnk+KCk7XG4gICAgcHVibGljIHNldFNjcm9sbE1hc3RlcihkaXI6IHN0cmluZywgc2Nyb2xsOiBWaXJ0dWFsSGVscGVyQmFzZURpcmVjdGl2ZSkge1xuICAgICAgICB0aGlzLl9tYXN0ZXJTY3JvbGwuc2V0KGRpciwgc2Nyb2xsKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgZ2V0U2Nyb2xsTWFzdGVyKGRpcjogc3RyaW5nKSB7XG4gICAgICAgIHJldHVybiB0aGlzLl9tYXN0ZXJTY3JvbGwuZ2V0KGRpcik7XG4gICAgfVxufVxuIl19
@@ -5,6 +5,7 @@ import { takeUntil } from 'rxjs/operators';
5
5
  import { AutoPositionStrategy, HorizontalAlignment } from '../../services/public_api';
6
6
  import { IgxToggleActionDirective } from '../toggle/toggle.directive';
7
7
  import { IgxTooltipComponent } from './tooltip.component';
8
+ import { IgxTooltipDirective } from './tooltip.directive';
8
9
  import { fadeOut, scaleInCenter } from 'igniteui-angular/animations';
9
10
  import * as i0 from "@angular/core";
10
11
  import * as i1 from "../../core/navigation";
@@ -27,7 +28,7 @@ export class IgxTooltipTargetDirective extends IgxToggleActionDirective {
27
28
  * @hidden
28
29
  */
29
30
  set target(target) {
30
- if (target !== null && target !== '') {
31
+ if (target instanceof IgxTooltipDirective) {
31
32
  this._target = target;
32
33
  }
33
34
  }
@@ -381,4 +382,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
381
382
  type: HostListener,
382
383
  args: ['document:touchstart', ['$event']]
383
384
  }] } });
384
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-target.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/directives/tooltip/tooltip-target.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { useAnimation } from '@angular/animations';\nimport { Directive, OnInit, OnDestroy, Output, ElementRef, Optional, ViewContainerRef, HostListener, Input, EventEmitter, booleanAttribute } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { IgxNavigationService } from '../../core/navigation';\nimport { IBaseEventArgs } from '../../core/utils';\nimport { AutoPositionStrategy, HorizontalAlignment, PositionSettings } from '../../services/public_api';\nimport { IgxToggleActionDirective } from '../toggle/toggle.directive';\nimport { IgxTooltipComponent } from './tooltip.component';\nimport { IgxTooltipDirective } from './tooltip.directive';\nimport { fadeOut, scaleInCenter } from 'igniteui-angular/animations';\n\nexport interface ITooltipShowEventArgs extends IBaseEventArgs {\n    target: IgxTooltipTargetDirective;\n    tooltip: IgxTooltipDirective;\n    cancel: boolean;\n}\nexport interface ITooltipHideEventArgs extends IBaseEventArgs {\n    target: IgxTooltipTargetDirective;\n    tooltip: IgxTooltipDirective;\n    cancel: boolean;\n}\n\n/**\n * **Ignite UI for Angular Tooltip Target** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/tooltip)\n *\n * The Ignite UI for Angular Tooltip Target directive is used to mark an HTML element in the markup as one that has a tooltip.\n * The tooltip target is used in combination with the Ignite UI for Angular Tooltip by assigning the exported tooltip reference to the\n * target's selector property.\n *\n * Example:\n * ```html\n * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\">Hover me</button>\n * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n * ```\n */\n@Directive({\n    exportAs: 'tooltipTarget',\n    selector: '[igxTooltipTarget]',\n    standalone: true\n})\nexport class IgxTooltipTargetDirective extends IgxToggleActionDirective implements OnInit, OnDestroy {\n    /**\n     * Gets/sets the amount of milliseconds that should pass before showing the tooltip.\n     *\n     * ```typescript\n     * // get\n     * let tooltipShowDelay = this.tooltipTarget.showDelay;\n     * ```\n     *\n     * ```html\n     * <!--set-->\n     * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\" [showDelay]=\"1500\">Hover me</button>\n     * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n     * ```\n     */\n    @Input('showDelay')\n    public showDelay = 500;\n\n    /**\n     * Gets/sets the amount of milliseconds that should pass before hiding the tooltip.\n     *\n     * ```typescript\n     * // get\n     * let tooltipHideDelay = this.tooltipTarget.hideDelay;\n     * ```\n     *\n     * ```html\n     * <!--set-->\n     * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\" [hideDelay]=\"1500\">Hover me</button>\n     * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n     * ```\n     */\n    @Input('hideDelay')\n    public hideDelay = 500;\n\n    /**\n     * Specifies if the tooltip should not show when hovering its target with the mouse. (defaults to false)\n     * While setting this property to 'true' will disable the user interactions that shows/hides the tooltip,\n     * the developer will still be able to show/hide the tooltip through the API.\n     *\n     * ```typescript\n     * // get\n     * let tooltipDisabledValue = this.tooltipTarget.tooltipDisabled;\n     * ```\n     *\n     * ```html\n     * <!--set-->\n     * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\" [tooltipDisabled]=\"true\">Hover me</button>\n     * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n     * ```\n     */\n    @Input({ alias: 'tooltipDisabled', transform: booleanAttribute })\n    public tooltipDisabled = false;\n\n    /**\n     * @hidden\n     */\n    @Input('igxTooltipTarget')\n    public override set target(target: any) {\n        if (target !== null && target !== '') {\n            this._target = target;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public override get target(): any {\n        if (typeof this._target === 'string') {\n            return this._navigationService.get(this._target);\n        }\n        return this._target;\n    }\n\n    /**\n    * @hidden\n    */\n    @Input()\n    public set tooltip(content: any) {\n        if (!this.target && (typeof content === 'string' || content instanceof String)) {\n            const tooltipComponent = this._viewContainerRef.createComponent(IgxTooltipComponent);\n            tooltipComponent.instance.content = content as string;\n\n            this._target = tooltipComponent.instance.tooltip;\n        }\n    }\n\n    /**\n     * Gets the respective native element of the directive.\n     *\n     * ```typescript\n     * let tooltipTargetElement = this.tooltipTarget.nativeElement;\n     * ```\n     */\n    public get nativeElement() {\n        return this._element.nativeElement;\n    }\n\n    /**\n     * Indicates if the tooltip that is is associated with this target is currently hidden.\n     *\n     * ```typescript\n     * let tooltipHiddenValue = this.tooltipTarget.tooltipHidden;\n     * ```\n     */\n    public get tooltipHidden(): boolean {\n        return !this.target || this.target.collapsed;\n    }\n\n    /**\n     * Emits an event when the tooltip that is associated with this target starts showing.\n     * This event is fired before the start of the countdown to showing the tooltip.\n     *\n     * ```typescript\n     * tooltipShowing(args: ITooltipShowEventArgs) {\n     *    alert(\"Tooltip started showing!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\" (tooltipShow)='tooltipShowing($event)'>Hover me</button>\n     * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n     * ```\n     */\n    @Output()\n    public tooltipShow = new EventEmitter<ITooltipShowEventArgs>();\n\n    /**\n     * Emits an event when the tooltip that is associated with this target starts hiding.\n     * This event is fired before the start of the countdown to hiding the tooltip.\n     *\n     * ```typescript\n     * tooltipHiding(args: ITooltipHideEventArgs) {\n     *    alert(\"Tooltip started hiding!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\" (tooltipHide)='tooltipHiding($event)'>Hover me</button>\n     * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n     * ```\n     */\n    @Output()\n    public tooltipHide = new EventEmitter<ITooltipHideEventArgs>();\n\n    private destroy$ = new Subject<void>();\n\n    constructor(private _element: ElementRef,\n        @Optional() private _navigationService: IgxNavigationService, private _viewContainerRef: ViewContainerRef) {\n        super(_element, _navigationService);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('click')\n    public override onClick() {\n        if (!this.target.collapsed) {\n            this.target.forceClose(this.mergedOverlaySettings);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('mouseenter')\n    public onMouseEnter() {\n        if (this.tooltipDisabled) {\n            return;\n        }\n\n        this.checkOutletAndOutsideClick();\n        const shouldReturn = this.preMouseEnterCheck();\n        if (shouldReturn) {\n            return;\n        }\n\n        const showingArgs = { target: this, tooltip: this.target, cancel: false };\n        this.tooltipShow.emit(showingArgs);\n\n        if (showingArgs.cancel) {\n            return;\n        }\n\n        this.target.toBeShown = true;\n        this.target.timeoutId = setTimeout(() => {\n            this.target.open(this.mergedOverlaySettings); // Call open() of IgxTooltipDirective\n            this.target.toBeShown = false;\n        }, this.showDelay);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('mouseleave')\n    public onMouseLeave() {\n        if (this.tooltipDisabled) {\n            return;\n        }\n\n        this.checkOutletAndOutsideClick();\n        const shouldReturn = this.preMouseLeaveCheck();\n        if (shouldReturn || this.target.collapsed) {\n            return;\n        }\n\n        this.target.toBeHidden = true;\n        this.target.timeoutId = setTimeout(() => {\n            this.target.close(); // Call close() of IgxTooltipDirective\n            this.target.toBeHidden = false;\n        }, this.hideDelay);\n\n\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('touchstart')\n    public onTouchStart() {\n        if (this.tooltipDisabled) {\n            return;\n        }\n\n        this.showTooltip();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('document:touchstart', ['$event'])\n    public onDocumentTouchStart(event) {\n        if (this.tooltipDisabled) {\n            return;\n        }\n\n        if (this.nativeElement !== event.target &&\n            !this.nativeElement.contains(event.target)\n        ) {\n            this.hideTooltip();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public override ngOnInit() {\n        super.ngOnInit();\n\n        const positionSettings: PositionSettings = {\n            horizontalDirection: HorizontalAlignment.Center,\n            horizontalStartPoint: HorizontalAlignment.Center,\n            openAnimation: useAnimation(scaleInCenter, { params: { duration: '150ms' } }),\n            closeAnimation: useAnimation(fadeOut, { params: { duration: '75ms' } })\n        };\n\n        this._overlayDefaults.positionStrategy = new AutoPositionStrategy(positionSettings);\n        this._overlayDefaults.closeOnOutsideClick = false;\n        this._overlayDefaults.closeOnEscape = true;\n\n        this.target.closing.pipe(takeUntil(this.destroy$)).subscribe((event) => {\n            const hidingArgs = { target: this, tooltip: this.target, cancel: false };\n            this.tooltipHide.emit(hidingArgs);\n\n            if (hidingArgs.cancel) {\n                event.cancel = true;\n            }\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnDestroy() {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    /**\n     * Shows the tooltip by respecting the 'showDelay' property.\n     *\n     * ```typescript\n     * this.tooltipTarget.showTooltip();\n     * ```\n     */\n    public showTooltip() {\n        clearTimeout(this.target.timeoutId);\n\n        if (!this.target.collapsed) {\n            //  if close animation has started finish it, or close the tooltip with no animation\n            this.target.forceClose(this.mergedOverlaySettings);\n            this.target.toBeHidden = false;\n        }\n\n        const showingArgs = { target: this, tooltip: this.target, cancel: false };\n        this.tooltipShow.emit(showingArgs);\n\n        if (showingArgs.cancel) {\n            return;\n        }\n\n        this.target.toBeShown = true;\n        this.target.timeoutId = setTimeout(() => {\n            this.target.open(this.mergedOverlaySettings); // Call open() of IgxTooltipDirective\n            this.target.toBeShown = false;\n        }, this.showDelay);\n    }\n\n    /**\n     * Hides the tooltip by respecting the 'hideDelay' property.\n     *\n     * ```typescript\n     * this.tooltipTarget.hideTooltip();\n     * ```\n     */\n    public hideTooltip() {\n        if (this.target.collapsed && this.target.toBeShown) {\n            clearTimeout(this.target.timeoutId);\n        }\n\n        if (this.target.collapsed || this.target.toBeHidden) {\n            return;\n        }\n\n        this.target.toBeHidden = true;\n        this.target.timeoutId = setTimeout(() => {\n            this.target.close(); // Call close() of IgxTooltipDirective\n            this.target.toBeHidden = false;\n        }, this.hideDelay);\n    }\n\n    private checkOutletAndOutsideClick() {\n        if (this.outlet) {\n            this._overlayDefaults.outlet = this.outlet;\n        }\n    }\n\n    private get mergedOverlaySettings() {\n        return Object.assign({}, this._overlayDefaults, this.overlaySettings);\n    }\n\n    // Return true if the execution in onMouseEnter should be terminated after this method\n    private preMouseEnterCheck() {\n        // If tooltip is about to be opened\n        if (this.target.toBeShown) {\n            clearTimeout(this.target.timeoutId);\n            this.target.toBeShown = false;\n        }\n\n        // If Tooltip is opened or about to be hidden\n        if (!this.target.collapsed || this.target.toBeHidden) {\n            clearTimeout(this.target.timeoutId);\n\n            //  if close animation has started finish it, or close the tooltip with no animation\n            this.target.forceClose(this.mergedOverlaySettings);\n            this.target.toBeHidden = false;\n        }\n\n        return false;\n    }\n\n    // Return true if the execution in onMouseLeave should be terminated after this method\n    private preMouseLeaveCheck(): boolean {\n        clearTimeout(this.target.timeoutId);\n\n        // If tooltip is about to be opened\n        if (this.target.toBeShown) {\n            this.target.toBeShown = false;\n            this.target.toBeHidden = false;\n            return true;\n        }\n\n        return false;\n    }\n}\n"]}
385
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip-target.directive.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/directives/tooltip/tooltip-target.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { useAnimation } from '@angular/animations';\nimport { Directive, OnInit, OnDestroy, Output, ElementRef, Optional, ViewContainerRef, HostListener, Input, EventEmitter, booleanAttribute } from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { IgxNavigationService } from '../../core/navigation';\nimport { IBaseEventArgs } from '../../core/utils';\nimport { AutoPositionStrategy, HorizontalAlignment, PositionSettings } from '../../services/public_api';\nimport { IgxToggleActionDirective } from '../toggle/toggle.directive';\nimport { IgxTooltipComponent } from './tooltip.component';\nimport { IgxTooltipDirective } from './tooltip.directive';\nimport { fadeOut, scaleInCenter } from 'igniteui-angular/animations';\n\nexport interface ITooltipShowEventArgs extends IBaseEventArgs {\n    target: IgxTooltipTargetDirective;\n    tooltip: IgxTooltipDirective;\n    cancel: boolean;\n}\nexport interface ITooltipHideEventArgs extends IBaseEventArgs {\n    target: IgxTooltipTargetDirective;\n    tooltip: IgxTooltipDirective;\n    cancel: boolean;\n}\n\n/**\n * **Ignite UI for Angular Tooltip Target** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/tooltip)\n *\n * The Ignite UI for Angular Tooltip Target directive is used to mark an HTML element in the markup as one that has a tooltip.\n * The tooltip target is used in combination with the Ignite UI for Angular Tooltip by assigning the exported tooltip reference to the\n * target's selector property.\n *\n * Example:\n * ```html\n * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\">Hover me</button>\n * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n * ```\n */\n@Directive({\n    exportAs: 'tooltipTarget',\n    selector: '[igxTooltipTarget]',\n    standalone: true\n})\nexport class IgxTooltipTargetDirective extends IgxToggleActionDirective implements OnInit, OnDestroy {\n    /**\n     * Gets/sets the amount of milliseconds that should pass before showing the tooltip.\n     *\n     * ```typescript\n     * // get\n     * let tooltipShowDelay = this.tooltipTarget.showDelay;\n     * ```\n     *\n     * ```html\n     * <!--set-->\n     * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\" [showDelay]=\"1500\">Hover me</button>\n     * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n     * ```\n     */\n    @Input('showDelay')\n    public showDelay = 500;\n\n    /**\n     * Gets/sets the amount of milliseconds that should pass before hiding the tooltip.\n     *\n     * ```typescript\n     * // get\n     * let tooltipHideDelay = this.tooltipTarget.hideDelay;\n     * ```\n     *\n     * ```html\n     * <!--set-->\n     * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\" [hideDelay]=\"1500\">Hover me</button>\n     * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n     * ```\n     */\n    @Input('hideDelay')\n    public hideDelay = 500;\n\n    /**\n     * Specifies if the tooltip should not show when hovering its target with the mouse. (defaults to false)\n     * While setting this property to 'true' will disable the user interactions that shows/hides the tooltip,\n     * the developer will still be able to show/hide the tooltip through the API.\n     *\n     * ```typescript\n     * // get\n     * let tooltipDisabledValue = this.tooltipTarget.tooltipDisabled;\n     * ```\n     *\n     * ```html\n     * <!--set-->\n     * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\" [tooltipDisabled]=\"true\">Hover me</button>\n     * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n     * ```\n     */\n    @Input({ alias: 'tooltipDisabled', transform: booleanAttribute })\n    public tooltipDisabled = false;\n\n    /**\n     * @hidden\n     */\n    @Input('igxTooltipTarget')\n    public override set target(target: any) {\n        if (target instanceof IgxTooltipDirective) {\n            this._target = target;\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public override get target(): any {\n        if (typeof this._target === 'string') {\n            return this._navigationService.get(this._target);\n        }\n        return this._target;\n    }\n\n    /**\n    * @hidden\n    */\n    @Input()\n    public set tooltip(content: any) {\n        if (!this.target && (typeof content === 'string' || content instanceof String)) {\n            const tooltipComponent = this._viewContainerRef.createComponent(IgxTooltipComponent);\n            tooltipComponent.instance.content = content as string;\n\n            this._target = tooltipComponent.instance.tooltip;\n        }\n    }\n\n    /**\n     * Gets the respective native element of the directive.\n     *\n     * ```typescript\n     * let tooltipTargetElement = this.tooltipTarget.nativeElement;\n     * ```\n     */\n    public get nativeElement() {\n        return this._element.nativeElement;\n    }\n\n    /**\n     * Indicates if the tooltip that is is associated with this target is currently hidden.\n     *\n     * ```typescript\n     * let tooltipHiddenValue = this.tooltipTarget.tooltipHidden;\n     * ```\n     */\n    public get tooltipHidden(): boolean {\n        return !this.target || this.target.collapsed;\n    }\n\n    /**\n     * Emits an event when the tooltip that is associated with this target starts showing.\n     * This event is fired before the start of the countdown to showing the tooltip.\n     *\n     * ```typescript\n     * tooltipShowing(args: ITooltipShowEventArgs) {\n     *    alert(\"Tooltip started showing!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\" (tooltipShow)='tooltipShowing($event)'>Hover me</button>\n     * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n     * ```\n     */\n    @Output()\n    public tooltipShow = new EventEmitter<ITooltipShowEventArgs>();\n\n    /**\n     * Emits an event when the tooltip that is associated with this target starts hiding.\n     * This event is fired before the start of the countdown to hiding the tooltip.\n     *\n     * ```typescript\n     * tooltipHiding(args: ITooltipHideEventArgs) {\n     *    alert(\"Tooltip started hiding!\");\n     * }\n     * ```\n     *\n     * ```html\n     * <button type=\"button\" igxButton [igxTooltipTarget]=\"tooltipRef\" (tooltipHide)='tooltipHiding($event)'>Hover me</button>\n     * <span #tooltipRef=\"tooltip\" igxTooltip>Hello there, I am a tooltip!</span>\n     * ```\n     */\n    @Output()\n    public tooltipHide = new EventEmitter<ITooltipHideEventArgs>();\n\n    private destroy$ = new Subject<void>();\n\n    constructor(private _element: ElementRef,\n        @Optional() private _navigationService: IgxNavigationService, private _viewContainerRef: ViewContainerRef) {\n        super(_element, _navigationService);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('click')\n    public override onClick() {\n        if (!this.target.collapsed) {\n            this.target.forceClose(this.mergedOverlaySettings);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('mouseenter')\n    public onMouseEnter() {\n        if (this.tooltipDisabled) {\n            return;\n        }\n\n        this.checkOutletAndOutsideClick();\n        const shouldReturn = this.preMouseEnterCheck();\n        if (shouldReturn) {\n            return;\n        }\n\n        const showingArgs = { target: this, tooltip: this.target, cancel: false };\n        this.tooltipShow.emit(showingArgs);\n\n        if (showingArgs.cancel) {\n            return;\n        }\n\n        this.target.toBeShown = true;\n        this.target.timeoutId = setTimeout(() => {\n            this.target.open(this.mergedOverlaySettings); // Call open() of IgxTooltipDirective\n            this.target.toBeShown = false;\n        }, this.showDelay);\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('mouseleave')\n    public onMouseLeave() {\n        if (this.tooltipDisabled) {\n            return;\n        }\n\n        this.checkOutletAndOutsideClick();\n        const shouldReturn = this.preMouseLeaveCheck();\n        if (shouldReturn || this.target.collapsed) {\n            return;\n        }\n\n        this.target.toBeHidden = true;\n        this.target.timeoutId = setTimeout(() => {\n            this.target.close(); // Call close() of IgxTooltipDirective\n            this.target.toBeHidden = false;\n        }, this.hideDelay);\n\n\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('touchstart')\n    public onTouchStart() {\n        if (this.tooltipDisabled) {\n            return;\n        }\n\n        this.showTooltip();\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('document:touchstart', ['$event'])\n    public onDocumentTouchStart(event) {\n        if (this.tooltipDisabled) {\n            return;\n        }\n\n        if (this.nativeElement !== event.target &&\n            !this.nativeElement.contains(event.target)\n        ) {\n            this.hideTooltip();\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public override ngOnInit() {\n        super.ngOnInit();\n\n        const positionSettings: PositionSettings = {\n            horizontalDirection: HorizontalAlignment.Center,\n            horizontalStartPoint: HorizontalAlignment.Center,\n            openAnimation: useAnimation(scaleInCenter, { params: { duration: '150ms' } }),\n            closeAnimation: useAnimation(fadeOut, { params: { duration: '75ms' } })\n        };\n\n        this._overlayDefaults.positionStrategy = new AutoPositionStrategy(positionSettings);\n        this._overlayDefaults.closeOnOutsideClick = false;\n        this._overlayDefaults.closeOnEscape = true;\n\n        this.target.closing.pipe(takeUntil(this.destroy$)).subscribe((event) => {\n            const hidingArgs = { target: this, tooltip: this.target, cancel: false };\n            this.tooltipHide.emit(hidingArgs);\n\n            if (hidingArgs.cancel) {\n                event.cancel = true;\n            }\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    public ngOnDestroy() {\n        this.destroy$.next();\n        this.destroy$.complete();\n    }\n\n    /**\n     * Shows the tooltip by respecting the 'showDelay' property.\n     *\n     * ```typescript\n     * this.tooltipTarget.showTooltip();\n     * ```\n     */\n    public showTooltip() {\n        clearTimeout(this.target.timeoutId);\n\n        if (!this.target.collapsed) {\n            //  if close animation has started finish it, or close the tooltip with no animation\n            this.target.forceClose(this.mergedOverlaySettings);\n            this.target.toBeHidden = false;\n        }\n\n        const showingArgs = { target: this, tooltip: this.target, cancel: false };\n        this.tooltipShow.emit(showingArgs);\n\n        if (showingArgs.cancel) {\n            return;\n        }\n\n        this.target.toBeShown = true;\n        this.target.timeoutId = setTimeout(() => {\n            this.target.open(this.mergedOverlaySettings); // Call open() of IgxTooltipDirective\n            this.target.toBeShown = false;\n        }, this.showDelay);\n    }\n\n    /**\n     * Hides the tooltip by respecting the 'hideDelay' property.\n     *\n     * ```typescript\n     * this.tooltipTarget.hideTooltip();\n     * ```\n     */\n    public hideTooltip() {\n        if (this.target.collapsed && this.target.toBeShown) {\n            clearTimeout(this.target.timeoutId);\n        }\n\n        if (this.target.collapsed || this.target.toBeHidden) {\n            return;\n        }\n\n        this.target.toBeHidden = true;\n        this.target.timeoutId = setTimeout(() => {\n            this.target.close(); // Call close() of IgxTooltipDirective\n            this.target.toBeHidden = false;\n        }, this.hideDelay);\n    }\n\n    private checkOutletAndOutsideClick() {\n        if (this.outlet) {\n            this._overlayDefaults.outlet = this.outlet;\n        }\n    }\n\n    private get mergedOverlaySettings() {\n        return Object.assign({}, this._overlayDefaults, this.overlaySettings);\n    }\n\n    // Return true if the execution in onMouseEnter should be terminated after this method\n    private preMouseEnterCheck() {\n        // If tooltip is about to be opened\n        if (this.target.toBeShown) {\n            clearTimeout(this.target.timeoutId);\n            this.target.toBeShown = false;\n        }\n\n        // If Tooltip is opened or about to be hidden\n        if (!this.target.collapsed || this.target.toBeHidden) {\n            clearTimeout(this.target.timeoutId);\n\n            //  if close animation has started finish it, or close the tooltip with no animation\n            this.target.forceClose(this.mergedOverlaySettings);\n            this.target.toBeHidden = false;\n        }\n\n        return false;\n    }\n\n    // Return true if the execution in onMouseLeave should be terminated after this method\n    private preMouseLeaveCheck(): boolean {\n        clearTimeout(this.target.timeoutId);\n\n        // If tooltip is about to be opened\n        if (this.target.toBeShown) {\n            this.target.toBeShown = false;\n            this.target.toBeHidden = false;\n            return true;\n        }\n\n        return false;\n    }\n}\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"events.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/common/events.ts"],"names":[],"mappings":"","sourcesContent":["import { IBaseEventArgs, CancelableEventArgs } from '../../core/utils';\nimport { GridKeydownTargetType } from './enums';\nimport { CellType, ColumnType, GridType, RowType } from './grid.interface';\nimport { IFilteringExpressionsTree } from '../../data-operations/filtering-expressions-tree';\nimport { IGroupingExpression } from '../../data-operations/grouping-expression.interface';\nimport { IgxBaseExporter } from '../../services/exporter-common/base-export-service';\nimport { IgxExporterOptionsBase } from '../../services/exporter-common/exporter-options-base';\nimport { ISortingExpression } from '../../data-operations/sorting-strategy';\nimport { IBaseSearchInfo } from '../../directives/text-highlight/text-highlight.directive';\n\n/** The event arguments when data from a grid is being copied. */\nexport interface IGridClipboardEvent {\n    /** `data` can be of any type and referes to the data that is being copied/stored to the clipboard */\n    data: any[];\n    /**\n     * `cancel` returns whether an external event has interepted the copying\n     * If the value becomes \"true\", it returns/exits from the method, instanciating the interface\n     */\n    cancel: boolean;\n}\n\n/** Represents an event argument related to grid cell interactions. */\nexport interface IGridCellEventArgs extends IBaseEventArgs {\n    /** Represents the grid cell that triggered the event. */\n    cell: CellType;\n    /**\n     * Represents the original event that ocurred\n     * Examples of such events include: selecting, clicking, double clicking, etc.\n     */\n    event: Event;\n}\n\n/** Represents an event argument related to grid row interactions. */\nexport interface IGridRowEventArgs extends IBaseEventArgs {\n    /** Represents the grid row that triggered the event. */\n    row: RowType;\n    /**\n     * Represents the original event that ocurred\n     * Examples of such events include: selecting, clicking, double clicking, etc.\n     */\n    event: Event;\n}\n\n/** Represents event arguments related to grid editing completion. */\nexport interface IGridEditDoneEventArgs extends IBaseEventArgs {\n    /**\n     * @deprecated since version 17.1.0. Use the `rowKey` property instead.\n     */\n    rowID: any;\n    /**\n     * @deprecated since version 17.1.0. Use the `rowKey` property instead.\n     */\n    primaryKey: any;\n    rowKey: any;\n    cellID?: {\n        rowID: any;\n        columnID: any;\n        rowIndex: number;\n    };\n    /**\n     * `rowData` represents the updated/committed data of the row after the edit (newValue)\n     * The only case rowData (of the current object) is used directly, is when there is no rowEditing or transactions enabled\n     */\n    rowData: any;\n    /**\n     * Represents the previous (before editing) value of the edited cell.\n     * It's used when the event has been stoped/exited.\n     */\n    oldValue: any;\n    /**\n     * Optional\n     * Represents the value, that is being entered in the edited cell\n     * When there is no `newValue` and the event has ended, the value of the cell returns to the `oldValue`\n     */\n    newValue?: any;\n    /**\n     * Optional\n     * Represents the original event, that has triggered the edit\n     */\n    event?: Event;\n    /**\n     * Optional\n     * Represents the column information of the edited cell\n     */\n    column?: ColumnType;\n    /**\n     * Optional\n     * Represents the grid instance that owns the edit event.\n     */\n    owner?: GridType;\n    /**\n     * Optional\n     * Indicates if the editing cosists of adding a new row\n     */\n    isAddRow?: boolean;\n    /**\n     * Optional\n     * Indicates if the new value would be valid.\n     * It can be set to return the result of the methods for validation of the grid\n     */\n    valid?: boolean;\n}\n\n\n/**\n * Represents event arguments related to grid editing.\n * The event is cancelable\n * It contains information about the row and the column, as well as the old and nwe value of the element/cell\n */\nexport interface IGridEditEventArgs extends CancelableEventArgs, IGridEditDoneEventArgs {\n}\n\nexport interface IRowDataCancelableEventArgs extends IRowDataEventArgs, IGridEditEventArgs {\n    /**\n     * @deprecated\n     */\n    cellID?: {\n        rowID: any;\n        columnID: any;\n        rowIndex: number;\n    };\n    /**\n     * @deprecated\n     */\n    oldValue: any;\n    /**\n     * @deprecated\n     */\n    newValue?: any;\n    /**\n     * @deprecated\n     */\n    isAddRow?: boolean;\n    owner: GridType;\n}\n\n/**\n * The event arguments after a column's pin state is changed.\n * `insertAtIndex`specifies at which index in the pinned/unpinned area the column was inserted.\n * `isPinned` returns the actual pin state of the column after the operation completed.\n */\nexport interface IPinColumnEventArgs extends IBaseEventArgs {\n    column: ColumnType;\n    /**\n     * If pinned, specifies at which index in the pinned area the column is inserted.\n     * If unpinned, specifies at which index in the unpinned area the column is inserted.\n     */\n    insertAtIndex: number;\n    /**\n     * Returns the actual pin state of the column.\n     * If pinning/unpinning is succesfull, value of `isPinned` will change accordingly when read in the \"-ing\" and \"-ed\" event.\n     */\n    isPinned: boolean;\n}\n\n/**\n * The event arguments before a column's pin state is changed.\n * `insertAtIndex`specifies at which index in the pinned/unpinned area the column is inserted.\n * Can be changed in the `columnPin` event.\n * `isPinned` returns the actual pin state of the column. When pinning/unpinning is succesfull,\n * the value of `isPinned` will change accordingly when read in the \"-ing\" and \"-ed\" event.\n */\nexport interface IPinColumnCancellableEventArgs extends IPinColumnEventArgs, CancelableEventArgs {\n}\n\n/**\n * Represents event arguments related to events, that can occur for rows in a grid\n * Example for events: adding, deleting, selection, transaction, etc.\n */\nexport interface IRowDataEventArgs extends IBaseEventArgs {\n    /**\n     * @deprecated since version 17.1.0. Use the `rowData` property instead.\n     */\n    data: any;\n    rowData: any\n    /**\n     * Represents the unique key, the row can be associated with.\n     * Available if `primaryKey` exists\n     * @deprecated since version 17.1.0. Use the `rowKey` property instead.\n     */\n    primaryKey: any;\n    rowKey: any;\n    /** Represents the grid instance that owns the edit event. */\n    owner: GridType;\n}\n\n\n/** The event arguments when a column is being resized */\nexport interface IColumnResizeEventArgs extends IBaseEventArgs {\n    /** Represents the informantion of the column that is being resized */\n    column: ColumnType;\n    /** Represents the old width of the column before the resizing */\n    prevWidth: string;\n    /** Represents the new width, the column is being resized to */\n    newWidth: string;\n}\n\n/**\n * The event arguments when a column is being resized\n * It contains information about the column, it's old and new width\n * The event can be canceled\n */\nexport interface IColumnResizingEventArgs extends IColumnResizeEventArgs, CancelableEventArgs {\n}\n\n/**\n * The event arguments when the selection state of a row is being changed\n * The event is cancelable\n */\nexport interface IRowSelectionEventArgs extends CancelableEventArgs, IBaseEventArgs {\n    /** Represents an array of rows, that have already been selected */\n    readonly oldSelection: any[];\n    /** Represents the newly selected rows */\n    newSelection: any[];\n    /**\n     * Represents an array of all added rows\n     * Whenever a row has been selected, the array is \"refreshed\" with the selected rows\n     */\n    readonly added: any[];\n    /**\n     * Represents an array of all rows, removed from the selection\n     * Whenever a row has been deselected, the array is \"refreshed\" with the rows,\n     * that have been previously selected, but are no longer\n     */\n    readonly removed: any[];\n    /**\n     * Represents the original event, that has triggered the selection change\n     * selecting, deselecting\n     */\n    readonly event?: Event;\n    /** Indicates whether or not all rows of the grid have been selected */\n    readonly allRowsSelected?: boolean;\n}\n\n/**\n * The event arguments when the selection state of a column is being chaged\n * The event is cancelable\n */\nexport interface IColumnSelectionEventArgs extends CancelableEventArgs, IBaseEventArgs {\n    /** Represents an array of columns, that have already been selected */\n    readonly oldSelection: string[];\n    /** Represents the newly selected columns */\n    newSelection: string[];\n    /**\n     * Represents an array of all added columns\n     * Whenever a column has been selected, the array is \"refreshed\" with the selected columns\n     */\n    readonly added: string[];\n    /**\n     * Represents an array of all columns, removed from the selection\n     * Whenever a column has been deselected, the array is \"refreshed\" with the columns, that have been previously selected, but are no longer\n     */\n    readonly removed: string[];\n    /**\n     * Represents the original event, that has triggered the selection change\n     * selecting, deselecting\n     */\n    readonly event?: Event;\n}\n\nexport interface ISearchInfo extends IBaseSearchInfo {\n    matchInfoCache: any[];\n    activeMatchIndex: number;\n}\n\n/**\n * Represents the arguments for the grid toolbar export event.\n * It provides information about the grid instance, exporter service, export options,\n * and allows the event to be canceled.\n */\nexport interface IGridToolbarExportEventArgs extends IBaseEventArgs {\n    /** `grid` represents a reference to the instance of the grid te event originated from */\n    grid: GridType;\n    /**\n     * The `exporter` is a base service.\n     * The type (an abstract class `IgxBaseExporter`) has it's own properties and methods\n     * It is used to define the format and options of the export, the exported element\n     * and methods for preparing the data from the elements for exporting\n     */\n    exporter: IgxBaseExporter;\n    /**\n     * Represents the different settings, that can be given to an export\n     * The type (an abstract class `IgxExporterOptionsBase`) has properties for column settings\n     * (whether they should be ignored) as well as method for generating a file name\n     */\n    options: IgxExporterOptionsBase;\n    /**\n     * `cancel` returns whether the event has been interepted and stopped\n     * If the value becomes \"true\", it returns/exits from the method, instanciating the interface\n     */\n    cancel: boolean;\n}\n\n/** Represents event arguments related to the start of a column moving operation in a grid. */\nexport interface IColumnMovingStartEventArgs extends IBaseEventArgs {\n    /**\n     * Represents the column that is being moved.\n     * The `ColumnType` contains the informatoin (the grid it belongs to, css data, settings, etc.) of the column in its properties\n     */\n    source: ColumnType;\n}\n\n/** Represents event arguments related to a column moving operation in a grid */\nexport interface IColumnMovingEventArgs extends IBaseEventArgs {\n    /**\n     * Represents the column that is being moved.\n     * The `ColumnType` contains the informatoin (the grid it belongs to, css data, settings, etc.) of the column in its properties\n     */\n    source: ColumnType;\n    /**\n     * `cancel` returns whether the event has been interepted and stopped\n     * If the value becomes \"true\", it returns/exits from the method, instanciating the interface\n     */\n    cancel: boolean;\n}\n\n/** Represents event arguments related to the end of a column moving operation in a grid */\nexport interface IColumnMovingEndEventArgs extends IBaseEventArgs {\n    /**\n     * The source of the event represents the column that is being moved.\n     * The `ColumnType` contains the informatoin (the grid it belongs to, css data, settings, etc.) of the column in its properties\n     */\n    source: ColumnType;\n    /**\n     * The target of the event represents the column, the source is being moved to.\n     * The `ColumnType` contains the informatoin (the grid it belongs to, css data, settings, etc.) of the column in its properties\n     */\n    target: ColumnType;\n    /**\n     * `cancel` returns whether the event has been interepted and stopped\n     * If the value becomes \"true\", it returns/exits from the method, instanciating the interface\n     */\n    cancel: boolean;\n}\n\n/**\n * Represents an event, emitted when keydown is triggered over element inside grid's body\n * This event is fired only if the key combination is supported in the grid.\n */\nexport interface IGridKeydownEventArgs extends IBaseEventArgs {\n    /** The `targetType` represents the type of the targeted object. For example a cell or a row */\n    targetType: GridKeydownTargetType;\n    /** Represents the information and details of the object itself */\n    target: any;\n    /** Represents the original event, that occured. */\n    event: Event;\n    /**\n     * The event is cancelable\n     * `cancel` returns whether the event has been interepted and stopped\n     * If the value becomes \"true\", it returns/exits from the method, instanciating the interface\n     */\n    cancel: boolean;\n}\n\n/** The event is triggered when getting the current position of a certain cell */\nexport interface ICellPosition {\n    /** It returns the position (index) of the row, the cell is in */\n    rowIndex: number;\n    /**\n     * It returns the position (index) of the colunm, the cell is in\n     * Counts only the visible (non hidden) columns\n     */\n    visibleColumnIndex: number;\n}\n\n/** Emitted when a dragging operation is finished (when the row is dropped) */\nexport interface IRowDragEndEventArgs extends IBaseEventArgs {\n    /** Represents the drag directive or information associated with the drag operation */\n    dragDirective: any;\n    /** Represents the information of the row that is being dragged. */\n    dragData: RowType;\n    /** Represents the HTML element itself */\n    dragElement: HTMLElement;\n    /** `animation` returns whether the event is animated */\n    animation: boolean;\n}\n\n/**\n * Emitted when a dragging operation is starting (when the row is \"picked\")\n * The event is cancelable\n */\nexport interface IRowDragStartEventArgs extends CancelableEventArgs, IBaseEventArgs {\n    /** Represents the drag directive or information associated with the drag operation */\n    dragDirective: any;\n    /** Represents the information of the row that is being dragged. */\n    dragData: RowType;\n    /** Represents the HTML element itself */\n    dragElement: HTMLElement;\n}\n\n/** Рepresents event arguments related to the row's expansion state being changed in a grid */\nexport interface IRowToggleEventArgs extends IBaseEventArgs {\n    /**\n     * Represents the ID of the row that emitted the event (which state is changed)\n     * @deprecated since version 17.1.0. Use the `rowKey` property instead.\n     */\n    rowID: any;\n    rowKey: any;\n    /**\n     * Returns the state of the row after the operation has ended\n     * Indicating whether the row is being expanded (true) or collapsed (false)\n     */\n    expanded: boolean;\n    /**\n     * Optional\n     * Represents the original event, that has triggered the expantion/collapse\n     */\n    event?: Event;\n    /**\n     * The event is cancelable\n     * `cancel` returns whether the event has been interepted and stopped\n     * If the value becomes \"true\", it returns/exits from the method, instanciating the interface\n     */\n    cancel: boolean;\n}\n\n/**\n * Event emitted when a row's pin state changes.\n * The event is cancelable\n */\nexport interface IPinRowEventArgs extends IBaseEventArgs, CancelableEventArgs {\n    /**\n     * The ID of the row, that was pinned/unpinned.\n     * ID is either the primaryKey value or the data record instance.\n     * @deprecated since version 17.1.0. Use the `rowKey` property instead.\n     */\n    readonly rowID: any;\n    readonly rowKey: any;\n    row?: RowType;\n    /** The index at which to pin the row in the pinned rows collection. */\n    insertAtIndex?: number;\n    /** Whether or not the row is pinned or unpinned. */\n    readonly isPinned: boolean;\n}\n\n/**\n * Event emitted when a grid is scrolled.\n */\nexport interface IGridScrollEventArgs extends IBaseEventArgs {\n    /** The scroll direction - vertical or horizontal. */\n    direction: string;\n    /** The original browser scroll event. */\n    event: Event;\n    /** The new scroll position */\n    scrollPosition: number;\n}\n\n/**\n * Event emitted when a checkbox in the checkbox\n * list of an IgxColumnActions component is clicked.\n */\nexport interface IColumnToggledEventArgs extends IBaseEventArgs {\n    /** The column that is toggled. */\n    column: ColumnType;\n    /** The checked state after the action. */\n    checked: boolean;\n}\n\n/** Emmited when the active node is changed */\nexport interface IActiveNodeChangeEventArgs extends IBaseEventArgs {\n    /** Represents the row index of the active node */\n    row: number;\n    /** Represents the column index of the active node */\n    column: number;\n    /**\n     * Optional\n     * Represents the hierarchical level of the active node\n     */\n    level?: number;\n    /**\n     * Represents the type of the active node.\n     * The GridKeydownTargetType is an enum or that specifies the possible target types\n     */\n    tag: GridKeydownTargetType;\n}\n\n/**\n * Represents event arguments related to sorting and grouping operations\n * The event is cancelable\n */\nexport interface ISortingEventArgs extends IBaseEventArgs, CancelableEventArgs {\n    /**\n     * Optional\n     * Represents the sorting expressions applied to the grid.\n     * It can be a single sorting expression or an array of them\n     * The expression contains information like file name, whether the letter case should be taken into account, etc.\n     */\n    sortingExpressions?: ISortingExpression | Array<ISortingExpression>;\n    /**\n     * Optional\n     * Represents the gouping expressions applied to the grid.\n     * It can be a single grouping expression or an array of them\n     * The expression contains information like the sorting expression and criteria by which the elements will be grouped\n     */\n    groupingExpressions?: IGroupingExpression | Array<IGroupingExpression>;\n}\n\n/**\n * Represents event arguments related to filtering operations\n * The event is cancelable\n */\nexport interface IFilteringEventArgs extends IBaseEventArgs, CancelableEventArgs {\n    /**\n     * Represents the filtering expressions applied to the grid.\n     * The expression contains information like filtering operands and operator, an expression or condition, etc.\n     */\n    filteringExpressions: IFilteringExpressionsTree;\n}\n\n/** The event arguments after a column's visibility is changed. */\nexport interface IColumnVisibilityChangedEventArgs extends IBaseEventArgs {\n    /** Represents the column the event originated from */\n    column: any;\n    /**\n     * The new hidden state that the column will have, if operation is succesfull.\n     * Will be `true` when hiding and `false` when showing.\n     */\n    newValue: boolean;\n}\n\n/**\n * The event arguments when a column's visibility is changed.\n * The event is cancelable\n * It contains information about the column and the it's visibility after the operation (will be `true` when hiding and `false` when showing)\n */\nexport interface IColumnVisibilityChangingEventArgs extends IColumnVisibilityChangedEventArgs, CancelableEventArgs {\n}\n\n"]}
2
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"events.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/common/events.ts"],"names":[],"mappings":"","sourcesContent":["import { IBaseEventArgs, CancelableEventArgs } from '../../core/utils';\nimport { GridKeydownTargetType } from './enums';\nimport { CellType, ColumnType, GridType, RowType } from './grid.interface';\nimport { IFilteringExpressionsTree } from '../../data-operations/filtering-expressions-tree';\nimport { IGroupingExpression } from '../../data-operations/grouping-expression.interface';\nimport { IgxBaseExporter } from '../../services/exporter-common/base-export-service';\nimport { IgxExporterOptionsBase } from '../../services/exporter-common/exporter-options-base';\nimport { ISortingExpression } from '../../data-operations/sorting-strategy';\nimport { IBaseSearchInfo } from '../../directives/text-highlight/text-highlight.directive';\n\n/** The event arguments when data from a grid is being copied. */\nexport interface IGridClipboardEvent {\n    /** `data` can be of any type and refers to the data that is being copied/stored to the clipboard */\n    data: any[];\n    /**\n     * `cancel` returns whether an external event has intercepted the copying\n     * If the value becomes \"true\", it returns/exits from the method, instantiating the interface\n     */\n    cancel: boolean;\n}\n\n/** Represents an event argument related to grid cell interactions. */\nexport interface IGridCellEventArgs extends IBaseEventArgs {\n    /** Represents the grid cell that triggered the event. */\n    cell: CellType;\n    /**\n     * Represents the original event that ocurred\n     * Examples of such events include: selecting, clicking, double clicking, etc.\n     */\n    event: Event;\n}\n\n/** Represents an event argument related to grid row interactions. */\nexport interface IGridRowEventArgs extends IBaseEventArgs {\n    /** Represents the grid row that triggered the event. */\n    row: RowType;\n    /**\n     * Represents the original event that ocurred\n     * Examples of such events include: selecting, clicking, double clicking, etc.\n     */\n    event: Event;\n}\n\n/** Represents event arguments related to grid editing completion. */\nexport interface IGridEditDoneEventArgs extends IBaseEventArgs {\n    /**\n     * @deprecated since version 17.1.0. Use the `rowKey` property instead.\n     */\n    rowID: any;\n    /**\n     * @deprecated since version 17.1.0. Use the `rowKey` property instead.\n     */\n    primaryKey: any;\n    rowKey: any;\n    cellID?: {\n        rowID: any;\n        columnID: any;\n        rowIndex: number;\n    };\n    /**\n     * `rowData` represents the updated/committed data of the row after the edit (newValue)\n     * The only case rowData (of the current object) is used directly, is when there is no rowEditing or transactions enabled\n     */\n    rowData: any;\n    /**\n     * Represents the previous (before editing) value of the edited cell.\n     * It's used when the event has been stopped/exited.\n     */\n    oldValue: any;\n    /**\n     * Optional\n     * Represents the value, that is being entered in the edited cell\n     * When there is no `newValue` and the event has ended, the value of the cell returns to the `oldValue`\n     */\n    newValue?: any;\n    /**\n     * Optional\n     * Represents the original event, that has triggered the edit\n     */\n    event?: Event;\n    /**\n     * Optional\n     * Represents the column information of the edited cell\n     */\n    column?: ColumnType;\n    /**\n     * Optional\n     * Represents the grid instance that owns the edit event.\n     */\n    owner?: GridType;\n    /**\n     * Optional\n     * Indicates if the editing consists of adding a new row\n     */\n    isAddRow?: boolean;\n    /**\n     * Optional\n     * Indicates if the new value would be valid.\n     * It can be set to return the result of the methods for validation of the grid\n     */\n    valid?: boolean;\n}\n\n\n/**\n * Represents event arguments related to grid editing.\n * The event is cancelable\n * It contains information about the row and the column, as well as the old and nwe value of the element/cell\n */\nexport interface IGridEditEventArgs extends CancelableEventArgs, IGridEditDoneEventArgs {\n}\n\nexport interface IRowDataCancelableEventArgs extends IRowDataEventArgs, IGridEditEventArgs {\n    /**\n     * @deprecated\n     */\n    cellID?: {\n        rowID: any;\n        columnID: any;\n        rowIndex: number;\n    };\n    /**\n     * @deprecated\n     */\n    oldValue: any;\n    /**\n     * @deprecated\n     */\n    newValue?: any;\n    /**\n     * @deprecated\n     */\n    isAddRow?: boolean;\n    owner: GridType;\n}\n\n/**\n * The event arguments after a column's pin state is changed.\n * `insertAtIndex`specifies at which index in the pinned/unpinned area the column was inserted.\n * `isPinned` returns the actual pin state of the column after the operation completed.\n */\nexport interface IPinColumnEventArgs extends IBaseEventArgs {\n    column: ColumnType;\n    /**\n     * If pinned, specifies at which index in the pinned area the column is inserted.\n     * If unpinned, specifies at which index in the unpinned area the column is inserted.\n     */\n    insertAtIndex: number;\n    /**\n     * Returns the actual pin state of the column.\n     * If pinning/unpinning is successful, value of `isPinned` will change accordingly when read in the \"-ing\" and \"-ed\" event.\n     */\n    isPinned: boolean;\n}\n\n/**\n * The event arguments before a column's pin state is changed.\n * `insertAtIndex`specifies at which index in the pinned/unpinned area the column is inserted.\n * Can be changed in the `columnPin` event.\n * `isPinned` returns the actual pin state of the column. When pinning/unpinning is successful,\n * the value of `isPinned` will change accordingly when read in the \"-ing\" and \"-ed\" event.\n */\nexport interface IPinColumnCancellableEventArgs extends IPinColumnEventArgs, CancelableEventArgs {\n}\n\n/**\n * Represents event arguments related to events, that can occur for rows in a grid\n * Example for events: adding, deleting, selection, transaction, etc.\n */\nexport interface IRowDataEventArgs extends IBaseEventArgs {\n    /**\n     * @deprecated since version 17.1.0. Use the `rowData` property instead.\n     */\n    data: any;\n    rowData: any\n    /**\n     * Represents the unique key, the row can be associated with.\n     * Available if `primaryKey` exists\n     * @deprecated since version 17.1.0. Use the `rowKey` property instead.\n     */\n    primaryKey: any;\n    rowKey: any;\n    /** Represents the grid instance that owns the edit event. */\n    owner: GridType;\n}\n\n\n/** The event arguments when a column is being resized */\nexport interface IColumnResizeEventArgs extends IBaseEventArgs {\n    /** Represents the information of the column that is being resized */\n    column: ColumnType;\n    /** Represents the old width of the column before the resizing */\n    prevWidth: string;\n    /** Represents the new width, the column is being resized to */\n    newWidth: string;\n}\n\n/**\n * The event arguments when a column is being resized\n * It contains information about the column, it's old and new width\n * The event can be canceled\n */\nexport interface IColumnResizingEventArgs extends IColumnResizeEventArgs, CancelableEventArgs {\n}\n\n/**\n * The event arguments when the selection state of a row is being changed\n * The event is cancelable\n */\nexport interface IRowSelectionEventArgs extends CancelableEventArgs, IBaseEventArgs {\n    /** Represents an array of rows, that have already been selected */\n    readonly oldSelection: any[];\n    /** Represents the newly selected rows */\n    newSelection: any[];\n    /**\n     * Represents an array of all added rows\n     * Whenever a row has been selected, the array is \"refreshed\" with the selected rows\n     */\n    readonly added: any[];\n    /**\n     * Represents an array of all rows, removed from the selection\n     * Whenever a row has been deselected, the array is \"refreshed\" with the rows,\n     * that have been previously selected, but are no longer\n     */\n    readonly removed: any[];\n    /**\n     * Represents the original event, that has triggered the selection change\n     * selecting, deselecting\n     */\n    readonly event?: Event;\n    /** Indicates whether or not all rows of the grid have been selected */\n    readonly allRowsSelected?: boolean;\n}\n\n/**\n * The event arguments when the selection state of a column is being changed\n * The event is cancelable\n */\nexport interface IColumnSelectionEventArgs extends CancelableEventArgs, IBaseEventArgs {\n    /** Represents an array of columns, that have already been selected */\n    readonly oldSelection: string[];\n    /** Represents the newly selected columns */\n    newSelection: string[];\n    /**\n     * Represents an array of all added columns\n     * Whenever a column has been selected, the array is \"refreshed\" with the selected columns\n     */\n    readonly added: string[];\n    /**\n     * Represents an array of all columns, removed from the selection\n     * Whenever a column has been deselected, the array is \"refreshed\" with the columns, that have been previously selected, but are no longer\n     */\n    readonly removed: string[];\n    /**\n     * Represents the original event, that has triggered the selection change\n     * selecting, deselecting\n     */\n    readonly event?: Event;\n}\n\nexport interface ISearchInfo extends IBaseSearchInfo {\n    matchInfoCache: any[];\n    activeMatchIndex: number;\n}\n\n/**\n * Represents the arguments for the grid toolbar export event.\n * It provides information about the grid instance, exporter service, export options,\n * and allows the event to be canceled.\n */\nexport interface IGridToolbarExportEventArgs extends IBaseEventArgs {\n    /** `grid` represents a reference to the instance of the grid te event originated from */\n    grid: GridType;\n    /**\n     * The `exporter` is a base service.\n     * The type (an abstract class `IgxBaseExporter`) has it's own properties and methods\n     * It is used to define the format and options of the export, the exported element\n     * and methods for preparing the data from the elements for exporting\n     */\n    exporter: IgxBaseExporter;\n    /**\n     * Represents the different settings, that can be given to an export\n     * The type (an abstract class `IgxExporterOptionsBase`) has properties for column settings\n     * (whether they should be ignored) as well as method for generating a file name\n     */\n    options: IgxExporterOptionsBase;\n    /**\n     * `cancel` returns whether the event has been intercepted and stopped\n     * If the value becomes \"true\", it returns/exits from the method, instantiating the interface\n     */\n    cancel: boolean;\n}\n\n/** Represents event arguments related to the start of a column moving operation in a grid. */\nexport interface IColumnMovingStartEventArgs extends IBaseEventArgs {\n    /**\n     * Represents the column that is being moved.\n     * The `ColumnType` contains the information (the grid it belongs to, css data, settings, etc.) of the column in its properties\n     */\n    source: ColumnType;\n}\n\n/** Represents event arguments related to a column moving operation in a grid */\nexport interface IColumnMovingEventArgs extends IBaseEventArgs {\n    /**\n     * Represents the column that is being moved.\n     * The `ColumnType` contains the information (the grid it belongs to, css data, settings, etc.) of the column in its properties\n     */\n    source: ColumnType;\n    /**\n     * `cancel` returns whether the event has been intercepted and stopped\n     * If the value becomes \"true\", it returns/exits from the method, instantiating the interface\n     */\n    cancel: boolean;\n}\n\n/** Represents event arguments related to the end of a column moving operation in a grid */\nexport interface IColumnMovingEndEventArgs extends IBaseEventArgs {\n    /**\n     * The source of the event represents the column that is being moved.\n     * The `ColumnType` contains the information (the grid it belongs to, css data, settings, etc.) of the column in its properties\n     */\n    source: ColumnType;\n    /**\n     * The target of the event represents the column, the source is being moved to.\n     * The `ColumnType` contains the information (the grid it belongs to, css data, settings, etc.) of the column in its properties\n     */\n    target: ColumnType;\n    /**\n     * `cancel` returns whether the event has been intercepted and stopped\n     * If the value becomes \"true\", it returns/exits from the method, instantiating the interface\n     */\n    cancel: boolean;\n}\n\n/**\n * Represents an event, emitted when keydown is triggered over element inside grid's body\n * This event is fired only if the key combination is supported in the grid.\n */\nexport interface IGridKeydownEventArgs extends IBaseEventArgs {\n    /** The `targetType` represents the type of the targeted object. For example a cell or a row */\n    targetType: GridKeydownTargetType;\n    /** Represents the information and details of the object itself */\n    target: any;\n    /** Represents the original event, that occurred. */\n    event: Event;\n    /**\n     * The event is cancelable\n     * `cancel` returns whether the event has been intercepted and stopped\n     * If the value becomes \"true\", it returns/exits from the method, instantiating the interface\n     */\n    cancel: boolean;\n}\n\n/** The event is triggered when getting the current position of a certain cell */\nexport interface ICellPosition {\n    /** It returns the position (index) of the row, the cell is in */\n    rowIndex: number;\n    /**\n     * It returns the position (index) of the column, the cell is in\n     * Counts only the visible (non hidden) columns\n     */\n    visibleColumnIndex: number;\n}\n\n/** Emitted when a dragging operation is finished (when the row is dropped) */\nexport interface IRowDragEndEventArgs extends IBaseEventArgs {\n    /** Represents the drag directive or information associated with the drag operation */\n    dragDirective: any;\n    /** Represents the information of the row that is being dragged. */\n    dragData: RowType;\n    /** Represents the HTML element itself */\n    dragElement: HTMLElement;\n    /** `animation` returns whether the event is animated */\n    animation: boolean;\n}\n\n/**\n * Emitted when a dragging operation is starting (when the row is \"picked\")\n * The event is cancelable\n */\nexport interface IRowDragStartEventArgs extends CancelableEventArgs, IBaseEventArgs {\n    /** Represents the drag directive or information associated with the drag operation */\n    dragDirective: any;\n    /** Represents the information of the row that is being dragged. */\n    dragData: RowType;\n    /** Represents the HTML element itself */\n    dragElement: HTMLElement;\n}\n\n/** Represents event arguments related to the row's expansion state being changed in a grid */\nexport interface IRowToggleEventArgs extends IBaseEventArgs {\n    /**\n     * Represents the ID of the row that emitted the event (which state is changed)\n     * @deprecated since version 17.1.0. Use the `rowKey` property instead.\n     */\n    rowID: any;\n    rowKey: any;\n    /**\n     * Returns the state of the row after the operation has ended\n     * Indicating whether the row is being expanded (true) or collapsed (false)\n     */\n    expanded: boolean;\n    /**\n     * Optional\n     * Represents the original event, that has triggered the expansion/collapse\n     */\n    event?: Event;\n    /**\n     * The event is cancelable\n     * `cancel` returns whether the event has been intercepted and stopped\n     * If the value becomes \"true\", it returns/exits from the method, instantiating the interface\n     */\n    cancel: boolean;\n}\n\n/**\n * Event emitted when a row's pin state changes.\n * The event is cancelable\n */\nexport interface IPinRowEventArgs extends IBaseEventArgs, CancelableEventArgs {\n    /**\n     * The ID of the row, that was pinned/unpinned.\n     * ID is either the primaryKey value or the data record instance.\n     * @deprecated since version 17.1.0. Use the `rowKey` property instead.\n     */\n    readonly rowID: any;\n    readonly rowKey: any;\n    row?: RowType;\n    /** The index at which to pin the row in the pinned rows collection. */\n    insertAtIndex?: number;\n    /** Whether or not the row is pinned or unpinned. */\n    readonly isPinned: boolean;\n}\n\n/**\n * Event emitted when a grid is scrolled.\n */\nexport interface IGridScrollEventArgs extends IBaseEventArgs {\n    /** The scroll direction - vertical or horizontal. */\n    direction: string;\n    /** The original browser scroll event. */\n    event: Event;\n    /** The new scroll position */\n    scrollPosition: number;\n}\n\n/**\n * Event emitted when a checkbox in the checkbox\n * list of an IgxColumnActions component is clicked.\n */\nexport interface IColumnToggledEventArgs extends IBaseEventArgs {\n    /** The column that is toggled. */\n    column: ColumnType;\n    /** The checked state after the action. */\n    checked: boolean;\n}\n\n/** Emitted when the active node is changed */\nexport interface IActiveNodeChangeEventArgs extends IBaseEventArgs {\n    /** Represents the row index of the active node */\n    row: number;\n    /** Represents the column index of the active node */\n    column: number;\n    /**\n     * Optional\n     * Represents the hierarchical level of the active node\n     */\n    level?: number;\n    /**\n     * Represents the type of the active node.\n     * The GridKeydownTargetType is an enum or that specifies the possible target types\n     */\n    tag: GridKeydownTargetType;\n}\n\n/**\n * Represents event arguments related to sorting and grouping operations\n * The event is cancelable\n */\nexport interface ISortingEventArgs extends IBaseEventArgs, CancelableEventArgs {\n    /**\n     * Optional\n     * Represents the sorting expressions applied to the grid.\n     * It can be a single sorting expression or an array of them\n     * The expression contains information like file name, whether the letter case should be taken into account, etc.\n     */\n    sortingExpressions?: ISortingExpression | Array<ISortingExpression>;\n    /**\n     * Optional\n     * Represents the grouping expressions applied to the grid.\n     * It can be a single grouping expression or an array of them\n     * The expression contains information like the sorting expression and criteria by which the elements will be grouped\n     */\n    groupingExpressions?: IGroupingExpression | Array<IGroupingExpression>;\n}\n\n/**\n * Represents event arguments related to filtering operations\n * The event is cancelable\n */\nexport interface IFilteringEventArgs extends IBaseEventArgs, CancelableEventArgs {\n    /**\n     * Represents the filtering expressions applied to the grid.\n     * The expression contains information like filtering operands and operator, an expression or condition, etc.\n     */\n    filteringExpressions: IFilteringExpressionsTree;\n}\n\n/** The event arguments after a column's visibility is changed. */\nexport interface IColumnVisibilityChangedEventArgs extends IBaseEventArgs {\n    /** Represents the column the event originated from */\n    column: any;\n    /**\n     * The new hidden state that the column will have, if operation is successful.\n     * Will be `true` when hiding and `false` when showing.\n     */\n    newValue: boolean;\n}\n\n/**\n * The event arguments when a column's visibility is changed.\n * The event is cancelable\n * It contains information about the column and the it's visibility after the operation (will be `true` when hiding and `false` when showing)\n */\nexport interface IColumnVisibilityChangingEventArgs extends IColumnVisibilityChangedEventArgs, CancelableEventArgs {\n}\n\n"]}