Skip to content

Angular Directive that uses CDK Portal to add mode toggle buttons to a PrimeNG Calendar component

License

Notifications You must be signed in to change notification settings

mikejacobson/primeng-calendar-mode-toggle-component-using-cdk-portal

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

primeng-calendar-mode-toggle-component-using-cdk-portal

Angular Component that adds Selection Mode toggle to PrimeNG Calendar component using CDK Portal


Working StackBlitz:

https://stackblitz.com/edit/primeng-calendar-with-selectionmode-toggle-using-cdk-portal?file=src%2Fapp%2Fcalendar-mode-toggle-buttons.component.ts


It just toggles between 'range' mode and 'single' mode but feel free to take the code and enhance it however you want. (The Calendar component also supports a 'multiple' mode but I didn't need to support that.)


Here's what the calendar looks like. I put the toggle buttons in the middle of the button bar because it seemed like a convenient and nice place for them.

Single-select Mode

Calendar in Single-select Mode

Range-select Mode

Calendar in Range-select Mode


And here's what the Component looks like sitting next to the p-calendar component. Note that it needs a reference to the p-calendar component passed into its calendar input.

<div class="p-fluid p-grid p-formgrid">
  <div class="p-field p-col-12 p-md-4">
    <label>Single Selection or Range</label>
    <p-calendar
      #calendar     <-------------- component needs reference to Calendar component
      [(ngModel)]="rangeDates"
      selectionMode="single"
      [showButtonBar]="true"
      [readonlyInput]="true"
      inputId="range">
    </p-calendar>
    <calendar-mode-toggle-buttons [calendar]="calendar"></calendar-mode-toggle-buttons> <---- boom
  </div>
</div>

I also played around with adding the buttons via Directives instead:

This Directive adds the buttons programmatically using Renderer:

https://github.com/mikejacobson/primeng-calendar-mode-toggle-directive-using-renderer

With this Directive, you define the buttons in the template, which makes them a little easier to work with visually compared with the pure Renderer approach:

https://github.com/mikejacobson/primeng-calendar-mode-toggle-directive

About

Angular Directive that uses CDK Portal to add mode toggle buttons to a PrimeNG Calendar component

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published