UNPKG

igniteui-angular

Version:

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

432 lines • 27.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { CommonModule } from '@angular/common'; import { Component, ElementRef, HostBinding, Input, NgModule, TemplateRef, ViewChild } from '@angular/core'; import { IgxIconModule } from '../icon/index'; /** @type {?} */ let NEXT_ID = 0; /** @enum {string} */ const Size = { SMALL: 'small', MEDIUM: 'medium', LARGE: 'large', }; export { Size }; /** @enum {string} */ const AvatarType = { DEFAULT: 'default', INITIALS: 'initials', IMAGE: 'image', ICON: 'icon', }; export { AvatarType }; /** * **Ignite UI for Angular Avatar** - * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/avatar.html) * * The Ignite UI Avatar provides an easy way to add an avatar icon to your application. This icon can be an * image, someone's initials or a material icon from the google material icon set. * * Example: * ```html * <igx-avatar initials="MS" roundShape="true" size="large"> * </igx-avatar> * ``` */ export class IgxAvatarComponent { /** * @param {?} elementRef */ constructor(elementRef) { this.elementRef = elementRef; /** * Returns the `aria-label` of the avatar. * * ```typescript * let ariaLabel = this.avatar.ariaLabel; * ``` * */ this.ariaLabel = 'avatar'; /** * Returns the `role` attribute of the avatar. * * ```typescript * let avatarRole = this.avatar.role; * ``` * * \@memberof IgxAvatarComponent */ this.role = 'img'; /** * Returns the class of the avatar. * * ```typescript * let avatarCLass = this.avatar.cssClass; * ``` * * \@memberof IgxAvatarComponent */ this.cssClass = 'igx-avatar'; /** * @hidden */ this._size = 'small'; /** * Sets the `id` of the avatar. If not set, the first avatar component will have `id` = `"igx-avatar-0"`. * * ```html * <igx-avatar id="my-first-avatar"></igx-avatar> * ``` * * \@memberof IgxAvatarComponent */ this.id = `igx-avatar-${NEXT_ID++}`; /** * Sets a round shape to the avatar if `roundShape` is `"true"`. * By default the shape of the avatar is a square. * * ```html * <igx-avatar roundShape = "true" ></igx-avatar> * ``` * * \@memberof IgxAvatarComponent */ this.roundShape = false; } /** * Returns the `size` of the avatar. * * ```typescript * let avatarSize = this.avatar.size; * ``` * * \@memberof IgxAvatarComponent * @return {?} */ get size() { return this._size; } /** * Sets the `size` of the avatar. * By default the `size` is `"small"`. It can be set to `"medium"` or `"large"`. * * ``` * <igx-avatar size="large"></igx-avatar> * ``` * * \@memberof IgxAvatarComponent * @param {?} value * @return {?} */ set size(value) { switch (value) { case 'small': case 'medium': case 'large': this._size = value; break; default: this._size = 'small'; } } /** * Returns the type of the avatar. * * ```typescript * let avatarType = this.avatar.type; * ``` * * \@memberof IgxAvatarComponent * @return {?} */ get type() { if (this.src) { return AvatarType.IMAGE; } if (this.icon) { return AvatarType.ICON; } if (this.initials) { return AvatarType.INITIALS; } return AvatarType.DEFAULT; } /** * Returns the template of the avatar. * * ```typescript * let template = this.avatar.template; * ``` * * \@memberof IgxAvatarComponent * @return {?} */ get template() { switch (this.type) { case AvatarType.IMAGE: return this.imageTemplate; case AvatarType.INITIALS: return this.initialsTemplate; case AvatarType.ICON: return this.iconTemplate; default: return this.defaultTemplate; } } /** * @hidden * @return {?} */ ngOnInit() { this.roleDescription = this.getRole(); } /** * @hidden * @return {?} */ ngAfterViewInit() { this.elementRef.nativeElement.classList .add(`igx-avatar--${this._size}`, `igx-avatar--${this.type}`); } /** * @hidden * @private * @return {?} */ getRole() { switch (this.type) { case AvatarType.IMAGE: return 'image avatar'; case AvatarType.ICON: return 'icon avatar'; case AvatarType.INITIALS: return 'initials avatar'; default: return 'custom avatar'; } } /** * Returns the url of the `image`. * * ```typescript * let imageSourceUrl = this.avatar.getSrcUrl(); * ``` * * \@memberof IgxAvatarComponent * @return {?} */ getSrcUrl() { return `url(${this.src})`; } } IgxAvatarComponent.decorators = [ { type: Component, args: [{ selector: 'igx-avatar', template: "<ng-template #defaultTemplate>\n <ng-content></ng-content>\n</ng-template>\n\n<ng-template #imageTemplate>\n <div #image class=\"igx-avatar__image\" [style.backgroundImage]=\"getSrcUrl()\"></div>\n</ng-template>\n\n<ng-template #initialsTemplate>\n <span>{{initials.substring(0, 2)}}</span>\n</ng-template>\n\n<ng-template #iconTemplate>\n <igx-icon>{{icon}}</igx-icon>\n</ng-template>\n\n<ng-container *ngTemplateOutlet=\"template\"></ng-container>\n" }] } ]; /** @nocollapse */ IgxAvatarComponent.ctorParameters = () => [ { type: ElementRef } ]; IgxAvatarComponent.propDecorators = { image: [{ type: ViewChild, args: ['image',] }], defaultTemplate: [{ type: ViewChild, args: ['defaultTemplate', { read: TemplateRef },] }], imageTemplate: [{ type: ViewChild, args: ['imageTemplate', { read: TemplateRef },] }], initialsTemplate: [{ type: ViewChild, args: ['initialsTemplate', { read: TemplateRef },] }], iconTemplate: [{ type: ViewChild, args: ['iconTemplate', { read: TemplateRef },] }], ariaLabel: [{ type: HostBinding, args: ['attr.aria-label',] }], role: [{ type: HostBinding, args: ['attr.role',] }], cssClass: [{ type: HostBinding, args: ['class.igx-avatar',] }], roleDescription: [{ type: HostBinding, args: ['attr.aria-roledescription',] }], id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }], roundShape: [{ type: HostBinding, args: ['class.igx-avatar--rounded',] }, { type: Input }], color: [{ type: HostBinding, args: ['style.color',] }, { type: Input }], bgColor: [{ type: HostBinding, args: ['style.background',] }, { type: Input }], initials: [{ type: Input }], icon: [{ type: Input }], src: [{ type: Input }], size: [{ type: Input }] }; if (false) { /** * This is a reference to the avatar `image` element in the DOM. * * ```typescript * let image = this.avatar.image; * ``` * \@memberof IgxAvatarComponent * @type {?} */ IgxAvatarComponent.prototype.image; /** * @hidden * @type {?} * @protected */ IgxAvatarComponent.prototype.defaultTemplate; /** * @hidden * @type {?} * @protected */ IgxAvatarComponent.prototype.imageTemplate; /** * @hidden * @type {?} * @protected */ IgxAvatarComponent.prototype.initialsTemplate; /** * @hidden * @type {?} * @protected */ IgxAvatarComponent.prototype.iconTemplate; /** * Returns the `aria-label` of the avatar. * * ```typescript * let ariaLabel = this.avatar.ariaLabel; * ``` * * @type {?} */ IgxAvatarComponent.prototype.ariaLabel; /** * Returns the `role` attribute of the avatar. * * ```typescript * let avatarRole = this.avatar.role; * ``` * * \@memberof IgxAvatarComponent * @type {?} */ IgxAvatarComponent.prototype.role; /** * Returns the class of the avatar. * * ```typescript * let avatarCLass = this.avatar.cssClass; * ``` * * \@memberof IgxAvatarComponent * @type {?} */ IgxAvatarComponent.prototype.cssClass; /** * Returns the type of the avatar. * The avatar can be: `"initials type avatar"`, `"icon type avatar"` or `"image type avatar"`. * * ```typescript * let avatarDescription = this.avatar.roleDescription; * ``` * * \@memberof IgxAvatarComponent * @type {?} */ IgxAvatarComponent.prototype.roleDescription; /** * @hidden * @type {?} * @private */ IgxAvatarComponent.prototype._size; /** * Sets the `id` of the avatar. If not set, the first avatar component will have `id` = `"igx-avatar-0"`. * * ```html * <igx-avatar id="my-first-avatar"></igx-avatar> * ``` * * \@memberof IgxAvatarComponent * @type {?} */ IgxAvatarComponent.prototype.id; /** * Sets a round shape to the avatar if `roundShape` is `"true"`. * By default the shape of the avatar is a square. * * ```html * <igx-avatar roundShape = "true" ></igx-avatar> * ``` * * \@memberof IgxAvatarComponent * @type {?} */ IgxAvatarComponent.prototype.roundShape; /** * Sets the avatar's `initials`/`icon` color. * * ```html * <igx-avatar color="blue"></igx-avatar> * ``` * * \@memberof IgxAvatarComponent * @type {?} */ IgxAvatarComponent.prototype.color; /** * Sets the background color of the avatar. * * ```html * <igx-avatar bgColor="yellow"></igx-avatar> * ``` * * \@memberof IgxAvatarComponent * @type {?} */ IgxAvatarComponent.prototype.bgColor; /** * Sets `initials` to the avatar. * * ```html * <igx-avatar initials="MN"></igx-avatar> * ``` * * \@memberof IgxAvatarComponent * @type {?} */ IgxAvatarComponent.prototype.initials; /** * Sets an `icon` to the avatar. All icons from the material icon set are supported. * * ```html * <igx-avatar icon="phone"></igx-avatar> * ``` * * \@memberof IgxAvatarComponent * @type {?} */ IgxAvatarComponent.prototype.icon; /** * Sets the `image` source of the avatar. * * ```html * <igx-avatar src="images/picture.jpg"></igx-avatar> * ``` * * \@memberof IgxAvatarComponent * @type {?} */ IgxAvatarComponent.prototype.src; /** @type {?} */ IgxAvatarComponent.prototype.elementRef; } /** * @hidden */ export class IgxAvatarModule { } IgxAvatarModule.decorators = [ { type: NgModule, args: [{ declarations: [IgxAvatarComponent], exports: [IgxAvatarComponent], imports: [CommonModule, IgxIconModule] },] } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/avatar/avatar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    HostBinding,\n    Input,\n    NgModule,\n    OnInit,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\nimport { IgxIconModule } from '../icon/index';\n\nlet NEXT_ID = 0;\n\nexport enum Size {\n    SMALL = 'small',\n    MEDIUM = 'medium',\n    LARGE = 'large'\n}\n\nexport enum AvatarType {\n    DEFAULT = 'default',\n    INITIALS = 'initials',\n    IMAGE = 'image',\n    ICON = 'icon'\n}\n\n/**\n * **Ignite UI for Angular Avatar** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/avatar.html)\n *\n * The Ignite UI Avatar provides an easy way to add an avatar icon to your application.  This icon can be an\n * image, someone's initials or a material icon from the google material icon set.\n *\n * Example:\n * ```html\n * <igx-avatar initials=\"MS\" roundShape=\"true\" size=\"large\">\n * </igx-avatar>\n * ```\n */\n@Component({\n    selector: 'igx-avatar',\n    templateUrl: 'avatar.component.html'\n})\nexport class IgxAvatarComponent implements OnInit, AfterViewInit {\n\n    /**\n     * This is a reference to the avatar `image` element in the DOM.\n     *\n     * ```typescript\n     *  let image =  this.avatar.image;\n     * ```\n     * @memberof IgxAvatarComponent\n     */\n    @ViewChild('image')\n    public image: ElementRef;\n\n    /**\n     *@hidden\n     */\n    @ViewChild('defaultTemplate', { read: TemplateRef })\n    protected defaultTemplate: TemplateRef<any>;\n\n    /**\n     *@hidden\n     */\n    @ViewChild('imageTemplate', { read: TemplateRef })\n    protected imageTemplate: TemplateRef<any>;\n\n    /**\n     *@hidden\n     */\n    @ViewChild('initialsTemplate', { read: TemplateRef })\n    protected initialsTemplate: TemplateRef<any>;\n\n    /**\n     *@hidden\n     */\n    @ViewChild('iconTemplate', { read: TemplateRef })\n    protected iconTemplate: TemplateRef<any>;\n\n    /**\n     * Returns the `aria-label` of the avatar.\n     *\n     * ```typescript\n     * let ariaLabel = this.avatar.ariaLabel;\n     * ```\n     *\n     */\n    @HostBinding('attr.aria-label')\n    public ariaLabel = 'avatar';\n\n    /**\n     * Returns the `role` attribute of the avatar.\n     *\n     * ```typescript\n     * let avatarRole = this.avatar.role;\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n    @HostBinding('attr.role')\n    public role = 'img';\n\n    /**\n     * Returns the class of the avatar.\n     *\n     * ```typescript\n     * let avatarCLass =  this.avatar.cssClass;\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n    @HostBinding('class.igx-avatar')\n    public cssClass = 'igx-avatar';\n\n    /**\n     * Returns the type of the avatar.\n     * The avatar can be: `\"initials type avatar\"`, `\"icon type avatar\"` or `\"image type avatar\"`.\n     *\n     * ```typescript\n     * let avatarDescription = this.avatar.roleDescription;\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n\n    @HostBinding('attr.aria-roledescription')\n    public roleDescription: string;\n\n    /**\n     * @hidden\n     */\n    private _size: string | Size = 'small';\n\n    /**\n     * Sets the `id` of the avatar. If not set, the first avatar component will have `id` = `\"igx-avatar-0\"`.\n     *\n     * ```html\n     * <igx-avatar id=\"my-first-avatar\"></igx-avatar>\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-avatar-${NEXT_ID++}`;\n\n    /**\n     * Sets a round shape to the avatar if `roundShape` is `\"true\"`.\n     * By default the shape of the avatar is a square.\n     *\n     * ```html\n     * <igx-avatar roundShape = \"true\" ></igx-avatar>\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n\n    @HostBinding('class.igx-avatar--rounded')\n    @Input()\n    public roundShape = false;\n\n    /**\n     * Sets the avatar's `initials`/`icon` color.\n     *\n     *```html\n     *<igx-avatar color=\"blue\"></igx-avatar>\n     *```\n     *\n     * @memberof IgxAvatarComponent\n     */\n\n    @HostBinding('style.color')\n    @Input()\n    public color: string;\n\n    /**\n     * Sets the background color of the avatar.\n     *\n     * ```html\n     * <igx-avatar bgColor=\"yellow\"></igx-avatar>\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n\n    @HostBinding('style.background')\n    @Input()\n    public bgColor: string;\n\n    /**\n     * Sets `initials` to the avatar.\n     *\n     * ```html\n     * <igx-avatar initials=\"MN\"></igx-avatar>\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n    @Input()\n    public initials: string;\n\n    /**\n     * Sets an `icon` to the avatar. All icons from the material icon set are supported.\n     *\n     * ```html\n     * <igx-avatar icon=\"phone\"></igx-avatar>\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n    @Input()\n    public icon: string;\n\n    /**\n     * Sets the `image` source of the avatar.\n     *\n     * ```html\n     * <igx-avatar src=\"images/picture.jpg\"></igx-avatar>\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n    @Input()\n    public src: string;\n\n    /**\n     * Returns the `size` of the avatar.\n     *\n     * ```typescript\n     *let avatarSize =  this.avatar.size;\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n    @Input()\n    public get size(): string | Size {\n        return this._size;\n    }\n\n    /**\n     * Sets the `size`  of the avatar.\n     * By default the `size` is `\"small\"`. It can be set to `\"medium\"` or `\"large\"`.\n     *\n     * ```\n     * <igx-avatar size=\"large\"></igx-avatar>\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n    public set size(value: string | Size) {\n        switch (value) {\n            case 'small':\n            case 'medium':\n            case 'large':\n                this._size = value;\n                break;\n            default:\n                this._size = 'small';\n        }\n    }\n\n    /**\n     * Returns the type of the avatar.\n     *\n     * ```typescript\n     * let avatarType = this.avatar.type;\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n    get type(): AvatarType {\n        if (this.src) {\n            return AvatarType.IMAGE;\n        }\n\n        if (this.icon) {\n            return AvatarType.ICON;\n        }\n\n        if (this.initials) {\n            return AvatarType.INITIALS;\n        }\n\n        return AvatarType.DEFAULT;\n    }\n\n    /**\n     * Returns the template of the avatar.\n     *\n     * ```typescript\n     * let template = this.avatar.template;\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n    get template(): TemplateRef<any> {\n        switch (this.type) {\n            case AvatarType.IMAGE:\n                return this.imageTemplate;\n            case AvatarType.INITIALS:\n                return this.initialsTemplate;\n            case AvatarType.ICON:\n                return this.iconTemplate;\n            default:\n                return this.defaultTemplate;\n        }\n    }\n\n    constructor(public elementRef: ElementRef) { }\n\n    /**\n     * @hidden\n     */\n    public ngOnInit() {\n        this.roleDescription = this.getRole();\n    }\n\n    /**\n     *@hidden\n     */\n    public ngAfterViewInit() {\n        this.elementRef.nativeElement.classList\n            .add(`igx-avatar--${this._size}`, `igx-avatar--${this.type}`);\n    }\n\n    /**\n     * @hidden\n     */\n    private getRole(): string {\n        switch (this.type) {\n            case AvatarType.IMAGE:\n                return 'image avatar';\n            case AvatarType.ICON:\n                return 'icon avatar';\n            case AvatarType.INITIALS:\n                return 'initials avatar';\n            default:\n                return 'custom avatar';\n        }\n    }\n\n    /**\n     * Returns the url of the `image`.\n     *\n     * ```typescript\n     * let imageSourceUrl = this.avatar.getSrcUrl();\n     * ```\n     *\n     * @memberof IgxAvatarComponent\n     */\n    public getSrcUrl() {\n        return `url(${this.src})`;\n    }\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxAvatarComponent],\n    exports: [IgxAvatarComponent],\n    imports: [CommonModule, IgxIconModule]\n})\nexport class IgxAvatarModule { }\n"]}