Search code examples
angularangular-templateangular-template-variable

Rewrite angular directive which uses template variables


I've written a structural directive which sets the itemTemplate on my custom Select2Component

@Directive({ selector: '[bsItemTemplate]' })
export class BsItemTemplateDirective {
  constructor(private select2component: BsSelect2Component, templateRef: TemplateRef<any>) {
    this.select2component.itemTemplate = templateRef;
  }
}

At the moment it's being used like this:

<h2>Select2 with custom template</h2>
<bs-select2 (provideSuggestions)="onProvideTagSuggestions($event)" [suggestions]="tagSuggestions" [selectedItems]="selectedTags">
    <ng-template bsItemTemplate let-item="item" let-select2="select2">
        <span class="select2-item" [style.background]="item.category.color" [style.color]="item.category.color | bsFontColor">
            <span (click)="select2.onRemoveItem(item,$event)">×</span>
            {{ item.text }}
        </span>
    </ng-template>
</bs-select2>

And rendered like this:

<div bsDropdown [(isOpen)]="isOpen">
    <ng-container *ngFor="let item of selectedItems">
        <!-- Render the template -->
        <ng-container *ngTemplateOutlet="itemTemplate ?? defaultItemTemplate; context: { item: item, select2: this }"></ng-container>
    </ng-container>

    <input type="text" [(ngModel)]="searchterm" />
    <div *bsDropdownMenu>
        <ul>
            <li *ngFor="let suggestion of suggestions">{{ suggestion.text }}</li>
        </ul>
    </div>
</div>

I want to be able to rewrite this using the star notation (*bsItemTemplate)


Solution

  • You can do it like this:

    <bs-select2 (provideSuggestions)="onProvideTagSuggestions($event)" [suggestions]="tagSuggestions" [selectedItems]="selectedTags">
        <span *bsItemTemplate="let item = item; let select2 = select2">
            <span (click)="select2.onRemoveItem(item,$event)">×</span>
            {{ item.text }}
        </span>
    </bs-select2>