Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(module:typography): more edit triggers #8420

Open
wants to merge 22 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
5c11a42
fix(module:tabs): wrong cursor
ParsaArvanehPA Feb 1, 2024
aac33c4
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Feb 13, 2024
f7525f5
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Feb 19, 2024
8a974b9
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Feb 19, 2024
e5276bb
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Feb 20, 2024
0f989fe
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Feb 27, 2024
ec35a90
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Feb 28, 2024
5a03136
feat(module:typography): more edit triggers
ParsaArvanehPA Mar 1, 2024
a10a874
feat(module:typography): more edit triggers
ParsaArvanehPA Mar 1, 2024
6ec6fe1
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Mar 2, 2024
6ca0a03
Merge branch 'master' into feature/typography-support-edit-on-text-click
ParsaArvanehPA Mar 2, 2024
5d1e384
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Mar 24, 2024
d81339e
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Mar 24, 2024
2284767
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Apr 6, 2024
0ac094d
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Apr 23, 2024
59d40a5
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA May 12, 2024
82afabb
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Jul 14, 2024
d426202
feat(module:typography): more edit triggers
ParsaArvanehPA Jul 14, 2024
aa3c404
feat(module:typography): more edit triggers
ParsaArvanehPA Jul 17, 2024
7f4b0e6
feat(module:typography): more edit triggers
ParsaArvanehPA Jul 17, 2024
11b7fc8
Merge branch 'NG-ZORRO:master' into master
ParsaArvanehPA Jul 17, 2024
816c62b
Merge branch 'refs/heads/master' into feature/typography-support-edit…
ParsaArvanehPA Jul 17, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 20 additions & 0 deletions components/typography/demo/interactive.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,22 @@ import { Component } from '@angular/core';
></p>
<p nz-typography nzEditable [nzEditTooltip]="null" [(nzContent)]="hideEditTooltipStr"></p>
<p nz-typography nzCopyable nzEditable [(nzContent)]="copyStr"></p>
<div>
<p>
<span>Trigger edit with: </span>
<nz-radio-group [(ngModel)]="triggerState" nzName="triggerEdit">
<label nz-radio [nzValue]="'icon'">icon</label>
<label nz-radio [nzValue]="'text'">text</label>
<label nz-radio [nzValue]="'both'">both</label>
</nz-radio-group>
</p>
<p
nz-typography
nzEditable
[nzTriggerType]="triggerState !== 'both' ? [triggerState] : ['icon', 'text']"
[(nzContent)]="triggerEditStr"
></p>
</div>
<p nz-typography nzCopyable nzCopyText="Hello, Ant Design!">Replace copy text.</p>
<p
nz-typography
Expand Down Expand Up @@ -40,4 +56,8 @@ export class NzDemoTypographyInteractiveComponent {
customEditIconStr = 'Custom edit icon and tooltip text.';
hideEditTooltipStr = 'Hide edit tooltip.';
copyStr = 'This is a copyable text.';
triggerEditStr = 'Text or icon as trigger - click to start editing.';

nzEditTriggerStates = ['icon', 'text', 'both'] as const;
triggerState: (typeof this.nzEditTriggerStates)[number] = 'icon';
}
3 changes: 2 additions & 1 deletion components/typography/demo/module
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import { NzTypographyModule } from 'ng-zorro-antd/typography';
import { NzDividerModule } from 'ng-zorro-antd/divider';
import { NzSliderModule } from 'ng-zorro-antd/slider';
import { NzRadioModule } from 'ng-zorro-antd/radio';

export const moduleList = [ NzTypographyModule, NzDividerModule, NzSliderModule ];
export const moduleList = [ NzTypographyModule, NzDividerModule, NzSliderModule, NzRadioModule ];
1 change: 1 addition & 0 deletions components/typography/doc/index.en-US.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ import { NzTypographyModule } from 'ng-zorro-antd/typography';
| `[nzContent]` | Component content | `string` | - | |
| `[nzCopyable]` | Can copy, require use `[nzContent]` | `boolean` | `false` | |
| `[nzEditable]` | Editable, require use `[nzContent]` | `boolean` | `false` | |
| `[nzTriggerType]` | Edit mode trigger, require use `[nzContent]` | `icon \| text \| both` | `icon` | |
| `[nzCopyIcons]` | Custom copy icons | `[string \| TemplateRef<void>, string \| TemplateRef<void>]` | `['copy', 'check']` | ✅ |
| `[nzCopyTooltips]` | Custom tooltips text, hide when it is `null` | `null \| [string \| TemplateRef<void>, string \| TemplateRef<void>]` | - | ✅ |
| `[nzEditIcon]` | Custom edit icon | `string \| TemplateRef<void>` | `'edit'` | ✅ |
Expand Down
39 changes: 20 additions & 19 deletions components/typography/doc/index.zh-CN.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,22 +22,23 @@ import { NzTypographyModule } from 'ng-zorro-antd/typography';

