igniteui-angular 18.2.3 → 18.2.4

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 (93) hide show
  1. package/esm2022/lib/avatar/avatar.component.mjs +17 -2
  2. package/esm2022/lib/checkbox/checkbox.component.mjs +73 -9
  3. package/esm2022/lib/core/utils.mjs +8 -1
  4. package/esm2022/lib/date-picker/date-picker.component.mjs +7 -3
  5. package/esm2022/lib/date-range-picker/date-range-picker.component.mjs +2 -2
  6. package/esm2022/lib/query-builder/query-builder.component.mjs +11 -6
  7. package/fesm2022/igniteui-angular.mjs +110 -15
  8. package/fesm2022/igniteui-angular.mjs.map +1 -1
  9. package/lib/avatar/avatar.component.d.ts +3 -1
  10. package/lib/checkbox/checkbox.component.d.ts +42 -2
  11. package/lib/core/styles/components/action-strip/_action-strip-component.scss +1 -1
  12. package/lib/core/styles/components/action-strip/_action-strip-theme.scss +1 -0
  13. package/lib/core/styles/components/avatar/_avatar-theme.scss +1 -0
  14. package/lib/core/styles/components/badge/_badge-theme.scss +1 -0
  15. package/lib/core/styles/components/banner/_banner-theme.scss +1 -0
  16. package/lib/core/styles/components/bottom-nav/_bottom-nav-theme.scss +1 -0
  17. package/lib/core/styles/components/button/_button-theme.scss +1 -0
  18. package/lib/core/styles/components/button-group/_button-group-theme.scss +1 -0
  19. package/lib/core/styles/components/calendar/_calendar-theme.scss +1 -0
  20. package/lib/core/styles/components/card/_card-theme.scss +1 -0
  21. package/lib/core/styles/components/carousel/_carousel-theme.scss +6 -5
  22. package/lib/core/styles/components/checkbox/_checkbox-component.scss +76 -14
  23. package/lib/core/styles/components/checkbox/_checkbox-theme.scss +98 -109
  24. package/lib/core/styles/components/chip/_chip-theme.scss +1 -0
  25. package/lib/core/styles/components/column-actions/_column-actions-theme.scss +1 -0
  26. package/lib/core/styles/components/combo/_combo-theme.scss +1 -0
  27. package/lib/core/styles/components/dialog/_dialog-theme.scss +1 -0
  28. package/lib/core/styles/components/divider/_divider-theme.scss +1 -0
  29. package/lib/core/styles/components/drop-down/_drop-down-theme.scss +1 -0
  30. package/lib/core/styles/components/expansion-panel/_expansion-panel-theme.scss +1 -0
  31. package/lib/core/styles/components/grid/_grid-component.scss +1 -0
  32. package/lib/core/styles/components/grid/_grid-theme.scss +4 -3
  33. package/lib/core/styles/components/grid/_pivot-data-selector-theme.scss +1 -0
  34. package/lib/core/styles/components/grid-summary/_grid-summary-theme.scss +1 -0
  35. package/lib/core/styles/components/grid-toolbar/_grid-toolbar-theme.scss +1 -0
  36. package/lib/core/styles/components/highlight/highlight-theme.scss +1 -0
  37. package/lib/core/styles/components/icon/_icon-theme.scss +2 -1
  38. package/lib/core/styles/components/icon-button/_icon-button-theme.scss +1 -0
  39. package/lib/core/styles/components/label/_label-theme.scss +1 -0
  40. package/lib/core/styles/components/list/_list-theme.scss +8 -53
  41. package/lib/core/styles/components/navbar/_navbar-theme.scss +1 -0
  42. package/lib/core/styles/components/navdrawer/_navdrawer-theme.scss +1 -0
  43. package/lib/core/styles/components/overlay/_overlay-theme.scss +1 -0
  44. package/lib/core/styles/components/paginator/_paginator-component.scss +1 -1
  45. package/lib/core/styles/components/paginator/_paginator-theme.scss +1 -0
  46. package/lib/core/styles/components/progress/_progress-theme.scss +2 -0
  47. package/lib/core/styles/components/query-builder/_query-builder-component.scss +9 -1
  48. package/lib/core/styles/components/query-builder/_query-builder-theme.scss +1 -0
  49. package/lib/core/styles/components/radio/_radio-theme.scss +1 -0
  50. package/lib/core/styles/components/ripple/_ripple-theme.scss +2 -1
  51. package/lib/core/styles/components/scrollbar/scrollbar-theme.scss +1 -0
  52. package/lib/core/styles/components/select/_select-theme.scss +1 -0
  53. package/lib/core/styles/components/slider/_slider-theme.scss +1 -0
  54. package/lib/core/styles/components/snackbar/_snackbar-theme.scss +1 -0
  55. package/lib/core/styles/components/splitter/_splitter-theme.scss +1 -0
  56. package/lib/core/styles/components/stepper/_stepper-theme.scss +1 -0
  57. package/lib/core/styles/components/switch/_switch-theme.scss +1 -0
  58. package/lib/core/styles/components/tabs/_tabs-theme.scss +21 -15
  59. package/lib/core/styles/components/time-picker/_time-picker-theme.scss +1 -0
  60. package/lib/core/styles/components/toast/_toast-theme.scss +1 -0
  61. package/lib/core/styles/components/tooltip/_tooltip-theme.scss +1 -0
  62. package/lib/core/styles/components/tree/_tree-theme.scss +1 -0
  63. package/lib/core/styles/components/watermark/_watermark-theme.scss +1 -0
  64. package/lib/core/styles/typography/_indigo.scss +3 -1
  65. package/lib/core/utils.d.ts +5 -0
  66. package/lib/date-picker/date-picker.component.d.ts +2 -1
  67. package/package.json +1 -1
  68. package/styles/igniteui-angular-dark.css +1 -1
  69. package/styles/igniteui-angular.css +1 -1
  70. package/styles/igniteui-bootstrap-dark.css +1 -1
  71. package/styles/igniteui-bootstrap-light.css +1 -1
  72. package/styles/igniteui-dark-green.css +1 -1
  73. package/styles/igniteui-fluent-dark-excel.css +1 -1
  74. package/styles/igniteui-fluent-dark-word.css +1 -1
  75. package/styles/igniteui-fluent-dark.css +1 -1
  76. package/styles/igniteui-fluent-light-excel.css +1 -1
  77. package/styles/igniteui-fluent-light-word.css +1 -1
  78. package/styles/igniteui-fluent-light.css +1 -1
  79. package/styles/igniteui-indigo-dark.css +1 -1
  80. package/styles/igniteui-indigo-light.css +1 -1
  81. package/styles/maps/igniteui-angular-dark.css.map +1 -1
  82. package/styles/maps/igniteui-angular.css.map +1 -1
  83. package/styles/maps/igniteui-bootstrap-dark.css.map +1 -1
  84. package/styles/maps/igniteui-bootstrap-light.css.map +1 -1
  85. package/styles/maps/igniteui-dark-green.css.map +1 -1
  86. package/styles/maps/igniteui-fluent-dark-excel.css.map +1 -1
  87. package/styles/maps/igniteui-fluent-dark-word.css.map +1 -1
  88. package/styles/maps/igniteui-fluent-dark.css.map +1 -1
  89. package/styles/maps/igniteui-fluent-light-excel.css.map +1 -1
  90. package/styles/maps/igniteui-fluent-light-word.css.map +1 -1
  91. package/styles/maps/igniteui-fluent-light.css.map +1 -1
  92. package/styles/maps/igniteui-indigo-dark.css.map +1 -1
  93. package/styles/maps/igniteui-indigo-light.css.map +1 -1
@@ -1,6 +1,6 @@
1
1
  import { NgTemplateOutlet } from '@angular/common';
2
2
  import { Component, HostBinding, Input, TemplateRef, ViewChild } from '@angular/core';
3
- import { mkenum } from '../core/utils';
3
+ import { mkenum, normalizeURI } from '../core/utils';
4
4
  import { IgxIconComponent } from '../icon/icon.component';
5
5
  import * as i0 from "@angular/core";
6
6
  let NEXT_ID = 0;
