主题Sass,在React App上Scss主题混合

问题描述

我使用sass-themify,但是它仅适用于node元素或id#,我想使用className来使用它,如何更改mixin? 感谢您的宝贵帮助

例如:

header {
  width: 100%;
  Box-shadow: 0px 1px 1px rgba(0,0.1);
  position: fixed;
  z-index: 666;
  img {
    height: 50px;
  };
}
@include sass-themify($element:header){
  background-color: sass-themify-get-color("primary-color");
} 

工作正常,而

.staffName {
  font-size: 20px;
  //color: $GR-tourterelle;
  font-weight: 400;
  font-style: italic;
  margin-right: 40px;
}
@include sass-themify($element:'.staffName'){
  color: sass-themify-get-color("primary-color");
} 

甚至

@include sass-themify() {
  .staffName {
    color: sass-themify-get-color("hello");
  }
}

不起作用 我也尝试将它添加到mixin中,但是它也不起作用

     .{$element}.#{$theme-name}{
        @content;
      }

这是mixin:

@mixin sass-themify-init($scheme-table){
  @if $scheme-table == null{
    @error "[sass-themify] sass-themify mixin needs a valid $scheme-table map defined"
  } @else {
    @if variable-exists("sass-themify-scheme-table") {
      @warn "[sass-themify] sass-themify has already been initialized once. Initializing again will replace the prevIoUs initialized color scheme"
    }
    $sass-themify-scheme-table: $scheme-table !global;
  }
}

@mixin sass-themify($element:"body"){
  //determine if global varaible has been declared or not
  @if not variable-exists("sass-themify-theme-name") {
    $sass-themify-theme-name: null !global;
  }

  @each $theme-name,$color-map in $sass-themify-scheme-table{
    $sass-themify-theme-name: $theme-name !global;
    @if $theme-name != "default"{
      #{$element}.#{$theme-name}{
        @content;
      }
    } @else {
      #{$element}{
        @content;
      }
    }
    $sass-themify-theme-name: null !global;
  }
}

@function sass-themify-get-map-deep($map,$keys...) {
  @each $key in $keys {
    $map: map-get($map,$key);
  }
  @return $map;
}


@function sass-themify-get-color($component){
  @if $sass-themify-scheme-table == null {
    @error "[sass-themify] You need to call sass-themify mixin to initialize a theme before you can call the sass-themify-get function.";
  }
  @if $sass-themify-theme-name == null {
    @error "[sass-themify] sass-themify-get function can only be used within the scope of the 'sass-themify' mixin.";
  }
  @return sass-themify-get-map-deep($sass-themify-scheme-table,$sass-themify-theme-name,$component);
}

@function sass-themify-get-theme-name(){
  @return $sass-themify-theme-name;
}

`````

and my themes :
`````
@import './colors';
@import './sass_themify.scss';

$theme : (
  'YR-theme' : (
    'header-color' : #6f7e0d,'header-image' : none,'hello' : #fff,'text' : $YR-brown,'CTA' : $YR-light-raspBerry,'CTA-hover' : $YR-raspBerry,'show-btn' : $YR-green,'show-btn-hover' : $YR-olive,),'GR-theme' : (
    'header-color' : $GR-beige--,'header-image' : url(),'hello' : $GR-tourterelle,'text' : $GR-roche,'CTA' : $GR-orange,'CTA-hover' : $GR-orange-hover,'show-btn' : $GR-tourterelle,'show-btn-hover' : $GR-tourterelle-hover,)
);

@include sass-themify-init($theme);

解决方法

我使用vary-sass

解决了问题