spin.scss 2.3 KB

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