@varlet/cli 1.27.20 → 2.0.0-alpha.1663742071515

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (176) hide show
  1. package/LICENCE +1 -1
  2. package/lib/commands/commitLint.js +1 -1
  3. package/lib/commands/compile.d.ts +5 -3
  4. package/lib/commands/compile.js +2 -2
  5. package/lib/commands/create.d.ts +8 -3
  6. package/lib/commands/create.js +100 -51
  7. package/lib/commands/dev.d.ts +4 -2
  8. package/lib/commands/dev.js +3 -3
  9. package/lib/commands/gen.d.ts +8 -1
  10. package/lib/commands/gen.js +61 -33
  11. package/lib/commands/jest.js +11 -7
  12. package/lib/commands/release.d.ts +4 -2
  13. package/lib/commands/release.js +2 -2
  14. package/lib/commands/test.d.ts +7 -0
  15. package/lib/commands/test.js +26 -0
  16. package/lib/commands/useVite.d.ts +1 -0
  17. package/lib/commands/useVite.js +70 -0
  18. package/lib/commands/vite.d.ts +3 -0
  19. package/lib/commands/vite.js +69 -0
  20. package/lib/compiler/compileModule.js +9 -5
  21. package/lib/compiler/compileSFC.js +14 -11
  22. package/lib/compiler/compileScript.js +4 -12
  23. package/lib/compiler/compileStyle.d.ts +1 -1
  24. package/lib/compiler/compileStyle.js +7 -17
  25. package/lib/compiler/compileTypes.js +4 -7
  26. package/lib/config/jest.config.js +1 -0
  27. package/lib/config/vite.config.js +1 -1
  28. package/lib/config/vitest.config.d.ts +2 -0
  29. package/lib/config/vitest.config.js +28 -0
  30. package/lib/index.js +22 -3
  31. package/lib/shared/constant.js +1 -1
  32. package/lib/shared/logger.d.ts +1 -0
  33. package/lib/shared/logger.js +3 -0
  34. package/package.json +16 -12
  35. package/site/components/button/Button.vue +45 -23
  36. package/site/components/button/button.less +6 -6
  37. package/site/components/button/props.ts +10 -2
  38. package/site/components/cell/Cell.vue +24 -12
  39. package/site/components/cell/cell.less +11 -7
  40. package/site/components/cell/props.ts +2 -2
  41. package/site/components/code-example/CodeExample.vue +17 -23
  42. package/site/components/context/index.ts +4 -0
  43. package/site/components/context/lock.ts +30 -41
  44. package/site/components/icon/Icon.vue +16 -9
  45. package/site/components/loading/Loading.vue +54 -25
  46. package/site/components/loading/loading.less +120 -35
  47. package/site/components/loading/props.ts +7 -2
  48. package/site/components/popup/Popup.tsx +102 -0
  49. package/site/components/popup/index.ts +10 -0
  50. package/site/components/popup/popup.less +125 -0
  51. package/site/components/popup/props.ts +63 -0
  52. package/site/components/progress/Progress.vue +28 -24
  53. package/site/components/progress/progress.less +16 -13
  54. package/site/components/progress/props.ts +1 -1
  55. package/site/components/ripple/index.ts +28 -7
  56. package/site/components/ripple/ripple.less +3 -0
  57. package/site/components/snackbar/Snackbar.vue +10 -7
  58. package/site/components/snackbar/core.vue +37 -22
  59. package/site/components/snackbar/index.tsx +14 -14
  60. package/site/components/snackbar/props.ts +10 -7
  61. package/site/components/utils/components.ts +49 -1
  62. package/site/components/utils/elements.ts +17 -0
  63. package/site/mobile/App.vue +42 -42
  64. package/site/mobile/components/AppHome.vue +1 -1
  65. package/site/mobile/components/app-bar/AppBar.vue +17 -21
  66. package/site/mobile/components/app-bar/appBar.less +2 -1
  67. package/site/mobile/main.ts +6 -2
  68. package/site/pc/Layout.vue +93 -67
  69. package/site/pc/components/AnimationBox.vue +3 -15
  70. package/site/pc/components/AppHeader.vue +110 -97
  71. package/site/pc/components/AppMobile.vue +8 -2
  72. package/site/pc/components/AppSidebar.vue +19 -10
  73. package/site/pc/components/LogoAnimation.vue +29 -31
  74. package/site/pc/floating.ts +3 -3
  75. package/site/pc/main.ts +6 -0
  76. package/site/pc/pages/index/index.less +142 -197
  77. package/site/pc/pages/index/index.vue +65 -80
  78. package/site/pc/pages/index/locale/en-US.ts +1 -5
  79. package/site/pc/pages/index/locale/zh-CN.ts +1 -5
  80. package/site/useProgress.ts +14 -17
  81. package/site/utils.ts +32 -20
  82. package/template/create/__tests__/index.spec.ejs +8 -0
  83. package/template/create/docs/en-US.md +0 -0
  84. package/template/create/docs/zh-CN.md +0 -0
  85. package/template/create/example/index.ejs +15 -0
  86. package/template/create/example/locale/en-US.ts +3 -0
  87. package/{generators/config/i18n/sfc/src/button → template/create}/example/locale/index.ts +0 -0
  88. package/template/create/example/locale/zh-CN.ts +3 -0
  89. package/template/create/index.ejs +12 -0
  90. package/template/create/less.ejs +3 -0
  91. package/template/create/props.ts +1 -0
  92. package/template/create/tsx.ejs +13 -0
  93. package/template/create/vue.ejs +17 -0
  94. package/{generators → template/generators}/base/.prettierignore +0 -0
  95. package/{generators → template/generators}/base/.prettierrc +0 -0
  96. package/{generators → template/generators}/base/README.md +0 -0
  97. package/{generators → template/generators}/base/babel.config.js +0 -0
  98. package/{generators → template/generators}/base/public/highlight.css +0 -0
  99. package/{generators → template/generators}/base/public/logo.svg +0 -0
  100. package/{generators → template/generators}/base/shims/shims-md.d.ts +0 -0
  101. package/{generators → template/generators}/base/shims/shims-vue.d.ts +0 -0
  102. package/{generators → template/generators}/base/tsconfig.json +0 -0
  103. package/{generators → template/generators}/config/default/base/docs/home.zh-CN.md +0 -0
  104. package/{generators → template/generators}/config/default/base/package.json +1 -1
  105. package/{generators → template/generators}/config/default/base/types/basicComponent.d.ts +0 -0
  106. package/{generators → template/generators}/config/default/base/types/button.d.ts +0 -0
  107. package/{generators → template/generators}/config/default/base/types/index.d.ts +0 -0
  108. package/{generators → template/generators}/config/default/base/varlet.config.js +1 -1
  109. package/{generators → template/generators}/config/default/sfc/src/button/Button.vue +6 -6
  110. package/{generators → template/generators}/config/default/sfc/src/button/__tests__/index.spec.js +0 -0
  111. package/{generators/config/default/tsx → template/generators/config/default/sfc}/src/button/button.less +1 -1
  112. package/{generators → template/generators}/config/default/sfc/src/button/docs/zh-CN.md +0 -0
  113. package/{generators → template/generators}/config/default/sfc/src/button/example/BasicUse.vue +0 -0
  114. package/{generators → template/generators}/config/default/sfc/src/button/example/ModifyColor.vue +0 -0
  115. package/{generators → template/generators}/config/default/sfc/src/button/example/index.vue +2 -2
  116. package/{generators → template/generators}/config/default/sfc/src/button/index.ts +0 -0
  117. package/{generators → template/generators}/config/default/tsx/src/button/Button.tsx +11 -13
  118. package/{generators → template/generators}/config/default/tsx/src/button/__tests__/index.spec.js +0 -0
  119. package/{generators/config/i18n → template/generators/config/default}/tsx/src/button/button.less +1 -1
  120. package/{generators → template/generators}/config/default/tsx/src/button/docs/zh-CN.md +0 -0
  121. package/{generators → template/generators}/config/default/tsx/src/button/example/BasicUse.vue +0 -0
  122. package/{generators → template/generators}/config/default/tsx/src/button/example/ModifyColor.vue +0 -0
  123. package/{generators → template/generators}/config/default/tsx/src/button/example/index.vue +2 -2
  124. package/{generators → template/generators}/config/default/tsx/src/button/index.ts +0 -0
  125. package/{generators → template/generators}/config/i18n/base/docs/home.en-US.md +0 -0
  126. package/{generators → template/generators}/config/i18n/base/docs/home.zh-CN.md +0 -0
  127. package/{generators → template/generators}/config/i18n/base/package.json +1 -1
  128. package/{generators → template/generators}/config/i18n/base/types/basicComponent.d.ts +0 -0
  129. package/{generators → template/generators}/config/i18n/base/types/button.d.ts +0 -0
  130. package/{generators → template/generators}/config/i18n/base/types/index.d.ts +0 -0
  131. package/{generators → template/generators}/config/i18n/base/types/locale.d.ts +0 -0
  132. package/{generators → template/generators}/config/i18n/base/varlet.config.js +3 -3
  133. package/{generators → template/generators}/config/i18n/sfc/src/button/Button.vue +7 -7
  134. package/{generators → template/generators}/config/i18n/sfc/src/button/__tests__/index.spec.js +0 -0
  135. package/{generators → template/generators}/config/i18n/sfc/src/button/button.less +1 -1
  136. package/{generators → template/generators}/config/i18n/sfc/src/button/docs/en-US.md +0 -0
  137. package/{generators → template/generators}/config/i18n/sfc/src/button/docs/zh-CN.md +0 -0
  138. package/{generators → template/generators}/config/i18n/sfc/src/button/example/BasicUse.vue +0 -0
  139. package/{generators → template/generators}/config/i18n/sfc/src/button/example/ModifyColor.vue +0 -0
  140. package/{generators → template/generators}/config/i18n/sfc/src/button/example/index.vue +1 -1
  141. package/{generators/config/i18n/tsx → template/generators/config/i18n/sfc}/src/button/example/locale/en-US.ts +1 -1
  142. package/{generators/config/i18n/tsx → template/generators/config/i18n/sfc}/src/button/example/locale/index.ts +0 -0
  143. package/{generators/config/i18n/tsx → template/generators/config/i18n/sfc}/src/button/example/locale/zh-CN.ts +1 -1
  144. package/{generators → template/generators}/config/i18n/sfc/src/button/index.ts +0 -0
  145. package/{generators → template/generators}/config/i18n/sfc/src/locale/__tests__/index.spec.js +0 -0
  146. package/{generators → template/generators}/config/i18n/sfc/src/locale/docs/en-US.md +0 -0
  147. package/{generators → template/generators}/config/i18n/sfc/src/locale/docs/zh-CN.md +0 -0
  148. package/{generators → template/generators}/config/i18n/sfc/src/locale/en-US.d.ts +0 -0
  149. package/{generators/config/i18n/tsx → template/generators/config/i18n/sfc}/src/locale/en-US.ts +1 -1
  150. package/{generators → template/generators}/config/i18n/sfc/src/locale/index.ts +0 -0
  151. package/{generators → template/generators}/config/i18n/sfc/src/locale/zh-CN.d.ts +0 -0
  152. package/{generators/config/i18n/tsx → template/generators/config/i18n/sfc}/src/locale/zh-CN.ts +1 -1
  153. package/{generators → template/generators}/config/i18n/tsx/src/button/Button.tsx +12 -14
  154. package/{generators → template/generators}/config/i18n/tsx/src/button/__tests__/index.spec.js +0 -0
  155. package/{generators/config/default/sfc → template/generators/config/i18n/tsx}/src/button/button.less +1 -1
  156. package/{generators → template/generators}/config/i18n/tsx/src/button/docs/en-US.md +0 -0
  157. package/{generators → template/generators}/config/i18n/tsx/src/button/docs/zh-CN.md +0 -0
  158. package/{generators → template/generators}/config/i18n/tsx/src/button/example/BasicUse.vue +0 -0
  159. package/{generators → template/generators}/config/i18n/tsx/src/button/example/ModifyColor.vue +0 -0
  160. package/{generators → template/generators}/config/i18n/tsx/src/button/example/index.vue +1 -1
  161. package/{generators/config/i18n/sfc → template/generators/config/i18n/tsx}/src/button/example/locale/en-US.ts +1 -1
  162. package/template/generators/config/i18n/tsx/src/button/example/locale/index.ts +23 -0
  163. package/{generators/config/i18n/sfc → template/generators/config/i18n/tsx}/src/button/example/locale/zh-CN.ts +1 -1
  164. package/{generators → template/generators}/config/i18n/tsx/src/button/index.ts +0 -0
  165. package/{generators → template/generators}/config/i18n/tsx/src/locale/__tests__/index.spec.js +0 -0
  166. package/{generators → template/generators}/config/i18n/tsx/src/locale/docs/en-US.md +0 -0
  167. package/{generators → template/generators}/config/i18n/tsx/src/locale/docs/zh-CN.md +0 -0
  168. package/{generators → template/generators}/config/i18n/tsx/src/locale/en-US.d.ts +0 -0
  169. package/{generators/config/i18n/sfc → template/generators/config/i18n/tsx}/src/locale/en-US.ts +1 -1
  170. package/{generators → template/generators}/config/i18n/tsx/src/locale/index.ts +0 -0
  171. package/{generators → template/generators}/config/i18n/tsx/src/locale/zh-CN.d.ts +0 -0
  172. package/{generators/config/i18n/sfc → template/generators/config/i18n/tsx}/src/locale/zh-CN.ts +1 -1
  173. package/varlet.default.config.js +137 -15
  174. package/site/mobile/components/styles/common.less +0 -64
  175. package/site/mobile/components/styles/elevation.less +0 -126
  176. package/site/mobile/components/styles/var.less +0 -27
