UNPKG

@catull/igniteui-angular

Version:

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

303 lines 25.5 kB
import { __decorate, __metadata } from "tslib"; import { CommonModule } from '@angular/common'; import { AfterViewInit, Component, ElementRef, HostBinding, Input, NgModule, OnInit, TemplateRef, ViewChild } from '@angular/core'; import { IgxIconModule } from '../icon/index'; let NEXT_ID = 0; export var Size; (function (Size) { Size["SMALL"] = "small"; Size["MEDIUM"] = "medium"; Size["LARGE"] = "large"; })(Size || (Size = {})); export var AvatarType; (function (AvatarType) { AvatarType["DEFAULT"] = "default"; AvatarType["INITIALS"] = "initials"; AvatarType["IMAGE"] = "image"; AvatarType["ICON"] = "icon"; })(AvatarType || (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> * ``` */ let IgxAvatarComponent = class IgxAvatarComponent { 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 */ 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 */ 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 */ 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 */ 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 */ ngOnInit() { this.roleDescription = this.getRole(); } /** *@hidden */ ngAfterViewInit() { this.elementRef.nativeElement.classList .add(`igx-avatar--${this._size}`, `igx-avatar--${this.type}`); } /** * @hidden */ 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 */ getSrcUrl() { return `url(${this.src})`; } }; IgxAvatarComponent.ctorParameters = () => [ { type: ElementRef } ]; __decorate([ ViewChild('image'), __metadata("design:type", ElementRef) ], IgxAvatarComponent.prototype, "image", void 0); __decorate([ ViewChild('defaultTemplate', { read: TemplateRef, static: true }), __metadata("design:type", TemplateRef) ], IgxAvatarComponent.prototype, "defaultTemplate", void 0); __decorate([ ViewChild('imageTemplate', { read: TemplateRef, static: true }), __metadata("design:type", TemplateRef) ], IgxAvatarComponent.prototype, "imageTemplate", void 0); __decorate([ ViewChild('initialsTemplate', { read: TemplateRef, static: true }), __metadata("design:type", TemplateRef) ], IgxAvatarComponent.prototype, "initialsTemplate", void 0); __decorate([ ViewChild('iconTemplate', { read: TemplateRef, static: true }), __metadata("design:type", TemplateRef) ], IgxAvatarComponent.prototype, "iconTemplate", void 0); __decorate([ HostBinding('attr.aria-label'), __metadata("design:type", Object) ], IgxAvatarComponent.prototype, "ariaLabel", void 0); __decorate([ HostBinding('attr.role'), __metadata("design:type", Object) ], IgxAvatarComponent.prototype, "role", void 0); __decorate([ HostBinding('class.igx-avatar'), __metadata("design:type", Object) ], IgxAvatarComponent.prototype, "cssClass", void 0); __decorate([ HostBinding('attr.aria-roledescription'), __metadata("design:type", String) ], IgxAvatarComponent.prototype, "roleDescription", void 0); __decorate([ HostBinding('attr.id'), Input(), __metadata("design:type", Object) ], IgxAvatarComponent.prototype, "id", void 0); __decorate([ HostBinding('class.igx-avatar--rounded'), Input(), __metadata("design:type", Object) ], IgxAvatarComponent.prototype, "roundShape", void 0); __decorate([ HostBinding('style.color'), Input(), __metadata("design:type", String) ], IgxAvatarComponent.prototype, "color", void 0); __decorate([ HostBinding('style.background'), Input(), __metadata("design:type", String) ], IgxAvatarComponent.prototype, "bgColor", void 0); __decorate([ Input(), __metadata("design:type", String) ], IgxAvatarComponent.prototype, "initials", void 0); __decorate([ Input(), __metadata("design:type", String) ], IgxAvatarComponent.prototype, "icon", void 0); __decorate([ Input(), __metadata("design:type", String) ], IgxAvatarComponent.prototype, "src", void 0); __decorate([ Input(), __metadata("design:type", String), __metadata("design:paramtypes", [String]) ], IgxAvatarComponent.prototype, "size", null); IgxAvatarComponent = __decorate([ Component({ 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" }), __metadata("design:paramtypes", [ElementRef]) ], IgxAvatarComponent); export { IgxAvatarComponent }; /** * @hidden */ let IgxAvatarModule = class IgxAvatarModule { }; IgxAvatarModule = __decorate([ NgModule({ declarations: [IgxAvatarComponent], exports: [IgxAvatarComponent], imports: [CommonModule, IgxIconModule] }) ], IgxAvatarModule); export { IgxAvatarModule }; //# 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, static: true })\n    protected defaultTemplate: TemplateRef<any>;\n\n    /**\n     *@hidden\n     */\n    @ViewChild('imageTemplate', { read: TemplateRef, static: true })\n    protected imageTemplate: TemplateRef<any>;\n\n    /**\n     *@hidden\n     */\n    @ViewChild('initialsTemplate', { read: TemplateRef, static: true })\n    protected initialsTemplate: TemplateRef<any>;\n\n    /**\n     *@hidden\n     */\n    @ViewChild('iconTemplate', { read: TemplateRef, static: true })\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"]}