igniteui-angular 18.1.5 → 18.1.6

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 (31) hide show
  1. package/esm2022/lib/input-group/input-group.component.mjs +5 -9
  2. package/fesm2022/igniteui-angular.mjs +4 -8
  3. package/fesm2022/igniteui-angular.mjs.map +1 -1
  4. package/lib/core/styles/components/divider/_divider-theme.scss +1 -1
  5. package/package.json +1 -1
  6. package/styles/igniteui-angular-dark.css +1 -1
  7. package/styles/igniteui-angular.css +1 -1
  8. package/styles/igniteui-bootstrap-dark.css +1 -1
  9. package/styles/igniteui-bootstrap-light.css +1 -1
  10. package/styles/igniteui-dark-green.css +1 -1
  11. package/styles/igniteui-fluent-dark-excel.css +1 -1
  12. package/styles/igniteui-fluent-dark-word.css +1 -1
  13. package/styles/igniteui-fluent-dark.css +1 -1
  14. package/styles/igniteui-fluent-light-excel.css +1 -1
  15. package/styles/igniteui-fluent-light-word.css +1 -1
  16. package/styles/igniteui-fluent-light.css +1 -1
  17. package/styles/igniteui-indigo-dark.css +1 -1
  18. package/styles/igniteui-indigo-light.css +1 -1
  19. package/styles/maps/igniteui-angular-dark.css.map +1 -1
  20. package/styles/maps/igniteui-angular.css.map +1 -1
  21. package/styles/maps/igniteui-bootstrap-dark.css.map +1 -1
  22. package/styles/maps/igniteui-bootstrap-light.css.map +1 -1
  23. package/styles/maps/igniteui-dark-green.css.map +1 -1
  24. package/styles/maps/igniteui-fluent-dark-excel.css.map +1 -1
  25. package/styles/maps/igniteui-fluent-dark-word.css.map +1 -1
  26. package/styles/maps/igniteui-fluent-dark.css.map +1 -1
  27. package/styles/maps/igniteui-fluent-light-excel.css.map +1 -1
  28. package/styles/maps/igniteui-fluent-light-word.css.map +1 -1
  29. package/styles/maps/igniteui-fluent-light.css.map +1 -1
  30. package/styles/maps/igniteui-indigo-dark.css.map +1 -1
  31. package/styles/maps/igniteui-indigo-light.css.map +1 -1
@@ -329,14 +329,10 @@ export class IgxInputGroupComponent {
329
329
  }
330
330
  /** @hidden @internal */
331
331
  ngAfterViewChecked() {
332
- if (!this._theme) {
333
- const theme = this.theme ?? this.themeService.getComponentTheme(this.element);
334
- if (theme) {
335
- Promise.resolve().then(() => {
336
- this._theme$.next(theme);
337
- this.cdr.markForCheck();
338
- });
339
- }
332
+ const theme = this.themeService.getComponentTheme(this.element);
333
+ if (theme) {
334
+ this._theme$.next(theme);
335
+ this.cdr.markForCheck();
340
336
  }
341
337
  }
342
338
  /** @hidden @internal */
@@ -443,4 +439,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImpor
443
439
  type: HostBinding,
444
440
  args: ['class.igx-input-group--search']
445
441
  }] } });
