spin.scss 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. //@import '../theme/variables.scss';
  2. @import './variables.scss';
  3. @import './mixin.scss';
  4. @import '../keyframes/rotate.scss';
  5. $module: #{$prefix}-spin;
  6. .#{$module} {
  7. position: relative;
  8. display: inline-block;
  9. @include size($width-spin_middle);
  10. &-wrapper {
  11. text-align: center;
  12. position: absolute;
  13. width: 100%;
  14. transform: $motion-spin_wrapper-translate;
  15. top: $spacing-spin_wrapper-top;
  16. color: $color-spin-bg;
  17. & > svg {
  18. animation: $motion-spin_wrapper_svg-animationDuration linear infinite #{$prefix}-animation-rotate;
  19. @include size($width-spin_middle);
  20. }
  21. }
  22. &-animate {
  23. display: inline-flex;
  24. animation: $motion-spin_animate_svg-animationDuration linear infinite #{$prefix}-animation-rotate;
  25. }
  26. &-children {
  27. opacity: $opacity-spin_children;
  28. user-select: none;
  29. }
  30. &-block {
  31. display: block;
  32. // 添加一个遮罩解决嵌套 Spin 穿透问题
  33. &::after {
  34. content: '';
  35. position: absolute;
  36. top: 0;
  37. left: 0;
  38. width: 100%;
  39. height: 100%;
  40. z-index: 1;
  41. }
  42. .#{$module}-wrapper {
  43. display: block;
  44. }
  45. &.#{$module} {
  46. height: auto;
  47. width: auto;
  48. }
  49. }
  50. &-hidden {
  51. &::after {
  52. content: none;
  53. }
  54. // 考虑到嵌套,.spin-chidren 节点的 opacity 由直接父级节点的 .spin-hidden 决定
  55. & > .#{$module}-children {
  56. opacity: 1;
  57. user-select: auto;
  58. }
  59. }
  60. }
  61. .#{$module}-small {
  62. @include size($width-spin_small);
  63. & > .#{$module}-wrapper svg {
  64. @include size($width-spin_small);
  65. }
  66. }
  67. .#{$module}-middle {
  68. @include size($width-spin_middle);
  69. & > .#{$module}-wrapper svg {
  70. @include size($width-spin_middle);
  71. }
  72. }
  73. .#{$module}-large {
  74. @include size($width-spin_large);
  75. & > .#{$module}-wrapper svg {
  76. @include size($width-spin_large);
  77. }
  78. }
  79. .#{$module}-container {
  80. overflow: hidden;
  81. }
  82. @import './rtl.scss';