欧美一区二区三区,国内熟女精品熟女A片视频小说,日本av网,小鲜肉男男GAY做受XXX网站

為什么我的Angular modal的樣式只有在刷新頁面后才起作用?

錢浩然2年前9瀏覽0評論

我向我的一個angular項目頁面添加了一個彈出模式,但是在我刷新頁面之前,該模式的樣式不起作用。您可以在截圖中看到日歷圖標對于每個日期選擇器來說是如何不合適的。

Pop-up Modal incorrect

當我刷新頁面時,樣式看起來和預期的一樣。

Pop-up Modal correct

打字稿:

import { Component, OnInit } from '@angular/core';
import { MatDatepickerInputEvent } from '@angular/material/datepicker';
import { MatDialogRef } from '@angular/material/dialog';

@Component({
  selector: 'ds-compare',
  templateUrl: './compare.component.html',
  styleUrls: ['./compare.component.scss']
})
export class CompareComponent implements OnInit {
  dayOne: Date = new Date();
  dayTwo: Date;
  dayThree: Date;
  selectionDayTwo: string;
  selectionDayThree: string;
  isDayTwoDisabled: boolean = false;
  isDayThreeDisabled: boolean = false;

  /*
  @Input() parentData: string;
  @Output() notify: EventEmitter<string> = new EventEmitter<string>();
  */

  constructor(public dialogRef: MatDialogRef<CompareComponent>) { }

  ngOnInit(): void {
    this.retrieveSavedData();
    
    if (!this.selectionDayTwo) {
      this.selectionDayTwo = 'week';
      this.updateDayTwo();
    }
    if (!this.selectionDayThree) {
      this.selectionDayThree = 'none';
      this.updateDayThree();
    }
  }

  updateDayTwo() {
    const currentDate = new Date(this.dayOne);
    this.dayTwo = new Date(currentDate);

    if (this.selectionDayTwo === 'day') {
      this.isDayTwoDisabled = false;
      this.dayTwo = new Date(currentDate);
    } else if (this.selectionDayTwo === 'week') {
      this.dayTwo.setDate(currentDate.getDate() - 7);
      this.isDayTwoDisabled = true;
    } else if (this.selectionDayTwo === 'month') {
      this.dayTwo.setMonth(currentDate.getMonth() - 1);
      this.isDayTwoDisabled = true;
    } else if (this.selectionDayTwo === 'year') {
      this.dayTwo.setFullYear(currentDate.getFullYear() - 1);
      this.isDayTwoDisabled = true;
    }
    this.saveData();
  }
  
  updateDayThree() {
    const currentDate = new Date(this.dayOne);
    this.dayThree = new Date(currentDate);

    if (this.selectionDayThree === 'day') {
      this.isDayThreeDisabled = false;
    } else if (this.selectionDayThree === 'week') {
      this.dayThree.setDate(currentDate.getDate() - 7);
      this.isDayThreeDisabled = true;
    } else if (this.selectionDayThree === 'month') {
      this.dayThree.setMonth(currentDate.getMonth() - 1);
      this.isDayThreeDisabled = true;
    } else if (this.selectionDayThree === 'year') {
      this.dayThree.setFullYear(currentDate.getFullYear() - 1);
      this.isDayThreeDisabled = true;
    }
    else if (this.selectionDayThree === 'none') {
      this.dayThree = null;
      this.isDayThreeDisabled = true;
    }
    this.saveData();
  }

  updateDayTwoDay(event: MatDatepickerInputEvent<Date>) {
    this.dayTwo = event.value;
    this.saveData();
  }

  updateDayThreeDay(event: MatDatepickerInputEvent<Date>) {
    this.dayThree = event.value;
    this.saveData();
  }

  private saveData() {
    const data = {
      dayOne: this.dayOne,
      dayTwo: this.dayTwo,
      dayThree: this.dayThree,
      selectionDayTwo: this.selectionDayTwo,
      selectionDayThree: this.selectionDayThree,
      isDayTwoDisabled: this.isDayTwoDisabled,
      isDayThreeDisabled: this.isDayThreeDisabled
    };

    sessionStorage.setItem('reports-hourly-chart-compare', JSON.stringify(data));
  }

  private retrieveSavedData() {
    const savedData = sessionStorage.getItem('reports-hourly-chart-compare');

    if (savedData) {
      const data = JSON.parse(savedData);

      this.dayOne = data.dayOne;
      this.dayTwo = data.dayTwo;
      this.dayThree = data.dayThree;
      this.selectionDayTwo = data.selectionDayTwo;
      this.selectionDayThree = data.selectionDayThree;
      this.isDayTwoDisabled = data.isDayTwoDisabled;
      this.isDayThreeDisabled = data.isDayThreeDisabled;
    } else {
      this.dayOne = new Date();
    }
  }

