Skip to content

Latest commit

 

History

History
272 lines (206 loc) · 8.65 KB

File metadata and controls

272 lines (206 loc) · 8.65 KB

Directives

Part of the igniteui-angular-components skill hub. For app setup, providers, and import patterns — see setup.md.

Contents

Button & Icon Button

Docs: Button Component

import { IgxButtonDirective, IgxIconButtonDirective } from 'igniteui-angular/directives';
import { IgxIconComponent } from 'igniteui-angular/icon';
<!-- Text buttons -->
<button igxButton="flat">Flat</button>
<button igxButton="contained">Contained</button>
<button igxButton="outlined">Outlined</button>
<button igxButton="fab">
  <igx-icon>add</igx-icon>
</button>

<!-- Icon-only buttons -->
<button igxIconButton="flat"><igx-icon>edit</igx-icon></button>
<button igxIconButton="outlined"><igx-icon>delete</igx-icon></button>
<button igxIconButton="contained"><igx-icon>save</igx-icon></button>

<!-- Disabled state -->
<button igxButton="contained" [disabled]="isLoading()">Submit</button>

Button variants for igxButton: 'flat', 'contained', 'outlined', 'fab'. Button variants for igxIconButton: 'flat', 'outlined', 'contained'.

Button Group

Docs: Button Group Component

// Option A — convenience collection (includes IgxButtonGroupComponent + IgxButtonDirective)
import { IGX_BUTTON_GROUP_DIRECTIVES } from 'igniteui-angular/button-group';

// Option B — individual imports
import { IgxButtonGroupComponent } from 'igniteui-angular/button-group';
import { IgxButtonDirective } from 'igniteui-angular/directives';

import { IgxIconComponent } from 'igniteui-angular/icon';
<!-- Text buttons — single selection (default) -->
<igx-buttongroup>
  <button igxButton>Left</button>
  <button igxButton [selected]="true">Center</button>
  <button igxButton>Right</button>
</igx-buttongroup>

<!-- Multi-selection -->
<igx-buttongroup selectionMode="multi">
  <button igxButton><igx-icon>format_bold</igx-icon></button>
  <button igxButton><igx-icon>format_italic</igx-icon></button>
  <button igxButton><igx-icon>format_underlined</igx-icon></button>
</igx-buttongroup>

<!-- singleRequired — always keeps one button selected, cannot deselect -->
<igx-buttongroup selectionMode="singleRequired">
  <button igxButton [selected]="true">Day</button>
  <button igxButton>Week</button>
  <button igxButton>Month</button>
</igx-buttongroup>

<!-- Vertical alignment -->
<igx-buttongroup alignment="vertical">
  <button igxButton>Top</button>
  <button igxButton>Middle</button>
  <button igxButton>Bottom</button>
</igx-buttongroup>

<!-- Disabled group -->
<igx-buttongroup [disabled]="true">
  <button igxButton>A</button>
  <button igxButton>B</button>
</igx-buttongroup>

<!-- React to selection / deselection events -->
<igx-buttongroup (selected)="onSelected($event)" (deselected)="onDeselected($event)">
  <button igxButton>One</button>
  <button igxButton>Two</button>
  <button igxButton>Three</button>
</igx-buttongroup>
import { IButtonGroupEventArgs } from 'igniteui-angular/button-group';

onSelected(event: IButtonGroupEventArgs) {
  console.log('Selected index:', event.index, 'button:', event.button);
}

onDeselected(event: IButtonGroupEventArgs) {
  console.log('Deselected index:', event.index);
}

Key inputs on igx-buttongroup:

Input Type Default Description
selectionMode 'single' | 'singleRequired' | 'multi' 'single' Selection behaviour. singleRequired prevents full deselection.
alignment 'horizontal' | 'vertical' 'horizontal' Layout direction of the buttons.
disabled boolean false Disables every button in the group.

Key outputs on igx-buttongroup:

Output Payload Emits when
(selected) IButtonGroupEventArgs A button is selected.
(deselected) IButtonGroupEventArgs A button is deselected.

IButtonGroupEventArgs: { owner: IgxButtonGroupComponent; button: IgxButtonDirective; index: number }, where IgxButtonDirective is imported from igniteui-angular/directives (see Button & Icon Button section above).

