message.scss 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. @use 'mixins/mixins' as *;
  2. @use 'mixins/var' as *;
  3. @use 'common/var' as *;
  4. @include b(message) {
  5. @include set-component-css-var('message', $message);
  6. }
  7. @include b(message) {
  8. width: fit-content;
  9. max-width: calc(100% - 32px);
  10. box-sizing: border-box;
  11. border-radius: getCssVar('border-radius-base');
  12. border-width: getCssVar('border-width');
  13. border-style: getCssVar('border-style');
  14. border-color: getCssVar('message', 'border-color');
  15. position: fixed;
  16. left: 50%;
  17. top: 20px;
  18. transform: translateX(-50%);
  19. background-color: getCssVar('message', 'bg-color');
  20. transition: opacity getCssVar('transition-duration'), transform 0.4s, top 0.4s;
  21. padding: getCssVar('message', 'padding');
  22. display: flex;
  23. align-items: center;
  24. @include when(center) {
  25. justify-content: center;
  26. }
  27. @include when(closable) {
  28. .#{$namespace}-message__content {
  29. padding-right: 31px;
  30. }
  31. }
  32. p {
  33. margin: 0;
  34. }
  35. @each $type in (success, info, warning, error) {
  36. @include m($type) {
  37. @include css-var-from-global(
  38. ('message', 'bg-color'),
  39. ('color', $type, 'light-9')
  40. );
  41. @include css-var-from-global(
  42. ('message', 'border-color'),
  43. ('color', $type, 'light-8')
  44. );
  45. @include css-var-from-global(('message', 'text-color'), ('color', $type));
  46. .#{$namespace}-message__content {
  47. color: getCssVar('message', 'text-color');
  48. overflow-wrap: anywhere;
  49. }
  50. }
  51. & .#{$namespace}-message-icon--#{$type} {
  52. color: getCssVar('message', 'text-color');
  53. }
  54. }
  55. @include e(icon) {
  56. margin-right: 10px;
  57. }
  58. .#{$namespace}-message__badge {
  59. position: absolute;
  60. top: -8px;
  61. right: -8px;
  62. }
  63. @include e(content) {
  64. padding: 0;
  65. font-size: 14px;
  66. line-height: 1;
  67. &:focus {
  68. outline-width: 0;
  69. }
  70. }
  71. & .#{$namespace}-message__closeBtn {
  72. position: absolute;
  73. top: 50%;
  74. right: 19px;
  75. transform: translateY(-50%);
  76. cursor: pointer;
  77. color: getCssVar('message', 'close-icon-color');
  78. font-size: getCssVar('message', 'close-size');
  79. &:focus {
  80. outline-width: 0;
  81. }
  82. &:hover {
  83. color: getCssVar('message', 'close-hover-color');
  84. }
  85. }
  86. }
  87. .#{$namespace}-message-fade-enter-from,
  88. .#{$namespace}-message-fade-leave-to {
  89. opacity: 0;
  90. transform: translate(-50%, -100%);
  91. }