  resetForm() {
    this.dayOne = new Date();
    this.selectionDayTwo = "week";
    this.selectionDayThree = "none";
    this.updateDayTwo();
    this.updateDayThree();
    this.saveData();
  }

  submitForm() {
    this.saveData();
    //this.notify.emit('Data from child: submitForm');
    this.dialogRef.close({submit: true, date1: this.dayOne, date2: this.dayTwo, date3: this.dayThree});
  }

  closePopup() {
    this.saveData();
    this.dialogRef.close({submit: false});
  }

}

HTML:

<div class="mainContainer">
    <button class="closeButton" (click)="closePopup()"><span class="material-icons">close</span></button>
    <h3>Compare periods</h3>
    <div>
        <p>Select the periods to compare between the data</p>
    </div>
    <div>
        <div>
            <p>Day 1</p>
            <div class="dateContainer">
                <mat-form-field appearance="outline">
                    <input matInput [matDatepicker]="picker1" [value]="dayOne" [(ngModel)]="dayOne"
                        (dateChange)="updateDayTwo(); updateDayThree()">
                    <mat-datepicker-toggle matSuffix [for]="picker1"></mat-datepicker-toggle>
                    <mat-datepicker #picker1></mat-datepicker>
                </mat-form-field>
            </div>
        </div>
        <div>
            <p>Day 2</p>
            <div class="dateContainer">
                <mat-form-field class="dropDown" appearance="outline">
                    <mat-select [(value)]="selectionDayTwo" (selectionChange)="updateDayTwo()" required>
                        <mat-option value="day">Day</mat-option>
                        <mat-option value="week">Week</mat-option>
                        <mat-option value="month">Month</mat-option>
                        <mat-option value="year">Year</mat-option>
                    </mat-select>
                </mat-form-field>

                <mat-form-field appearance="outline">
                    <input matInput [matDatepicker]="picker2" [value]="dayTwo" [disabled]="isDayTwoDisabled" (dateChange)="updateDayTwoDay($event)" required>
                    <mat-datepicker-toggle matSuffix [for]="picker2"></mat-datepicker-toggle>
                    <mat-datepicker #picker2></mat-datepicker>
                </mat-form-field>
            </div>
        </div>
        <div>
            <p>Day 3</p>
            <div class="dateContainer">
                <mat-form-field class="dropDown" appearance="outline">
                    <mat-select [(value)]="selectionDayThree" (selectionChange)="updateDayThree()">
                        <mat-option value="none">None</mat-option>
                        <mat-option value="day">Day</mat-option>
                        <mat-option value="week">Week</mat-option>
                        <mat-option value="month">Month</mat-option>
                        <mat-option value="year">Year</mat-option>
                    </mat-select>
                </mat-form-field>

                <mat-form-field appearance="outline">
                    <input matInput [matDatepicker]="picker3" [value]="dayThree" [disabled]="isDayThreeDisabled" (dateChange)="updateDayThreeDay($event)">
                    <mat-datepicker-toggle matSuffix [for]="picker3"></mat-datepicker-toggle>
                    <mat-datepicker #picker3></mat-datepicker>
                </mat-form-field>
            </div>
        </div>
        <div class="buttonContainer">
            <button class="reset" (click)="resetForm()">Reset</button>
            <button class="apply" (click)="submitForm()">Apply</button>
        </div>
    </div>
</div>

SCSS:

::ng-deep {
  .mainContainer {
    display: flex;
    flex-direction: column;
    padding: 20px;
    background-color: #FFFFFF;
  }

  .buttonContainer {
    display: flex;
    justify-content: space-between;
    margin-top: 20px;
  }

  .buttonContainer button {
    padding: 10px 20px;
    border: 2px solid transparent;
    border-radius: 4px;
    font-size: 16px;
    cursor: pointer;
    transition: background-color 0.3s ease;
  }

  .buttonContainer button.reset {
    background-color: white;
    color: black;
  }

  .buttonContainer button.apply {
    background-color: blue;
    color: white;
  }

  .buttonContainer button:hover {
    border-color: blue;
  }

  .closeButton {
    position: absolute;
    top: 10px;
    right: 10px;
    background: none;
    border: none;
    cursor: pointer;
  }

  .material-icons {
    font-size: 24px;
  }

  h3 {
    margin-top: 0;
  }

  div>p {
    margin: 10px 0;
  }

  .dateContainer {
    display: flex;
  }

  .dropDown {
    width: 30%;
  }
}