File

libs/rucken/todo-web/src/lib/entities/statuses/status-input/status-input.component.ts

Extends

StatusesGridComponent

Implements

OnInit

Metadata

changeDetection ChangeDetectionStrategy.OnPush
selector status-input
templateUrl ./status-input.component.html

Index

Methods

Constructor

constructor(modalsService: ModalsService, errorsExtractor: ErrorsExtractor, translateService: TranslateService, dynamicRepository: DynamicRepository, statusesConfig: IRestProviderOptions)
Parameters :
Name Type Optional
modalsService ModalsService No
errorsExtractor ErrorsExtractor No
translateService TranslateService No
dynamicRepository DynamicRepository No
statusesConfig IRestProviderOptions<StatusWithProject> No

Methods

defaultAppendFromGridModal
defaultAppendFromGridModal()
Returns : any
ngOnInit
ngOnInit()
Returns : void
onSelect
onSelect(item: StatusWithProject)
Parameters :
Name Type Optional
item StatusWithProject No
Returns : void
defaultCreateCreateModal
defaultCreateCreateModal(item?: StatusWithProject)
Inherited from StatusesGridComponent
Parameters :
Name Type Optional
item StatusWithProject Yes
Returns : any
defaultCreateUpdateModal
defaultCreateUpdateModal(item?: StatusWithProject)
Inherited from StatusesGridComponent
Parameters :
Name Type Optional
item StatusWithProject Yes
Returns : any
ngOnInit
ngOnInit()
Inherited from StatusesGridComponent
Returns : void
onChangeFilter
onChangeFilter(filter?: IBaseEntityGridFilter)
Inherited from StatusesGridComponent
Parameters :
Name Type Optional
filter IBaseEntityGridFilter Yes
Returns : void
import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, OnInit, Output } from '@angular/core';
import { TranslateService } from '@ngx-translate/core';
import { ErrorsExtractor, IBaseEntityModalOptions, ModalsService, translate } from '@rucken/core';
import { STATUSES_CONFIG_TOKEN, StatusWithProject } from '@rucken/todo-core';
import { DynamicRepository, IRestProviderOptions } from 'ngx-repository';
import { StatusesGridModalComponent } from '../statuses-grid-modal/statuses-grid-modal.component';
import { StatusesGridComponent } from '../statuses-grid/statuses-grid.component';
import { BindIoInner } from 'ngx-bind-io';

@BindIoInner()
@Component({
  selector: 'status-input',
  templateUrl: './status-input.component.html',
  changeDetection: ChangeDetectionStrategy.OnPush
})
export class StatusInputComponent extends StatusesGridComponent implements OnInit {
  @Input()
  modalAppendFromGrid: IBaseEntityModalOptions = {
    component: StatusesGridModalComponent,
    initialState: {
      title: translate('Select status'),
      yesTitle: translate('Select')
    }
  };
  @Output()
  select = new EventEmitter<StatusWithProject>();

  constructor(
    modalsService: ModalsService,
    protected errorsExtractor: ErrorsExtractor,
    protected translateService: TranslateService,
    protected dynamicRepository: DynamicRepository,
    @Inject(STATUSES_CONFIG_TOKEN)
    protected statusesConfig: IRestProviderOptions<StatusWithProject>
  ) {
    super(modalsService, errorsExtractor, translateService, dynamicRepository, statusesConfig);
  }
  ngOnInit() {
    this.mockedItems = [];
    this.useMock({
      items: this.mockedItems,
      ...this.statusesConfig
    });
    this.mockedItemsChange.subscribe(items => this.onSelect(items[0]));
  }
  defaultAppendFromGridModal() {
    this.modalAppendFromGrid = {
      ...this.modalAppendFromGrid,
      initialState: {
        ...this.modalAppendFromGrid.initialState,
        project: this.project
      }
    };
    return super.defaultAppendFromGridModal();
  }
  onSelect(item: StatusWithProject) {
    this.select.emit(item);
  }
}
<entity-input
    [readonly]="readonly"
    (select)="onAppendFromGridClick($event)">
    <ng-content></ng-content>
</entity-input>
Legend
Html element
Component
Html element with directive

result-matching ""

    No results matching ""