igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
432 lines • 27.5 kB
JavaScript
/**
* @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"]}