Skip to main content Skip to footer

Customizing Indentation and Icons with a TreeGrid in Angular

The difference in customizing Indentation and Icons in a TreeGrid

Background:

There may be times when default styling does not meet your applications needs, and you want to adjust the style of your TreeGrid columns so you can more easily understand the hierarchy. This can be achieved with Wijmo by following this article.

Steps to Complete:

  1. Customize Indentation with the formatItem Event
  2. Replace the Default Tree Icons Using CSS

Getting Started:

Customize Indentation with the formatItem Event

This will determine how far each row is indented based on its hierarchy level.

onFormatItem(e: FormatItemEventArgs) {
  const col = e.getColumn();
  const row = e.getRow();

  if (col.binding === 'name') {
    let padding = (row.level || 0) * 14;

    // Extra space for leaf nodes so icons line up
    if (!row.hasChildren) {
      padding += 21;
    }

    e.cell.style.paddingLeft = `${padding}px`;
  }
}

 

Replace the Default Tree Icons Using CSS

The default expand/collapse icons can be replaced using CSS selectors that target Wijmo’s built-in glyph classes.

/* app.component.css */
.wj-flexgrid .wj-cell:has(.wj-glyph-down-right) {
  display: flex;
}
.wj-flexgrid .wj-cell:has(.wj-glyph-right) {
  display: flex;
  align-items: center;
}

.wj-glyph-down-right {
  background-image: url('');
  background-repeat: no-repeat;
  width: 20px;
  height: 20px;
  border: none !important; /* Make sure to remove border */
}

.wj-glyph-right {
  background-image: url('');
  background-repeat: no-repeat;
  width: 20px;
  height: 20px;
  border: none !important;
}

 

You can of course accomplish more of the styling through the formatItem event if you prefer, this is just one way of adding customization.

I hope you find this article helpful. Happy coding!

 

Code for reference:

// app.component.ts
import { Component, ViewChild } from '@angular/core';
import { FlexGrid, FormatItemEventArgs, Column, Row } from '@mescius/wijmo.grid';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  @ViewChild('treeGrid', { static: true }) treeGrid: FlexGrid;

  data = [
    {
      name: 'Electronics',
      sales: 120000,
      children: [
        { name: 'Phones', sales: 55000 },
        { name: 'Laptops', sales: 65000 }
      ]
    },
    {
      name: 'Home',
      sales: 95000,
      children: [
        { name: 'Furniture', sales: 50000 },
        { name: 'Kitchen', sales: 45000 }
      ]
    }
  ];

  onFormatItem(e: FormatItemEventArgs) {
    const col: Column = e.getColumn();
    const row: Row = e.getRow();

    if (col.binding === 'name') {
      let padding = (row.level || 0) * 14;

      // Add extra padding for leaf nodes so the icons align
      if (!row.hasChildren) {
        padding += 21;
      }

      e.cell.style.paddingLeft = `${padding}px`;
    }
  }
}

 

<!-- app.component.html -->
<div style="margin: 20px;">
  <h2>Angular TreeGrid with Custom Indentation & Icons</h2>

  <wj-flex-grid #treeGrid
                [itemsSource]="data"
                [childItemsPath]="'children'"
                [autoGenerateColumns]="false"
                (formatItem)="onFormatItem($event)">

    <wj-flex-grid-column [binding]="'name'" header="Name"></wj-flex-grid-column>
    <wj-flex-grid-column [binding]="'sales'" header="Sales"></wj-flex-grid-column>

  </wj-flex-grid>
</div>

Andrew Peterson

Technical Engagement Engineer