File

core/data-grid/column/filtering-form-renderer.component.ts

Implements

OnChanges

Metadata

changeDetection ChangeDetectionStrategy.OnPush
selector c8y-filtering-form-renderer
templateUrl ./filtering-form-renderer.component.html

Index

Properties
Methods
Inputs
Accessors

Constructor

constructor(injector: Injector, cd: ChangeDetectorRef)
Parameters :
Name Type Optional
injector Injector No
cd ChangeDetectorRef No

Inputs

spec

Methods

ngOnChanges
ngOnChanges()
Returns : void

Properties

defaultRendererFilterText
defaultRendererFilterText: string
Type : string
Default value : ''
rendererInjector
rendererInjector: Injector
Type : Injector
rendererType
rendererType: "TEMPLATE" | "COMPONENT"
Type : "TEMPLATE" | "COMPONENT"
spec
spec: FilteringFormRendererSpec
Type : FilteringFormRendererSpec

Accessors

_spec
set_spec(spec)
Parameters :
Name Optional
spec No
Returns : void
<ng-container *ngIf="spec.renderer">
  <ng-container
    *ngIf="rendererType === 'TEMPLATE'"
    [ngTemplateOutlet]="spec.renderer"
    [ngTemplateOutletContext]="{ $implicit: spec.context }"
  >
  </ng-container>

  <ng-container
    *ngIf="rendererType === 'COMPONENT'"
    [ngComponentOutlet]="spec.renderer"
    [ngComponentOutletInjector]="rendererInjector"
  >
  </ng-container>
</ng-container>

<ng-container *ngIf="!spec.renderer">
  <div class="form-group">
    <label translate>Filter text</label>
    <input
      class="form-control"
      [(ngModel)]="defaultRendererFilterText"
      (keyup.enter)="
        spec.context.applyFilter({
          filterPredicate: defaultRendererFilterText
        })
      "
    />
  </div>
  <div class="flex-row">
    <button
      class="btn btn-default btn-sm flex-grow m-r-8"
      (click)="defaultRendererFilterText = ''; spec.context.resetFilter()"
      translate
    >
      Reset
    </button>
    <button
      class="btn btn-primary btn-sm flex-grow"
      (click)="
        spec.context.applyFilter({
          filterPredicate: defaultRendererFilterText
        })
      "
      translate
    >
      Apply
    </button>
  </div>
</ng-container>

result-matching ""

    No results matching ""