2020-02-11 18:11:51 +08:00
|
|
|
@import 'config.scss';
|
|
|
|
@import '../themes/dark/index.scss';
|
|
|
|
@import '../themes/light/index.scss';
|
|
|
|
@import '../themes/common.scss';
|
|
|
|
@import '../themes/transition.scss';
|
2019-05-24 20:09:35 +08:00
|
|
|
|
2019-09-17 19:21:36 +08:00
|
|
|
/**
|
|
|
|
* BEM related mixins
|
|
|
|
*/
|
2019-09-03 19:18:16 +08:00
|
|
|
$B: null;
|
|
|
|
$BE: null;
|
2019-09-17 19:21:36 +08:00
|
|
|
$block-depth: 0;
|
2019-09-17 00:57:51 +08:00
|
|
|
|
2020-01-20 22:58:23 +08:00
|
|
|
@function block ($block: null) {
|
|
|
|
@if $block {
|
2020-02-11 18:11:51 +08:00
|
|
|
@return $namespace + '-' + $block;
|
2020-01-20 22:58:23 +08:00
|
|
|
} @else if $B {
|
|
|
|
@return $B;
|
|
|
|
}
|
2019-12-09 15:12:53 +08:00
|
|
|
}
|
|
|
|
|
2019-09-03 19:18:16 +08:00
|
|
|
@mixin b($block) {
|
2019-09-17 19:21:36 +08:00
|
|
|
$block-depth: $block-depth + 1 !global;
|
2019-09-03 19:18:16 +08:00
|
|
|
$temp-block: $B;
|
|
|
|
$temp-block-element: $BE;
|
2020-02-11 18:11:51 +08:00
|
|
|
$B: $namespace + '-' + $block !global;
|
2019-09-03 19:18:16 +08:00
|
|
|
$BE: $B!global;
|
2019-10-09 17:38:08 +08:00
|
|
|
@if (not $common-css-attrs-generated) or $block-depth != 1 {
|
2019-09-17 19:21:36 +08:00
|
|
|
.#{$B} {
|
|
|
|
@content;
|
|
|
|
}
|
|
|
|
} @else {
|
2020-02-11 17:19:00 +08:00
|
|
|
.#{$namespace}-#{$theme}-theme.#{$B} {
|
2019-09-17 19:21:36 +08:00
|
|
|
@content
|
|
|
|
}
|
2019-05-24 20:09:35 +08:00
|
|
|
}
|
2019-09-03 19:18:16 +08:00
|
|
|
$B: $temp-block !global;
|
|
|
|
$BE: $temp-block-element !global;
|
2019-09-17 19:21:36 +08:00
|
|
|
$block-depth: $block-depth - 1 !global;
|
2019-09-03 19:18:16 +08:00
|
|
|
}
|
|
|
|
|
2019-09-04 23:56:14 +08:00
|
|
|
@mixin e($elements...) {
|
2019-09-03 19:18:16 +08:00
|
|
|
$temp-block-element: $BE;
|
2019-09-04 23:56:14 +08:00
|
|
|
$BEs: '';
|
|
|
|
@each $element in $elements {
|
2019-09-17 00:57:51 +08:00
|
|
|
$BE: $B + $element-separator + $element !global;
|
2019-09-04 23:56:14 +08:00
|
|
|
.#{$BE} {
|
2019-09-17 19:21:36 +08:00
|
|
|
@content;
|
2019-09-04 23:56:14 +08:00
|
|
|
}
|
2019-09-03 19:18:16 +08:00
|
|
|
}
|
|
|
|
$BE: $temp-block-element !global;
|
|
|
|
}
|
|
|
|
|
2019-09-04 23:56:14 +08:00
|
|
|
@mixin m($modifiers...) {
|
|
|
|
$BEMs: '';
|
|
|
|
@for $i from 0 to length($modifiers) {
|
|
|
|
$modifier: nth($modifiers, $i + 1);
|
|
|
|
@if $i == 0 {
|
2019-09-17 00:57:51 +08:00
|
|
|
$BEMs: '&.' + $BE + $modifier-separator + $modifier;
|
2019-09-04 23:56:14 +08:00
|
|
|
} @else {
|
2019-09-17 00:57:51 +08:00
|
|
|
$BEMs: $BEMs + ', &.' + $BE + $modifier-separator + $modifier;
|
2019-09-04 23:56:14 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
#{$BEMs} {
|
2019-09-17 19:21:36 +08:00
|
|
|
@content;
|
2019-09-03 19:18:16 +08:00
|
|
|
}
|
2019-07-17 14:11:05 +08:00
|
|
|
}
|
|
|
|
|
2019-09-16 17:52:31 +08:00
|
|
|
@mixin not-m($modifier) {
|
|
|
|
$BEM: '';
|
2020-02-11 18:11:51 +08:00
|
|
|
$BEM: '.' + $BE + $modifier-separator + $modifier;
|
2019-09-16 17:52:31 +08:00
|
|
|
&:not(#{$BEM}) {
|
2019-09-17 19:21:36 +08:00
|
|
|
@content;
|
2019-09-16 17:52:31 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-17 19:21:36 +08:00
|
|
|
/**
|
|
|
|
* Theme related mixins
|
|
|
|
*/
|
|
|
|
$common-css-attrs-generated: false;
|
|
|
|
$theme: null;
|
|
|
|
$in-themes-mixin: false;
|
2020-02-11 18:11:51 +08:00
|
|
|
$theme-names: 'dark', 'light';
|
|
|
|
/** wait for sass to support dynamic @include mixins */
|
|
|
|
$default-theme: 'light';
|
|
|
|
|
2019-09-17 19:21:36 +08:00
|
|
|
@mixin themes-mixin() {
|
|
|
|
$in-themes-mixin: true !global;
|
2020-03-11 20:46:45 +08:00
|
|
|
$theme: 'light' !global;
|
2020-02-11 18:11:51 +08:00
|
|
|
@include setup-light-theme();
|
2019-09-17 19:21:36 +08:00
|
|
|
@content;
|
|
|
|
$common-css-attrs-generated: true !global;
|
2019-09-17 00:57:51 +08:00
|
|
|
@each $theme-name in $theme-names {
|
2019-09-17 19:21:36 +08:00
|
|
|
@if $theme-name == 'light' {
|
|
|
|
$theme: $theme-name !global;
|
|
|
|
@include setup-light-theme();
|
|
|
|
@content;
|
|
|
|
$theme: null !global;
|
2019-09-24 16:58:39 +08:00
|
|
|
} @else if $theme-name == 'dark' {
|
2019-09-17 19:21:36 +08:00
|
|
|
$theme: $theme-name !global;
|
2019-09-24 12:43:56 +08:00
|
|
|
@include setup-dark-theme();
|
2019-09-17 19:21:36 +08:00
|
|
|
@content;
|
|
|
|
$theme: null !global;
|
|
|
|
}
|
2019-09-17 00:57:51 +08:00
|
|
|
}
|
2019-09-17 19:21:36 +08:00
|
|
|
$common-css-attrs-generated: false !global;
|
|
|
|
$in-themes-mixin: false !global;
|
2019-10-09 17:38:08 +08:00
|
|
|
$theme: null !global;
|
2019-09-17 00:57:51 +08:00
|
|
|
}
|
|
|
|
|
2019-11-06 14:04:28 +08:00
|
|
|
@mixin as-form-item {
|
2020-02-11 17:19:00 +08:00
|
|
|
&.#{$namespace}-form-item {
|
2020-02-13 22:06:22 +08:00
|
|
|
.#{$namespace}-form-item-blank {
|
2019-11-06 14:04:28 +08:00
|
|
|
@content;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@mixin with-status ($status) {
|
2020-02-11 18:11:51 +08:00
|
|
|
&.#{$namespace}-form-item-blank#{$modifier-separator}#{$status} {
|
2019-11-06 14:04:28 +08:00
|
|
|
@content;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-04 23:38:19 +08:00
|
|
|
@mixin as-modal-content {
|
2020-03-06 16:13:45 +08:00
|
|
|
&.#{$namespace}-modal-content, &.#{$namespace}-drawer {
|
2020-03-04 23:38:19 +08:00
|
|
|
@content;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-09-17 00:57:51 +08:00
|
|
|
@mixin once() {
|
2019-09-17 19:21:36 +08:00
|
|
|
@if not $common-css-attrs-generated {
|
|
|
|
@content;
|
2019-09-17 00:57:51 +08:00
|
|
|
}
|
2019-05-24 20:09:35 +08:00
|
|
|
}
|