@@ -2,9 +2,8 @@
2
2
  import config from '@config'
3
3
  import { get } from 'lodash-es'
4
4
  import { computed, defineComponent, onMounted, onBeforeUnmount, ref, watch, nextTick } from 'vue'
5
- import { animationBoxData, animationEl, animationElClientRect } from '../floating'
5
+ import { animationBoxData, animationEl, animationElClientRect, isMountedCount } from '../floating'
6
6
  import type { Ref, StyleValue } from 'vue'
7
- import { useRouter } from 'vue-router'
8
7
 
9
8
  export default defineComponent({
10
9
  name: 'LogoAnimation',
@@ -15,6 +14,8 @@ export default defineComponent({
15
14
 
16
15
  watch(animationElClientRect, async (newClientRect) => {
17
16
  if (newClientRect) {
17
+ isMountedCount.value > 1 && (floatingState.value = true)
18
+
18
19
  proxyRect.value = newClientRect
19
20
  }
20
21
  })
@@ -26,13 +27,6 @@ export default defineComponent({
26
27
  left: `${proxyRect.value?.left}px`,
27
28
  }))
28
29
 
29
- const router = useRouter()
30
- router.beforeEach(async (to: any, from: any) => {
31
- if (!floatingState.value && from.path !== '/') {
32
- floatingState.value = true
33
- }
34
- })
35
-
36
30
  onMounted(() => {
37
31
  window.addEventListener('resize', resetPosition, false)
38
32
  })
@@ -54,6 +48,7 @@ export default defineComponent({
54
48
  await nextTick()
55
49
  }
56
50
  clearTimeout(resetTimer)
51
+
57
52
  const newBRect = animationEl.value?.getBoundingClientRect()
58
53
  if (newBRect) {
59
54
  resetTimer = window.setTimeout(() => {
@@ -76,44 +71,47 @@ export default defineComponent({
76
71
 
77
72
  <template>
78
73
  <Teleport :to="animationEl || 'body'">
79
- <img
80
- v-show="!floatingState"
81
- v-bind="animationBoxData.attrs"
82
- :style="styles"
83
- :src="logo"
84
- alt="logo"
74
+ <img
85
75
  v-if="logo && animationEl"
86
- class="varlet-cli-logo-animation"
87
- :class="{ 'varlet-cli-logo-position': !animationEl }"
76
+ v-bind="animationBoxData.attrs"
77
+ :class="{ 'varlet-cli-logo-position': !animationEl, 'varlet-cli-logo-show': !floatingState }"
78
+ :style="styles"
79
+ :src="logo"
80
+ class="varlet-cli-logo-entity"
81
+ alt="logo"
88
82
  />
89
83
  </Teleport>
90
- <div v-show="floatingState">
91
- <img
92
- @transitionend="land"
93
- v-bind="animationBoxData.attrs"
94
- :style="styles"
95
- :src="logo"
96
- alt="logo"
97
- v-if="logo && animationEl"
98
- class="varlet-cli-logo-animation varlet-cli-logo-position varlet-cli-logo-transition"
99
- />
100
- </div>
84
+ <img
85
+ v-if="logo && animationEl"
86
+ v-bind="animationBoxData.attrs"
87
+ :class="{ 'varlet-cli-logo-show': floatingState }"
88
+ :style="styles"
89
+ :src="logo"
90
+ @transitionend="land"
91
+ class="varlet-cli-logo-entity varlet-cli-logo-position varlet-cli-logo-transition"
92
+ alt="logo"
93
+ />
101
94
  </template>
102
95
 
103
96
  <style lang="less">
104
97
  .varlet-cli-logo-transition {
105
- transition: 0.5s all ease-in-out;
106
98
  width: 100%;
107
99
  height: 100%;
108
- display: block;
109
100
  }
110
101
 
111
- .varlet-cli-logo-animation {
102
+ .varlet-cli-logo-entity {
112
103
  z-index: 10;
113
104
  pointer-events: none;
105
+ opacity: 0;
114
106
  }
115
107
 
116
108
  .varlet-cli-logo-position {
117
109
  position: fixed;
110
+ transition: 0.5s ease-in-out;
111
+ transition-property: left, top, height, width;
112
+ }
113
+
114
+ .varlet-cli-logo-show {
115
+ opacity: 1;
118
116
  }
119
117
  </style>
@@ -1,9 +1,9 @@
1
1
  import { reactive, ref } from 'vue'
2
2
 
3
- // 动画节点属性存储
4
3
  export const animationBoxData = reactive<any>({})
5
4
 
6
- // 存储节点
7
5
  export const animationEl = ref<HTMLElement | null>()
8
6
 
9
- export const animationElClientRect = ref<DOMRect | null>();
7
+ export const animationElClientRect = ref<DOMRect | null>()
8
+
9
+ export const isMountedCount = ref<number>(0)
package/site/pc/main.ts CHANGED
@@ -6,6 +6,8 @@ import config from '@config'
6
6
  import Icon from '../components/icon'
7
7
  import Cell from '../components/cell'
8
8
  import Ripple from '../components/ripple'
9
+ import Button from '../components/button'
10
+ import Popup from '../components/popup'
9
11
  import CodeExample from '../components/code-example'
10
12
  import Snackbar from '../components/snackbar'
11
13
 
@@ -91,4 +93,8 @@ createApp(App)
91
93
  // @ts-ignore
92
94
  .use(CodeExample)
93
95
  .use(Snackbar)
96
+ // @ts-ignore
97
+ .use(Popup)
98
+ // @ts-ignore
99
+ .use(Button)
94
100
  .mount('#app')
@@ -1,231 +1,176 @@
1
- .home-page {
2
- position: relative;
3
- width: 100vw;
4
- height: 100vh;
5
- box-sizing: border-box;
6
- min-width: 1200px;
7
- min-height: 460px;
8
- background: var(--site-config-color-home-page-background);
9
- overflow: hidden;
10
- display: flex;
11
- align-items: center;
12
- }
13
-
14
- @keyframes fade-in {
1
+ @keyframes logo-wave {
15
2
  0% {
16
- opacity: 0;
17
- transform: translateX(-100%);
3
+ transform: translate(8%, 8%);
18
4
  }
19
5
 
6
+ 20% {
7
+ transform: translate(-8%, 8%);
8
+ }
20
9
 
21
- to {
22
- opacity: 1;
23
- transform: translateX(0%);
10
+ 40% {
11
+ transform: translate(-8%, -8%);
12
+ }
13
+
14
+ 60% {
15
+ transform: translate(-2%, 8%);
24
16
  }
25
- }
26
17
 
27
- @keyframes slash-1 {
28
- from {
29
- transform: rotate(90deg);
30
- ;
18
+ 80% {
19
+ transform: translate(8%, -8%);
31
20
  }
32
21
 
33
- to {
34
- transform: rotate(10deg);
22
+ 100% {
23
+ transform: translate(8%, 8%);
35
24
  }
36
25
  }
37
26
 
38
- @keyframes slash-2 {
39
- from {
40
- transform: rotate(90deg);
41
- ;
27
+ .varlet-doc-index {
28
+ position: relative;
29
+ display: flex;
30
+ flex-direction: column;
31
+ align-items: center;
32
+ min-height: 100vh;
33
+ box-sizing: border-box;
34
+ background: var(--site-config-color-index-page-background);
35
+ padding-bottom: 100px;
36
+ min-width: 1050px;
37
+
38
+ &__layout {
39
+ display: flex;
40
+ flex-direction: column;
41
+ align-items: center;
42
+ padding: 110px 0;
43
+ max-width: 1200px;
44
+ transition: all .2s;
42
45
  }
43
46
 
44
- to {
45
- transform: rotate(20deg);
47
+ &__logo {
48
+ width: 100%;
49
+ height: 100%;
50
+ flex-shrink: 0;
51
+ z-index: 2;
46
52
  }
47
- }
48
53
 
49
- @keyframes slash-3 {
50
- from {
51
- transform: rotate(90deg);
52
- ;
54
+ &__logo-container {
55
+ position: relative;
56
+ display: flex;
57
+ justify-content: center;
58
+ width: 160px;
59
+ height: 160px;
53
60
  }
54
61
 
55
- to {
56
- transform: rotate(30deg);
62
+ &__logo-background-mask {
63
+ position: absolute;
64
+ left: -40px;
65
+ top: -40px;
66
+ bottom: -40px;
67
+ right: -40px;
68
+ background: var(--site-config-color-index-page-logo-mask-background);
69
+ transition: background-color .2s;
70
+ filter: blur(45px);
71
+ border-radius: 50%;
72
+ animation: logo-wave 6s infinite linear;
57
73
  }
58
- }
59
74
 
60
- @keyframes slash-4 {
61
- from {
62
- transform: rotate(90deg);
63
- ;
75
+ &__title {
76
+ font-size: 54px;
77
+ margin-top: 60px;
64
78
  }
65
79
 
66
- to {
67
- transform: rotate(40deg);
80
+ &__description {
81
+ max-width: 700px;
82
+ width: 90vw;
83
+ font-size: 16px;
84
+ line-height: 28px;
85
+ letter-spacing: 1px;
86
+ margin-top: 30px;
87
+ padding: 0 20px;
88
+ text-align: center;
89
+ box-sizing: border-box;
90
+ color: var(--site-config-color-index-page-second-text-color);
68
91
  }
69
- }
70
92
 
71
- @keyframes slash-5 {
72
- from {
73
- transform: rotate(90deg);
74
- ;
93
+ &__link-button-group {
94
+ display: flex;
95
+ justify-content: space-around;
96
+ margin-top: 30px;
75
97
  }
76
98
 
77
- to {
78
- transform: rotate(50deg);
99
+ &__link-button {
100
+ height: 44px;
101
+ font-size: 18px;
102
+ transition: all .2s;
103
+ margin: 0 10px;
79
104
  }
80
- }
81
105
 
82
- .slash-box {
83
- position: absolute;
84
- width: 30px;
85
- bottom: -70%;
86
- top: -130%;
87
- right: 52%;
88
- transform-origin: bottom right;
89
- transition: box-shadow 0.5s;
90
- box-shadow: -20px 0 20px var(--site-config-color-home-page-slash);
91
- }
106
+ &__link-button-text {
107
+ margin-right: 4px;
108
+ }
92
109
 
93
- .box-1 {
94
- animation: slash-1 .75s forwards;
95
- }
110
+ &__features {
111
+ display: flex;
112
+ justify-content: center;
113
+ flex-wrap: wrap;
114
+ margin-top: 70px;
115
+ }
96
116
 
97
- .box-2 {
98
- animation: slash-2 .75s forwards;
99
- }
117
+ &__feature {
118
+ width: 280px;
119
+ margin: 10px;
120
+ padding: 20px;
121
+ border-radius: 4px;
122
+ background: var(--site-config-color-index-page-feature-background);
123
+ box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
124
+ }
100
125
 
101
- .box-3 {
102
- animation: slash-3 .75s forwards;
103
- }
126
+ &__feature-description {
127
+ color: var(--site-config-color-index-page-second-text-color);
128
+ font-size: 14px;
129
+ margin-top: 10px;
130
+ line-height: 1.5;
131
+ }
104
132
 
105
- .box-4 {
106
- animation: slash-4 .75s forwards;
107
- }
133
+ &__contributors {
134
+ display: flex;
135
+ flex-direction: column;
136
+ align-items: center;
137
+ margin-top: 80px;
138
+ }
108
139
 
109
- .box-5 {
110
- animation: slash-5 .75s forwards;
111
- }
140
+ &__contributors-title {
141
+ padding-top: 30px;
142
+ line-height: 32px;
143
+ font-size: 22px;
144
+ border-top: thin solid var(--site-config-color-index-page-divider-color);
145
+ color: var(--site-config-color-index-page-second-text-color);
146
+ letter-spacing: 1px;
147
+ transition: all .2s;
148
+ }
112
149
 
113
- .profile-container {
114
- height: 100vh;
115
- padding-left: 10vw;
116
- display: flex;
117
- justify-content: center;
118
- align-items: center;
150
+ &__contributors-link {
151
+ display: block;
152
+ margin-top: 50px;
153
+ width: 700px;
154
+ }
119
155
 
120
- .container-box {
121
- width: 35vw;
122
- min-width: 500px;
123
-
124
- .logo-container {
125
- margin-right: 20px;
126
- }
127
-
128
- .button-group {
129
- display: flex;
130
- margin-top: 25px;
131
- align-items: center;
132
- }
133
-
134
- .block-button-content {
135
- display: flex;
136
- align-items: center;
137
- }
138
-
139
- .common-button {
140
- height: 52px;
141
- font-size: 18px;
142
- transition: all .25s;
143
- animation: fade-in .75s forwards;
144
- }
145
-
146
- .extra-button {
147
- flex-shrink: 0;
148
- background-color: var(--site-config-color-home-page-extra-button-background);
149
- }
150
-
151
- .github-button {
152
- background-color: var(--site-config-color-home-page-github-button-background);
153
- color: #fff;
154
- }
155
-
156
- .primary-button {
157
- background-color: var(--site-config-color-home-page-primary-button-background);
158
- }
159
-
160
- .margin-left {
161
- margin-left: 10px;
162
- }
163
-
164
- @media all and (max-width: 2560px) {
165
- .description-container {
166
- display: flex;
167
- margin-bottom: 40px;
168
- }
169
-
170
- .base-title {
171
- font-size: 110px;
172
- line-height: 72px;
173
- font-weight: 500;
174
- margin-top: 21px;
175
- animation: fade-in .75s forwards;
176
- }
177
-
178
- .base-description {
179
- font-size: 20px;
180
- line-height: 38px;
181
- padding-left: 4px;
182
- font-weight: 500;
183
- margin-bottom: 43px;
184
- letter-spacing: 1px;
185
- animation: fade-in .75s forwards;
186
- }
187
-
188
- .logo-box {
189
- width: 120px;
190
- height: 120px;
191
- flex-shrink: 0;
192
- margin-right: 30px;
193
- z-index: 2;
194
- }
195
- }
196
-
197
- @media all and (max-width: 1920px) {
198
-
199
- .description-container {
200
- display: flex;
201
- margin-bottom: 35px;
202
- }
203
-
204
- .base-title {
205
- font-size: 84px;
206
- line-height: 72px;
207
- font-weight: 500;
208
- margin-top: 8px;
209
- animation: fade-in .75s forwards;
210
- }
211
-
212
- .base-description {
213
- font-size: 16px;
214
- line-height: 28px;
215
- padding-left: 4px;
216
- font-weight: 500;
217
- margin-bottom: 45px;
218
- letter-spacing: 1px;
219
- animation: fade-in .75s forwards;
220
- }
221
-
222
- .logo-box {
223
- width: 90px;
224
- height: 90px;
225
- flex-shrink: 0;
226
- margin-right: 25px;
227
- z-index: 2;
228
- }
229
- }
230
- }
231
- }
156
+ &__contributors-image {
157
+ display: block;
158
+ width: 100%;
159
+ }
160
+
161
+ &__footer {
162
+ position: absolute;
163
+ bottom: 0;
164
+ display: flex;
165
+ flex-direction: column;
166
+ justify-content: center;
167
+ align-items: center;
168
+ width: 100%;
169
+ height: 100px;
170
+ border-top: thin solid var(--site-config-color-index-page-divider-color);
171
+ color: var(--site-config-color-index-page-second-text-color);
172
+ font-size: 14px;
173
+ line-height: 26px;
174
+ transition: all .2s;
175
+ }
176
+ }