@@ -46,6 +46,21 @@ export class IgxAvatarComponent {
46
46
  get isCircle() {
47
47
  return this.shape === 'circle';
48
48
  }
49
+ /**
50
+ * Sets the image source of the avatar.
51
+ *
52
+ * @example
53
+ * ```html
54
+ * <igx-avatar src="images/picture.jpg"></igx-avatar>
55
+ * ```
56
+ * @igxFriendlyName Image URL
57
+ */
58
+ set src(value) {
59
+ this._src = normalizeURI(value);
60
+ }
61
+ get src() {
62
+ return this._src;
63
+ }
49
64
  /**
50
65
  * Returns the size of the avatar.
51
66
  *
@@ -280,4 +295,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImpor
280
295
  type: HostBinding,
281
296
  args: ['style.--component-size']
282
297
  }] } });
283
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/avatar/avatar.component.ts","../../../../../projects/igniteui-angular/src/lib/avatar/avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n    Component,\n    ElementRef,\n    HostBinding,\n    Input,\n    OnInit,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport { mkenum } from '../core/utils';\nimport { IgxIconComponent } from '../icon/icon.component';\n\nlet NEXT_ID = 0;\nexport const IgxAvatarSize = /*@__PURE__*/mkenum({\n    SMALL: 'small',\n    MEDIUM: 'medium',\n    LARGE: 'large'\n});\nexport type IgxAvatarSize = (typeof IgxAvatarSize)[keyof typeof IgxAvatarSize];\n\nexport const IgxAvatarType = /*@__PURE__*/mkenum({\n    INITIALS: 'initials',\n    IMAGE: 'image',\n    ICON: 'icon',\n    CUSTOM: 'custom'\n});\nexport type IgxAvatarType = (typeof IgxAvatarType)[keyof typeof IgxAvatarType];\n\n/**\n * Avatar provides a way to display an image, icon or initials to the user.\n *\n * @igxModule IgxAvatarModule\n *\n * @igxTheme igx-avatar-theme, igx-icon-theme\n *\n * @igxKeywords avatar, profile, picture, initials\n *\n * @igxGroup Layouts\n *\n * @remarks\n *\n * The Ignite UI Avatar provides an easy way to add an avatar icon to your application.  This icon can be an\n * image, someone's initials or a material icon from the Google Material icon set.\n *\n * @example\n * ```html\n * <igx-avatar initials=\"MS\" shape=\"rounded\" size=\"large\">\n * </igx-avatar>\n * ```\n */\n@Component({\n    selector: 'igx-avatar',\n    templateUrl: 'avatar.component.html',\n    standalone: true,\n    imports: [IgxIconComponent, NgTemplateOutlet]\n})\nexport class IgxAvatarComponent implements OnInit {\n    /**\n     * Returns the `aria-label` attribute of the avatar.\n     *\n     * @example\n     * ```typescript\n     * let ariaLabel = this.avatar.ariaLabel;\n     * ```\n     *\n     */\n    @HostBinding('attr.aria-label')\n    public ariaLabel = 'avatar';\n\n    /**\n     * Returns the `role` attribute of the avatar.\n     *\n     * @example\n     * ```typescript\n     * let avatarRole = this.avatar.role;\n     * ```\n     */\n    @HostBinding('attr.role')\n    public role = 'img';\n\n    /**\n     * Host `class.igx-avatar` binding.\n     *\n     * @hidden\n     * @internal\n     */\n    @HostBinding('class.igx-avatar')\n    public cssClass = 'igx-avatar';\n\n    /**\n     * Returns the type of the avatar.\n     * The avatar can be:\n     * - `\"initials type avatar\"`\n     * - `\"icon type avatar\"`\n     * - `\"image type avatar\"`.\n     * - `\"custom type avatar\"`.\n     *\n     * @example\n     * ```typescript\n     * let avatarDescription = this.avatar.roleDescription;\n     * ```\n     */\n    @HostBinding('attr.aria-roledescription')\n    public roleDescription: string;\n\n    /**\n     * Sets the `id` of the avatar. If not set, the first avatar component will have `id` = `\"igx-avatar-0\"`.\n     *\n     * @example\n     * ```html\n     * <igx-avatar id=\"my-first-avatar\"></igx-avatar>\n     * ```\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-avatar-${NEXT_ID++}`;\n\n    /**\n     * Sets square, rounded or circular shape to the avatar.\n     * By default the shape of the avatar is square.\n     *\n     * @example\n     * ```html\n     * <igx-avatar shape=\"rounded\"></igx-avatar>\n     * ```\n     */\n    @Input()\n    public shape: 'square' | 'rounded' | 'circle' = 'square';\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-avatar--rounded')\n    public get isRounded(): boolean {\n        return this.shape === 'rounded';\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-avatar--circle')\n    public get isCircle(): boolean {\n        return this.shape === 'circle';\n    }\n\n    /**\n     * Sets the color of the avatar's initials or icon.\n     *\n     * @example\n     * ```html\n     * <igx-avatar color=\"blue\"></igx-avatar>\n     * ```\n     * @deprecated in version 17.2.0.\n     */\n\n    @HostBinding('style.color')\n    @Input()\n    public color: string;\n\n    /**\n     * Sets the background color of the avatar.\n     *\n     * @example\n     * ```html\n     * <igx-avatar bgColor=\"yellow\"></igx-avatar>\n     * ```\n     * @igxFriendlyName Background color\n     * @deprecated in version 17.2.0.\n     */\n\n    @HostBinding('style.background')\n    @Input()\n    public bgColor: string;\n\n    /**\n     * Sets initials to the avatar.\n     *\n     * @example\n     * ```html\n     * <igx-avatar initials=\"MN\"></igx-avatar>\n     * ```\n     */\n    @Input()\n    public initials: string;\n\n    /**\n     * Sets an icon to the avatar. All icons from the material icon set are supported.\n     *\n     * @example\n     * ```html\n     * <igx-avatar icon=\"phone\"></igx-avatar>\n     * ```\n     */\n    @Input()\n    public icon: string;\n\n    /**\n     * Sets the image source of the avatar.\n     *\n     * @example\n     * ```html\n     * <igx-avatar src=\"images/picture.jpg\"></igx-avatar>\n     * ```\n     * @igxFriendlyName Image URL\n     */\n    @Input()\n    public src: string;\n\n    /** @hidden @internal */\n    @ViewChild('defaultTemplate', { read: TemplateRef, static: true })\n    protected defaultTemplate: TemplateRef<any>;\n\n    /** @hidden @internal */\n    @ViewChild('imageTemplate', { read: TemplateRef, static: true })\n    protected imageTemplate: TemplateRef<any>;\n\n    /** @hidden @internal */\n    @ViewChild('initialsTemplate', { read: TemplateRef, static: true })\n    protected initialsTemplate: TemplateRef<any>;\n\n    /** @hidden @internal */\n    @ViewChild('iconTemplate', { read: TemplateRef, static: true })\n    protected iconTemplate: TemplateRef<any>;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    private _size: string | IgxAvatarSize;\n\n    /**\n     * Returns the size of the avatar.\n     *\n     * @example\n     * ```typescript\n     * let avatarSize = this.avatar.size;\n     * ```\n     */\n    @Input()\n    public get size(): string | IgxAvatarSize {\n        return this._size || IgxAvatarSize.SMALL;\n    }\n\n    /**\n     * Sets the size  of the avatar.\n     * By default, the size is `\"small\"`. It can be set to `\"medium\"` or `\"large\"`.\n     *\n     * @example\n     * ```html\n     * <igx-avatar size=\"large\"></igx-avatar>\n     * ```\n     */\n    public set size(value: string | IgxAvatarSize) {\n        switch (value) {\n            case 'small':\n            case 'medium':\n            case 'large':\n                this._size = value;\n                break;\n            default:\n                this._size = 'small';\n        }\n    }\n\n    /**\n     * Returns the type of the avatar.\n     *\n     * @example\n     * ```typescript\n     * let avatarType = this.avatar.type;\n     * ```\n     */\n    public get type(): IgxAvatarType {\n        if (this.src) {\n            return IgxAvatarType.IMAGE;\n        }\n\n        if (this.icon) {\n            return IgxAvatarType.ICON;\n        }\n\n        if (this.initials) {\n            return IgxAvatarType.INITIALS;\n        }\n\n        return IgxAvatarType.CUSTOM;\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-avatar--image')\n    public get _isImageType(): boolean {\n        return this.type === IgxAvatarType.IMAGE;\n    }\n    /** @hidden @internal */\n    @HostBinding('class.igx-avatar--icon')\n    public get _isIconType(): boolean {\n        return this.type === IgxAvatarType.ICON;\n    }\n    /** @hidden @internal */\n    @HostBinding('class.igx-avatar--initials')\n    public get _isInitialsType(): boolean {\n        return this.type === IgxAvatarType.INITIALS;\n    }\n\n    @HostBinding('style.--component-size')\n    protected get componentSize() {\n        if (this._size) {\n            return `var(--ig-size-${this._size})`;\n        }\n    }\n\n    /**\n     * Returns the template of the avatar.\n     *\n     * @hidden\n     * @internal\n     */\n    public get template(): TemplateRef<any> {\n        switch (this.type) {\n            case IgxAvatarType.IMAGE:\n                return this.imageTemplate;\n            case IgxAvatarType.INITIALS:\n                return this.initialsTemplate;\n            case IgxAvatarType.ICON:\n                return this.iconTemplate;\n            default:\n                return this.defaultTemplate;\n        }\n    }\n\n    constructor(public elementRef: ElementRef) { }\n\n    /**\n     * Returns the css url of the image.\n     *\n     * @hidden\n     * @internal\n     */\n    public getSrcUrl() {\n        return `url(${this.src})`;\n    }\n\n    /** @hidden @internal */\n    public ngOnInit() {\n        this.roleDescription = this.getRole();\n    }\n\n    /** @hidden @internal */\n    private getRole(): string {\n        switch (this.type) {\n            case IgxAvatarType.IMAGE:\n                return 'image avatar';\n            case IgxAvatarType.ICON:\n                return 'icon avatar';\n            case IgxAvatarType.INITIALS:\n                return 'initials avatar';\n            default:\n                return 'custom avatar';\n        }\n    }\n}\n\n","<ng-template #defaultTemplate>\n    <ng-content></ng-content>\n</ng-template>\n\n<ng-template #imageTemplate>\n    <div #image class=\"igx-avatar__image\" [style.backgroundImage]=\"getSrcUrl()\"></div>\n</ng-template>\n\n<ng-template #initialsTemplate>\n    <span>{{initials.substring(0, 2)}}</span>\n</ng-template>\n\n<ng-template #iconTemplate>\n     <igx-icon>{{icon}}</igx-icon>\n</ng-template>\n\n<ng-container *ngTemplateOutlet=\"template\"></ng-container>\n"]}
298
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/avatar/avatar.component.ts","../../../../../projects/igniteui-angular/src/lib/avatar/avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport {\n    Component,\n    ElementRef,\n    HostBinding,\n    Input,\n    OnInit,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport { mkenum, normalizeURI } from '../core/utils';\nimport { IgxIconComponent } from '../icon/icon.component';\n\nlet NEXT_ID = 0;\nexport const IgxAvatarSize = /*@__PURE__*/mkenum({\n    SMALL: 'small',\n    MEDIUM: 'medium',\n    LARGE: 'large'\n});\nexport type IgxAvatarSize = (typeof IgxAvatarSize)[keyof typeof IgxAvatarSize];\n\nexport const IgxAvatarType = /*@__PURE__*/mkenum({\n    INITIALS: 'initials',\n    IMAGE: 'image',\n    ICON: 'icon',\n    CUSTOM: 'custom'\n});\nexport type IgxAvatarType = (typeof IgxAvatarType)[keyof typeof IgxAvatarType];\n\n/**\n * Avatar provides a way to display an image, icon or initials to the user.\n *\n * @igxModule IgxAvatarModule\n *\n * @igxTheme igx-avatar-theme, igx-icon-theme\n *\n * @igxKeywords avatar, profile, picture, initials\n *\n * @igxGroup Layouts\n *\n * @remarks\n *\n * The Ignite UI Avatar provides an easy way to add an avatar icon to your application.  This icon can be an\n * image, someone's initials or a material icon from the Google Material icon set.\n *\n * @example\n * ```html\n * <igx-avatar initials=\"MS\" shape=\"rounded\" size=\"large\">\n * </igx-avatar>\n * ```\n */\n@Component({\n    selector: 'igx-avatar',\n    templateUrl: 'avatar.component.html',\n    standalone: true,\n    imports: [IgxIconComponent, NgTemplateOutlet]\n})\nexport class IgxAvatarComponent implements OnInit {\n    /**\n     * Returns the `aria-label` attribute of the avatar.\n     *\n     * @example\n     * ```typescript\n     * let ariaLabel = this.avatar.ariaLabel;\n     * ```\n     *\n     */\n    @HostBinding('attr.aria-label')\n    public ariaLabel = 'avatar';\n\n    /**\n     * Returns the `role` attribute of the avatar.\n     *\n     * @example\n     * ```typescript\n     * let avatarRole = this.avatar.role;\n     * ```\n     */\n    @HostBinding('attr.role')\n    public role = 'img';\n\n    /**\n     * Host `class.igx-avatar` binding.\n     *\n     * @hidden\n     * @internal\n     */\n    @HostBinding('class.igx-avatar')\n    public cssClass = 'igx-avatar';\n\n    /**\n     * Returns the type of the avatar.\n     * The avatar can be:\n     * - `\"initials type avatar\"`\n     * - `\"icon type avatar\"`\n     * - `\"image type avatar\"`.\n     * - `\"custom type avatar\"`.\n     *\n     * @example\n     * ```typescript\n     * let avatarDescription = this.avatar.roleDescription;\n     * ```\n     */\n    @HostBinding('attr.aria-roledescription')\n    public roleDescription: string;\n\n    /**\n     * Sets the `id` of the avatar. If not set, the first avatar component will have `id` = `\"igx-avatar-0\"`.\n     *\n     * @example\n     * ```html\n     * <igx-avatar id=\"my-first-avatar\"></igx-avatar>\n     * ```\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-avatar-${NEXT_ID++}`;\n\n    /**\n     * Sets square, rounded or circular shape to the avatar.\n     * By default the shape of the avatar is square.\n     *\n     * @example\n     * ```html\n     * <igx-avatar shape=\"rounded\"></igx-avatar>\n     * ```\n     */\n    @Input()\n    public shape: 'square' | 'rounded' | 'circle' = 'square';\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-avatar--rounded')\n    public get isRounded(): boolean {\n        return this.shape === 'rounded';\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-avatar--circle')\n    public get isCircle(): boolean {\n        return this.shape === 'circle';\n    }\n\n    /**\n     * Sets the color of the avatar's initials or icon.\n     *\n     * @example\n     * ```html\n     * <igx-avatar color=\"blue\"></igx-avatar>\n     * ```\n     * @deprecated in version 17.2.0.\n     */\n\n    @HostBinding('style.color')\n    @Input()\n    public color: string;\n\n    /**\n     * Sets the background color of the avatar.\n     *\n     * @example\n     * ```html\n     * <igx-avatar bgColor=\"yellow\"></igx-avatar>\n     * ```\n     * @igxFriendlyName Background color\n     * @deprecated in version 17.2.0.\n     */\n\n    @HostBinding('style.background')\n    @Input()\n    public bgColor: string;\n\n    /**\n     * Sets initials to the avatar.\n     *\n     * @example\n     * ```html\n     * <igx-avatar initials=\"MN\"></igx-avatar>\n     * ```\n     */\n    @Input()\n    public initials: string;\n\n    /**\n     * Sets an icon to the avatar. All icons from the material icon set are supported.\n     *\n     * @example\n     * ```html\n     * <igx-avatar icon=\"phone\"></igx-avatar>\n     * ```\n     */\n    @Input()\n    public icon: string;\n\n    /**\n     * Sets the image source of the avatar.\n     *\n     * @example\n     * ```html\n     * <igx-avatar src=\"images/picture.jpg\"></igx-avatar>\n     * ```\n     * @igxFriendlyName Image URL\n     */\n    @Input()\n    public set src(value: string) {\n        this._src = normalizeURI(value);\n    }\n\n    public get src() {\n        return this._src;\n    }\n\n    /** @hidden @internal */\n    @ViewChild('defaultTemplate', { read: TemplateRef, static: true })\n    protected defaultTemplate: TemplateRef<any>;\n\n    /** @hidden @internal */\n    @ViewChild('imageTemplate', { read: TemplateRef, static: true })\n    protected imageTemplate: TemplateRef<any>;\n\n    /** @hidden @internal */\n    @ViewChild('initialsTemplate', { read: TemplateRef, static: true })\n    protected initialsTemplate: TemplateRef<any>;\n\n    /** @hidden @internal */\n    @ViewChild('iconTemplate', { read: TemplateRef, static: true })\n    protected iconTemplate: TemplateRef<any>;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    private _size: string | IgxAvatarSize;\n    private _src: string;\n\n    /**\n     * Returns the size of the avatar.\n     *\n     * @example\n     * ```typescript\n     * let avatarSize = this.avatar.size;\n     * ```\n     */\n    @Input()\n    public get size(): string | IgxAvatarSize {\n        return this._size || IgxAvatarSize.SMALL;\n    }\n\n    /**\n     * Sets the size  of the avatar.\n     * By default, the size is `\"small\"`. It can be set to `\"medium\"` or `\"large\"`.\n     *\n     * @example\n     * ```html\n     * <igx-avatar size=\"large\"></igx-avatar>\n     * ```\n     */\n    public set size(value: string | IgxAvatarSize) {\n        switch (value) {\n            case 'small':\n            case 'medium':\n            case 'large':\n                this._size = value;\n                break;\n            default:\n                this._size = 'small';\n        }\n    }\n\n    /**\n     * Returns the type of the avatar.\n     *\n     * @example\n     * ```typescript\n     * let avatarType = this.avatar.type;\n     * ```\n     */\n    public get type(): IgxAvatarType {\n        if (this.src) {\n            return IgxAvatarType.IMAGE;\n        }\n\n        if (this.icon) {\n            return IgxAvatarType.ICON;\n        }\n\n        if (this.initials) {\n            return IgxAvatarType.INITIALS;\n        }\n\n        return IgxAvatarType.CUSTOM;\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-avatar--image')\n    public get _isImageType(): boolean {\n        return this.type === IgxAvatarType.IMAGE;\n    }\n    /** @hidden @internal */\n    @HostBinding('class.igx-avatar--icon')\n    public get _isIconType(): boolean {\n        return this.type === IgxAvatarType.ICON;\n    }\n    /** @hidden @internal */\n    @HostBinding('class.igx-avatar--initials')\n    public get _isInitialsType(): boolean {\n        return this.type === IgxAvatarType.INITIALS;\n    }\n\n    @HostBinding('style.--component-size')\n    protected get componentSize() {\n        if (this._size) {\n            return `var(--ig-size-${this._size})`;\n        }\n    }\n\n    /**\n     * Returns the template of the avatar.\n     *\n     * @hidden\n     * @internal\n     */\n    public get template(): TemplateRef<any> {\n        switch (this.type) {\n            case IgxAvatarType.IMAGE:\n                return this.imageTemplate;\n            case IgxAvatarType.INITIALS:\n                return this.initialsTemplate;\n            case IgxAvatarType.ICON:\n                return this.iconTemplate;\n            default:\n                return this.defaultTemplate;\n        }\n    }\n\n    constructor(public elementRef: ElementRef) { }\n\n    /**\n     * Returns the css url of the image.\n     *\n     * @hidden\n     * @internal\n     */\n    public getSrcUrl() {\n        return `url(${this.src})`;\n    }\n\n    /** @hidden @internal */\n    public ngOnInit() {\n        this.roleDescription = this.getRole();\n    }\n\n    /** @hidden @internal */\n    private getRole(): string {\n        switch (this.type) {\n            case IgxAvatarType.IMAGE:\n                return 'image avatar';\n            case IgxAvatarType.ICON:\n                return 'icon avatar';\n            case IgxAvatarType.INITIALS:\n                return 'initials avatar';\n            default:\n                return 'custom avatar';\n        }\n    }\n}\n\n","<ng-template #defaultTemplate>\n    <ng-content></ng-content>\n</ng-template>\n\n<ng-template #imageTemplate>\n    <div #image class=\"igx-avatar__image\" [style.backgroundImage]=\"getSrcUrl()\"></div>\n</ng-template>\n\n<ng-template #initialsTemplate>\n    <span>{{initials.substring(0, 2)}}</span>\n</ng-template>\n\n<ng-template #iconTemplate>\n     <igx-icon>{{icon}}</igx-icon>\n</ng-template>\n\n<ng-container *ngTemplateOutlet=\"template\"></ng-container>\n"]}
@@ -1,4 +1,4 @@
1
- import { Component, EventEmitter, HostListener, HostBinding, Input, Output, ViewChild, Optional, Self, booleanAttribute } from '@angular/core';
1
+ import { Component, EventEmitter, HostListener, HostBinding, Input, Output, ViewChild, ElementRef, Optional, Self, booleanAttribute, inject, DestroyRef } from '@angular/core';
2
2
  import { Validators } from '@angular/forms';
3
3
  import { IgxRippleDirective } from '../directives/ripple/ripple.directive';
4
4
  import { mkenum } from '../core/utils';
@@ -65,6 +65,50 @@ export class IgxCheckboxComponent {
65
65
  set required(value) {
66
66
  this._required = value;
67
67
  }
68
+ /**
69
+ * Returns if the component is of type `material`.
70
+ *
71
+ * @example
72
+ * ```typescript
73
+ * let checkbox = this.checkbox.material;
74
+ * ```
75
+ */
76
+ get material() {
77
+ return this.theme === 'material';
78
+ }
79
+ /**
80
+ * Returns if the component is of type `indigo`.
81
+ *
82
+ * @example
83
+ * ```typescript
84
+ * let checkbox = this.checkbox.indigo;
85
+ * ```
86
+ */
87
+ get indigo() {
88
+ return this.theme === 'indigo';
89
+ }
90
+ /**
91
+ * Returns if the component is of type `bootstrap`.
92
+ *
93
+ * @example
94
+ * ```typescript
95
+ * let checkbox = this.checkbox.bootstrap;
96
+ * ```
97
+ */
98
+ get bootstrap() {
99
+ return this.theme === 'bootstrap';
100
+ }
101
+ /**
102
+ * Returns if the component is of type `fluent`.
103
+ *
104
+ * @example
105
+ * ```typescript
106
+ * let checkbox = this.checkbox.fluent;
107
+ * ```
108
+ */
109
+ get fluent() {
110
+ return this.theme === 'fluent';
111
+ }
68
112
  /**
69
113
  * Sets/gets whether the checkbox is checked.
70
114
  * Default value is `false`.
@@ -301,15 +345,18 @@ export class IgxCheckboxComponent {
301
345
  * @internal
302
346
  */
303
347
  this._required = false;
304
- /**
305
- * @hidden
306
- * @internal
307
- */
308
- this.theme = 'material';
309
- this.theme = this.themeService?.globalTheme;
348
+ this.elRef = inject(ElementRef);
349
+ this._theme$ = new Subject();
350
+ this.destroyRef = inject(DestroyRef);
310
351
  if (this.ngControl !== null) {
311
352
  this.ngControl.valueAccessor = this;
312
353
  }
354
+ this.theme = this.themeService.globalTheme;
355
+ this._subscription = this._theme$.asObservable().subscribe(value => {
356
+ this.theme = value;
357
+ this.cdr.detectChanges();
358
+ });
359
+ this.destroyRef.onDestroy(() => this._subscription.unsubscribe());
313
360
  }
314
361
  /**
315
362
  * @hidden
@@ -323,6 +370,11 @@ export class IgxCheckboxComponent {
323
370
  this.cdr.detectChanges();
324
371
  }
325
372
  }
373
+ const theme = this.themeService.getComponentTheme(this.elRef);
374
+ if (theme) {
375
+ this._theme$.next(theme);
376
+ this.cdr.markForCheck();
377
+ }
326
378
  }
327
379
  /** @hidden @internal */
328
380
  onKeyUp(event) {
@@ -444,7 +496,7 @@ export class IgxCheckboxComponent {
444
496
  }
445
497
  }
446
498
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.4", ngImport: i0, type: IgxCheckboxComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }, { token: i1.ThemeService }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
447
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.4", type: IgxCheckboxComponent, isStandalone: true, selector: "igx-checkbox", inputs: { id: "id", labelId: "labelId", value: "value", name: "name", tabindex: "tabindex", labelPosition: "labelPosition", disableRipple: ["disableRipple", "disableRipple", booleanAttribute], required: ["required", "required", booleanAttribute], ariaLabelledBy: ["aria-labelledby", "ariaLabelledBy"], ariaLabel: ["aria-label", "ariaLabel"], indeterminate: ["indeterminate", "indeterminate", booleanAttribute], checked: ["checked", "checked", booleanAttribute], disabled: ["disabled", "disabled", booleanAttribute], invalid: ["invalid", "invalid", booleanAttribute], readonly: ["readonly", "readonly", booleanAttribute], disableTransitions: ["disableTransitions", "disableTransitions", booleanAttribute] }, outputs: { change: "change" }, host: { listeners: { "keyup": "onKeyUp($event)", "click": "_onCheckboxClick($event)", "blur": "onBlur()" }, properties: { "attr.id": "this.id", "class.igx-checkbox": "this.cssClass", "class.igx-checkbox--focused": "this.focused", "class.igx-checkbox--indeterminate": "this.indeterminate", "class.igx-checkbox--checked": "this.checked", "class.igx-checkbox--disabled": "this.disabled", "class.igx-checkbox--invalid": "this.invalid", "class.igx-checkbox--plain": "this.disableTransitions" } }, providers: [{
499
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.4", type: IgxCheckboxComponent, isStandalone: true, selector: "igx-checkbox", inputs: { id: "id", labelId: "labelId", value: "value", name: "name", tabindex: "tabindex", labelPosition: "labelPosition", disableRipple: ["disableRipple", "disableRipple", booleanAttribute], required: ["required", "required", booleanAttribute], ariaLabelledBy: ["aria-labelledby", "ariaLabelledBy"], ariaLabel: ["aria-label", "ariaLabel"], indeterminate: ["indeterminate", "indeterminate", booleanAttribute], checked: ["checked", "checked", booleanAttribute], disabled: ["disabled", "disabled", booleanAttribute], invalid: ["invalid", "invalid", booleanAttribute], readonly: ["readonly", "readonly", booleanAttribute], disableTransitions: ["disableTransitions", "disableTransitions", booleanAttribute] }, outputs: { change: "change" }, host: { listeners: { "keyup": "onKeyUp($event)", "click": "_onCheckboxClick($event)", "blur": "onBlur()" }, properties: { "attr.id": "this.id", "class.igx-checkbox": "this.cssClass", "class.igx-checkbox--material": "this.material", "class.igx-checkbox--indigo": "this.indigo", "class.igx-checkbox--bootstrap": "this.bootstrap", "class.igx-checkbox--fluent": "this.fluent", "class.igx-checkbox--focused": "this.focused", "class.igx-checkbox--indeterminate": "this.indeterminate", "class.igx-checkbox--checked": "this.checked", "class.igx-checkbox--disabled": "this.disabled", "class.igx-checkbox--invalid": "this.invalid", "class.igx-checkbox--plain": "this.disableTransitions" } }, providers: [{
448
500
  provide: EDITOR_PROVIDER,
449
501
  useExisting: IgxCheckboxComponent,
450
502
  multi: true
@@ -502,6 +554,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImpor
502
554
  }], cssClass: [{
503
555
  type: HostBinding,
504
556
  args: ['class.igx-checkbox']
557
+ }], material: [{
558
+ type: HostBinding,
559
+ args: ['class.igx-checkbox--material']
560
+ }], indigo: [{
561
+ type: HostBinding,
562
+ args: ['class.igx-checkbox--indigo']
563
+ }], bootstrap: [{
564
+ type: HostBinding,
565
+ args: ['class.igx-checkbox--bootstrap']
566
+ }], fluent: [{
567
+ type: HostBinding,
568
+ args: ['class.igx-checkbox--fluent']
505
569
  }], focused: [{
506
570
  type: HostBinding,
507
571
  args: ['class.igx-checkbox--focused']
@@ -548,4 +612,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.4", ngImpor
548
612
  type: HostListener,
549
613
  args: ['blur']
550
614
  }] } });
