angularx-flatpickr не работает в Material Modal в Angular 7 - PullRequest
0 голосов
/ 28 февраля 2019

Я следовал инструкциям, указанным в здесь , и смог получить средство выбора даты и времени, как и ожидалось, во всех моих представлениях.Когда дело доходит до диалогового окна материала, средство выбора даты не отображается, и когда я смотрю на консоль, ошибок не обнаружено.В чем может быть причина?

Вот мой код компонента для диалогового окна.(Фрагмент кода не будет запущен, я не отображаю все сегменты кода с представлениями)

import { Component, OnInit, ViewChild, Inject, ElementRef } from '@angular/core';
import { CdkDragDrop, moveItemInArray, transferArrayItem } from '@angular/cdk/drag-drop';
import { ResourceService } from '../services/resource.service';
import { MatPaginator, MatSort, MatTableDataSource, MatDialog, MatDialogRef, MAT_DIALOG_DATA, MatTable } from '@angular/material';
import { FeedPrintJobService } from '../services/feed-print-job.service';
import { PrintJobDragDrop } from '../shared/print-job-drag-drop';
import { NgForm } from '@angular/forms';
import { ShedularService } from '../services/shedular.service';
import { Resource } from '../shared/resource.model';
import { Guid } from 'guid-typescript';
import { ToastrService } from 'ngx-toastr';
import { forOwn } from 'lodash';
import { SchedularJobs } from '../shared/shedular';
import { Scheduler } from 'rxjs';

export interface DialogData {
  animal: string;
  name: string;
}

@Component({
  selector: 'app-schedular',
  templateUrl: './schedular.component.html',
  styleUrls: ['./schedular.component.css'],
})
export class SchedularComponent implements OnInit{
  @ViewChild('table') table: MatTable<PrintJobDragDrop>;
  @ViewChild(MatPaginator) paginator: MatPaginator;
  @ViewChild(MatSort) sort: MatSort;

  dataSource : any;
  dataSourceFilter : any;
  data : any;

  tableHeaders=[];

  /** Columns displayed in the table. Columns IDs can be added, removed, or reordered. */
  displayedColumns = [
  'id',
  'timestamp',
  'emaiAddress',
  'to',
  'from',
  'customerName',
  'status'//,
  //'star'
  ];
  constructor(private resService : ResourceService,private feedJobService : FeedPrintJobService,public dialog: MatDialog,private service : ShedularService) {
  }

  animal: string;
  name: string;

  openDialog(item: any): void {
    debugger
    const dialogRef = this.dialog.open(DialogOverviewExampleDialog, {
      //width: '500px',
      data: item
    });

    //this.service.

    dialogRef.afterClosed().subscribe(result => {
      console.log('The dialog was closed');
      this.animal = result;
    });
  }

  openModifySchedularDialog(response: any):void 
  {
    const dialogRef = this.dialog.open(ModifySchedularJobDialogBox, {

      //width: '500px',
      data: response
    });
    console.log(this.service.ScheduledJobDet);

    dialogRef.afterClosed().subscribe(result => {
      console.log('The dialog was closed');
      //this.animal = result;
    });
  }

  ngOnInit(): void {
    this.resService.getDepartmentList();
    this.resService.getLocationList();

      this.getQueuedJobList();
      this.service.formData = 
      {
         id:'00000000-0000-0000-0000-000000000000',
         borad : '',
         dateAndTime : Date.now(),
         locationId : 0,
         printJobId : '00000000-0000-0000-0000-000000000000',
        resourceId : 0
      }
  }
  getQueuedJobList(): any {
    this.feedJobService.getQueuedJobListForDragDrop().subscribe(
      response => {
        debugger
        if(response)
        {
          this.data = response;
          this.dataSource = new MatTableDataSource(this.data);
          this.dataSource.paginator = this.paginator;
          this.dataSource.sort = this.sort;
        }
        
      });
  }

  todo = [
    'Get to work',
    'Pick up groceries',
    'Go home',
    'Fall asleep'
  ];

  done = [
    'Get up',
    'Brush teeth',
    'Take a shower',
    'Check e-mail',
    'Walk dog'
  ];

  dateTimeColumn = [];

