diff --git a/components/avatar/avatar.spec.ts b/components/avatar/avatar.spec.ts
index 3419e478c84..eddafb2b3f4 100644
--- a/components/avatar/avatar.spec.ts
+++ b/components/avatar/avatar.spec.ts
@@ -102,6 +102,24 @@ describe('avatar', () => {
expect(dl.query(By.css(`.ant-avatar-${item.cls}`)) !== null).toBe(true);
});
}
+
+ it('custom size', () => {
+ context.nzSize = 64;
+ context.nzIcon = null;
+ context.nzSrc = null;
+ fixture.detectChanges();
+ const size = `${64}px`;
+ const hostStyle = dl.nativeElement.querySelector('nz-avatar').style;
+ expect(hostStyle.height === size).toBe(true);
+ expect(hostStyle.width === size).toBe(true);
+ expect(hostStyle.lineHeight === size).toBe(true);
+ expect(hostStyle.fontSize === ``).toBe(true);
+
+ context.nzIcon = 'user';
+ fixture.detectChanges();
+ expect(hostStyle.fontSize === `${context.nzSize / 2}px`).toBe(true);
+ });
+
});
describe('order: image > icon > text', () => {
@@ -151,7 +169,7 @@ describe('avatar', () => {
class TestAvatarComponent {
@ViewChild('comp') comp: NzAvatarComponent;
nzShape = 'square';
- nzSize = 'large';
+ nzSize: string | number = 'large';
nzIcon = 'anticon anticon-user';
nzText = 'A';
nzSrc = ``;
diff --git a/components/avatar/demo/badge.ts b/components/avatar/demo/badge.ts
index 47f3e029387..bf3e46aeefd 100644
--- a/components/avatar/demo/badge.ts
+++ b/components/avatar/demo/badge.ts
@@ -4,10 +4,10 @@ import { Component } from '@angular/core';
selector: 'nz-demo-avatar-badge',
template: `
-
+
-
+
`
})
diff --git a/components/avatar/demo/basic.ts b/components/avatar/demo/basic.ts
index 0dc28343095..f34e86c9164 100644
--- a/components/avatar/demo/basic.ts
+++ b/components/avatar/demo/basic.ts
@@ -4,14 +4,16 @@ import { Component } from '@angular/core';
selector: 'nz-demo-avatar-basic',
template: `
-
-
-
+
+
+
+
-
-
-
+
+
+
+
`,
styles: [`
diff --git a/components/avatar/demo/type.ts b/components/avatar/demo/type.ts
index 41f61e29ca9..d3b741b8586 100644
--- a/components/avatar/demo/type.ts
+++ b/components/avatar/demo/type.ts
@@ -3,12 +3,12 @@ import { Component } from '@angular/core';
@Component({
selector: 'nz-demo-avatar-type',
template: `
-
+
-
+
-
+
`,
styles: [`
:host ::ng-deep .ant-avatar {
diff --git a/components/avatar/doc/index.en-US.md b/components/avatar/doc/index.en-US.md
index 7cbffa5b557..92e3c833268 100644
--- a/components/avatar/doc/index.en-US.md
+++ b/components/avatar/doc/index.en-US.md
@@ -14,6 +14,6 @@ Avatars can be used to represent people or objects. It supports images, `Icon`s,
| -------- | ----------- | ---- | ------- |
| `[nzIcon]` | the `Icon` type for an icon avatar, see `Icon` | string | - |
| `[nzShape]` | the shape of avatar | `circle` | `square` | `circle` |
-| `[nzSize]` | the size of the avatar | `large` | `small` | `default` | `default` |
+| `[nzSize]` | the size of the avatar | `large` | `small` | `default` | number | `default` |
| `[nzSrc]` | the address of the image for an image avatar | string | - |
| `[nzText]` | letter type avatar | string | - |
diff --git a/components/avatar/doc/index.zh-CN.md b/components/avatar/doc/index.zh-CN.md
index 3011d5f185c..eedfd7c15e6 100644
--- a/components/avatar/doc/index.zh-CN.md
+++ b/components/avatar/doc/index.zh-CN.md
@@ -15,6 +15,6 @@ title: Avatar
| --- | --- | --- | --- |
| `[nzIcon]` | 设置头像的图标类型,参考 `Icon` | string | - |
| `[nzShape]` | 指定头像的形状 | Enum{ 'circle', 'square' } | `circle` |
-| `[nzSize]` | 设置头像的大小 | Enum{ 'large', 'small', 'default' } | `default` |
+| `[nzSize]` | 设置头像的大小 | Enum{ 'large', 'small', 'default', number } | `default` |
| `[nzSrc]` | 图片类头像的资源地址 | string | - |
| `[nzText]` | 文本类头像 | string | - |
diff --git a/components/avatar/nz-avatar.component.ts b/components/avatar/nz-avatar.component.ts
index 9e2ce0948fc..b3b94429bfa 100644
--- a/components/avatar/nz-avatar.component.ts
+++ b/components/avatar/nz-avatar.component.ts
@@ -1,10 +1,11 @@
import {
+ Attribute,
ChangeDetectionStrategy,
ChangeDetectorRef,
Component,
ElementRef,
Input,
- OnChanges,
+ OnChanges, Renderer2,
SimpleChanges,
ViewChild
} from '@angular/core';
@@ -13,6 +14,7 @@ import { NzUpdateHostClassService } from '../core/services/update-host-class.ser
import { NzSizeLDSType } from '../core/types/size';
export type NzAvatarShape = 'square' | 'circle';
+export type NzAvatarSize = NzSizeLDSType | number;
@Component({
selector : 'nz-avatar',
@@ -44,13 +46,17 @@ export class NzAvatarComponent implements OnChanges {
@Input() nzShape: NzAvatarShape = 'circle';
- @Input() nzSize: NzSizeLDSType = 'default';
+ @Input() nzSize: NzAvatarSize = 'default';
@Input() nzText: string;
@Input() nzSrc: string;
- constructor(private elementRef: ElementRef, private cd: ChangeDetectorRef, private updateHostClassService: NzUpdateHostClassService) {
+ constructor(
+ private elementRef: ElementRef,
+ private cd: ChangeDetectorRef,
+ private updateHostClassService: NzUpdateHostClassService,
+ private renderer: Renderer2) {
}
private el: HTMLElement = this.elementRef.nativeElement;
private prefixCls = 'ant-avatar';
@@ -63,7 +69,7 @@ export class NzAvatarComponent implements OnChanges {
[ `${this.prefixCls}-${this.sizeMap[ this.nzSize ]}` ]: this.sizeMap[ this.nzSize ],
[ `${this.prefixCls}-${this.nzShape}` ] : this.nzShape,
[ `${this.prefixCls}-icon` ] : this.nzIcon,
- [ `${this.prefixCls}-image` ] : this.nzSrc
+ [ `${this.prefixCls}-image` ] : this.hasSrc // downgrade after image error
};
this.updateHostClassService.updateHostClass(this.el, classMap);
this.cd.detectChanges();
@@ -80,6 +86,7 @@ export class NzAvatarComponent implements OnChanges {
this.hasText = true;
}
this.setClass().notifyCalc();
+ this.setSizeStyle();
}
ngOnChanges(changes: SimpleChanges): void {
@@ -88,6 +95,7 @@ export class NzAvatarComponent implements OnChanges {
this.hasSrc = !!this.nzSrc;
this.setClass().notifyCalc();
+ this.setSizeStyle();
}
private calcStringSize(): void {
@@ -118,4 +126,16 @@ export class NzAvatarComponent implements OnChanges {
});
return this;
}
+
+ private setSizeStyle(): void {
+ if (typeof this.nzSize === 'string') {
+ return;
+ }
+ this.renderer.setStyle(this.el, 'width', `${this.nzSize}px`);
+ this.renderer.setStyle(this.el, 'height', `${this.nzSize}px`);
+ this.renderer.setStyle(this.el, 'line-height', `${this.nzSize}px`);
+ if (this.hasIcon) {
+ this.renderer.setStyle(this.el, 'font-size', `${this.nzSize / 2}px`);
+ }
+ }
}