### [nz-typography]:standalone

| 参数 | 说明 | 类型 | 默认值 | 全局配置 |
| ------------------- | --------------------------------------------------- | -------------------------------------------------------------------- | ------------------- | -------- |
| `[nzContent]` | 组件内容 | `string` | - |
| `[nzCopyable]` | 是否可拷贝,需要配合 `[nzContent]` 使用 | `boolean` | `false` |
| `[nzEditable]` | 是否可编辑,需要配合 `[nzContent]` 使用 | `boolean` | `false` |
| `[nzCopyIcons]` | 自定义拷贝图标 | `[string \| TemplateRef<void>, string \| TemplateRef<void>]` | `['copy', 'check']` | ✅ |
| `[nzCopyTooltips]` | 自定义提示文案,为 `null` 时隐藏文案 | `null \| [string \| TemplateRef<void>, string \| TemplateRef<void>]` | - | ✅ |
| `[nzEditIcon]` | 自定义编辑图标 | `string \| TemplateRef<void>` | `'edit'` | ✅ |
| `[nzEditTooltip]` | 自定义提示文案,为 `null` 时隐藏文案 | `null \| string \| TemplateRef<void>` | - | ✅ |
| `[nzEllipsis]` | 自动溢出省略,动态内容时需要配合 `[nzContent]` 使用 | `boolean` | `false` |
| `[nzExpandable]` | 自动溢出省略时是否可展开 | `boolean` | `false` | |
| `[nzSuffix]` | 自动溢出省略时的文本后缀 | `string` | - | |
| `[nzCopyText]` | 自定义被拷贝的文本 | `string` | - | |
| `[nzDisabled]` | 禁用文本 | `boolean` | `false` | |
| `[nzEllipsisRows]` | 自动溢出省略时省略行数 | `number` | `1` | ✅ |
| `[nzType]` | 文本类型 | `'secondary' \| 'warning' \| 'danger' \| 'success'` | - | |
| `(nzContentChange)` | 当用户提交编辑内容时触发 | `EventEmitter<string>` | - | |
| `(nzExpandChange)` | 展开省略文本时触发 | `EventEmitter<void>` | - | |
| `(nzOnEllipsis)` | 当省略状态变化时触发 | `EventEmitter<boolean>` | - | |
| 参数 | 说明 | 类型 | 默认值 | 全局配置 |
| ------------------- | --------------------------------------------------- | -------------------------------------------------------------------- | -------- | -------- |
| `[nzContent]` | 组件内容 | `string` | - | |
| `[nzCopyable]` | 是否可拷贝,需要配合 `[nzContent]` 使用 | `boolean` | `false` | |
| `[nzEditable]` | 是否可编辑,需要配合 `[nzContent]` 使用 | `boolean` | `false` | |
| `[nzEditable]` | 是否可编辑,需要配合 `[nzContent]` 使用 | `boolean` | `false` | |
| `[nzTriggerType]` | 编辑模式触发器类型, 需要配合 `[nzContent]` 使用 | `icon \| text \| both` | `icon` | |
| `[nzCopyTooltips]` | 自定义提示文案,为 `null` 时隐藏文案 | `null \| [string \| TemplateRef<void>, string \| TemplateRef<void>]` | - | ✅ |
| `[nzEditIcon]` | 自定义编辑图标 | `string \| TemplateRef<void>` | `'edit'` | ✅ |
| `[nzEditTooltip]` | 自定义提示文案,为 `null` 时隐藏文案 | `null \| string \| TemplateRef<void>` | - | ✅ |
| `[nzEllipsis]` | 自动溢出省略,动态内容时需要配合 `[nzContent]` 使用 | `boolean` | `false` | |
| `[nzExpandable]` | 自动溢出省略时是否可展开 | `boolean` | `false` | |
| `[nzSuffix]` | 自动溢出省略时的文本后缀 | `string` | - | |
| `[nzCopyText]` | 自定义被拷贝的文本 | `string` | - | |
| `[nzDisabled]` | 禁用文本 | `boolean` | `false` | |
| `[nzEllipsisRows]` | 自动溢出省略时省略行数 | `number` | `1` | ✅ |
| `[nzType]` | 文本类型 | `'secondary' \| 'warning' \| 'danger' \| 'success'` | - | |
| `(nzContentChange)` | 当用户提交编辑内容时触发 | `EventEmitter<string>` | - | |
| `(nzExpandChange)` | 展开省略文本时触发 | `EventEmitter<void>` | - | |
| `(nzOnEllipsis)` | 当省略状态变化时触发 | `EventEmitter<boolean>` | - | |
28 changes: 18 additions & 10 deletions components/typography/text-edit.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,9 @@ import { NzIconModule } from 'ng-zorro-antd/icon';
import { NzAutosizeDirective, NzInputModule } from 'ng-zorro-antd/input';
import { NzToolTipModule } from 'ng-zorro-antd/tooltip';