551
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/checkbox/checkbox.component.ts","../../../../../projects/igniteui-angular/src/lib/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    HostListener,\n    HostBinding,\n    Input,\n    Output,\n    ViewChild,\n    ElementRef,\n    AfterViewInit,\n    ChangeDetectorRef,\n    Renderer2,\n    Optional,\n    Self,\n    booleanAttribute\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl, Validators } from '@angular/forms';\nimport { IgxRippleDirective } from '../directives/ripple/ripple.directive';\nimport { IBaseEventArgs, mkenum } from '../core/utils';\nimport { EditorProvider, EDITOR_PROVIDER } from '../core/edit-provider';\nimport { noop, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { IgxTheme, ThemeService } from '../services/theme/theme.service';\n\nexport const LabelPosition = /*@__PURE__*/mkenum({\n    BEFORE: 'before',\n    AFTER: 'after'\n});\nexport type LabelPosition = typeof LabelPosition[keyof typeof LabelPosition];\n\nexport interface IChangeCheckboxEventArgs extends IBaseEventArgs {\n    checked: boolean;\n    value?: any;\n}\n\nlet nextId = 0;\n/**\n * Allows users to make a binary choice for a certain condition.\n *\n * @igxModule IgxCheckboxModule\n *\n * @igxTheme igx-checkbox-theme\n *\n * @igxKeywords checkbox, label\n *\n * @igxGroup Data entry and display\n *\n * @remarks\n * The Ignite UI Checkbox is a selection control that allows users to make a binary choice for a certain condition.It behaves similarly\n * to the native browser checkbox.\n *\n * @example\n * ```html\n * <igx-checkbox [checked]=\"true\">\n *   simple checkbox\n * </igx-checkbox>\n * ```\n */\n@Component({\n    selector: 'igx-checkbox',\n    providers: [{\n        provide: EDITOR_PROVIDER,\n        useExisting: IgxCheckboxComponent,\n        multi: true\n    }],\n    preserveWhitespaces: false,\n    templateUrl: 'checkbox.component.html',\n    standalone: true,\n    imports: [IgxRippleDirective]\n})\nexport class IgxCheckboxComponent implements EditorProvider, AfterViewInit, ControlValueAccessor {\n\n    /**\n     * An event that is emitted after the checkbox state is changed.\n     * Provides references to the `IgxCheckboxComponent` and the `checked` property as event arguments.\n     */\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() public readonly change: EventEmitter<IChangeCheckboxEventArgs> = new EventEmitter<IChangeCheckboxEventArgs>();\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public destroy$ = new Subject<boolean>();\n\n    /**\n     * Returns reference to the native checkbox element.\n     *\n     * @example\n     * ```typescript\n     * let checkboxElement =  this.component.checkboxElement;\n     * ```\n     */\n    @ViewChild('checkbox', { static: true })\n    public nativeInput: ElementRef;\n\n    /**\n     * Returns reference to the native label element.\n     * ```typescript\n     *\n     * @example\n     * let labelElement =  this.component.nativeLabel;\n     * ```\n     */\n    @ViewChild('label', { static: true })\n    public nativeLabel: ElementRef;\n\n    /**\n     * Returns reference to the `nativeElement` of the igx-checkbox/igx-switch.\n     *\n     * @example\n     * ```typescript\n     * let nativeElement = this.component.nativeElement;\n     * ```\n     */\n    public get nativeElement() {\n        return this.nativeInput.nativeElement;\n    }\n\n    /**\n     * Returns reference to the label placeholder element.\n     * ```typescript\n     *\n     * @example\n     * let labelPlaceholder =  this.component.placeholderLabel;\n     * ```\n     */\n    @ViewChild('placeholderLabel', { static: true })\n    public placeholderLabel: ElementRef;\n\n    /**\n     * Sets/gets the `id` of the checkbox component.\n     * If not set, the `id` of the first checkbox component will be `\"igx-checkbox-0\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox id=\"my-first-checkbox\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let checkboxId =  this.checkbox.id;\n     * ```\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-checkbox-${nextId++}`;\n\n    /**\n     * Sets/gets the id of the `label` element.\n     * If not set, the id of the `label` in the first checkbox component will be `\"igx-checkbox-0-label\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox labelId=\"Label1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let labelId =  this.component.labelId;\n     * ```\n     */\n    @Input() public labelId = `${this.id}-label`;\n\n    /**\n     * Sets/gets the `value` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [value]=\"'CheckboxValue'\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let value =  this.checkbox.value;\n     * ```\n     */\n    @Input() public value: any;\n\n    /**\n     * Sets/gets the `name` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox name=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let name =  this.checkbox.name;\n     * ```\n     */\n    @Input() public name: string;\n\n    /**\n     * Sets/gets the value of the `tabindex` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [tabindex]=\"1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let tabIndex =  this.checkbox.tabindex;\n     * ```\n     */\n    @Input() public tabindex: number = null;\n\n    /**\n     *  Sets/gets the position of the `label`.\n     *  If not set, the `labelPosition` will have value `\"after\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox labelPosition=\"before\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let labelPosition =  this.checkbox.labelPosition;\n     * ```\n     */\n    @Input()\n    public labelPosition: LabelPosition | string = LabelPosition.AFTER;\n\n    /**\n     * Enables/Disables the ripple effect.\n     * If not set, `disableRipple` will have value `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [disableRipple]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isRippleDisabled = this.checkbox.desableRipple;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public disableRipple = false;\n\n    /**\n     * Sets/gets whether the checkbox is required.\n     * If not set, `required` will have value `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox required></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isRequired = this.checkbox.required;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public get required(): boolean {\n        return this._required || this.nativeElement.hasAttribute('required');\n    }\n    public set required(value: boolean) {\n        this._required = value;\n    }\n\n    /**\n     * Sets/gets the `aria-labelledby` attribute.\n     * If not set, the `aria-labelledby` will be equal to the value of `labelId` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox aria-labelledby=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let ariaLabelledBy = this.checkbox.ariaLabelledBy;\n     * ```\n     */\n    @Input('aria-labelledby')\n    public ariaLabelledBy = this.labelId;\n\n    /**\n     * Sets/gets the value of the `aria-label` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox aria-label=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let ariaLabel = this.checkbox.ariaLabel;\n     * ```\n     */\n    @Input('aria-label')\n    public ariaLabel: string | null = null;\n\n    /**\n     * Returns the class of the checkbox component.\n     *\n     * @example\n     * ```typescript\n     * let class = this.checkbox.cssClass;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox')\n    public cssClass = 'igx-checkbox';\n\n    /**\n     * Sets/gets whether the checkbox component is on focus.\n     * Default value is `false`.\n     *\n     * @example\n     * ```typescript\n     * this.checkbox.focused =  true;\n     * ```\n     * ```typescript\n     * let isFocused = this.checkbox.focused;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--focused')\n    public focused = false;\n\n    /**\n     * Sets/gets the checkbox indeterminate visual state.\n     * Default value is `false`;\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [indeterminate]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isIndeterminate = this.checkbox.indeterminate;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--indeterminate')\n    @Input({ transform: booleanAttribute })\n    public indeterminate = false;\n\n    /**\n     * Sets/gets whether the checkbox is checked.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [checked]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isChecked =  this.checkbox.checked;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--checked')\n    @Input({ transform: booleanAttribute })\n    public get checked() {\n        return this._checked;\n    }\n    public set checked(value: boolean) {\n        if (this._checked !== value) {\n            this._checked = value;\n            this._onChangeCallback(this._checked);\n        }\n    }\n\n    /**\n     * Sets/gets whether the checkbox is disabled.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox disabled></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isDisabled = this.checkbox.disabled;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--disabled')\n    @Input({ transform: booleanAttribute })\n    public disabled = false;\n\n    /**\n     * Sets/gets whether the checkbox is invalid.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox invalid></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isInvalid = this.checkbox.invalid;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--invalid')\n    @Input({ transform: booleanAttribute })\n    public invalid = false\n\n    /**\n     * Sets/gets whether the checkbox is readonly.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [readonly]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let readonly = this.checkbox.readonly;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public readonly = false;\n\n    /**\n     * Sets/gets whether the checkbox should disable all css transitions.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [disableTransitions]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let disableTransitions = this.checkbox.disableTransitions;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--plain')\n    @Input({ transform: booleanAttribute })\n    public disableTransitions = false;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public inputId = `${this.id}-input`;\n    /**\n     * @hidden\n     */\n    protected _onChangeCallback: (_: any) => void = noop;\n    /**\n     * @hidden\n     */\n    private _onTouchedCallback: () => void = noop;\n    /**\n     * @hidden\n     * @internal\n     */\n    protected _checked = false;\n    /**\n     * @hidden\n     * @internal\n     */\n    private _required = false;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    protected theme: IgxTheme = 'material';\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected renderer: Renderer2,\n        protected themeService: ThemeService,\n        @Optional() @Self() public ngControl: NgControl,\n    ) {\n        this.theme = this.themeService?.globalTheme;\n\n        if (this.ngControl !== null) {\n            this.ngControl.valueAccessor = this;\n        }\n    }\n\n    /**\n     * @hidden\n     * @internal\n    */\n    public ngAfterViewInit() {\n        if (this.ngControl) {\n            this.ngControl.statusChanges.pipe(takeUntil(this.destroy$)).subscribe(this.updateValidityState.bind(this));\n\n            if (this.ngControl.control.validator || this.ngControl.control.asyncValidator) {\n                this._required = this.ngControl?.control?.hasValidator(Validators.required);\n                this.cdr.detectChanges();\n            }\n        }\n    }\n\n    /** @hidden @internal */\n    @HostListener('keyup', ['$event'])\n    public onKeyUp(event: KeyboardEvent) {\n        event.stopPropagation();\n        this.focused = true;\n    }\n\n    /** @hidden @internal */\n    @HostListener('click', ['$event'])\n    public _onCheckboxClick(event: PointerEvent | MouseEvent) {\n        // Since the original checkbox is hidden and the label\n        // is used for styling and to change the checked state of the checkbox,\n        // we need to prevent the checkbox click event from bubbling up\n        // as it gets triggered on label click\n        // NOTE: The above is no longer valid, as the native checkbox is not labeled\n        // by the SVG anymore.\n        if (this.disabled || this.readonly) {\n            // readonly prevents the component from changing state (see toggle() method).\n            // However, the native checkbox can still be activated through user interaction (focus + space, label click)\n            // Prevent the native change so the input remains in sync\n            event.preventDefault();\n            return;\n        }\n\n        this.nativeInput.nativeElement.focus();\n\n        this.indeterminate = false;\n        this.checked = !this.checked;\n        this.updateValidityState();\n\n        // K.D. March 23, 2021 Emitting on click and not on the setter because otherwise every component\n        // bound on change would have to perform self checks for weather the value has changed because\n        // of the initial set on initialization\n        this.change.emit({ checked: this.checked, value: this.value, owner: this });\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public get ariaChecked() {\n        if (this.indeterminate) {\n            return 'mixed';\n        } else {\n            return this.checked;\n        }\n    }\n\n    /** @hidden @internal */\n    public _onCheckboxChange(event: Event) {\n        // We have to stop the original checkbox change event\n        // from bubbling up since we emit our own change event\n        event.stopPropagation();\n    }\n\n    /** @hidden @internal */\n    @HostListener('blur')\n    public onBlur() {\n        this.focused = false;\n        this._onTouchedCallback();\n        this.updateValidityState();\n    }\n\n    /** @hidden @internal */\n    public writeValue(value: boolean) {\n        this._checked = value;\n    }\n\n    /** @hidden @internal */\n    public get labelClass(): string {\n        switch (this.labelPosition) {\n            case LabelPosition.BEFORE:\n                return `${this.cssClass}__label--before`;\n            case LabelPosition.AFTER:\n            default:\n                return `${this.cssClass}__label`;\n        }\n    }\n\n    /** @hidden @internal */\n    public registerOnChange(fn: (_: any) => void) {\n        this._onChangeCallback = fn;\n    }\n\n    /** @hidden @internal */\n    public registerOnTouched(fn: () => void) {\n        this._onTouchedCallback = fn;\n    }\n\n    /** @hidden @internal */\n    public setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n\n    /** @hidden @internal */\n    public getEditElement() {\n        return this.nativeInput.nativeElement;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    protected updateValidityState() {\n        if (this.ngControl) {\n            if (!this.disabled && !this.readonly &&\n                (this.ngControl.control.touched || this.ngControl.control.dirty)) {\n                // the control is not disabled and is touched or dirty\n                this.invalid = this.ngControl.invalid;\n            } else {\n                //  if the control is untouched, pristine, or disabled, its state is initial. This is when the user did not interact\n                //  with the checkbox or when the form/control is reset\n                this.invalid = false;\n            }\n        } else {\n            this.checkNativeValidity();\n        }\n    }\n\n    /**\n     * A function to assign a native validity property of a checkbox.\n     * This should be used when there's no ngControl\n     *\n     * @hidden\n     * @internal\n     */\n    private checkNativeValidity() {\n        if (!this.disabled && this._required && !this.checked && !this.readonly) {\n            this.invalid = true;\n        } else {\n            this.invalid = false;\n        }\n    }\n}\n","<input #checkbox class=\"igx-checkbox__input\"\n    type=\"checkbox\"\n    [id]=\"inputId\"\n    [name]=\"name\"\n    [value]=\"value\"\n    [tabindex]=\"tabindex\"\n    [disabled]=\"disabled\"\n    [indeterminate]=\"indeterminate\"\n    [checked]=\"checked\"\n    [required]=\"required\"\n    [attr.aria-required]=\"required\"\n    [attr.aria-invalid]=\"invalid\"\n    [attr.aria-checked]=\"ariaChecked\"\n    [attr.aria-labelledby]=\"ariaLabel ? null : ariaLabelledBy\"\n    [attr.aria-label]=\"ariaLabel\"\n    (change)=\"_onCheckboxChange($event)\"\n    (blur)=\"onBlur()\" />\n\n<div\n    igxRipple\n    igxRippleTarget=\".igx-checkbox__ripple\"\n    [igxRippleDisabled]=\"disableRipple\"\n    [igxRippleCentered]=\"true\"\n    [igxRippleDuration]=\"300\"\n    class=\"igx-checkbox__composite-wrapper\"\n>\n    <span #label class=\"igx-checkbox__composite\">\n        @if (theme === 'indigo') {\n            <svg class=\"igx-checkbox__composite-mark\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n                <rect width=\"18\" height=\"4\" x=\"2\" y=\"9\" rx=\"1.85\"/>\n                <path d=\"M19.033 5a1.966 1.966 0 0 0-1.418.586l-8.479 8.577-2.753-2.77a1.971 1.971 0 0 0-2.8 0 1.998 1.998 0 0 0 0 2.822l4.155 4.196a1.955 1.955 0 0 0 2.8 0l9.879-9.99a1.998 1.998 0 0 0 0-2.821 1.966 1.966 0 0 0-1.384-.6Z\"/>\n            </svg>\n        } @else {\n            <svg class=\"igx-checkbox__composite-mark\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n                <path d=\"M4.1,12.7 9,17.6 20.3,6.3\"/>\n            </svg>\n        }\n    </span>\n\n    <div class=\"igx-checkbox__ripple\"></div>\n</div>\n\n<span #placeholderLabel\n    [class]=\"labelClass\"\n    [id]=\"labelId\">\n    <ng-content></ng-content>\n</span>\n"]}
615
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/checkbox/checkbox.component.ts","../../../../../projects/igniteui-angular/src/lib/checkbox/checkbox.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    HostListener,\n    HostBinding,\n    Input,\n    Output,\n    ViewChild,\n    ElementRef,\n    AfterViewInit,\n    ChangeDetectorRef,\n    Renderer2,\n    Optional,\n    Self,\n    booleanAttribute,\n    inject,\n    DestroyRef\n} from '@angular/core';\nimport { ControlValueAccessor, NgControl, Validators } from '@angular/forms';\nimport { IgxRippleDirective } from '../directives/ripple/ripple.directive';\nimport { IBaseEventArgs, mkenum } from '../core/utils';\nimport { EditorProvider, EDITOR_PROVIDER } from '../core/edit-provider';\nimport { noop, Subject, Subscription } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { IgxTheme, ThemeService } from '../services/theme/theme.service';\n\nexport const LabelPosition = /*@__PURE__*/mkenum({\n    BEFORE: 'before',\n    AFTER: 'after'\n});\nexport type LabelPosition = typeof LabelPosition[keyof typeof LabelPosition];\n\nexport interface IChangeCheckboxEventArgs extends IBaseEventArgs {\n    checked: boolean;\n    value?: any;\n}\n\nlet nextId = 0;\n/**\n * Allows users to make a binary choice for a certain condition.\n *\n * @igxModule IgxCheckboxModule\n *\n * @igxTheme igx-checkbox-theme\n *\n * @igxKeywords checkbox, label\n *\n * @igxGroup Data entry and display\n *\n * @remarks\n * The Ignite UI Checkbox is a selection control that allows users to make a binary choice for a certain condition.It behaves similarly\n * to the native browser checkbox.\n *\n * @example\n * ```html\n * <igx-checkbox [checked]=\"true\">\n *   simple checkbox\n * </igx-checkbox>\n * ```\n */\n@Component({\n    selector: 'igx-checkbox',\n    providers: [{\n        provide: EDITOR_PROVIDER,\n        useExisting: IgxCheckboxComponent,\n        multi: true\n    }],\n    preserveWhitespaces: false,\n    templateUrl: 'checkbox.component.html',\n    standalone: true,\n    imports: [IgxRippleDirective]\n})\nexport class IgxCheckboxComponent implements EditorProvider, AfterViewInit, ControlValueAccessor {\n\n    /**\n     * An event that is emitted after the checkbox state is changed.\n     * Provides references to the `IgxCheckboxComponent` and the `checked` property as event arguments.\n     */\n    // eslint-disable-next-line @angular-eslint/no-output-native\n    @Output() public readonly change: EventEmitter<IChangeCheckboxEventArgs> = new EventEmitter<IChangeCheckboxEventArgs>();\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public destroy$ = new Subject<boolean>();\n\n    /**\n     * Returns reference to the native checkbox element.\n     *\n     * @example\n     * ```typescript\n     * let checkboxElement =  this.component.checkboxElement;\n     * ```\n     */\n    @ViewChild('checkbox', { static: true })\n    public nativeInput: ElementRef;\n\n    /**\n     * Returns reference to the native label element.\n     * ```typescript\n     *\n     * @example\n     * let labelElement =  this.component.nativeLabel;\n     * ```\n     */\n    @ViewChild('label', { static: true })\n    public nativeLabel: ElementRef;\n\n    /**\n     * Returns reference to the `nativeElement` of the igx-checkbox/igx-switch.\n     *\n     * @example\n     * ```typescript\n     * let nativeElement = this.component.nativeElement;\n     * ```\n     */\n    public get nativeElement() {\n        return this.nativeInput.nativeElement;\n    }\n\n    /**\n     * Returns reference to the label placeholder element.\n     * ```typescript\n     *\n     * @example\n     * let labelPlaceholder =  this.component.placeholderLabel;\n     * ```\n     */\n    @ViewChild('placeholderLabel', { static: true })\n    public placeholderLabel: ElementRef;\n\n    /**\n     * Sets/gets the `id` of the checkbox component.\n     * If not set, the `id` of the first checkbox component will be `\"igx-checkbox-0\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox id=\"my-first-checkbox\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let checkboxId =  this.checkbox.id;\n     * ```\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-checkbox-${nextId++}`;\n\n    /**\n     * Sets/gets the id of the `label` element.\n     * If not set, the id of the `label` in the first checkbox component will be `\"igx-checkbox-0-label\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox labelId=\"Label1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let labelId =  this.component.labelId;\n     * ```\n     */\n    @Input() public labelId = `${this.id}-label`;\n\n    /**\n     * Sets/gets the `value` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [value]=\"'CheckboxValue'\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let value =  this.checkbox.value;\n     * ```\n     */\n    @Input() public value: any;\n\n    /**\n     * Sets/gets the `name` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox name=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let name =  this.checkbox.name;\n     * ```\n     */\n    @Input() public name: string;\n\n    /**\n     * Sets/gets the value of the `tabindex` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [tabindex]=\"1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let tabIndex =  this.checkbox.tabindex;\n     * ```\n     */\n    @Input() public tabindex: number = null;\n\n    /**\n     *  Sets/gets the position of the `label`.\n     *  If not set, the `labelPosition` will have value `\"after\"`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox labelPosition=\"before\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let labelPosition =  this.checkbox.labelPosition;\n     * ```\n     */\n    @Input()\n    public labelPosition: LabelPosition | string = LabelPosition.AFTER;\n\n    /**\n     * Enables/Disables the ripple effect.\n     * If not set, `disableRipple` will have value `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [disableRipple]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isRippleDisabled = this.checkbox.desableRipple;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public disableRipple = false;\n\n    /**\n     * Sets/gets whether the checkbox is required.\n     * If not set, `required` will have value `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox required></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isRequired = this.checkbox.required;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public get required(): boolean {\n        return this._required || this.nativeElement.hasAttribute('required');\n    }\n    public set required(value: boolean) {\n        this._required = value;\n    }\n\n    /**\n     * Sets/gets the `aria-labelledby` attribute.\n     * If not set, the `aria-labelledby` will be equal to the value of `labelId` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox aria-labelledby=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let ariaLabelledBy = this.checkbox.ariaLabelledBy;\n     * ```\n     */\n    @Input('aria-labelledby')\n    public ariaLabelledBy = this.labelId;\n\n    /**\n     * Sets/gets the value of the `aria-label` attribute.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox aria-label=\"Checkbox1\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let ariaLabel = this.checkbox.ariaLabel;\n     * ```\n     */\n    @Input('aria-label')\n    public ariaLabel: string | null = null;\n\n    /**\n     * Returns the class of the checkbox component.\n     *\n     * @example\n     * ```typescript\n     * let class = this.checkbox.cssClass;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox')\n    public cssClass = 'igx-checkbox';\n\n    /**\n     * Returns if the component is of type `material`.\n     *\n     * @example\n     * ```typescript\n     * let checkbox = this.checkbox.material;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--material')\n    protected get material() {\n        return this.theme === 'material';\n    }\n\n    /**\n     * Returns if the component is of type `indigo`.\n     *\n     * @example\n     * ```typescript\n     * let checkbox = this.checkbox.indigo;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--indigo')\n    protected get indigo() {\n        return this.theme === 'indigo';\n    }\n\n    /**\n     * Returns if the component is of type `bootstrap`.\n     *\n     * @example\n     * ```typescript\n     * let checkbox = this.checkbox.bootstrap;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--bootstrap')\n    protected get bootstrap() {\n        return this.theme === 'bootstrap';\n    }\n\n    /**\n     * Returns if the component is of type `fluent`.\n     *\n     * @example\n     * ```typescript\n     * let checkbox = this.checkbox.fluent;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--fluent')\n    protected get fluent() {\n        return this.theme === 'fluent';\n    }\n\n    /**\n     * Sets/gets whether the checkbox component is on focus.\n     * Default value is `false`.\n     *\n     * @example\n     * ```typescript\n     * this.checkbox.focused =  true;\n     * ```\n     * ```typescript\n     * let isFocused = this.checkbox.focused;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--focused')\n    public focused = false;\n\n    /**\n     * Sets/gets the checkbox indeterminate visual state.\n     * Default value is `false`;\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [indeterminate]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isIndeterminate = this.checkbox.indeterminate;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--indeterminate')\n    @Input({ transform: booleanAttribute })\n    public indeterminate = false;\n\n    /**\n     * Sets/gets whether the checkbox is checked.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [checked]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isChecked =  this.checkbox.checked;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--checked')\n    @Input({ transform: booleanAttribute })\n    public get checked() {\n        return this._checked;\n    }\n    public set checked(value: boolean) {\n        if (this._checked !== value) {\n            this._checked = value;\n            this._onChangeCallback(this._checked);\n        }\n    }\n\n    /**\n     * Sets/gets whether the checkbox is disabled.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox disabled></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isDisabled = this.checkbox.disabled;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--disabled')\n    @Input({ transform: booleanAttribute })\n    public disabled = false;\n\n    /**\n     * Sets/gets whether the checkbox is invalid.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox invalid></igx-checkbox>\n     * ```\n     * ```typescript\n     * let isInvalid = this.checkbox.invalid;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--invalid')\n    @Input({ transform: booleanAttribute })\n    public invalid = false\n\n    /**\n     * Sets/gets whether the checkbox is readonly.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [readonly]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let readonly = this.checkbox.readonly;\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public readonly = false;\n\n    /**\n     * Sets/gets whether the checkbox should disable all css transitions.\n     * Default value is `false`.\n     *\n     * @example\n     * ```html\n     * <igx-checkbox [disableTransitions]=\"true\"></igx-checkbox>\n     * ```\n     * ```typescript\n     * let disableTransitions = this.checkbox.disableTransitions;\n     * ```\n     */\n    @HostBinding('class.igx-checkbox--plain')\n    @Input({ transform: booleanAttribute })\n    public disableTransitions = false;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public inputId = `${this.id}-input`;\n\n    /**\n     * @hidden\n     */\n    protected _onChangeCallback: (_: any) => void = noop;\n\n    /**\n     * @hidden\n     */\n    private _onTouchedCallback: () => void = noop;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    protected _checked = false;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    protected theme: IgxTheme;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    private _required = false;\n    private elRef = inject(ElementRef);\n    private _theme$ = new Subject<IgxTheme>();\n    private _subscription: Subscription;\n    private destroyRef = inject(DestroyRef);\n\n    constructor(\n        protected cdr: ChangeDetectorRef,\n        protected renderer: Renderer2,\n        protected themeService: ThemeService,\n        @Optional() @Self() public ngControl: NgControl,\n    ) {\n        if (this.ngControl !== null) {\n            this.ngControl.valueAccessor = this;\n        }\n\n        this.theme = this.themeService.globalTheme;\n\n        this._subscription = this._theme$.asObservable().subscribe(value => {\n            this.theme = value as IgxTheme;\n            this.cdr.detectChanges();\n        });\n\n        this.destroyRef.onDestroy(() => this._subscription.unsubscribe());\n    }\n\n    /**\n     * @hidden\n     * @internal\n    */\n    public ngAfterViewInit() {\n        if (this.ngControl) {\n            this.ngControl.statusChanges.pipe(takeUntil(this.destroy$)).subscribe(this.updateValidityState.bind(this));\n\n            if (this.ngControl.control.validator || this.ngControl.control.asyncValidator) {\n                this._required = this.ngControl?.control?.hasValidator(Validators.required);\n                this.cdr.detectChanges();\n            }\n        }\n\n        const theme = this.themeService.getComponentTheme(this.elRef);\n\n        if (theme) {\n            this._theme$.next(theme);\n            this.cdr.markForCheck();\n        }\n    }\n\n    /** @hidden @internal */\n    @HostListener('keyup', ['$event'])\n    public onKeyUp(event: KeyboardEvent) {\n        event.stopPropagation();\n        this.focused = true;\n    }\n\n    /** @hidden @internal */\n    @HostListener('click', ['$event'])\n    public _onCheckboxClick(event: PointerEvent | MouseEvent) {\n        // Since the original checkbox is hidden and the label\n        // is used for styling and to change the checked state of the checkbox,\n        // we need to prevent the checkbox click event from bubbling up\n        // as it gets triggered on label click\n        // NOTE: The above is no longer valid, as the native checkbox is not labeled\n        // by the SVG anymore.\n        if (this.disabled || this.readonly) {\n            // readonly prevents the component from changing state (see toggle() method).\n            // However, the native checkbox can still be activated through user interaction (focus + space, label click)\n            // Prevent the native change so the input remains in sync\n            event.preventDefault();\n            return;\n        }\n\n        this.nativeInput.nativeElement.focus();\n\n        this.indeterminate = false;\n        this.checked = !this.checked;\n        this.updateValidityState();\n\n        // K.D. March 23, 2021 Emitting on click and not on the setter because otherwise every component\n        // bound on change would have to perform self checks for weather the value has changed because\n        // of the initial set on initialization\n        this.change.emit({ checked: this.checked, value: this.value, owner: this });\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    public get ariaChecked() {\n        if (this.indeterminate) {\n            return 'mixed';\n        } else {\n            return this.checked;\n        }\n    }\n\n    /** @hidden @internal */\n    public _onCheckboxChange(event: Event) {\n        // We have to stop the original checkbox change event\n        // from bubbling up since we emit our own change event\n        event.stopPropagation();\n    }\n\n    /** @hidden @internal */\n    @HostListener('blur')\n    public onBlur() {\n        this.focused = false;\n        this._onTouchedCallback();\n        this.updateValidityState();\n    }\n\n    /** @hidden @internal */\n    public writeValue(value: boolean) {\n        this._checked = value;\n    }\n\n    /** @hidden @internal */\n    public get labelClass(): string {\n        switch (this.labelPosition) {\n            case LabelPosition.BEFORE:\n                return `${this.cssClass}__label--before`;\n            case LabelPosition.AFTER:\n            default:\n                return `${this.cssClass}__label`;\n        }\n    }\n\n    /** @hidden @internal */\n    public registerOnChange(fn: (_: any) => void) {\n        this._onChangeCallback = fn;\n    }\n\n    /** @hidden @internal */\n    public registerOnTouched(fn: () => void) {\n        this._onTouchedCallback = fn;\n    }\n\n    /** @hidden @internal */\n    public setDisabledState(isDisabled: boolean) {\n        this.disabled = isDisabled;\n    }\n\n    /** @hidden @internal */\n    public getEditElement() {\n        return this.nativeInput.nativeElement;\n    }\n\n    /**\n     * @hidden\n     * @internal\n     */\n    protected updateValidityState() {\n        if (this.ngControl) {\n            if (!this.disabled && !this.readonly &&\n                (this.ngControl.control.touched || this.ngControl.control.dirty)) {\n                // the control is not disabled and is touched or dirty\n                this.invalid = this.ngControl.invalid;\n            } else {\n                //  if the control is untouched, pristine, or disabled, its state is initial. This is when the user did not interact\n                //  with the checkbox or when the form/control is reset\n                this.invalid = false;\n            }\n        } else {\n            this.checkNativeValidity();\n        }\n    }\n\n    /**\n     * A function to assign a native validity property of a checkbox.\n     * This should be used when there's no ngControl\n     *\n     * @hidden\n     * @internal\n     */\n    private checkNativeValidity() {\n        if (!this.disabled && this._required && !this.checked && !this.readonly) {\n            this.invalid = true;\n        } else {\n            this.invalid = false;\n        }\n    }\n}\n","<input #checkbox class=\"igx-checkbox__input\"\n    type=\"checkbox\"\n    [id]=\"inputId\"\n    [name]=\"name\"\n    [value]=\"value\"\n    [tabindex]=\"tabindex\"\n    [disabled]=\"disabled\"\n    [indeterminate]=\"indeterminate\"\n    [checked]=\"checked\"\n    [required]=\"required\"\n    [attr.aria-required]=\"required\"\n    [attr.aria-invalid]=\"invalid\"\n    [attr.aria-checked]=\"ariaChecked\"\n    [attr.aria-labelledby]=\"ariaLabel ? null : ariaLabelledBy\"\n    [attr.aria-label]=\"ariaLabel\"\n    (change)=\"_onCheckboxChange($event)\"\n    (blur)=\"onBlur()\" />\n\n<div\n    igxRipple\n    igxRippleTarget=\".igx-checkbox__ripple\"\n    [igxRippleDisabled]=\"disableRipple\"\n    [igxRippleCentered]=\"true\"\n    [igxRippleDuration]=\"300\"\n    class=\"igx-checkbox__composite-wrapper\"\n>\n    <span #label class=\"igx-checkbox__composite\">\n        @if (theme === 'indigo') {\n            <svg class=\"igx-checkbox__composite-mark\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n                <rect width=\"18\" height=\"4\" x=\"2\" y=\"9\" rx=\"1.85\"/>\n                <path d=\"M19.033 5a1.966 1.966 0 0 0-1.418.586l-8.479 8.577-2.753-2.77a1.971 1.971 0 0 0-2.8 0 1.998 1.998 0 0 0 0 2.822l4.155 4.196a1.955 1.955 0 0 0 2.8 0l9.879-9.99a1.998 1.998 0 0 0 0-2.821 1.966 1.966 0 0 0-1.384-.6Z\"/>\n            </svg>\n        } @else {\n            <svg class=\"igx-checkbox__composite-mark\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 24 24\">\n                <path d=\"M4.1,12.7 9,17.6 20.3,6.3\"/>\n            </svg>\n        }\n    </span>\n\n    <div class=\"igx-checkbox__ripple\"></div>\n</div>\n\n<span #placeholderLabel\n    [class]=\"labelClass\"\n    [id]=\"labelId\">\n    <ng-content></ng-content>\n</span>\n"]}