如何使用 material 工具提示为 ag-grid 制作自定义工具提示组件

how to make a custom tooltip component for ag-grid using material tooltip

当前 angular ag-grid 工具提示示例不工作。

https://stackblitz.com/edit/angular-ag-grid-tooltip-example-fb7nko

Javascript/typescript。 运行 Angular 8 和最新的 ag-grid 版本。我试图按照 plunker 的例子去做 T 但没有运气。我现在正在尝试这个。我有一个名为 CustomTooltipComponent 的组件,它在模板中有一个动态 mat-tooltip,它从我的 .ts 文件中获取 {{data}}。工具提示没有显示,所以我输入了一个跨度,它显示了,但它以纯文本显示。创建的组件也已经添加到我的入口和声明模块中

<<<----   component that wants the tooltip --->

this.gridOptions = {
      deltaRowDataMode: true,
      getRowNodeId: (data) => data.name,
      onRowDoubleClicked: (data) => this.selectRow(data),
      rowSelection: 'single',
      defaultColDef: {
        sortable: true,
        resizable: true,
        tooltipComponentFramework: CustomTooltipComponent,
        tooltipValueGetter: (params: ITooltipParams) => params.data,
      }
    };```

      this.columnDefs = [
        {
          headerName: 'Name',
          field: 'name',
          sort: 'asc',
         // tooltipField: 'name'
        }



<<<-------- tooltip component .ts ------->>>

import { Component } from '@angular/core';
import { ITooltipAngularComp } from 'ag-grid-angular';
import { ITooltipParams } from 'ag-grid-community';

@Component({
  selector: 'app-custom-tooltip',
  templateUrl: './custom-tooltip.component.html',
  styleUrls: ['./custom-tooltip.component.scss'],
})
export class CustomTooltipComponent implements ITooltipAngularComp {

  public params: ITooltipParams;
  public data: any;

  constructor() { }

  agInit(params: ITooltipParams): void {
    this.data = params.api.getDisplayedRowAtIndex(params.rowIndex).data;
  }

}

<<<----------- tooltip component .html ---->>>

<span matTooltip="{{data.name}}"></span>

<div>
<p><span>Name: </span>{{data.name}}</p>
<p><span>Created by: </span>{{data.createdBy}}</p>
<p><span>Modified by: </span>{{data.modifiedBy}}</p>

</div>

期望工具提示以 mat-tooltip 格式显示 期望 toolTipParams: () 使用这种方法

关于数据问题,你的StackBlitz和这个问题有点不同步,但你需要确保数据对象上的属性与行数据上的属性具有相同的大小写;如果您在 tool-tip.component.html 中将 fname 更改为 fName 并将 lname 更改为 lName 那么您应该会看到数据正确通过。

关于 material 工具提示,设计的用法是您有一个具有 matTooltip 属性的元素(例如 span),然后当您将鼠标悬停在该元素上时,您将看到使用属性内容呈现的工具提示。但是,您在此处使用它的方式是尝试呈现一个元素,该元素在 ag-Grid 正在呈现的工具提示中附加了 material 工具提示,这就是您看到纯文本的原因。如果您确实希望绕过 ag-Grid 的工具提示呈现并改用 material 工具提示,那么 custom cell renderer.

可能会更幸运

它并不完美,但我能够在使用上面@adrian 提到的 cellRendererFramework 时让它工作。这是我修复的一个工作示例,可以在 angular ag-grid 自定义组件中使用 [matTooltip] 及其所有功能。包括作为字符串数组传递的换行符。感谢大家的帮助!

https://stackblitz.com/edit/angular-ag-grid-tooltip-example-ywzxle