GitHub

Modal

Modal is a dynamically rendered element that floats above the rest of a page's content. It can be especially useful for interstitials that require additional user feedback.

Basic Modal

Usage

Within a standalone component

To use modal in a standalone component, import DAFF_MODAL_COMPONENTS directly into your custom component:

@Component({
  selector: 'custom-component',
  templateUrl: './custom-component.component.html',
  standalone: true,
  imports: [
    DAFF_MODAL_COMPONENTS,
  ],
})
export class CustomComponent {}

Within a module (deprecated)

To use modal in a module, import DaffModalModule into your custom module:

import { NgModule } from '@angular/core';

import { DaffModalModule } from '@daffodil/design/modal';

@NgModule({
    declarations: [
    CustomComponent,
  ],
  exports: [
    CustomComponent,
  ],
  imports: [
    DaffModalModule,
  ],
})
export class CustomComponentModule { }

This method is deprecated. It's recommended to update all custom components to standalone.

Supported Content Types

A modal includes minimally pre-styled components and directives to help structure the content in your modal.

Header can be added to a modal by using <daff-modal-header>. The header includes a title and an optional close button.

Title

Title can be added to the header by using the [daffModalTitle] directive.

Close Button

The close button in the header is shown by default but can be hidden by setting the dismissible property to false on the header.

Content

Content can be added to a modal by using <daff-modal-content>. It should only be used once. It's a wrapper container that can be used to place all additional components and text content within a modal. The content container allows for a ton of control and customization because it's minimally pre-styled and serves as a wrapping and spacing container that is scrollable.

Actions

Buttons can be added to a modal by using <daff-modal-actions>. This container will always be positioned at the bottom of a modal. The horizontal alignment of the actions is set to end.

Dismissing a Modal

A modal can be dismissed via the close button or the ESC key. The close button is shown by default but can be hidden by setting the dismissible property to false on <daff-modal-header>. Additionally, the [daffModalClose] directive can be added to a <button> HTML element.

Accessibility

Modal works with the ARIA role="dialog" and aria-modal="true" attributes to provide an accessible experience. The first tabbable element will receive focus when a modal is opened.

aria-labelledby is assigned the [daffModalTitle] string when it's used. If there is no title, aria-labelledby should be set in the configurations through the DaffModalService.

constructor(private modalService: DaffModalService) {}

showModal() {
    this.modal = this.modalService.open(
        BasicModalContentComponent,
        { ariaLabelledBy: 'Modal Title' },
    );
}

Keyboard Interactions

A modal can be closed by choosing one of the actions buttons, the close button in the header, or it can be dismissed by pressing the ESC key.

Graycore, LLC © 2018 - 2025. Code licensed under an MIT-style License. Documentation licensed under CC BY 4.0.