UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

461 lines 40.5 kB
var IgxInputGroupComponent_1; import { __decorate, __metadata, __param } from "tslib"; import { CommonModule } from '@angular/common'; import { Component, ContentChild, ContentChildren, ElementRef, HostBinding, HostListener, Input, NgModule, QueryList, Inject, Optional } from '@angular/core'; import { IgxHintDirective } from '../directives/hint/hint.directive'; import { IgxInputDirective, IgxInputState } from '../directives/input/input.directive'; import { IgxLabelDirective } from '../directives/label/label.directive'; import { IgxPrefixModule } from '../directives/prefix/prefix.directive'; import { IgxSuffixModule } from '../directives/suffix/suffix.directive'; import { DisplayDensity, DisplayDensityToken, DisplayDensityBase } from '../core/displayDensity'; import { IgxInputGroupBase } from './input-group.common'; let NEXT_ID = 0; var IgxInputGroupType; (function (IgxInputGroupType) { IgxInputGroupType[IgxInputGroupType["LINE"] = 0] = "LINE"; IgxInputGroupType[IgxInputGroupType["BOX"] = 1] = "BOX"; IgxInputGroupType[IgxInputGroupType["BORDER"] = 2] = "BORDER"; IgxInputGroupType[IgxInputGroupType["FLUENT"] = 3] = "FLUENT"; IgxInputGroupType[IgxInputGroupType["SEARCH"] = 4] = "SEARCH"; IgxInputGroupType[IgxInputGroupType["FLUENT_SEARCH"] = 5] = "FLUENT_SEARCH"; })(IgxInputGroupType || (IgxInputGroupType = {})); let IgxInputGroupComponent = IgxInputGroupComponent_1 = class IgxInputGroupComponent extends DisplayDensityBase { constructor(_element, _displayDensityOptions) { super(_displayDensityOptions); this._element = _element; this._displayDensityOptions = _displayDensityOptions; this._type = IgxInputGroupType.LINE; this._filled = false; this._supressInputAutofocus = false; /** * An @Input property that sets the value of `id` attribute. If not provided it will be automatically generated. * ```html * <igx-input-group [id]="'igx-input-group-55'"></igx-input-group> * ``` */ this.id = `igx-input-group-${NEXT_ID++}`; /** * Property that enables/disables the autogenerated class of the `IgxInputGroupComponent`. * By default applied the class is applied. *```typescript *@ViewChild("MyInputGroup") *public inputGroup: IgxInputGroupComponent; *ngAfterViewInit(){ *this.inputGroup.defaultClass = false; *``` *} */ this.defaultClass = true; /** * @hidden */ this.hasPlaceholder = false; /** * @hidden */ this.isRequired = false; /** * @hidden */ this.isFocused = false; /** * @hidden */ this.isBox = false; /** * @hidden */ this.isBorder = false; /** * @hidden */ this.isSearch = false; /** * @hidden */ this.isFluentSearch = false; /** * @hidden */ this.isFluent = false; /** * An @Input property that disables the `IgxInputGroupComponent`. * ```html * <igx-input-group [disabled]="'true'"></igx-input-group> * ``` */ this.disabled = false; /** * @hidden */ this.hasWarning = false; this.element = _element; } /** * @hidden */ get validClass() { return this.input.valid === IgxInputState.VALID; } /** * @hidden */ get invalidClass() { return this.input.valid === IgxInputState.INVALID; } /** *@hidden */ onClick(event) { if (!this._supressInputAutofocus) { this.input.focus(); } } /** * An @Input property that sets how the input will be styled. * The allowed values are `line`, `box`, `border`, `fluent`, `search` and `fluentSearch`. The default is `line`. * ```html *<igx-input-group [type]="'search'"> * ``` */ set type(value) { const type = IgxInputGroupType[value.toUpperCase()]; if (type !== undefined) { this.isBox = this.isFluent = this.isFluentSearch = this.isBorder = this.isSearch = false; switch (type) { case IgxInputGroupType.BOX: this.isBox = true; break; case IgxInputGroupType.BORDER: this.isBorder = true; break; case IgxInputGroupType.FLUENT: this.isFluent = true; break; case IgxInputGroupType.FLUENT_SEARCH: this.isFluentSearch = true; break; case IgxInputGroupType.SEARCH: this.isSearch = true; break; default: break; } this._type = type; } } /** * Returns whether the input element of the input group will be automatically focused on click. * ```typescript * let supressInputAutofocus = this.inputGroup.supressInputAutofocus; * ``` */ get supressInputAutofocus() { return this._supressInputAutofocus; } /** * Sets whether the input element of the input group will be automatically focused on click. * ```html * <igx-input-group [supressInputAutofocus]="true"></igx-input-group> * ``` */ set supressInputAutofocus(value) { this._supressInputAutofocus = value; } /** *@hidden */ get isFilled() { return this._filled || (this.input && this.input.value); } /** *@hidden */ get isDisplayDensityCosy() { return this.displayDensity === DisplayDensity.cosy; } /** *@hidden */ get isDisplayDensityComfortable() { return this.displayDensity === DisplayDensity.comfortable; } /** *@hidden */ get isDisplayDensityCompact() { return this.displayDensity === DisplayDensity.compact; } /** * Returns the type of the `IgxInputGroupComponent`. How the input is styled. * Values are `line` - 0, `box` - 1, `border` - 2, `fluent` - 3 `fluentSearch` - 4 and `search` - 5. The default is `line`. * ```typescript *@ViewChild("MyInputGroup") *public inputGroup: IgxInputGroupComponent; *ngAfterViewInit(){ * let inputType = this.inputGroup.type; *} * ``` */ get type() { return this._type.toString(); } /** * Returns whether the `IgxInputGroupComponent` has hints. * ```typescript *@ViewChild("MyInputGroup") *public inputGroup: IgxInputGroupComponent; *ngAfterViewInit(){ * let inputHints = this.inputGroup.hasHints; *} * ``` */ get hasHints() { return this.hints.length > 0; } /** * Returns whether the `IgxInputGroupComponent` has border. * ```typescript *@ViewChild("MyInputGroup") *public inputGroup: IgxInputGroupComponent; *ngAfterViewInit(){ * let inputBroder = this.inputGroup.hasBorder; *} * ``` */ get hasBorder() { return this._type === IgxInputGroupType.LINE || this._type === IgxInputGroupType.BOX; } /** * Returns whether the `IgxInputGroupComponent` type is line. * ```typescript *@ViewChild("MyInputGroup1") *public inputGroup: IgxInputGroupComponent; *ngAfterViewInit(){ * let isTypeLine = this.inputGroup.isTypeLine; *} * ``` */ get isTypeLine() { return this._type === IgxInputGroupType.LINE; } /** * Returns whether the `IgxInputGroupComponent` type is box. * ```typescript *@ViewChild("MyInputGroup1") *public inputGroup: IgxInputGroupComponent; *ngAfterViewInit(){ * let isTypeBox = this.inputGroup.isTypeBox; *} *``` */ get isTypeBox() { return this._type === IgxInputGroupType.BOX; } /** * Returns whether the `IgxInputGroupComponent` type is border. * ```typescript *@ViewChild("MyInputGroup1") *public inputGroup: IgxInputGroupComponent; *ngAfterViewInit(){ * let isTypeBorder = this.inputGroup.isTypeBorder; *} * ``` */ get isTypeBorder() { return this._type === IgxInputGroupType.BORDER; } /** * Returns whether the `IgxInputGroupComponent` type is Fluent. * ```typescript *@ViewChild("MyInputGroup1") *public inputGroup: IgxInputGroupComponent; *ngAfterViewInit(){ * let isTypeFluent = this.inputGroup.isTypeFluent; *} * ``` */ get isTypeFluent() { return this._type === IgxInputGroupType.FLUENT; } /** * Returns whether the `IgxInputGroupComponent` type is search. * ```typescript *@ViewChild("MyInputGroup1") *public inputGroup: IgxInputGroupComponent; *ngAfterViewInit(){ * let isTypeSearch = this.inputGroup.isTypeSearch; *} * ``` */ get isTypeSearch() { return this._type === IgxInputGroupType.SEARCH; } /** * Returns whether the `IgxInputGroupComponent` type is fluentSearch. * ```typescript *@ViewChild("MyInputGroup1") *public inputGroup: IgxInputGroupComponent; *ngAfterViewInit(){ * let isTypeFluentSearch = this.inputGroup.isTypeFluentSearch; *} * ``` */ get isTypeFluentSearch() { return this._type === IgxInputGroupType.FLUENT_SEARCH; } get filled() { return this._filled; } set filled(val) { this._filled = val; } }; IgxInputGroupComponent.ctorParameters = () => [ { type: ElementRef }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DisplayDensityToken,] }] } ]; __decorate([ HostBinding('attr.id'), Input(), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "id", void 0); __decorate([ HostBinding('class.igx-input-group'), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "defaultClass", void 0); __decorate([ HostBinding('class.igx-input-group--placeholder'), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "hasPlaceholder", void 0); __decorate([ HostBinding('class.igx-input-group--required'), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "isRequired", void 0); __decorate([ HostBinding('class.igx-input-group--focused'), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "isFocused", void 0); __decorate([ HostBinding('class.igx-input-group--box'), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "isBox", void 0); __decorate([ HostBinding('class.igx-input-group--border'), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "isBorder", void 0); __decorate([ HostBinding('class.igx-input-group--search'), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "isSearch", void 0); __decorate([ HostBinding('class.igx-input-group--fluent-search'), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "isFluentSearch", void 0); __decorate([ HostBinding('class.igx-input-group--fluent'), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "isFluent", void 0); __decorate([ HostBinding('class.igx-input-group--disabled'), Input(), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "disabled", void 0); __decorate([ HostBinding('class.igx-input-group--valid'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxInputGroupComponent.prototype, "validClass", null); __decorate([ HostBinding('class.igx-input-group--invalid'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxInputGroupComponent.prototype, "invalidClass", null); __decorate([ HostBinding('class.igx-input-group--warning'), __metadata("design:type", Object) ], IgxInputGroupComponent.prototype, "hasWarning", void 0); __decorate([ ContentChildren(IgxHintDirective, { read: IgxHintDirective }), __metadata("design:type", QueryList) ], IgxInputGroupComponent.prototype, "hints", void 0); __decorate([ ContentChild(IgxInputDirective, { read: IgxInputDirective, static: true }), __metadata("design:type", IgxInputDirective) ], IgxInputGroupComponent.prototype, "input", void 0); __decorate([ HostListener('click', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], IgxInputGroupComponent.prototype, "onClick", null); __decorate([ Input('type'), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], IgxInputGroupComponent.prototype, "type", null); __decorate([ Input(), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxInputGroupComponent.prototype, "supressInputAutofocus", null); __decorate([ HostBinding('class.igx-input-group--filled'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxInputGroupComponent.prototype, "isFilled", null); __decorate([ HostBinding('class.igx-input-group--cosy'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxInputGroupComponent.prototype, "isDisplayDensityCosy", null); __decorate([ HostBinding('class.igx-input-group--comfortable'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxInputGroupComponent.prototype, "isDisplayDensityComfortable", null); __decorate([ HostBinding('class.igx-input-group--compact'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxInputGroupComponent.prototype, "isDisplayDensityCompact", null); IgxInputGroupComponent = IgxInputGroupComponent_1 = __decorate([ Component({ selector: 'igx-input-group', template: "<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\">\n <ng-content select=\"igx-hint,[igxHint]\"></ng-content>\n</div>\n\n<ng-template #material>\n <ng-content select=\"[igxLabel]\"></ng-content>\n</ng-template>\n\n<ng-template #bundle>\n\n<!-- <ng-content *ngIf=\"isTypeFluent\" select=\"[igxLabel]\"></ng-content>-->\n <ng-container *ngIf=\"isTypeFluent\">\n <ng-container *ngTemplateOutlet=\"material\"></ng-container>\n </ng-container>\n\n <div class=\"igx-input-group__bundle\">\n <ng-content select=\"igx-prefix,[igxPrefix]\"></ng-content>\n <div class=\"igx-input-group__bundle-main\">\n\n <ng-container *ngIf=\"!isTypeFluent\">\n <ng-container *ngTemplateOutlet=\"material\"></ng-container>\n </ng-container>\n<!-- <ng-content *ngIf=\"!isTypeFluent\" select=\"[igxLabel]\"></ng-content>-->\n\n <ng-content select=\"[igxInput]\"></ng-content>\n </div>\n <ng-content select=\"igx-suffix,[igxSuffix]\"></ng-content>\n </div>\n <div class=\"igx-input-group__border\" *ngIf=\"hasBorder\"></div>\n</ng-template>\n", providers: [{ provide: IgxInputGroupBase, useExisting: IgxInputGroupComponent_1 }] }), __param(1, Optional()), __param(1, Inject(DisplayDensityToken)), __metadata("design:paramtypes", [ElementRef, Object]) ], IgxInputGroupComponent); export { IgxInputGroupComponent }; /** * @hidden */ let IgxInputGroupModule = class IgxInputGroupModule { }; IgxInputGroupModule = __decorate([ NgModule({ declarations: [ IgxInputGroupComponent, IgxHintDirective, IgxInputDirective, IgxLabelDirective ], exports: [ IgxInputGroupComponent, IgxHintDirective, IgxInputDirective, IgxLabelDirective, IgxPrefixModule, IgxSuffixModule ], imports: [ CommonModule, IgxPrefixModule, IgxSuffixModule ] }) ], IgxInputGroupModule); export { IgxInputGroupModule }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-group.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/input-group/input-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    Component,\n    ContentChild,\n    ContentChildren,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Input,\n    NgModule,\n    QueryList,\n    Inject,\n    Optional\n} from '@angular/core';\nimport { IgxHintDirective } from '../directives/hint/hint.directive';\nimport { IgxInputDirective, IgxInputState } from '../directives/input/input.directive';\nimport { IgxLabelDirective } from '../directives/label/label.directive';\nimport { IgxPrefixDirective, IgxPrefixModule} from '../directives/prefix/prefix.directive';\nimport { IgxSuffixDirective, IgxSuffixModule } from '../directives/suffix/suffix.directive';\nimport { DisplayDensity, IDisplayDensityOptions, DisplayDensityToken, DisplayDensityBase } from '../core/displayDensity';\nimport { IgxInputGroupBase } from './input-group.common';\n\nlet NEXT_ID = 0;\n\nenum IgxInputGroupType {\n    LINE,\n    BOX,\n    BORDER,\n    FLUENT,\n    SEARCH,\n    FLUENT_SEARCH,\n}\n\n@Component({\n    selector: 'igx-input-group',\n    templateUrl: 'input-group.component.html',\n    providers: [{ provide: IgxInputGroupBase, useExisting: IgxInputGroupComponent }]\n})\nexport class IgxInputGroupComponent extends DisplayDensityBase implements IgxInputGroupBase {\n    private _type = IgxInputGroupType.LINE;\n    private _filled = false;\n    private _supressInputAutofocus = false;\n\n    /**\n     * An ElementRef property of the `IgxInputGroupComponent`.\n     */\n    public element: ElementRef;\n\n    /**\n     * An @Input property that sets the value of `id` attribute. If not provided it will be automatically generated.\n     * ```html\n     * <igx-input-group [id]=\"'igx-input-group-55'\"></igx-input-group>\n     * ```\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-input-group-${NEXT_ID++}`;\n\n    /**\n     * Property that enables/disables the autogenerated 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    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-input-group--placeholder')\n    public hasPlaceholder = false;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-input-group--required')\n    public isRequired = false;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-input-group--focused')\n    public isFocused = false;\n\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-input-group--box')\n    public isBox = false;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-input-group--border')\n    public isBorder = false;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-input-group--search')\n    public isSearch = false;\n    /**\n     * @hidden\n     */\n\n    @HostBinding('class.igx-input-group--fluent-search')\n    public isFluentSearch = false;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-input-group--fluent')\n    public isFluent = false;\n\n    /**\n     * An @Input property that disables the `IgxInputGroupComponent`.\n     * ```html\n     * <igx-input-group [disabled]=\"'true'\"></igx-input-group>\n     * ```\n     */\n    @HostBinding('class.igx-input-group--disabled')\n    @Input()\n    public disabled = false;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-input-group--valid')\n    public get validClass(): boolean {\n        return this.input.valid === IgxInputState.VALID;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-input-group--invalid')\n    public get invalidClass(): boolean {\n        return this.input.valid === IgxInputState.INVALID;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-input-group--warning')\n    public hasWarning = false;\n\n    /**\n     * @hidden\n     */\n    @ContentChildren(IgxHintDirective, { read: IgxHintDirective })\n    protected hints: QueryList<IgxHintDirective>;\n\n    /**\n     * @hidden\n     */\n    @ContentChild(IgxInputDirective, { read: IgxInputDirective, static: true })\n    protected input: IgxInputDirective;\n\n    /**\n     *@hidden\n     */\n    @HostListener('click', ['$event'])\n    public onClick(event) {\n        if (!this._supressInputAutofocus) {\n            this.input.focus();\n        }\n    }\n\n    /**\n     * An @Input property that sets how the input will be styled.\n     * The allowed values are `line`, `box`, `border`, `fluent`, `search` and `fluentSearch`. The default is `line`.\n     * ```html\n     *<igx-input-group [type]=\"'search'\">\n     * ```\n     */\n    @Input('type')\n    set type(value: string) {\n        const type: IgxInputGroupType = (IgxInputGroupType as any)[value.toUpperCase()];\n        if (type !== undefined) {\n            this.isBox = this.isFluent = this.isFluentSearch = this.isBorder = this.isSearch = false;\n            switch (type) {\n                case IgxInputGroupType.BOX:\n                    this.isBox = true;\n                    break;\n                case IgxInputGroupType.BORDER:\n                    this.isBorder = true;\n                    break;\n                case IgxInputGroupType.FLUENT:\n                    this.isFluent = true;\n                    break;\n                case IgxInputGroupType.FLUENT_SEARCH:\n                    this.isFluentSearch = true;\n                    break;\n                case IgxInputGroupType.SEARCH:\n                    this.isSearch = true;\n                    break;\n                default: break;\n            }\n\n            this._type = type;\n        }\n    }\n\n    /**\n     * Returns whether the input element of the input group will be automatically focused on click.\n     * ```typescript\n     * let supressInputAutofocus = this.inputGroup.supressInputAutofocus;\n     * ```\n     */\n    @Input()\n    public get supressInputAutofocus(): boolean {\n        return this._supressInputAutofocus;\n    }\n\n    /**\n     * Sets whether the input element of the input group will be automatically focused on click.\n     * ```html\n     * <igx-input-group [supressInputAutofocus]=\"true\"></igx-input-group>\n     * ```\n     */\n    public set supressInputAutofocus(value: boolean) {\n        this._supressInputAutofocus = value;\n    }\n\n    /**\n     *@hidden\n     */\n    @HostBinding('class.igx-input-group--filled')\n    get isFilled() {\n        return this._filled || (this.input && this.input.value);\n    }\n\n    /**\n     *@hidden\n     */\n    @HostBinding('class.igx-input-group--cosy')\n    get isDisplayDensityCosy() {\n        return this.displayDensity === DisplayDensity.cosy;\n    }\n\n    /**\n     *@hidden\n     */\n    @HostBinding('class.igx-input-group--comfortable')\n    get isDisplayDensityComfortable() {\n        return this.displayDensity === DisplayDensity.comfortable;\n    }\n\n    /**\n     *@hidden\n     */\n    @HostBinding('class.igx-input-group--compact')\n    get isDisplayDensityCompact() {\n        return this.displayDensity === DisplayDensity.compact;\n    }\n\n    /**\n     * Returns the type of the `IgxInputGroupComponent`. How the input is styled.\n     * Values are `line` - 0, `box` - 1, `border` - 2,  `fluent` - 3 `fluentSearch` - 4 and `search` - 5. 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    get type() {\n        return this._type.toString();\n    }\n\n    constructor(private _element: ElementRef,\n        @Optional() @Inject(DisplayDensityToken) private _displayDensityOptions: IDisplayDensityOptions) {\n        super(_displayDensityOptions);\n        this.element = _element;\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    get hasHints() {\n        return this.hints.length > 0;\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` has border.\n     * ```typescript\n     *@ViewChild(\"MyInputGroup\")\n     *public inputGroup: IgxInputGroupComponent;\n     *ngAfterViewInit(){\n     *    let inputBroder = this.inputGroup.hasBorder;\n     *}\n     * ```\n     */\n    get hasBorder() {\n        return this._type === IgxInputGroupType.LINE ||\n            this._type === IgxInputGroupType.BOX;\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 === IgxInputGroupType.LINE;\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    get isTypeBox() {\n        return this._type === IgxInputGroupType.BOX;\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    get isTypeBorder() {\n        return this._type === IgxInputGroupType.BORDER;\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` type is Fluent.\n     * ```typescript\n     *@ViewChild(\"MyInputGroup1\")\n     *public inputGroup: IgxInputGroupComponent;\n     *ngAfterViewInit(){\n     *    let isTypeFluent = this.inputGroup.isTypeFluent;\n     *}\n     * ```\n     */\n    get isTypeFluent() {\n        return this._type === IgxInputGroupType.FLUENT;\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    get isTypeSearch() {\n        return  this._type === IgxInputGroupType.SEARCH;\n    }\n\n    /**\n     * Returns whether the `IgxInputGroupComponent` type is fluentSearch.\n     * ```typescript\n     *@ViewChild(\"MyInputGroup1\")\n     *public inputGroup: IgxInputGroupComponent;\n     *ngAfterViewInit(){\n     *    let isTypeFluentSearch = this.inputGroup.isTypeFluentSearch;\n     *}\n     * ```\n     */\n    get isTypeFluentSearch() {\n        return  this._type === IgxInputGroupType.FLUENT_SEARCH;\n    }\n\n    get filled() {\n        return this._filled;\n    }\n\n    set filled(val) {\n        this._filled = val;\n    }\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [\n        IgxInputGroupComponent,\n        IgxHintDirective,\n        IgxInputDirective,\n        IgxLabelDirective\n    ],\n    exports: [\n        IgxInputGroupComponent,\n        IgxHintDirective,\n        IgxInputDirective,\n        IgxLabelDirective,\n        IgxPrefixModule,\n        IgxSuffixModule\n    ],\n    imports: [\n        CommonModule,\n        IgxPrefixModule,\n        IgxSuffixModule\n    ]\n})\nexport class IgxInputGroupModule { }\n"]}