Тема Angular Material не изменяет цвет акцента mat-диалога

#css #angular #sass #angular-material

#css #angular #sass #angular-материал

Вопрос:

Мне нужно изменить цветовую тему моего приложения в соответствии с параметром, и это должна быть очень простая операция. В своем приложении я использую тему Fuse angular material. Когда я пытаюсь переключиться с основной темы на второстепенную, цвет акцента диалогового компонента не меняется, в то время как другие компоненты (например, панель навигации) меняются.

_тема.scss

 @import '~@angular/material/theming';
@import './component-themes';

$primary: mat-palette($mat-fusedark);
$accent: mat-palette($mat-light-blue, 600, 400, 700);
$warn: mat-palette($mat-red);
$white: mat-palette($mat-white);
$black: mat-palette($mat-black);

$first-theme: mat-light-theme($primary, $accent, $warn);

$background: map-get($first-theme, background);
$foreground: map-get($first-theme, foreground);

@include angular-material-theme($first-theme);
@include component-themes($first-theme);

$second-primary: mat-palette($mat-fusedark);
$second-accent: mat-palette($mat-green, 600, 400, 700);
$second-warn: mat-palette($mat-red);

$second-theme: mat-light-theme($second-primary, $second-accent, $second-warn);

.second-theme {
  @include angular-material-theme($second-theme);
  @include component-themes($second-theme);
}
 

компонент-theme.scss

 @import "../partials/navigation";
@import "../partials/dialog";

@mixin component-themes($theme) {
  @include navigation-theme($theme);
  @include dialog-theme($theme);
}
 

_dialog.scss

 @import '~@angular/material/theming';

    @mixin dialog-theme($theme) {
      $accent: map-get($theme, accent);
    
      .dialog-wrapper {
        .mat-dialog-container {
          padding: 0;
          overflow: hidden;
        }
    
        .mat-dialog-title {
          display: flex;
          flex: 1 1 auto;
          justify-content: space-between;
          margin: 0;
          padding: 24px;
    
        }
    
        .mat-toolbar {
          background-color: mat-color($accent) !important;
        }
    
        .mat-dialog-content {
          padding: 16px 32px 0px;
          margin: 0;
        }
    
        .mat-dialog-actions {
          display: flex;
          flex: 1 1 auto;
          margin: 1px 0 0 0;
          padding: 0px 32px 16px;
        }
    
      }
    }
 

Если я изменю в _dialog.scss значение

 background-color: mat-color($accent) !important;
 

в

 background-color: green !important;
 

он работает правильно. Похоже mat-color($accent) , что это не работает, но только для scss этого компонента.

Ответ №1:

Для тех, кто сталкивается с этой проблемой, я наконец нашел решение. Я не смог изменить тему некоторых компонентов, потому что они вложены, а контейнер наложения блокирует распространение темы. Чтобы исправить это, я импортировал overlayContainer и добавил класс theme в overlayContainer в методе ngOnInit.

 import {OverlayContainer} from '@angular/cdk/overlay';

constructor(
    private overlayContainer: OverlayContainer
  ) {}

ngOnInit() {
    if (this.data.theme === 'second-theme') {
          this.overlayContainer.getContainerElement().classList.add(this.data.theme);
        }
}
 

Очень простое решение, когда вы знаете, в чем проблема, самое сложное было найти ее 🙂