igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
647 lines • 43 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 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 { IgxPrefixDirective, IgxPrefixModule } from '../directives/prefix/prefix.directive';
import { IgxSuffixDirective, IgxSuffixModule } from '../directives/suffix/suffix.directive';
import { DisplayDensity, DisplayDensityToken, DisplayDensityBase } from '../core/displayDensity';
import { IgxInputGroupBase } from './input-group.common';
/** @type {?} */
var NEXT_ID = 0;
/** @enum {number} */
var IgxInputGroupType = {
LINE: 0,
BOX: 1,
BORDER: 2,
SEARCH: 3,
};
IgxInputGroupType[IgxInputGroupType.LINE] = 'LINE';
IgxInputGroupType[IgxInputGroupType.BOX] = 'BOX';
IgxInputGroupType[IgxInputGroupType.BORDER] = 'BORDER';
IgxInputGroupType[IgxInputGroupType.SEARCH] = 'SEARCH';
var IgxInputGroupComponent = /** @class */ (function (_super) {
tslib_1.__extends(IgxInputGroupComponent, _super);
function IgxInputGroupComponent(_element, _displayDensityOptions) {
var _this = _super.call(this, _displayDensityOptions) || this;
_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;
/**
* 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;
return _this;
}
Object.defineProperty(IgxInputGroupComponent.prototype, "validClass", {
/**
* @hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this.input.valid === IgxInputState.VALID;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "invalidClass", {
/**
* @hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this.input.valid === IgxInputState.INVALID;
},
enumerable: true,
configurable: true
});
/**
*@hidden
*/
/**
* @hidden
* @param {?} event
* @return {?}
*/
IgxInputGroupComponent.prototype.onClick = /**
* @hidden
* @param {?} event
* @return {?}
*/
function (event) {
if (!this._supressInputAutofocus) {
this.input.focus();
}
};
Object.defineProperty(IgxInputGroupComponent.prototype, "type", {
/**
* Returns the type of the `IgxInputGroupComponent`. How the input is styled.
* Values are `line` - 0, `box` - 1, `border` - 2 and `search` - 3. The default is `line`.
* ```typescript
*@ViewChild("MyInputGroup")
*public inputGroup: IgxInputGroupComponent;
*ngAfterViewInit(){
* let inputType = this.inputGroup.type;
*}
* ```
*/
get: /**
* Returns the type of the `IgxInputGroupComponent`. How the input is styled.
* Values are `line` - 0, `box` - 1, `border` - 2 and `search` - 3. The default is `line`.
* ```typescript
* \@ViewChild("MyInputGroup")
* public inputGroup: IgxInputGroupComponent;
* ngAfterViewInit(){
* let inputType = this.inputGroup.type;
* }
* ```
* @return {?}
*/
function () {
return this._type.toString();
},
/**
* An @Input property that sets how the input will be styled.
* The allowed values are `line`, `box`, `border` and `search`. The default is `line`.
* ```html
*<igx-input-group [type]="'search'">
* ```
*/
set: /**
* An \@Input property that sets how the input will be styled.
* The allowed values are `line`, `box`, `border` and `search`. The default is `line`.
* ```html
* <igx-input-group [type]="'search'">
* ```
* @param {?} value
* @return {?}
*/
function (value) {
/** @type {?} */
var type = ((/** @type {?} */ (IgxInputGroupType)))[value.toUpperCase()];
if (type !== undefined) {
this.isBox = this.isBorder = this.isSearch = false;
switch (type) {
case IgxInputGroupType.BOX:
this.isBox = true;
break;
case IgxInputGroupType.BORDER:
this.isBorder = true;
break;
case IgxInputGroupType.SEARCH:
this.isSearch = true;
break;
default: break;
}
this._type = type;
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "supressInputAutofocus", {
/**
* Returns whether the input element of the input group will be automatically focused on click.
* ```typescript
* let supressInputAutofocus = this.inputGroup.supressInputAutofocus;
* ```
*/
get: /**
* Returns whether the input element of the input group will be automatically focused on click.
* ```typescript
* let supressInputAutofocus = this.inputGroup.supressInputAutofocus;
* ```
* @return {?}
*/
function () {
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: /**
* Sets whether the input element of the input group will be automatically focused on click.
* ```html
* <igx-input-group [supressInputAutofocus]="true"></igx-input-group>
* ```
* @param {?} value
* @return {?}
*/
function (value) {
this._supressInputAutofocus = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "isFilled", {
/**
*@hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this._filled || (this.input && this.input.value);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "isDisplayDensityCosy", {
/**
*@hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this.displayDensity === DisplayDensity.cosy;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "isDisplayDensityComfortable", {
/**
*@hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this.displayDensity === DisplayDensity.comfortable;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "isDisplayDensityCompact", {
/**
*@hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this.displayDensity === DisplayDensity.compact;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "hasHints", {
/**
* Returns whether the `IgxInputGroupComponent` has hints.
* ```typescript
*@ViewChild("MyInputGroup")
*public inputGroup: IgxInputGroupComponent;
*ngAfterViewInit(){
* let inputHints = this.inputGroup.hasHints;
*}
* ```
*/
get: /**
* Returns whether the `IgxInputGroupComponent` has hints.
* ```typescript
* \@ViewChild("MyInputGroup")
* public inputGroup: IgxInputGroupComponent;
* ngAfterViewInit(){
* let inputHints = this.inputGroup.hasHints;
* }
* ```
* @return {?}
*/
function () {
return this.hints.length > 0;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "hasBorder", {
/**
* Returns whether the `IgxInputGroupComponent` has border.
* ```typescript
*@ViewChild("MyInputGroup")
*public inputGroup: IgxInputGroupComponent;
*ngAfterViewInit(){
* let inputBroder = this.inputGroup.hasBorder;
*}
* ```
*/
get: /**
* Returns whether the `IgxInputGroupComponent` has border.
* ```typescript
* \@ViewChild("MyInputGroup")
* public inputGroup: IgxInputGroupComponent;
* ngAfterViewInit(){
* let inputBroder = this.inputGroup.hasBorder;
* }
* ```
* @return {?}
*/
function () {
return this._type === IgxInputGroupType.LINE ||
this._type === IgxInputGroupType.BOX;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "isTypeLine", {
/**
* Returns whether the `IgxInputGroupComponent` type is line.
* ```typescript
*@ViewChild("MyInputGroup1")
*public inputGroup: IgxInputGroupComponent;
*ngAfterViewInit(){
* let isTypeLine = this.inputGroup.isTypeLine;
*}
* ```
*/
get: /**
* Returns whether the `IgxInputGroupComponent` type is line.
* ```typescript
* \@ViewChild("MyInputGroup1")
* public inputGroup: IgxInputGroupComponent;
* ngAfterViewInit(){
* let isTypeLine = this.inputGroup.isTypeLine;
* }
* ```
* @return {?}
*/
function () {
return this._type === IgxInputGroupType.LINE;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "isTypeBox", {
/**
* Returns whether the `IgxInputGroupComponent` type is box.
* ```typescript
*@ViewChild("MyInputGroup1")
*public inputGroup: IgxInputGroupComponent;
*ngAfterViewInit(){
* let isTypeBox = this.inputGroup.isTypeBox;
*}
*```
*/
get: /**
* Returns whether the `IgxInputGroupComponent` type is box.
* ```typescript
* \@ViewChild("MyInputGroup1")
* public inputGroup: IgxInputGroupComponent;
* ngAfterViewInit(){
* let isTypeBox = this.inputGroup.isTypeBox;
* }
* ```
* @return {?}
*/
function () {
return this._type === IgxInputGroupType.BOX;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "isTypeBorder", {
/**
* Returns whether the `IgxInputGroupComponent` type is border.
* ```typescript
*@ViewChild("MyInputGroup1")
*public inputGroup: IgxInputGroupComponent;
*ngAfterViewInit(){
* let isTypeBorder = this.inputGroup.isTypeBorder;
*}
* ```
*/
get: /**
* Returns whether the `IgxInputGroupComponent` type is border.
* ```typescript
* \@ViewChild("MyInputGroup1")
* public inputGroup: IgxInputGroupComponent;
* ngAfterViewInit(){
* let isTypeBorder = this.inputGroup.isTypeBorder;
* }
* ```
* @return {?}
*/
function () {
return this._type === IgxInputGroupType.BORDER;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "isTypeSearch", {
/**
* Returns whether the `IgxInputGroupComponent` type is search.
* ```typescript
*@ViewChild("MyInputGroup1")
*public inputGroup: IgxInputGroupComponent;
*ngAfterViewInit(){
* let isTypeSearch = this.inputGroup.isTypeSearch;
*}
* ```
*/
get: /**
* Returns whether the `IgxInputGroupComponent` type is search.
* ```typescript
* \@ViewChild("MyInputGroup1")
* public inputGroup: IgxInputGroupComponent;
* ngAfterViewInit(){
* let isTypeSearch = this.inputGroup.isTypeSearch;
* }
* ```
* @return {?}
*/
function () {
return this._type === IgxInputGroupType.SEARCH;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxInputGroupComponent.prototype, "filled", {
get: /**
* @return {?}
*/
function () {
return this._filled;
},
set: /**
* @param {?} val
* @return {?}
*/
function (val) {
this._filled = val;
},
enumerable: true,
configurable: true
});
IgxInputGroupComponent.decorators = [
{ type: Component, args: [{
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<div class=\"igx-input-group__hint\">\n <ng-content select=\"igx-hint,[igxHint]\"></ng-content>\n</div>\n<ng-template #bundle>\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 <ng-content select=\"[igxLabel]\"></ng-content>\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 }]
}] }
];
/** @nocollapse */
IgxInputGroupComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DisplayDensityToken,] }] }
]; };
IgxInputGroupComponent.propDecorators = {
id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }],
defaultClass: [{ type: HostBinding, args: ['class.igx-input-group',] }],
hasPlaceholder: [{ type: HostBinding, args: ['class.igx-input-group--placeholder',] }],
isRequired: [{ type: HostBinding, args: ['class.igx-input-group--required',] }],
isFocused: [{ type: HostBinding, args: ['class.igx-input-group--focused',] }],
isBox: [{ type: HostBinding, args: ['class.igx-input-group--box',] }],
isBorder: [{ type: HostBinding, args: ['class.igx-input-group--border',] }],
isSearch: [{ type: HostBinding, args: ['class.igx-input-group--search',] }],
disabled: [{ type: HostBinding, args: ['class.igx-input-group--disabled',] }, { type: Input }],
validClass: [{ type: HostBinding, args: ['class.igx-input-group--valid',] }],
invalidClass: [{ type: HostBinding, args: ['class.igx-input-group--invalid',] }],
hasWarning: [{ type: HostBinding, args: ['class.igx-input-group--warning',] }],
hints: [{ type: ContentChildren, args: [IgxHintDirective, { read: IgxHintDirective },] }],
input: [{ type: ContentChild, args: [IgxInputDirective, { read: IgxInputDirective },] }],
onClick: [{ type: HostListener, args: ['click', ['$event'],] }],
type: [{ type: Input, args: ['type',] }],
supressInputAutofocus: [{ type: Input }],
isFilled: [{ type: HostBinding, args: ['class.igx-input-group--filled',] }],
isDisplayDensityCosy: [{ type: HostBinding, args: ['class.igx-input-group--cosy',] }],
isDisplayDensityComfortable: [{ type: HostBinding, args: ['class.igx-input-group--comfortable',] }],
isDisplayDensityCompact: [{ type: HostBinding, args: ['class.igx-input-group--compact',] }]
};
return IgxInputGroupComponent;
}(DisplayDensityBase));
export { IgxInputGroupComponent };
if (false) {
/**
* @type {?}
* @private
*/
IgxInputGroupComponent.prototype._type;
/**
* @type {?}
* @private
*/
IgxInputGroupComponent.prototype._filled;
/**
* @type {?}
* @private
*/
IgxInputGroupComponent.prototype._supressInputAutofocus;
/**
* An ElementRef property of the `IgxInputGroupComponent`.
* @type {?}
*/
IgxInputGroupComponent.prototype.element;
/**
* 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>
* ```
* @type {?}
*/
IgxInputGroupComponent.prototype.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;
* ```
* }
* @type {?}
*/
IgxInputGroupComponent.prototype.defaultClass;
/**
* @hidden
* @type {?}
*/
IgxInputGroupComponent.prototype.hasPlaceholder;
/**
* @hidden
* @type {?}
*/
IgxInputGroupComponent.prototype.isRequired;
/**
* @hidden
* @type {?}
*/
IgxInputGroupComponent.prototype.isFocused;
/**
* @hidden
* @type {?}
*/
IgxInputGroupComponent.prototype.isBox;
/**
* @hidden
* @type {?}
*/
IgxInputGroupComponent.prototype.isBorder;
/**
* @hidden
* @type {?}
*/
IgxInputGroupComponent.prototype.isSearch;
/**
* An \@Input property that disables the `IgxInputGroupComponent`.
* ```html
* <igx-input-group [disabled]="'true'"></igx-input-group>
* ```
* @type {?}
*/
IgxInputGroupComponent.prototype.disabled;
/**
* @hidden
* @type {?}
*/
IgxInputGroupComponent.prototype.hasWarning;
/**
* @hidden
* @type {?}
* @protected
*/
IgxInputGroupComponent.prototype.hints;
/**
* @hidden
* @type {?}
* @protected
*/
IgxInputGroupComponent.prototype.input;
/**
* @type {?}
* @private
*/
IgxInputGroupComponent.prototype._element;
/**
* @type {?}
* @private
*/
IgxInputGroupComponent.prototype._displayDensityOptions;
}
/**
* @hidden
*/
var IgxInputGroupModule = /** @class */ (function () {
function IgxInputGroupModule() {
}
IgxInputGroupModule.decorators = [
{ type: NgModule, args: [{
declarations: [IgxInputGroupComponent, IgxHintDirective, IgxInputDirective, IgxLabelDirective],
exports: [IgxInputGroupComponent, IgxHintDirective, IgxInputDirective, IgxLabelDirective, IgxPrefixDirective, IgxSuffixDirective],
imports: [CommonModule, IgxPrefixModule, IgxSuffixModule]
},] }
];
return 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    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    /**\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 })\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` and `search`. 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.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.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  and `search` - 3. 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 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    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: [IgxInputGroupComponent, IgxHintDirective, IgxInputDirective, IgxLabelDirective],\n    exports: [IgxInputGroupComponent,  IgxHintDirective, IgxInputDirective, IgxLabelDirective, IgxPrefixDirective, IgxSuffixDirective],\n    imports: [CommonModule, IgxPrefixModule, IgxSuffixModule]\n})\nexport class IgxInputGroupModule { }\n"]}