Adding tooltips
Adding a tooltip
You can add a default tooltip to a cell or your custom one. To add a tooltip, you should do the following:
- Import the Tooltip component
- To enable/disable tooltips, use the
tooltip
parameter of thecolumns
property:- set it to false to disable
- set it to true or do not specify to show a tooltip by default
tooltip
can be a function that takes an object to be processed as an argument and returns the processed value
- Wrap the Grid tag inside the Tooltip tag and bind to the Grid api
Example:
<script>
import { getData } from "./common/data";
import { Tooltip } from "wx-svelte-core";
import { Grid } from "wx-svelte-grid";
const { data } = getData();
const columnsTooltip = [
{ id: "id", width: 50, tooltip: false },
{
id: "city",
width: 100,
header: "City",
footer: "City",
},
{
id: "firstName",
header: "First Name",
footer: "First Name",
width: 150,
tooltip: false,
},
{
id: "lastName",
header: "Last Name",
footer: "Last Name",
width: 150,
tooltip: false,
},
{ id: "email", header: "Email", footer: "Email" },
{ id: "companyName", header: "Company", footer: "Company" },
{ id: "stars", tooltip: false },
{ id: "date", tooltip: (obj) => obj.date?.toDateString() },
];
let api;
</script>
<Tooltip {api}>
<Grid {data} columns={columnsTooltip} bind:this={api} />
</Tooltip>
In the next example we add a custom Svelte component as a tooltip:
- import the Tooltip component that should be a Svelte component
- prepare you custom Svelte template
- import your custom template
- add the name of the template as the value of the Tooltip content attribute
- wrap the Grid tag into the Tooltip tag
- use the internal api object to get access to the methods
<script>
import { getData } from "../data";
import { Grid, Tooltip } from "wx-svelte-grid";
import YourCustomTooltip from "../custom/CustomTooltip.svelte";
const { data, columns } = getData();
let api;
</script>
<Tooltip content={YourCustomTooltip} {api}>
<Grid {data} {columns} bind:this={api} />
</Tooltip>
Example of a custom component:
<script>
export let data;
</script>
{#if data}
<div class="data">
<div class="text">
{data.email}
</div>
</div>
{/if}
<style>
.data {
background-color: white;
}
.text {
font-family: var(--wx-font-family);
font-size: 13px;
color: black;
}
</style>
Changing the tooltip style
The example below shows how to change the default style of tooltips changing the values in the CSS class.
<script>
import { getData } from "../data";
import { Grid, Tooltip } from "wx-svelte-grid";
const { data, columns } = getData();
const columnsTooltip = [
{ id: "id", width: 50, tooltip: false },
{
id: "city",
width: 100,
header: "City",
footer: "City",
},
{
id: "firstName",
header: "First Name",
footer: "First Name",
width: 150,
tooltip: false,
},
{
id: "lastName",
header: "Last Name",
footer: "Last Name",
width: 150,
tooltip: false,
},
{ id: "email", header: "Email", footer: "Email" },
{ id: "companyName", header: "Company", footer: "Company" },
{ id: "stars", tooltip: false },
{ id: "date", tooltip: obj => obj.date?.toDateString() },
];
let api;
</script>
<Tooltip {api}>
<Grid {data} columns={columnsTooltip} bind:this={api} />
</Tooltip>
<style>
:global(.wx-area .tooltip){
background-color:white;
color:black;
border: 2px black;
}
</style>