云链智安app
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. @import '@/uni_modules/lime-ui/style/index.scss';
  2. // $primary-color: #0052d9;
  3. $name: l-switch;
  4. $switch-checked-color: var(--l-switch-checked-color, $brand-color);
  5. $switch-checked-disabled-color: var(--l-switch-checked-disabled-color, $brand-color-disabled);
  6. $switch-unchecked-color: var(--l-switch-unchecked-color, $gray-4);
  7. $switch-unchecked-disabled-color: var(--l-switch-unchecked-disabled-color, $gray-2);
  8. $switch-width: var(--l-switch-width, 90rpx);
  9. $switch-height: var(--l-switch-height, 56rpx);
  10. // $switch-radius: var(--l-switch-radius, calc($switch-height / 2));
  11. $switch-radius: var(--l-switch-radius, 8rpx);
  12. $switch-dot-margin: var(--l-switch-dot-margin, 6rpx);
  13. $switch-dot-bg-color: var(--l-switch-dot-bg-color, white);
  14. $switch-dot-size: var(--l-switch-dot-size, 44rpx);
  15. // $switch-dot-radius: var(--l-switch-dot-radius, 99rpx);
  16. $switch-dot-radius: var(--l-switch-dot-radius, 5rpx);
  17. $switch-dot-shadow: var(--l-switch-dot-shadow, $shadow);
  18. // large
  19. $switch-large-width: var(--l-switch-large-width, 104rpx);
  20. $switch-large-height: var(--l-switch-large-height, 64rpx);
  21. // $switch-large-radius: var(--l-switch-large-radius, calc($switch-large-height / 2));
  22. $switch-large-radius: var(--l-switch-large-radius, $switch-radius);
  23. $switch-dot-large-size: var(--l-switch-dot-large-size, 52rpx);
  24. $switch-dot-plain-large-size: var(--l-switch-dot-plain-large-size, 44rpx);
  25. // small
  26. $switch-small-width: var(--l-switch-small-width, 78rpx);
  27. $switch-small-height: var(--l-switch-small-height, 48rpx);
  28. $switch-small-radius: var(--l-switch-small-radius, $switch-radius);
  29. // $switch-small-radius: var(--l-switch-small-radius, calc($switch-small-height / 2));
  30. $switch-dot-small-size: var(--l-switch-dot-small-size, 36rpx);
  31. $swtich-label-font-size: var(--l-swtich-label-font-size, $font-size);
  32. $swtich-label-large-font-size: var(--l-swtich-label-font-size, 32rpx);
  33. $swtich-label-small-font-size: var(--l-swtich-label-font-size, 24rpx);
  34. // icon
  35. // $switch-icon-size: var(--l-switch-icon-size, 40rpx);
  36. // $switch-icon-large-size: var(--l-switch-icon-large-size, 48rpx);
  37. // $switch-icon-small-size: var(--l-switch-icon-small-size, 32rpx);
  38. :host {
  39. display: inline-flex;
  40. }
  41. .l-wave {
  42. position: absolute;
  43. background: transparent;
  44. pointer-events: none;
  45. box-sizing: border-box;
  46. color: var(--l-wave-color, currentcolor);
  47. border-radius: $switch-radius;
  48. left: 0;
  49. right: 0;
  50. top: 0;
  51. bottom: 0;
  52. box-shadow: 0 0 0 0 currentcolor;
  53. opacity: 0.3;
  54. z-index: 0;
  55. transition: box-shadow 0.4s cubic-bezier(0.08, 0.82, 0.17, 1), opacity 2s cubic-bezier(0.08, 0.82, 0.17, 1);
  56. &-active {
  57. box-shadow: 0 0 0 16rpx currentcolor;
  58. opacity: 0;
  59. }
  60. }
  61. .#{$name} {
  62. display: inline-flex;
  63. position: relative;
  64. color: $switch-unchecked-color;
  65. width: $switch-width;
  66. height: $switch-height;
  67. background-color: $switch-unchecked-color;
  68. border-radius: $switch-radius;
  69. border-width: $switch-dot-margin;
  70. border-style: solid;
  71. border-color: rgba(0, 0, 0, 0);
  72. box-sizing: border-box;
  73. transition: all 0.3s ease;
  74. overflow: hidden;
  75. font-size: $swtich-label-font-size;
  76. &-inner {
  77. // background-color: $switch-unchecked-color;
  78. // color: $switch-unchecked-color;
  79. flex: 1;
  80. height: 100%;
  81. // overflow: hidden;
  82. &-checked {
  83. position: absolute;
  84. color: white;
  85. left: 0;
  86. transform: translateX(-110%);
  87. }
  88. &-unchecked {
  89. position: absolute;
  90. color: white;
  91. right: 0;
  92. transform: translateX(110%);
  93. }
  94. }
  95. &--checked {
  96. background-color: $switch-checked-color;
  97. color: $switch-checked-color;
  98. &.#{$name}--disabled {
  99. background-color: $switch-checked-disabled-color;
  100. color: $switch-checked-disabled-color;
  101. }
  102. }
  103. &--disabled {
  104. background-color: $switch-unchecked-disabled-color;
  105. // color: $switch-unchecked-disabled-color;
  106. }
  107. // &--checked&--disabled {
  108. // background-color: $switch-checked-disabled-color;
  109. // }
  110. &--large {
  111. font-size: $swtich-label-large-font-size;
  112. width: $switch-large-width;
  113. height: $switch-large-height;
  114. border-radius: $switch-large-radius;
  115. }
  116. &--small {
  117. font-size: $swtich-label-small-font-size;
  118. width: $switch-small-width;
  119. height: $switch-small-height;
  120. border-radius: $switch-small-radius;
  121. }
  122. &__dot {
  123. width: $switch-dot-size;
  124. height: $switch-dot-size;
  125. background-color: $switch-dot-bg-color;
  126. border-radius: $switch-dot-radius;
  127. display: flex;
  128. justify-content: center;
  129. align-items: center;
  130. box-shadow: $switch-dot-shadow;
  131. transition: padding 0.2s ease-in-out;
  132. &--large {
  133. width: $switch-dot-large-size;
  134. height: $switch-dot-large-size;
  135. }
  136. &--small {
  137. width: $switch-dot-small-size;
  138. height: $switch-dot-small-size;
  139. }
  140. }
  141. &--round{
  142. border-radius: calc($switch-large-height / 2);
  143. .#{$name}__dot{
  144. border-radius: calc($switch-large-height / 2);
  145. }
  146. .l-wave{
  147. border-radius: calc($switch-large-height / 2);
  148. }
  149. }
  150. }