Angular 7のDateTimeピッカーはありませんか?

Aug 30 2020

Angular 7のDateTimeピッカーが見つかりませんでした。そこで、DatePickerとTimePickerを組み合わせることにしました。

https://ng-bootstrap.github.io/#/components/datepicker

https://ng-bootstrap.github.io/#/components/timepicker

<ng-template #dateTimePicker>
  <ngb-datepicker #createdStartDate name="datepicker"></ngb-datepicker>
  <ngb-timepicker #createdStartTime name="timepicker" [meridian]="true"></ngb-timepicker>
</ng-template>

<form [formGroup]="managePromotionsForm" 
    <div class="col-md-6">
      <div class="row form-group">
        <label class="col-md-4 control-label" for="createdStartDate" translate="">Created From </label>
        <div class="col-md-6">
          <div class="input-group">
            <input readOnly class="form-control" id="createdStartDate" placeholder="From Date"
              [formControl]="controls['createdStartDate']">
              
              
            <div class="input-group-append">
              <button class="btn btn-outline-secondary calendar" [ngbPopover]="dateTimePicker"  type="button"></button>
            </div>
          </div>
        </div>
      </div>
    </div>
</form>

これは私が今まで持っているものです

選択した日付と時刻をcreatedStartDateテキストボックスに表示するにはどうすればよいですか?

回答

1 Eliseo Aug 30 2020 at 10:21

必要に応じて、ngbDropDown、ngbDatePicker、およびngbTimePickerと組み合わせて使用​​できます。

このためには、2つの変数と1つのゲッターが必要です

  date: any;
  time:any= {hour:0,minute:0};

  _value;
  label;
  ngOnInit()
  {
    this.getDatetime()
  }
  getDatetime() {
    let value = null;
    if (!this.date) {
      if (!this.time) value = "yyyy/MM/dd hh:mm";
      else
        value =
          "yyyy/MM/dd " +
          ("0" + this.time.hour).slice(-2) +
          ":" +
          ("0" + this.time.minute).slice(-2);
    }
    if (!value) {
      value = new Date(Date.UTC(
        this.date.year,
        this.date.month - 1,
        this.date.day,
        this.time ? this.time.hour : 0,
        this.time ? this.time.minute : 0
      );
      this._value=value;
   } else 
      this._value=null

   this.form.get("control").setValue(this._value);
   this.label=value;
  }

<form [formGroup]="form">
  <div ngbDropdown>
  <button class="datepicker btn btn-link"  ngbDropdownToggle>{{_value?(_value|date:'medium'):label}}</button>
      <div ngbDropdownMenu >
        <ngb-datepicker #dp [(ngModel)]="date" (dateSelect)="getDatetime()"[ngModelOptions]="{standalone:true}" ></ngb-datepicker>
        <ngb-timepicker [ngModel]="time" (ngModelChange)="time=$event;getDatetime()"[ngModelOptions]="{standalone:true}"></ngb-timepicker>
      </div>
      </div>
  <button class="btn btn-primary">submit</button>

stackblitzで見る

注:これは、依存関係を作らないようにカスタムフォームコントロールを作成する場合です。

好奇心のための更新、stackblitzでカスタムフォームコントロールを作成します

1 MuhammadKamran Aug 30 2020 at 08:15

バインドできるフォーム要素を作成する場合。より良い方法は、別のコンポーネントを作成し、制御値アクセサーを実装することです。

次に、コンポーネントをフォーム要素として使用し、ngModalまたはフォームコントロールをそれにバインドできます。