446
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-group.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/input-group/input-group.component.ts","../../../../../projects/igniteui-angular/src/lib/input-group/input-group.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,gBAAgB,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AACrH,OAAO,EAGH,SAAS,EACT,YAAY,EACZ,eAAe,EAEf,WAAW,EACX,YAAY,EAAE,MAAM,EAAE,KAAK,EAE3B,QAAQ,EAAa,gBAAgB,EACxC,MAAM,eAAe,CAAC;AACvB,OAAO,EAAyB,sBAAsB,EAAE,MAAM,8BAA8B,CAAC;AAE7F,OAAO,EAAE,kBAAkB,EAAE,MAAM,uCAAuC,CAAC;AAC3E,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AACrE,OAAO,EACH,iBAAiB,EACjB,aAAa,EAChB,MAAM,qCAAqC,CAAC;AAC7C,OAAO,EAAE,kBAAkB,EAAE,MAAM,uCAAuC,CAAC;AAC3E,OAAO,EAAE,kBAAkB,EAAE,MAAM,uCAAuC,CAAC;AAE3E,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AACzD,OAAO,EAAqB,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AAC3E,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,yBAAyB,EAAE,MAAM,wBAAwB,CAAC;AAEnE,OAAO,EAAE,OAAO,EAAgB,MAAM,MAAM,CAAC;;;;AAS7C,MAAM,OAAO,sBAAsB;IAC/B;;;OAGG;IACH,IACW,eAAe,CAAC,KAA4B;QACnD,IAAI,CAAC,gBAAgB,GAAG,MAAM,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC;IAC5E,CAAC;IAED;;OAEG;IACH,IAAW,eAAe;QACtB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IACjC,CAAC;IA6ED,cAAc;IACd,IACW,UAAU;QACjB,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,aAAa,CAAC,KAAK,CAAC;IACpD,CAAC;IAED,cAAc;IACd,IACW,YAAY;QACnB,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,aAAa,CAAC,OAAO,CAAC;IACtD,CAAC;IAED,cAAc;IACd,IACW,QAAQ;QACf,OAAO,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;IAC5D,CAAC;IAED,cAAc;IACd,IACW,aAAa;QACpB,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC;IACjC,CAAC;IAED;;;;;;OAMG;IACH,IACW,IAAI,CAAC,KAAwB;QACpC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACvB,CAAC;IAED;;;;;;;;;;OAUG;IACH,IAAW,IAAI;QACX,OAAO,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,eAAe,IAAI,MAAM,CAAC;IACxD,CAAC;IAED;;;;;;;;;OASG;IACH,IACW,KAAK,CAAC,KAAe;QAC5B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAED;;;;;;;;;OASG;IACH,IAAW,KAAK;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,YACW,OAAgC,EAG/B,eAAkC,EAElC,QAAa,EACb,QAAsB,EACtB,GAAsB,EACtB,YAA0B;QAR3B,YAAO,GAAP,OAAO,CAAyB;QAG/B,oBAAe,GAAf,eAAe,CAAmB;QAElC,aAAQ,GAAR,QAAQ,CAAK;QACb,aAAQ,GAAR,QAAQ,CAAc;QACtB,QAAG,GAAH,GAAG,CAAmB;QACtB,iBAAY,GAAZ,YAAY,CAAc;QApKtC;;;;;;;;;;WAUG;QAEI,iBAAY,GAAG,IAAI,CAAC;QAE3B,cAAc;QAEP,mBAAc,GAAG,KAAK,CAAC;QAE9B,cAAc;QAEP,eAAU,GAAG,KAAK,CAAC;QAE1B,cAAc;QAEP,cAAS,GAAG,KAAK,CAAC;QAEzB;;;;;;;WAOG;QAEI,aAAQ,GAAG,KAAK,CAAC;QAExB;;;;;;;;;WASG;QAEI,2BAAsB,GAAG,KAAK,CAAC;QAEtC,cAAc;QAEP,eAAU,GAAG,KAAK,CAAC;QAgBlB,UAAK,GAAsB,IAAI,CAAC;QAChC,YAAO,GAAG,KAAK,CAAC;QAEhB,YAAO,GAAG,IAAI,OAAO,EAAY,CAAC;QAElC,qBAAgB,GAAG,yBAAyB,CAAC,sBAAsB,CAAC,CAAC;QA6FzE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC;QAE5C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAC/D,IAAI,CAAC,MAAM,GAAG,KAAiB,CAAC;YAChC,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,cAAc;IAEP,OAAO,CAAC,KAAiB;QAC5B,IACI,CAAC,IAAI,CAAC,SAAS;YACf,KAAK,CAAC,MAAM,KAAK,IAAI,CAAC,KAAK,CAAC,aAAa;YACzC,CAAC,IAAI,CAAC,sBAAsB,EAC9B,CAAC;YACC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;QACvB,CAAC;IACL,CAAC;IAED,cAAc;IAEP,aAAa,CAAC,KAAmB;QACpC,IAAI,IAAI,CAAC,SAAS,IAAI,KAAK,CAAC,MAAM,KAAK,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;YAC9D,KAAK,CAAC,cAAc,EAAE,CAAC;QAC3B,CAAC;IACL,CAAC;IAED,wBAAwB;IACjB,gBAAgB,CAAC,KAAiB;QACrC,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;IAED;;;;;;;;;OASG;IACH,IAAW,QAAQ;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;IACjC,CAAC;IAED,wBAAwB;IACxB,IACW,WAAW;QAClB,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC;IACxD,CAAC;IAED,wBAAwB;IACxB,IAAW,QAAQ,CAAC,KAAoC;QACpD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,wBAAwB;IACxB,IACW,WAAW;QAClB,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,QAAQ,CAAC;IACzE,CAAC;IAED,wBAAwB;IACxB,IAAW,QAAQ,CAAC,KAAoC;QACpD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED;;;;;;;;;OASG;IACH,IAAW,SAAS;QAChB,OAAO,CACH,CAAC,IAAI,CAAC,IAAI,KAAK,MAAM,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,CAAC;YAC7C,IAAI,CAAC,MAAM,KAAK,UAAU,CAC7B,CAAC;IACN,CAAC;IAED;;;;;;;;;OASG;IACH,IAAW,UAAU;QACjB,OAAO,IAAI,CAAC,IAAI,KAAK,MAAM,IAAI,IAAI,CAAC,MAAM,KAAK,UAAU,CAAC;IAC9D,CAAC;IAED;;;;;;;;;OASG;IACH,IACW,SAAS;QAChB,OAAO,IAAI,CAAC,IAAI,KAAK,KAAK,IAAI,IAAI,CAAC,MAAM,KAAK,UAAU,CAAC;IAC7D,CAAC;IAED,wBAAwB;IACjB,mBAAmB;QACtB,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACrC,CAAC;IAED,wBAAwB;IACjB,iBAAiB;QACpB,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;IAED,wBAAwB;IACxB,IACW,UAAU;QACjB,OAAO,IAAI,CAAC,KAAK,CAAC,IAAI,KAAK,MAAM,CAAC;IACtC,CAAC;IAED,wBAAwB;IACxB,IAAW,SAAS;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC,SAAS,IAAI,IAAI,CAAC,gBAAgB,CAAC,0BAA0B,CAAC;IACpF,CAAC;IAED;;;;;;;;;OASG;IACH,IACW,YAAY;QACnB,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,MAAM,KAAK,UAAU,CAAC;IAChE,CAAC;IAED;;;;;;;;;OASG;IACH,IACW,YAAY;QACnB,OAAO,IAAI,CAAC,MAAM,KAAK,QAAQ,CAAC;IACpC,CAAC;IAED;;;;;;;;;OASG;IACH,IACW,eAAe;QACtB,OAAO,IAAI,CAAC,MAAM,KAAK,WAAW,CAAC;IACvC,CAAC;IAED;;;;;;;;;OASG;IACH,IACW,YAAY;QACnB,OAAO,IAAI,CAAC,MAAM,KAAK,QAAQ,CAAC;IACpC,CAAC;IAED;;;;;;;;;OASG;IACH,IACW,YAAY;QACnB,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC;IAClC,CAAC;IAED,cAAc;IACd,IAAW,MAAM;QACb,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,cAAc;IACd,IAAW,MAAM,CAAC,GAAG;QACjB,IAAI,CAAC,OAAO,GAAG,GAAG,CAAC;IACvB,CAAC;IAED,wBAAwB;IACjB,kBAAkB;QACrB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACf,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAE9E,IAAI,KAAK,EAAE,CAAC;gBACR,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;oBACxB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBACzB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;gBAC5B,CAAC,CAAC,CAAC;YACP,CAAC;QACL,CAAC;IACL,CAAC;IAED,wBAAwB;IACjB,WAAW;QACd,IAAI,CAAC,aAAa,CAAC,WAAW,EAAE,CAAC;IACrC,CAAC;8GAraQ,sBAAsB,4CA+KnB,oBAAoB,6BAEpB,QAAQ;kGAjLX,sBAAsB,8KAgEX,gBAAgB,wpCApEzB,CAAC,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,sBAAsB,EAAE,CAAC,6DAsFlE,iBAAiB,2BAAU,iBAAiB,sDAVzC,gBAAgB,QAAU,gBAAgB,4CAG1C,kBAAkB,2BAAU,kBAAkB,4CAG9C,kBAAkB,2BAAU,kBAAkB,6BCpHnE,wmKAwJA,4CDpHc,IAAI,6FAAE,gBAAgB,oJAAE,kBAAkB,8EAAE,kBAAkB,oIAAE,OAAO,oFAAE,kBAAkB,4EAAE,gBAAgB,2FAAE,QAAQ,6EAAE,YAAY,qFAAE,eAAe;;2FAEvJ,sBAAsB;kBAPlC,SAAS;+BACI,iBAAiB,aAEhB,CAAC,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,wBAAwB,EAAE,CAAC,cACpE,IAAI,WACP,CAAC,IAAI,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,OAAO,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,QAAQ,EAAE,YAAY,EAAE,eAAe,CAAC;;0BAgL5J,QAAQ;;0BACR,MAAM;2BAAC,oBAAoB;;0BAE3B,MAAM;2BAAC,QAAQ;+HA3KT,eAAe;sBADzB,KAAK;gBAwBC,YAAY;sBADlB,WAAW;uBAAC,uBAAuB;gBAK7B,cAAc;sBADpB,WAAW;uBAAC,oCAAoC;gBAK1C,UAAU;sBADhB,WAAW;uBAAC,iCAAiC;gBAKvC,SAAS;sBADf,WAAW;uBAAC,gCAAgC;gBAYtC,QAAQ;sBADd,WAAW;uBAAC,iCAAiC;gBAcvC,sBAAsB;sBAD5B,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAK/B,UAAU;sBADhB,WAAW;uBAAC,gCAAgC;gBAKnC,KAAK;sBADd,eAAe;uBAAC,gBAAgB,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE;gBAInD,SAAS;sBADlB,eAAe;uBAAC,kBAAkB,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,WAAW,EAAE,IAAI,EAAE;gBAI1E,SAAS;sBADlB,eAAe;uBAAC,kBAAkB,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,WAAW,EAAE,IAAI,EAAE;gBAK1E,KAAK;sBADd,YAAY;uBAAC,iBAAiB,EAAE,EAAE,IAAI,EAAE,iBAAiB,EAAE,MAAM,EAAE,IAAI,EAAE;gBAY/D,UAAU;sBADpB,WAAW;uBAAC,8BAA8B;gBAOhC,YAAY;sBADtB,WAAW;uBAAC,gCAAgC;gBAOlC,QAAQ;sBADlB,WAAW;uBAAC,+BAA+B;gBAOjC,aAAa;sBADvB,WAAW;uBAAC,uCAAuC;gBAazC,IAAI;sBADd,KAAK;uBAAC,MAAM;gBA+BF,KAAK;sBADf,KAAK;gBAwCC,OAAO;sBADb,YAAY;uBAAC,OAAO,EAAE,CAAC,QAAQ,CAAC;gBAa1B,aAAa;sBADnB,YAAY;uBAAC,aAAa,EAAE,CAAC,QAAQ,CAAC;gBA4B5B,WAAW;sBADrB,WAAW;uBAAC,iCAAiC;gBAYnC,WAAW;sBADrB,WAAW;uBAAC,iCAAiC;gBAoDnC,SAAS;sBADnB,WAAW;uBAAC,4BAA4B;gBAiB9B,UAAU;sBADpB,WAAW;uBAAC,6BAA6B;gBAqB/B,YAAY;sBADtB,WAAW;uBAAC,+BAA+B;gBAgBjC,YAAY;sBADtB,WAAW;uBAAC,+BAA+B;gBAgBjC,eAAe;sBADzB,WAAW;uBAAC,kCAAkC;gBAgBpC,YAAY;sBADtB,WAAW;uBAAC,+BAA+B;gBAgBjC,YAAY;sBADtB,WAAW;uBAAC,+BAA+B","sourcesContent":["import { DOCUMENT, NgIf, NgTemplateOutlet, NgClass, NgSwitch, NgSwitchCase, NgSwitchDefault } from '@angular/common';\nimport {\n    AfterViewChecked,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    ElementRef,\n    HostBinding,\n    HostListener, Inject, Input,\n    OnDestroy,\n    Optional, QueryList, booleanAttribute\n} from '@angular/core';\nimport { IInputResourceStrings, InputResourceStringsEN } from '../core/i18n/input-resources';\nimport { PlatformUtil } from '../core/utils';\nimport { IgxButtonDirective } from '../directives/button/button.directive';\nimport { IgxHintDirective } from '../directives/hint/hint.directive';\nimport {\n    IgxInputDirective,\n    IgxInputState\n} from '../directives/input/input.directive';\nimport { IgxPrefixDirective } from '../directives/prefix/prefix.directive';\nimport { IgxSuffixDirective } from '../directives/suffix/suffix.directive';\n\nimport { IgxInputGroupBase } from './input-group.common';\nimport { IgxInputGroupType, IGX_INPUT_GROUP_TYPE } from './inputGroupType';\nimport { IgxIconComponent } from '../icon/icon.component';\nimport { getCurrentResourceStrings } from '../core/i18n/resources';\nimport { IgxTheme, ThemeService } from '../services/theme/theme.service';\nimport { Subject, Subscription } from 'rxjs';\n\n@Component({\n    selector: 'igx-input-group',\n    templateUrl: 'input-group.component.html',\n    providers: [{ provide: IgxInputGroupBase, useExisting: IgxInputGroupComponent }],\n    standalone: true,\n    imports: [NgIf, NgTemplateOutlet, IgxPrefixDirective, IgxButtonDirective, NgClass, IgxSuffixDirective, IgxIconComponent, NgSwitch, NgSwitchCase, NgSwitchDefault]\n})\nexport class IgxInputGroupComponent implements IgxInputGroupBase, AfterViewChecked, OnDestroy {\n    /**\n     * Sets the resource strings.\n     * By default it uses EN resources.\n     */\n    @Input()\n    public set resourceStrings(value: IInputResourceStrings) {\n        this._resourceStrings = Object.assign({}, this._resourceStrings, value);\n    }\n\n    /**\n     * Returns the resource strings.\n     */\n    public get resourceStrings(): IInputResourceStrings {\n        return this._resourceStrings;\n    }\n\n    /**\n     * Property that enables/disables the auto-generated class of the `IgxInputGroupComponent`.\n     * By default applied the class is applied.\n     * ```typescript\n     *  @ViewChild(\"MyInputGroup\")\n     *  public inputGroup: IgxInputGroupComponent;\n     *  ngAfterViewInit(){\n     *  this.inputGroup.defaultClass = false;\n     * ```\n     * }\n     */\n    @HostBinding('class.igx-input-group')\n    public defaultClass = true;\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--placeholder')\n    public hasPlaceholder = false;\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--required')\n    public isRequired = false;\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--focused')\n    public isFocused = false;\n\n    /**\n     * @hidden @internal\n     * When truthy, disables the `IgxInputGroupComponent`.\n     * Controlled by the underlying `IgxInputDirective`.\n     * ```html\n     * <igx-input-group [disabled]=\"true\"></igx-input-group>\n     * ```\n     */\n    @HostBinding('class.igx-input-group--disabled')\n    public disabled = false;\n\n    /**\n     * Prevents automatically focusing the input when clicking on other elements in the input group (e.g. prefix or suffix).\n     *\n     * @remarks Automatic focus causes software keyboard to show on mobile devices.\n     *\n     * @example\n     * ```html\n     * <igx-input-group [suppressInputAutofocus]=\"true\"></igx-input-group>\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public suppressInputAutofocus = false;\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--warning')\n    public hasWarning = false;\n\n    /** @hidden */\n    @ContentChildren(IgxHintDirective, { read: IgxHintDirective })\n    protected hints: QueryList<IgxHintDirective>;\n\n    @ContentChildren(IgxPrefixDirective, { read: IgxPrefixDirective, descendants: true })\n    protected _prefixes: QueryList<IgxPrefixDirective>;\n\n    @ContentChildren(IgxSuffixDirective, { read: IgxSuffixDirective, descendants: true })\n    protected _suffixes: QueryList<IgxSuffixDirective>;\n\n    /** @hidden */\n    @ContentChild(IgxInputDirective, { read: IgxInputDirective, static: true })\n    protected input: IgxInputDirective;\n\n    private _type: IgxInputGroupType = null;\n    private _filled = false;\n    private _theme: IgxTheme;\n    private _theme$ = new Subject<IgxTheme>();\n    private _subscription: Subscription;\n    private _resourceStrings = getCurrentResourceStrings(InputResourceStringsEN);\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--valid')\n    public get validClass(): boolean {\n        return this.input.valid === IgxInputState.VALID;\n    }\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--invalid')\n    public get invalidClass(): boolean {\n        return this.input.valid === IgxInputState.INVALID;\n    }\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--filled')\n    public get isFilled() {\n        return this._filled || (this.input && this.input.value);\n    }\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--textarea-group')\n    public get textAreaClass(): boolean {\n        return this.input.isTextArea;\n    }\n\n    /**\n     * Sets how the input will be styled.\n     * Allowed values of type IgxInputGroupType.\n     * ```html\n     * <igx-input-group [type]=\"'search'\">\n     * ```\n     */\n    @Input('type')\n    public set type(value: IgxInputGroupType) {\n        this._type = value;\n    }\n\n    /**\n     * Returns the type of the `IgxInputGroupComponent`. How the input is styled.\n     * The default is `line`.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let inputType = this.inputGroup.type;\n     * }\n     * ```\n     */\n    public get type() {\n        return this._type || this._inputGroupType || 'line';\n    }\n\n    /**\n     * Sets the theme of the input.\n     * Allowed values of type IgxInputGroupTheme.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit() {\n     *  let inputTheme = 'fluent';\n     * }\n     */\n    @Input()\n    public set theme(value: IgxTheme) {\n        this._theme = value;\n    }\n\n    /**\n     * Returns the theme of the input.\n     * The returned value is of type IgxInputGroupType.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit() {\n     *  let inputTheme = this.inputGroup.theme;\n     * }\n     */\n    public get theme(): IgxTheme {\n        return this._theme;\n    }\n\n    constructor(\n        public element: ElementRef<HTMLElement>,\n        @Optional()\n        @Inject(IGX_INPUT_GROUP_TYPE)\n        private _inputGroupType: IgxInputGroupType,\n        @Inject(DOCUMENT)\n        private document: any,\n        private platform: PlatformUtil,\n        private cdr: ChangeDetectorRef,\n        private themeService: ThemeService,\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\n    /** @hidden */\n    @HostListener('click', ['$event'])\n    public onClick(event: MouseEvent) {\n        if (\n            !this.isFocused &&\n            event.target !== this.input.nativeElement &&\n            !this.suppressInputAutofocus\n        ) {\n            this.input.focus();\n        }\n    }\n\n    /** @hidden */\n    @HostListener('pointerdown', ['$event'])\n    public onPointerDown(event: PointerEvent) {\n        if (this.isFocused && event.target !== this.input.nativeElement) {\n            event.preventDefault();\n        }\n    }\n\n    /** @hidden @internal */\n    public hintClickHandler(event: MouseEvent) {\n        event.stopPropagation();\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` has hints.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let inputHints = this.inputGroup.hasHints;\n     * }\n     * ```\n     */\n    public get hasHints() {\n        return this.hints.length > 0;\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-input-group--prefixed')\n    public get hasPrefixes() {\n        return this._prefixes.length > 0 || this.isFileType;\n    }\n\n    /** @hidden @internal */\n    public set prefixes(items: QueryList<IgxPrefixDirective>) {\n        this._prefixes = items;\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-input-group--suffixed')\n    public get hasSuffixes() {\n        return this._suffixes.length > 0 || this.isFileType && this.isFilled;\n    }\n\n    /** @hidden @internal */\n    public set suffixes(items: QueryList<IgxPrefixDirective>) {\n        this._suffixes = items;\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` has border.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let inputBorder = this.inputGroup.hasBorder;\n     * }\n     * ```\n     */\n    public get hasBorder() {\n        return (\n            (this.type === 'line' || this.type === 'box') &&\n            this._theme === 'material'\n        );\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` type is line.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeLine = this.inputGroup.isTypeLine;\n     * }\n     * ```\n     */\n    public get isTypeLine(): boolean {\n        return this.type === 'line' && this._theme === 'material';\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` type is box.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeBox = this.inputGroup.isTypeBox;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--box')\n    public get isTypeBox() {\n        return this.type === 'box' && this._theme === 'material';\n    }\n\n    /** @hidden @internal */\n    public uploadButtonHandler() {\n        this.input.nativeElement.click();\n    }\n\n    /** @hidden @internal */\n    public clearValueHandler() {\n        this.input.clear();\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-input-group--file')\n    public get isFileType() {\n        return this.input.type === 'file';\n    }\n\n    /** @hidden @internal */\n    public get fileNames() {\n        return this.input.fileNames || this._resourceStrings.igx_input_file_placeholder;\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` type is border.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeBorder = this.inputGroup.isTypeBorder;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--border')\n    public get isTypeBorder() {\n        return this.type === 'border' && this._theme === 'material';\n    }\n\n    /**\n     * Returns true if the `IgxInputGroupComponent` theme is Fluent.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeFluent = this.inputGroup.isTypeFluent;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--fluent')\n    public get isTypeFluent() {\n        return this._theme === 'fluent';\n    }\n\n    /**\n     * Returns true if the `IgxInputGroupComponent` theme is Bootstrap.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeBootstrap = this.inputGroup.isTypeBootstrap;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--bootstrap')\n    public get isTypeBootstrap() {\n        return this._theme === 'bootstrap';\n    }\n\n    /**\n     * Returns true if the `IgxInputGroupComponent` theme is Indigo.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeIndigo = this.inputGroup.isTypeIndigo;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--indigo')\n    public get isTypeIndigo() {\n        return this._theme === 'indigo';\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` type is search.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeSearch = this.inputGroup.isTypeSearch;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--search')\n    public get isTypeSearch() {\n        return this.type === 'search';\n    }\n\n    /** @hidden */\n    public get filled() {\n        return this._filled;\n    }\n\n    /** @hidden */\n    public set filled(val) {\n        this._filled = val;\n    }\n\n    /** @hidden @internal */\n    public ngAfterViewChecked() {\n        if (!this._theme) {\n            const theme = this.theme ?? this.themeService.getComponentTheme(this.element);\n\n            if (theme) {\n                Promise.resolve().then(() => {\n                    this._theme$.next(theme);\n                    this.cdr.markForCheck();\n                });\n            }\n        }\n    }\n\n    /** @hidden @internal */\n    public ngOnDestroy() {\n        this._subscription.unsubscribe();\n    }\n}\n","<div class=\"igx-input-group__wrapper\" *ngIf=\"isTypeBox; else bundle\">\n    <ng-container *ngTemplateOutlet=\"bundle\"></ng-container>\n</div>\n\n<div class=\"igx-input-group__hint\" (click)=\"hintClickHandler($event)\">\n    <ng-content select=\"igx-hint, [igxHint]\"></ng-content>\n</div>\n\n<ng-template #label>\n    <ng-content select=\"[igxLabel]\"></ng-content>\n</ng-template>\n\n<ng-template #input>\n    <ng-content select=\"[igxInput]\"></ng-content>\n</ng-template>\n\n<ng-template #prefix>\n    <ng-content select=\"igx-prefix, [igxPrefix]\"></ng-content>\n</ng-template>\n\n<ng-template #uploadButton>\n    <igx-prefix *ngIf=\"isFileType\" class=\"igx-input-group__upload-button\">\n        <button\n            igxButton=\"contained\"\n            type=\"button\"\n            (click)=\"uploadButtonHandler()\"\n            [disabled]=\"disabled\"\n            [ngClass]=\"{ 'igx-input-group__upload-button': isTypeLine }\"\n        >\n            {{ resourceStrings.igx_input_upload_button }}\n        </button>\n    </igx-prefix>\n</ng-template>\n\n<ng-template #files>\n    <div\n        *ngIf=\"isFileType\"\n        class=\"igx-input-group__file-input\"\n        [title]=\"fileNames\"\n    >\n        <span>{{ fileNames }}</span>\n    </div>\n</ng-template>\n\n<ng-template #clear>\n    <igx-suffix\n        class=\"igx-input-group__clear-icon\"\n        *ngIf=\"isFileType && isFilled\"\n        (click)=\"clearValueHandler()\"\n        (keydown.Enter)=\"clearValueHandler()\"\n        title=\"clear files\"\n        tabindex=\"0\"\n    >\n        <igx-icon family=\"default\" name=\"input_clear\"></igx-icon>\n    </igx-suffix>\n</ng-template>\n\n<ng-template #suffix>\n    <ng-content select=\"igx-suffix, [igxSuffix]\"></ng-content>\n</ng-template>\n\n<ng-template #materialBundle>\n    <div class=\"igx-input-group__bundle\">\n        <div class=\"igx-input-group__bundle-start\">\n            <ng-container *ngTemplateOutlet=\"prefix\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"uploadButton\"></ng-container>\n        </div>\n\n        <ng-container>\n            <div class=\"igx-input-group__notch\">\n                <ng-container *ngTemplateOutlet=\"label\"></ng-container>\n            </div>\n        </ng-container>\n\n        <div class=\"igx-input-group__bundle-main\">\n            <ng-container *ngTemplateOutlet=\"input\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"files\"></ng-container>\n        </div>\n\n        <div class=\"igx-input-group__filler\"></div>\n\n        <div class=\"igx-input-group__bundle-end\">\n            <ng-container *ngTemplateOutlet=\"clear\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"suffix\"></ng-container>\n        </div>\n\n        <div class=\"igx-input-group__line\" *ngIf=\"hasBorder\"></div>\n    </div>\n</ng-template>\n\n<ng-template #fluentBundle>\n    <ng-container *ngTemplateOutlet=\"label\"></ng-container>\n\n    <div class=\"igx-input-group__bundle\">\n        <div class=\"igx-input-group__bundle-start\">\n            <ng-container *ngTemplateOutlet=\"prefix\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"uploadButton\"></ng-container>\n        </div>\n\n\n        <div class=\"igx-input-group__bundle-main\">\n            <ng-container *ngTemplateOutlet=\"input\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"files\"></ng-container>\n        </div>\n\n        <div class=\"igx-input-group__bundle-end\">\n            <ng-container *ngTemplateOutlet=\"clear\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"suffix\"></ng-container>\n        </div>\n\n        <div class=\"igx-input-group__line\" *ngIf=\"hasBorder\"></div>\n    </div>\n</ng-template>\n\n<ng-template #bootstrapBundle>\n    <ng-container *ngTemplateOutlet=\"label\"></ng-container>\n\n    <div class=\"igx-input-group__bundle\">\n        <div class=\"igx-input-group__bundle-start\">\n            <ng-container *ngTemplateOutlet=\"prefix\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"uploadButton\"></ng-container>\n        </div>\n\n        <ng-container *ngTemplateOutlet=\"input\"></ng-container>\n        <ng-container *ngTemplateOutlet=\"files\"></ng-container>\n\n        <div class=\"igx-input-group__bundle-end\">\n            <ng-container *ngTemplateOutlet=\"clear\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"suffix\"></ng-container>\n        </div>\n    </div>\n</ng-template>\n\n<ng-template #bundle>\n    <ng-container [ngSwitch]=\"theme\">\n        <ng-container *ngSwitchCase=\"'bootstrap'\">\n            <ng-container *ngTemplateOutlet=\"bootstrapBundle\"></ng-container>\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'fluent'\">\n            <ng-container *ngTemplateOutlet=\"fluentBundle\"></ng-container>\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'indigo'\">\n            <ng-container *ngTemplateOutlet=\"fluentBundle\"></ng-container>\n        </ng-container>\n\n        <ng-container *ngSwitchDefault>\n            <ng-container *ngTemplateOutlet=\"materialBundle\"></ng-container>\n        </ng-container>\n    </ng-container>\n</ng-template>\n"]}
442
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-group.component.js","sourceRoot":"","sources":["../../../../../projects/igniteui-angular/src/lib/input-group/input-group.component.ts","../../../../../projects/igniteui-angular/src/lib/input-group/input-group.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT, NgIf, NgTemplateOutlet, NgClass, NgSwitch, NgSwitchCase, NgSwitchDefault } from '@angular/common';\nimport {\n    AfterViewChecked,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    ContentChildren,\n    ElementRef,\n    HostBinding,\n    HostListener, Inject, Input,\n    OnDestroy,\n    Optional, QueryList, booleanAttribute\n} from '@angular/core';\nimport { IInputResourceStrings, InputResourceStringsEN } from '../core/i18n/input-resources';\nimport { PlatformUtil } from '../core/utils';\nimport { IgxButtonDirective } from '../directives/button/button.directive';\nimport { IgxHintDirective } from '../directives/hint/hint.directive';\nimport {\n    IgxInputDirective,\n    IgxInputState\n} from '../directives/input/input.directive';\nimport { IgxPrefixDirective } from '../directives/prefix/prefix.directive';\nimport { IgxSuffixDirective } from '../directives/suffix/suffix.directive';\n\nimport { IgxInputGroupBase } from './input-group.common';\nimport { IgxInputGroupType, IGX_INPUT_GROUP_TYPE } from './inputGroupType';\nimport { IgxIconComponent } from '../icon/icon.component';\nimport { getCurrentResourceStrings } from '../core/i18n/resources';\nimport { IgxTheme, ThemeService } from '../services/theme/theme.service';\nimport { Subject, Subscription } from 'rxjs';\n\n@Component({\n    selector: 'igx-input-group',\n    templateUrl: 'input-group.component.html',\n    providers: [{ provide: IgxInputGroupBase, useExisting: IgxInputGroupComponent }],\n    standalone: true,\n    imports: [NgIf, NgTemplateOutlet, IgxPrefixDirective, IgxButtonDirective, NgClass, IgxSuffixDirective, IgxIconComponent, NgSwitch, NgSwitchCase, NgSwitchDefault]\n})\nexport class IgxInputGroupComponent implements IgxInputGroupBase, AfterViewChecked, OnDestroy {\n    /**\n     * Sets the resource strings.\n     * By default it uses EN resources.\n     */\n    @Input()\n    public set resourceStrings(value: IInputResourceStrings) {\n        this._resourceStrings = Object.assign({}, this._resourceStrings, value);\n    }\n\n    /**\n     * Returns the resource strings.\n     */\n    public get resourceStrings(): IInputResourceStrings {\n        return this._resourceStrings;\n    }\n\n    /**\n     * Property that enables/disables the auto-generated class of the `IgxInputGroupComponent`.\n     * By default applied the class is applied.\n     * ```typescript\n     *  @ViewChild(\"MyInputGroup\")\n     *  public inputGroup: IgxInputGroupComponent;\n     *  ngAfterViewInit(){\n     *  this.inputGroup.defaultClass = false;\n     * ```\n     * }\n     */\n    @HostBinding('class.igx-input-group')\n    public defaultClass = true;\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--placeholder')\n    public hasPlaceholder = false;\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--required')\n    public isRequired = false;\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--focused')\n    public isFocused = false;\n\n    /**\n     * @hidden @internal\n     * When truthy, disables the `IgxInputGroupComponent`.\n     * Controlled by the underlying `IgxInputDirective`.\n     * ```html\n     * <igx-input-group [disabled]=\"true\"></igx-input-group>\n     * ```\n     */\n    @HostBinding('class.igx-input-group--disabled')\n    public disabled = false;\n\n    /**\n     * Prevents automatically focusing the input when clicking on other elements in the input group (e.g. prefix or suffix).\n     *\n     * @remarks Automatic focus causes software keyboard to show on mobile devices.\n     *\n     * @example\n     * ```html\n     * <igx-input-group [suppressInputAutofocus]=\"true\"></igx-input-group>\n     * ```\n     */\n    @Input({ transform: booleanAttribute })\n    public suppressInputAutofocus = false;\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--warning')\n    public hasWarning = false;\n\n    /** @hidden */\n    @ContentChildren(IgxHintDirective, { read: IgxHintDirective })\n    protected hints: QueryList<IgxHintDirective>;\n\n    @ContentChildren(IgxPrefixDirective, { read: IgxPrefixDirective, descendants: true })\n    protected _prefixes: QueryList<IgxPrefixDirective>;\n\n    @ContentChildren(IgxSuffixDirective, { read: IgxSuffixDirective, descendants: true })\n    protected _suffixes: QueryList<IgxSuffixDirective>;\n\n    /** @hidden */\n    @ContentChild(IgxInputDirective, { read: IgxInputDirective, static: true })\n    protected input: IgxInputDirective;\n\n    private _type: IgxInputGroupType = null;\n    private _filled = false;\n    private _theme: IgxTheme;\n    private _theme$ = new Subject<IgxTheme>();\n    private _subscription: Subscription;\n    private _resourceStrings = getCurrentResourceStrings(InputResourceStringsEN);\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--valid')\n    public get validClass(): boolean {\n        return this.input.valid === IgxInputState.VALID;\n    }\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--invalid')\n    public get invalidClass(): boolean {\n        return this.input.valid === IgxInputState.INVALID;\n    }\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--filled')\n    public get isFilled() {\n        return this._filled || (this.input && this.input.value);\n    }\n\n    /** @hidden */\n    @HostBinding('class.igx-input-group--textarea-group')\n    public get textAreaClass(): boolean {\n        return this.input.isTextArea;\n    }\n\n    /**\n     * Sets how the input will be styled.\n     * Allowed values of type IgxInputGroupType.\n     * ```html\n     * <igx-input-group [type]=\"'search'\">\n     * ```\n     */\n    @Input('type')\n    public set type(value: IgxInputGroupType) {\n        this._type = value;\n    }\n\n    /**\n     * Returns the type of the `IgxInputGroupComponent`. How the input is styled.\n     * The default is `line`.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let inputType = this.inputGroup.type;\n     * }\n     * ```\n     */\n    public get type() {\n        return this._type || this._inputGroupType || 'line';\n    }\n\n    /**\n     * Sets the theme of the input.\n     * Allowed values of type IgxInputGroupTheme.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit() {\n     *  let inputTheme = 'fluent';\n     * }\n     */\n    @Input()\n    public set theme(value: IgxTheme) {\n        this._theme = value;\n    }\n\n    /**\n     * Returns the theme of the input.\n     * The returned value is of type IgxInputGroupType.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit() {\n     *  let inputTheme = this.inputGroup.theme;\n     * }\n     */\n    public get theme(): IgxTheme {\n        return this._theme;\n    }\n\n    constructor(\n        public element: ElementRef<HTMLElement>,\n        @Optional()\n        @Inject(IGX_INPUT_GROUP_TYPE)\n        private _inputGroupType: IgxInputGroupType,\n        @Inject(DOCUMENT)\n        private document: any,\n        private platform: PlatformUtil,\n        private cdr: ChangeDetectorRef,\n        private themeService: ThemeService,\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\n    /** @hidden */\n    @HostListener('click', ['$event'])\n    public onClick(event: MouseEvent) {\n        if (\n            !this.isFocused &&\n            event.target !== this.input.nativeElement &&\n            !this.suppressInputAutofocus\n        ) {\n            this.input.focus();\n        }\n    }\n\n    /** @hidden */\n    @HostListener('pointerdown', ['$event'])\n    public onPointerDown(event: PointerEvent) {\n        if (this.isFocused && event.target !== this.input.nativeElement) {\n            event.preventDefault();\n        }\n    }\n\n    /** @hidden @internal */\n    public hintClickHandler(event: MouseEvent) {\n        event.stopPropagation();\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` has hints.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let inputHints = this.inputGroup.hasHints;\n     * }\n     * ```\n     */\n    public get hasHints() {\n        return this.hints.length > 0;\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-input-group--prefixed')\n    public get hasPrefixes() {\n        return this._prefixes.length > 0 || this.isFileType;\n    }\n\n    /** @hidden @internal */\n    public set prefixes(items: QueryList<IgxPrefixDirective>) {\n        this._prefixes = items;\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-input-group--suffixed')\n    public get hasSuffixes() {\n        return this._suffixes.length > 0 || this.isFileType && this.isFilled;\n    }\n\n    /** @hidden @internal */\n    public set suffixes(items: QueryList<IgxPrefixDirective>) {\n        this._suffixes = items;\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` has border.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let inputBorder = this.inputGroup.hasBorder;\n     * }\n     * ```\n     */\n    public get hasBorder() {\n        return (\n            (this.type === 'line' || this.type === 'box') &&\n            this._theme === 'material'\n        );\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` type is line.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeLine = this.inputGroup.isTypeLine;\n     * }\n     * ```\n     */\n    public get isTypeLine(): boolean {\n        return this.type === 'line' && this._theme === 'material';\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` type is box.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeBox = this.inputGroup.isTypeBox;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--box')\n    public get isTypeBox() {\n        return this.type === 'box' && this._theme === 'material';\n    }\n\n    /** @hidden @internal */\n    public uploadButtonHandler() {\n        this.input.nativeElement.click();\n    }\n\n    /** @hidden @internal */\n    public clearValueHandler() {\n        this.input.clear();\n    }\n\n    /** @hidden @internal */\n    @HostBinding('class.igx-input-group--file')\n    public get isFileType() {\n        return this.input.type === 'file';\n    }\n\n    /** @hidden @internal */\n    public get fileNames() {\n        return this.input.fileNames || this._resourceStrings.igx_input_file_placeholder;\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` type is border.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeBorder = this.inputGroup.isTypeBorder;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--border')\n    public get isTypeBorder() {\n        return this.type === 'border' && this._theme === 'material';\n    }\n\n    /**\n     * Returns true if the `IgxInputGroupComponent` theme is Fluent.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeFluent = this.inputGroup.isTypeFluent;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--fluent')\n    public get isTypeFluent() {\n        return this._theme === 'fluent';\n    }\n\n    /**\n     * Returns true if the `IgxInputGroupComponent` theme is Bootstrap.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeBootstrap = this.inputGroup.isTypeBootstrap;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--bootstrap')\n    public get isTypeBootstrap() {\n        return this._theme === 'bootstrap';\n    }\n\n    /**\n     * Returns true if the `IgxInputGroupComponent` theme is Indigo.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeIndigo = this.inputGroup.isTypeIndigo;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--indigo')\n    public get isTypeIndigo() {\n        return this._theme === 'indigo';\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` type is search.\n     * ```typescript\n     * @ViewChild(\"MyInputGroup1\")\n     * public inputGroup: IgxInputGroupComponent;\n     * ngAfterViewInit(){\n     *    let isTypeSearch = this.inputGroup.isTypeSearch;\n     * }\n     * ```\n     */\n    @HostBinding('class.igx-input-group--search')\n    public get isTypeSearch() {\n        return this.type === 'search';\n    }\n\n    /** @hidden */\n    public get filled() {\n        return this._filled;\n    }\n\n    /** @hidden */\n    public set filled(val) {\n        this._filled = val;\n    }\n\n    /** @hidden @internal */\n    public ngAfterViewChecked() {\n        const theme = this.themeService.getComponentTheme(this.element);\n\n        if (theme) {\n            this._theme$.next(theme);\n            this.cdr.markForCheck();\n        }\n    }\n\n    /** @hidden @internal */\n    public ngOnDestroy() {\n        this._subscription.unsubscribe();\n    }\n}\n","<div class=\"igx-input-group__wrapper\" *ngIf=\"isTypeBox; else bundle\">\n    <ng-container *ngTemplateOutlet=\"bundle\"></ng-container>\n</div>\n\n<div class=\"igx-input-group__hint\" (click)=\"hintClickHandler($event)\">\n    <ng-content select=\"igx-hint, [igxHint]\"></ng-content>\n</div>\n\n<ng-template #label>\n    <ng-content select=\"[igxLabel]\"></ng-content>\n</ng-template>\n\n<ng-template #input>\n    <ng-content select=\"[igxInput]\"></ng-content>\n</ng-template>\n\n<ng-template #prefix>\n    <ng-content select=\"igx-prefix, [igxPrefix]\"></ng-content>\n</ng-template>\n\n<ng-template #uploadButton>\n    <igx-prefix *ngIf=\"isFileType\" class=\"igx-input-group__upload-button\">\n        <button\n            igxButton=\"contained\"\n            type=\"button\"\n            (click)=\"uploadButtonHandler()\"\n            [disabled]=\"disabled\"\n            [ngClass]=\"{ 'igx-input-group__upload-button': isTypeLine }\"\n        >\n            {{ resourceStrings.igx_input_upload_button }}\n        </button>\n    </igx-prefix>\n</ng-template>\n\n<ng-template #files>\n    <div\n        *ngIf=\"isFileType\"\n        class=\"igx-input-group__file-input\"\n        [title]=\"fileNames\"\n    >\n        <span>{{ fileNames }}</span>\n    </div>\n</ng-template>\n\n<ng-template #clear>\n    <igx-suffix\n        class=\"igx-input-group__clear-icon\"\n        *ngIf=\"isFileType && isFilled\"\n        (click)=\"clearValueHandler()\"\n        (keydown.Enter)=\"clearValueHandler()\"\n        title=\"clear files\"\n        tabindex=\"0\"\n    >\n        <igx-icon family=\"default\" name=\"input_clear\"></igx-icon>\n    </igx-suffix>\n</ng-template>\n\n<ng-template #suffix>\n    <ng-content select=\"igx-suffix, [igxSuffix]\"></ng-content>\n</ng-template>\n\n<ng-template #materialBundle>\n    <div class=\"igx-input-group__bundle\">\n        <div class=\"igx-input-group__bundle-start\">\n            <ng-container *ngTemplateOutlet=\"prefix\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"uploadButton\"></ng-container>\n        </div>\n\n        <ng-container>\n            <div class=\"igx-input-group__notch\">\n                <ng-container *ngTemplateOutlet=\"label\"></ng-container>\n            </div>\n        </ng-container>\n\n        <div class=\"igx-input-group__bundle-main\">\n            <ng-container *ngTemplateOutlet=\"input\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"files\"></ng-container>\n        </div>\n\n        <div class=\"igx-input-group__filler\"></div>\n\n        <div class=\"igx-input-group__bundle-end\">\n            <ng-container *ngTemplateOutlet=\"clear\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"suffix\"></ng-container>\n        </div>\n\n        <div class=\"igx-input-group__line\" *ngIf=\"hasBorder\"></div>\n    </div>\n</ng-template>\n\n<ng-template #fluentBundle>\n    <ng-container *ngTemplateOutlet=\"label\"></ng-container>\n\n    <div class=\"igx-input-group__bundle\">\n        <div class=\"igx-input-group__bundle-start\">\n            <ng-container *ngTemplateOutlet=\"prefix\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"uploadButton\"></ng-container>\n        </div>\n\n\n        <div class=\"igx-input-group__bundle-main\">\n            <ng-container *ngTemplateOutlet=\"input\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"files\"></ng-container>\n        </div>\n\n        <div class=\"igx-input-group__bundle-end\">\n            <ng-container *ngTemplateOutlet=\"clear\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"suffix\"></ng-container>\n        </div>\n\n        <div class=\"igx-input-group__line\" *ngIf=\"hasBorder\"></div>\n    </div>\n</ng-template>\n\n<ng-template #bootstrapBundle>\n    <ng-container *ngTemplateOutlet=\"label\"></ng-container>\n\n    <div class=\"igx-input-group__bundle\">\n        <div class=\"igx-input-group__bundle-start\">\n            <ng-container *ngTemplateOutlet=\"prefix\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"uploadButton\"></ng-container>\n        </div>\n\n        <ng-container *ngTemplateOutlet=\"input\"></ng-container>\n        <ng-container *ngTemplateOutlet=\"files\"></ng-container>\n\n        <div class=\"igx-input-group__bundle-end\">\n            <ng-container *ngTemplateOutlet=\"clear\"></ng-container>\n            <ng-container *ngTemplateOutlet=\"suffix\"></ng-container>\n        </div>\n    </div>\n</ng-template>\n\n<ng-template #bundle>\n    <ng-container [ngSwitch]=\"theme\">\n        <ng-container *ngSwitchCase=\"'bootstrap'\">\n            <ng-container *ngTemplateOutlet=\"bootstrapBundle\"></ng-container>\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'fluent'\">\n            <ng-container *ngTemplateOutlet=\"fluentBundle\"></ng-container>\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'indigo'\">\n            <ng-container *ngTemplateOutlet=\"fluentBundle\"></ng-container>\n        </ng-container>\n\n        <ng-container *ngSwitchDefault>\n            <ng-container *ngTemplateOutlet=\"materialBundle\"></ng-container>\n        </ng-container>\n    </ng-container>\n</ng-template>\n"]}
@@ -10037,14 +10037,10 @@ class IgxInputGroupComponent {
10037
10037
  }
10038
10038
  /** @hidden @internal */
10039
10039
  ngAfterViewChecked() {
10040
- if (!this._theme) {
10041
- const theme = this.theme ?? this.themeService.getComponentTheme(this.element);
10042
- if (theme) {
10043
- Promise.resolve().then(() => {
10044
- this._theme$.next(theme);
10045
- this.cdr.markForCheck();
10046
- });
10047
- }
10040
+ const theme = this.themeService.getComponentTheme(this.element);
10041
+ if (theme) {
10042
+ this._theme$.next(theme);
10043
+ this.cdr.markForCheck();
10048
10044
  }
10049
10045
  }
10050
10046
  /** @hidden @internal */