const nzEditTriggerStates = ['icon', 'text'] as const;
export type NzEditTriggerState = Array<(typeof nzEditTriggerStates)[number]>;

@Component({
selector: 'nz-text-edit',
exportAs: 'nzTextEdit',
Expand All @@ -45,17 +48,21 @@ import { NzToolTipModule } from 'ng-zorro-antd/tooltip';
</ng-template>

<ng-template #notEditing>
<button
nz-tooltip
nz-trans-button
class="ant-typography-edit"
[nzTooltipTitle]="tooltip === null ? null : tooltip || locale?.edit"
(click)="onClick()"
>
<ng-container *nzStringTemplateOutlet="icon; let icon">
<span nz-icon [nzType]="icon"></span>
@if (nzTriggerType.includes('icon')) {
<ng-container>
<button
nz-tooltip
nz-trans-button
class="ant-typography-edit"
[nzTooltipTitle]="tooltip === null ? null : tooltip || locale?.edit"
(click)="onClick()"
>
<ng-container *nzStringTemplateOutlet="icon; let icon">
<span nz-icon [nzType]="icon"></span>
</ng-container>
</button>
</ng-container>
</button>
}
</ng-template>
`,
changeDetection: ChangeDetectionStrategy.OnPush,
Expand All @@ -71,6 +78,7 @@ export class NzTextEditComponent implements OnInit {

@Input() text?: string;
@Input() icon: NzTSType = 'edit';
@Input() nzTriggerType: NzEditTriggerState = ['icon'];
@Input() tooltip?: null | NzTSType;
@Output() readonly startEditing = new EventEmitter<void>();
@Output() readonly endEditing = new EventEmitter<string>(true);
Expand Down
16 changes: 14 additions & 2 deletions components/typography/typography.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,7 +40,7 @@ import { isStyleSupport, measure } from 'ng-zorro-antd/core/util';
import { NzI18nService, NzTextI18nInterface } from 'ng-zorro-antd/i18n';

import { NzTextCopyComponent } from './text-copy.component';
import { NzTextEditComponent } from './text-edit.component';
import { NzEditTriggerState, NzTextEditComponent } from './text-edit.component';

const NZ_CONFIG_MODULE_NAME: NzConfigKey = 'typography';
const EXPAND_ELEMENT_CLASSNAME = 'ant-typography-expand';
Expand All @@ -57,7 +57,11 @@ const EXPAND_ELEMENT_CLASSNAME = 'ant-typography-expand';
template: `
<ng-template #contentTemplate let-content="content">
<ng-content *ngIf="!content"></ng-content>
{{ content }}
@if (nzEllipsis) {
{{ content }}
} @else {
<span (click)="onTextClickEdit()">{{ content }}</span>
}
</ng-template>
<ng-container *ngIf="!editing">
<ng-container
Expand Down Expand Up @@ -90,6 +94,7 @@ const EXPAND_ELEMENT_CLASSNAME = 'ant-typography-expand';
[text]="nzContent"
[icon]="nzEditIcon"
[tooltip]="nzEditTooltip"
[nzTriggerType]="nzTriggerType"
(endEditing)="onEndEditing($event)"
(startEditing)="onStartEditing()"
></nz-text-edit>
Expand Down Expand Up @@ -140,6 +145,7 @@ export class NzTypographyComponent implements OnInit, AfterViewInit, OnDestroy,
@Input() nzType: 'secondary' | 'warning' | 'danger' | 'success' | undefined;
@Input() nzCopyText: string | undefined;
@Input() nzSuffix: string | undefined;
@Input() nzTriggerType: NzEditTriggerState = ['icon'];
@Output() readonly nzContentChange = new EventEmitter<string>();
@Output() readonly nzCopy = new EventEmitter<string>();
@Output() readonly nzExpandChange = new EventEmitter<void>();
Expand Down Expand Up @@ -203,6 +209,12 @@ export class NzTypographyComponent implements OnInit, AfterViewInit, OnDestroy,
this.editing = true;
}

onTextClickEdit(): void {
if (this.nzEditable && this.nzTriggerType.includes('text')) {
this.textEditRef?.onClick();
}
}

onEndEditing(text: string): void {
this.editing = false;
this.nzContentChange.emit(text);
Expand Down
54 changes: 54 additions & 0 deletions components/typography/typography.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -19,6 +19,7 @@ import { NzSafeAny } from 'ng-zorro-antd/core/types';
import { NzIconTestModule } from 'ng-zorro-antd/icon/testing';

import { NzTextEditComponent } from '.';
import { NzEditTriggerState } from './text-edit.component';
import { NzTypographyComponent } from './typography.component';
import { NzTypographyModule } from './typography.module';

Expand Down Expand Up @@ -540,6 +541,57 @@ describe('change detection behavior', () => {
done();
});
});