Key inputs on each <button igxButton> child:

Input Type Description
[selected] boolean Sets the initial selected state of the button.
[disabled] boolean Disables a specific button within the group.

Programmatic control:

import { viewChild } from '@angular/core';
import { IgxButtonGroupComponent } from 'igniteui-angular/button-group';

buttonGroup = viewChild.required<IgxButtonGroupComponent>('myGroup');

selectSecond()   { this.buttonGroup().selectButton(1); }
deselectSecond() { this.buttonGroup().deselectButton(1); }
getSelected()    { return this.buttonGroup().selectedButtons; }
<igx-buttongroup #myGroup selectionMode="multi">
  <button igxButton>A</button>
  <button igxButton>B</button>
  <button igxButton>C</button>
</igx-buttongroup>

Ripple Effect

Docs: Ripple Directive

import { IgxRippleDirective } from 'igniteui-angular/directives';
<!-- Add to any clickable element for Material-style ink ripple -->
<button igxButton="contained" igxRipple>Click me</button>
<div igxRipple igxRippleTarget=".my-class" class="custom-surface">Interactive div</div>

Inputs: [igxRipple] (ripple color), [igxRippleCentered] (always start from center), [igxRippleDisabled].

<button igxButton="contained" igxRipple="#ff4081" [igxRippleCentered]="true">Pink ripple</button>

Tooltip

Docs: Tooltip Directive

import { IgxTooltipDirective, IgxTooltipTargetDirective } from 'igniteui-angular/directives';
<button igxButton [igxTooltipTarget]="myTooltip" [igxTooltipTargetShowDelay]="500">
  Hover or focus me
</button>
<div igxTooltip #myTooltip="tooltip">Helpful tooltip text</div>

Inputs on [igxTooltipTarget]: [igxTooltipTargetShowDelay] (ms), [igxTooltipTargetHideDelay] (ms), [tooltipDisabled].

Programmatic control:

tooltip = viewChild.required<IgxTooltipDirective>('myTooltip');

showTooltip() { this.tooltip().open(); }
hideTooltip() { this.tooltip().close(); }

Drag and Drop

Docs: Drag and Drop

import { IgxDragDirective, IgxDropDirective, IDragMoveEventArgs, IDropDroppedEventArgs } from 'igniteui-angular/directives';

Basic drag and drop

<!-- Draggable source -->
<div igxDrag [dragData]="item" (dragMove)="onDragMove($event)" (dragEnd)="onDragEnd($event)">
  <igx-icon>drag_indicator</igx-icon>
  {{ item.name }}
</div>

<!-- Drop target -->
<div igxDrop (dropped)="onDrop($event)" (dragEnter)="onDragEnter($event)" (dragLeave)="onDragLeave($event)">
  Drop here
</div>
onDrop(event: IDropDroppedEventArgs) {
  const draggedItem = event.drag.data;
  // Move draggedItem to this drop zone
  event.cancel = false; // allow the drop
}

Ghost element (custom drag preview)

<div igxDrag [ghostTemplate]="ghostTmpl">Drag me</div>

<ng-template #ghostTmpl>
  <div class="custom-ghost">
    <igx-icon>content_copy</igx-icon> Moving...
  </div>
</ng-template>

Reorderable list

<igx-list>
  @for (item of items; track item.id) {
    <igx-list-item igxDrag [dragData]="item" igxDrop (dropped)="reorder($event, item)">
      <igx-icon igxListAction>drag_handle</igx-icon>
      <span igxListLine>{{ item.name }}</span>
    </igx-list-item>
  }
</igx-list>

Key drag events: (dragStart), (dragMove), (dragEnd), (dragClick), (transitioned). Key drop events: (dragEnter), (dragLeave), (dragOver), (dropped).

NOTE: For touch-based drag, add importProvidersFrom(HammerModule) to app.config.ts providers.

See Also

  • setup.md — App providers, architecture, all entry points
  • form-controls.md — Input Group, Combo, Select, Date/Time Pickers, Calendar, Checkbox, Radio, Switch, Slider
  • layout.md — Tabs, Stepper, Accordion, Splitter, Navigation Drawer
  • data-display.md — List, Tree, Card and other display components
  • feedback.md — Dialog, Snackbar, Toast, Banner