5c68b98d57db58e8baa73d00f557c14a0d58baee31ca560da7deaf4312e354fb18f0063eb94899abb721d2f62dab355dd92c931279d84a370a71b080e0a5d2 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. @import "mixins/mixins";
  2. @import "mixins/_button";
  3. @import "common/var";
  4. @include b(radio-button) {
  5. position: relative;
  6. display: inline-block;
  7. outline: none;
  8. @include e(inner) {
  9. display: inline-block;
  10. line-height: 1;
  11. white-space: nowrap;
  12. vertical-align: middle;
  13. background: $--button-default-background-color;
  14. border: $--border-base;
  15. font-weight: $--button-font-weight;
  16. border-left: 0;
  17. color: $--button-default-font-color;
  18. -webkit-appearance: none;
  19. text-align: center;
  20. box-sizing: border-box;
  21. outline: none;
  22. margin: 0;
  23. position: relative;
  24. cursor: pointer;
  25. transition: $--all-transition;
  26. @include button-size($--button-padding-vertical, $--button-padding-horizontal, $--button-font-size, 0);
  27. &:hover {
  28. color: $--color-primary;
  29. }
  30. & [class*="el-icon-"] {
  31. line-height: 0.9;
  32. & + span {
  33. margin-left: 5px;
  34. }
  35. }
  36. }
  37. &:first-child {
  38. .el-radio-button__inner {
  39. border-left: $--border-base;
  40. border-radius: $--border-radius-base 0 0 $--border-radius-base;
  41. box-shadow: none !important;
  42. }
  43. }
  44. @include e(orig-radio) {
  45. opacity: 0;
  46. outline: none;
  47. position: absolute;
  48. z-index: -1;
  49. &:checked {
  50. & + .el-radio-button__inner {
  51. color: $--radio-button-checked-font-color;
  52. background-color: $--radio-button-checked-background-color;
  53. border-color: $--radio-button-checked-border-color;
  54. box-shadow: -1px 0 0 0 $--radio-button-checked-border-color;
  55. }
  56. }
  57. &:disabled {
  58. & + .el-radio-button__inner {
  59. color: $--button-disabled-font-color;
  60. cursor: not-allowed;
  61. background-image: none;
  62. background-color: $--button-disabled-background-color;
  63. border-color: $--button-disabled-border-color;
  64. box-shadow: none;
  65. }
  66. &:checked + .el-radio-button__inner {
  67. background-color: $--radio-button-disabled-checked-fill;
  68. }
  69. }
  70. }
  71. &:last-child {
  72. .el-radio-button__inner {
  73. border-radius: 0 $--border-radius-base $--border-radius-base 0;
  74. }
  75. }
  76. &:first-child:last-child {
  77. .el-radio-button__inner {
  78. border-radius: $--border-radius-base;
  79. }
  80. }
  81. @include m(medium) {
  82. & .el-radio-button__inner {
  83. @include button-size($--button-medium-padding-vertical, $--button-medium-padding-horizontal, $--button-medium-font-size, 0);
  84. }
  85. }
  86. @include m(small) {
  87. & .el-radio-button__inner {
  88. @include button-size($--button-small-padding-vertical, $--button-small-padding-horizontal, $--button-small-font-size, 0);
  89. }
  90. }
  91. @include m(mini) {
  92. & .el-radio-button__inner {
  93. @include button-size($--button-mini-padding-vertical, $--button-mini-padding-horizontal, $--button-mini-font-size, 0);
  94. }
  95. }
  96. &:focus:not(.is-focus):not(:active):not(.is-disabled){ /*获得焦点时 样式提醒*/
  97. box-shadow: 0 0 2px 2px $--radio-button-checked-border-color;
  98. }
  99. }