zhangyong
2023-08-22 1353e87cb21a4032d585d7404bae9042f2ebcf08
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
@use 'sass:map';
 
@use 'common/var' as *;
@use 'mixins/mixins' as *;
@use 'mixins/utils' as *;
@use 'mixins/var' as *;
@use 'mixins/button' as *;
 
@include b(checkbox-button) {
  @include set-component-css-var('checkbox-button', $checkbox-button);
}
 
@include b(checkbox-button) {
  position: relative;
  display: inline-block;
 
  @include e(inner) {
    display: inline-block;
    line-height: 1;
    font-weight: getCssVar('checkbox-font-weight');
    white-space: nowrap;
    vertical-align: middle;
    cursor: pointer;
    background: var(
      #{getCssVarName('button-bg-color')},
      map.get($button, 'bg-color')
    );
    border: getCssVar('border');
    border-left: 0;
    color: var(
      #{getCssVarName('button-text-color')},
      map.get($button, 'text-color')
    );
    -webkit-appearance: none;
    text-align: center;
    box-sizing: border-box;
    outline: none;
    margin: 0;
    position: relative;
    transition: getCssVar('transition-all');
    user-select: none;
 
    @include button-size(
      map.get($button-padding-vertical, 'default') - $button-border-width,
      map.get($button-padding-horizontal, 'default') - $button-border-width,
      map.get($button-font-size, 'default'),
      0
    );
 
    &:hover {
      color: getCssVar('color-primary');
    }
 
    & [class*='#{$namespace}-icon-'] {
      line-height: 0.9;
 
      & + span {
        margin-left: 5px;
      }
    }
  }
 
  @include e(original) {
    opacity: 0;
    outline: none;
    position: absolute;
    margin: 0;
    z-index: -1;
  }
 
  &.is-checked {
    & .#{$namespace}-checkbox-button__inner {
      color: getCssVar('checkbox-button-checked-text-color');
      background-color: getCssVar('checkbox-button-checked-bg-color');
      border-color: getCssVar('checkbox-button-checked-border-color');
      box-shadow: -1px 0 0 0 getCssVar('color-primary-light-7');
    }
    &:first-child .#{$namespace}-checkbox-button__inner {
      border-left-color: getCssVar('checkbox-button-checked-border-color');
    }
  }
 
  &.is-disabled {
    & .#{$namespace}-checkbox-button__inner {
      color: getCssVar('disabled-text-color');
      cursor: not-allowed;
      background-image: none;
      background-color: var(
        #{getCssVarName('button-disabled-bg-color')},
        map.get($button, 'disabled-bg-color')
      );
      border-color: var(
        #{getCssVarName('button-disabled-border-color')},
        map.get($button, 'disabled-border-color')
      );
      box-shadow: none;
    }
    &:first-child .#{$namespace}-checkbox-button__inner {
      border-left-color: var(
        #{getCssVarName('button-disabled-border-color')},
        map.get($button, 'disabled-border-color')
      );
    }
  }
 
  &:first-child {
    .#{$namespace}-checkbox-button__inner {
      border-left: getCssVar('border');
      border-top-left-radius: getCssVar('border-radius-base');
      border-bottom-left-radius: getCssVar('border-radius-base');
      box-shadow: none !important;
    }
  }
 
  &.is-focus {
    & .#{$namespace}-checkbox-button__inner {
      border-color: getCssVar('checkbox-button-checked-border-color');
    }
  }
 
  &:last-child {
    .#{$namespace}-checkbox-button__inner {
      border-top-right-radius: getCssVar('border-radius-base');
      border-bottom-right-radius: getCssVar('border-radius-base');
    }
  }
 
  @each $size in (large, small) {
    @include m($size) {
      .#{$namespace}-checkbox-button__inner {
        @include button-size(
          map.get($button-padding-vertical, $size) - $button-border-width,
          map.get($button-padding-horizontal, $size) - $button-border-width,
          map.get($button-font-size, $size),
          0
        );
      }
    }
  }
}