it('should have default edit trigger option', () => {
expect(fixture.componentInstance.nzTrigger).toEqual(['icon']);
});

it('should have edit button in "both" and "icon" trigger state', () => {
fixture.componentInstance.nzTrigger = ['text', 'icon'];
fixture.detectChanges();
let editButton = componentElement.querySelector<HTMLButtonElement>('.ant-typography-edit');
expect(editButton).not.toBeNull();

fixture.componentInstance.nzTrigger = ['icon'];
fixture.detectChanges();
editButton = componentElement.querySelector<HTMLButtonElement>('.ant-typography-edit');
expect(editButton).not.toBeNull();

fixture.componentInstance.nzTrigger = ['text'];
fixture.detectChanges();
editButton = componentElement.querySelector<HTMLButtonElement>('.ant-typography-edit');
expect(editButton).toBeNull();
});

it('in "both" trigger state, should start editing when text is clicked', () => {
fixture.componentInstance.nzTrigger = ['text', 'icon'];
fixture.detectChanges();
let text = componentElement.querySelector<HTMLButtonElement>('span');
text!.click();
fixture.detectChanges();
let editingTextArea = componentElement.querySelector<HTMLButtonElement>('textarea');
expect(editingTextArea).not.toBeNull();
});

it('in "text" trigger state, should start editing when text is clicked', () => {
fixture.componentInstance.nzTrigger = ['text'];
fixture.detectChanges();
let text = componentElement.querySelector<HTMLButtonElement>('span');
text!.click();
fixture.detectChanges();
let editingTextArea = componentElement.querySelector<HTMLButtonElement>('textarea');
expect(editingTextArea).not.toBeNull();
});

it('in "icon" trigger state, should not start editing when text is clicked', () => {
fixture.componentInstance.nzTrigger = ['icon'];
fixture.detectChanges();
let text = componentElement.querySelector<HTMLButtonElement>('span');
text!.click();
fixture.detectChanges();
let editingTextArea = componentElement.querySelector<HTMLButtonElement>('textarea');
expect(editingTextArea).toBeNull();
});
});

@Component({
Expand Down Expand Up @@ -597,6 +649,7 @@ export class NzTestTypographyCopyComponent {
nzEditable
[nzEditIcon]="icon"
[nzEditTooltip]="tooltip"
[nzTriggerType]="nzTrigger"
(nzContentChange)="onChange($event)"
[nzContent]="str"
></p>
Expand All @@ -607,6 +660,7 @@ export class NzTestTypographyEditComponent {
str = 'This is an editable text.';
icon = 'edit';
tooltip?: string | null;
nzTrigger: NzEditTriggerState = ['icon'];

onChange = (text: string): void => {
this.str = text;
Expand Down
Loading