  drop(event: CdkDragDrop<PrintJobDragDrop[]>) {
    debugger

    this.service.schedularJobList.forEach(element => {
      element.printJobId = event.item.data.id;
      element.id='00000000-0000-0000-0000-000000000000';
    });
    this.openDialog(event.item.data);
    if (event.previousContainer === event.container) {
      moveItemInArray(event.container.data, event.previousIndex, event.currentIndex);
    } else {
      transferArrayItem(event.previousContainer.data,
          event.container.data,
          event.previousIndex,
          event.currentIndex);
    }
  }
  dropTable(event: CdkDragDrop<PrintJobDragDrop[]>) {
    const prevIndex = this.dataSource.findIndex((d) => d === event.item.data);
    moveItemInArray(this.dataSource, prevIndex, event.currentIndex);
    this.table.renderRows();
  }
    /** Predicate function that doesn't allow items to be dropped into a list. */
    noReturnPredicate() {
      return false;
    }

  applyFilter(filterValue: string) {
    this.dataSource.filter = filterValue.trim().toLowerCase();

    if (this.dataSource.paginator) {
      this.dataSource.paginator.firstPage();
    }
  }

  openModifyDialog(id:string,resourceName: number,dateAndTime: string)
  {
    debugger
    this.service.getScheduledJobdeatils(id,resourceName).subscribe(
      response => {
        debugger
        if(response)
        {
          this.openModifySchedularDialog(response);      
        }       
      });
    
  }
  onSubmit(form: NgForm) {
    debugger;
    console.log(form.value);
    if (form.value!=null)
    {
      this.service.setGlobalDateAndLocationId(form.value);
      this.resService.setLocationId(form.value.locationId);     
      this.service.setDateTimeColumn(form.value.datetime);
      this.service.getResourceListbyLocationId(form.value.locationId).subscribe(
      response => {
         
      });


      this.service.getLocSpecificDetails(form.value.locationId).subscribe(res=>{
        if(res)
        {
          debugger
          this.service.schedularJob = 
          {
            id : '',
            endsAt : '',
            isActive : false,
            isCompleted : false,
            isFinal : false,
            printJobId : '',
            resourceId : 0,
            startsAt : ''
          }

          for (let key in res) {
            let value = res[key];
            // Use `key` and `value`
          }

          //for(let i=0; i< Object.keys(res).length; i++)
          for (let key in res)
          {
            debugger
            this.service.schedularJob = 
            {
              id : '00000000-0000-0000-0000-000000000000',
              endsAt : '',
              isActive : false,
              isCompleted : false,
              isFinal : false,
              printJobId : '',
              resourceId : 0,//res[key][0].resourceId,
              startsAt : ''
            }
            this.service.schedularJobList.push(this.service.schedularJob)
          }
          console.log(this.service.schedularJobList[1]);
        }
      });

    }
    else{
      //this.updateRecord(form);
    }
  }
}





@Component({
  selector: 'dialog-dialog',
  templateUrl: 'dialog-box.html',
})

export class DialogOverviewExampleDialog implements OnInit{

  @ViewChild(MatPaginator) paginator: MatPaginator;
  @ViewChild(MatSort) sort: MatSort;
  
  dataSource : any;
  dataSourceFilter : any;
  tableData : any;

  constructor(
    public dialogRef: MatDialogRef<DialogOverviewExampleDialog>,
    @Inject(MAT_DIALOG_DATA) public data: DialogData,private resService : ResourceService,private feedJobService : FeedPrintJobService,private service : ShedularService,private toastr:ToastrService) {}

    ngOnInit(): void {
      let locId = this.resService.getSelectedLocationId();

      this.resService.formData=
      {
        departmentId : 0,
        isActive : false,
        isDeleted : false,
        locationId : locId,
        name :'',
        resourceId : 0
      };

      this.resService.getDepartmentList();
      this.resService.getLocationList();
    }
  
  onNoClick(): void {
    this.dialogRef.close();
  }

  doSomething(event)
  {
    console.log(event.value);
    this.resService.getResource(event.value);
  }

  onSubmitSchedular(schedularJobList: SchedularJobs[]) {

    debugger;
    if (schedularJobList!=null)
    {
      this.service.InsertSchedular(schedularJobList).subscribe(res => {
        debugger
        this.toastr.success('Schedular record created successfully', 'Schedular');
        this.ResetScheduledJobTableData();
        this.onNoClick();
        this.getQueuedJobList();
      });
    }
    else{
    }
  }


}

Ниже приведен ввод для выбора даты и времени

      <input 
  class="form-control"
  type="text" 
  mwlFlatpickr 
  name="selectedDate"
  [(ngModel)]="selectedDate" 
  [altInput]="true" 
  [convertModelValue]="true">
...