@antv/dumi-theme-antv 0.1.0

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 (111) hide show
  1. package/README.md +9 -0
  2. package/es/antv/404/index.js +20 -0
  3. package/es/antv/Banner/Banner.module.less +412 -0
  4. package/es/antv/Banner/Notification.js +44 -0
  5. package/es/antv/Banner/Notification.module.less +108 -0
  6. package/es/antv/Banner/index.js +115 -0
  7. package/es/antv/Cases/Cases.js +124 -0
  8. package/es/antv/Cases/Cases.module.less +203 -0
  9. package/es/antv/Features/FeatureCard.js +25 -0
  10. package/es/antv/Features/FeatureCard.module.less +51 -0
  11. package/es/antv/Features/Features.module.less +169 -0
  12. package/es/antv/Features/index.js +102 -0
  13. package/es/antv/Footer/Footer.module.less +36 -0
  14. package/es/antv/Footer/index.js +232 -0
  15. package/es/antv/Header/Logo.js +130 -0
  16. package/es/antv/Products/Product.js +61 -0
  17. package/es/antv/Products/Product.module.less +146 -0
  18. package/es/antv/Products/getNewProducts.js +41 -0
  19. package/es/antv/Products/getProducts.js +466 -0
  20. package/es/antv/Products/index.js +81 -0
  21. package/es/antv/hooks.js +81 -0
  22. package/es/antv/mixins.less +21 -0
  23. package/es/antv/utils.js +49 -0
  24. package/es/builtins/API.js +37 -0
  25. package/es/builtins/Alert.js +9 -0
  26. package/es/builtins/Alert.less +62 -0
  27. package/es/builtins/Badge.js +9 -0
  28. package/es/builtins/Badge.less +31 -0
  29. package/es/builtins/Example.js +48 -0
  30. package/es/builtins/Example.less +47 -0
  31. package/es/builtins/Previewer.js +225 -0
  32. package/es/builtins/Previewer.less +406 -0
  33. package/es/builtins/SourceCode.js +72 -0
  34. package/es/builtins/SourceCode.less +103 -0
  35. package/es/builtins/Table.js +56 -0
  36. package/es/builtins/Table.less +43 -0
  37. package/es/builtins/Tree.js +219 -0
  38. package/es/builtins/Tree.less +159 -0
  39. package/es/components/Dark.js +125 -0
  40. package/es/components/Dark.less +121 -0
  41. package/es/components/LocaleSelect.js +53 -0
  42. package/es/components/LocaleSelect.less +59 -0
  43. package/es/components/Navbar.js +155 -0
  44. package/es/components/Navbar.less +180 -0
  45. package/es/components/SearchBar.js +83 -0
  46. package/es/components/SearchBar.less +165 -0
  47. package/es/components/SideMenu.js +99 -0
  48. package/es/components/SideMenu.less +379 -0
  49. package/es/components/SlugList.js +33 -0
  50. package/es/components/SlugList.less +18 -0
  51. package/es/layout.js +276 -0
  52. package/es/style/layout.less +402 -0
  53. package/es/style/markdown.less +240 -0
  54. package/es/style/variables.less +37 -0
  55. package/package.json +58 -0
  56. package/src/antv/404/index.tsx +25 -0
  57. package/src/antv/Banner/Banner.module.less +412 -0
  58. package/src/antv/Banner/Notification.module.less +108 -0
  59. package/src/antv/Banner/Notification.tsx +45 -0
  60. package/src/antv/Banner/index.tsx +121 -0
  61. package/src/antv/Cases/Cases.module.less +203 -0
  62. package/src/antv/Cases/Cases.tsx +116 -0
  63. package/src/antv/Features/FeatureCard.module.less +51 -0
  64. package/src/antv/Features/FeatureCard.tsx +24 -0
  65. package/src/antv/Features/Features.module.less +169 -0
  66. package/src/antv/Features/index.tsx +86 -0
  67. package/src/antv/Footer/Footer.module.less +36 -0
  68. package/src/antv/Footer/index.tsx +272 -0
  69. package/src/antv/Header/Logo.tsx +85 -0
  70. package/src/antv/Products/Product.module.less +146 -0
  71. package/src/antv/Products/Product.tsx +80 -0
  72. package/src/antv/Products/getNewProducts.tsx +53 -0
  73. package/src/antv/Products/getProducts.tsx +626 -0
  74. package/src/antv/Products/index.tsx +70 -0
  75. package/src/antv/hooks.ts +87 -0
  76. package/src/antv/mixins.less +21 -0
  77. package/src/antv/utils.ts +44 -0
  78. package/src/builtins/API.tsx +57 -0
  79. package/src/builtins/Alert.less +62 -0
  80. package/src/builtins/Alert.tsx +4 -0
  81. package/src/builtins/Badge.less +31 -0
  82. package/src/builtins/Badge.tsx +4 -0
  83. package/src/builtins/Example.less +47 -0
  84. package/src/builtins/Example.tsx +34 -0
  85. package/src/builtins/Previewer.less +406 -0
  86. package/src/builtins/Previewer.tsx +264 -0
  87. package/src/builtins/SourceCode.less +103 -0
  88. package/src/builtins/SourceCode.tsx +55 -0
  89. package/src/builtins/Table.less +43 -0
  90. package/src/builtins/Table.tsx +42 -0
  91. package/src/builtins/Tree.less +159 -0
  92. package/src/builtins/Tree.tsx +130 -0
  93. package/src/components/Dark.less +121 -0
  94. package/src/components/Dark.tsx +78 -0
  95. package/src/components/LocaleSelect.less +59 -0
  96. package/src/components/LocaleSelect.tsx +53 -0
  97. package/src/components/Navbar.less +180 -0
  98. package/src/components/Navbar.tsx +152 -0
  99. package/src/components/SearchBar.less +165 -0
  100. package/src/components/SearchBar.tsx +68 -0
  101. package/src/components/SideMenu.less +379 -0
  102. package/src/components/SideMenu.tsx +148 -0
  103. package/src/components/SlugList.less +18 -0
  104. package/src/components/SlugList.tsx +20 -0
  105. package/src/layout.tsx +225 -0
  106. package/src/style/layout.less +402 -0
  107. package/src/style/markdown.less +240 -0
  108. package/src/style/variables.less +37 -0
  109. package/src/test/SearchBar.test.ts +32 -0
  110. package/src/test/Table.test.tsx +41 -0
  111. package/src/test/index.test.tsx +377 -0
@@ -0,0 +1,240 @@
1
+ @import (reference) './variables.less';
2
+
3
+ .markdown {
4
+ color: @c-text;
5
+ font-size: 15px;
6
+ line-height: 1.60625;
7
+
8
+ [data-prefers-color=dark] & {
9
+ color: @c-secondary-dark;
10
+ }
11
+
12
+ &:not(:first-child):empty {
13
+ min-height: 32px;
14
+ }
15
+
16
+ // titles
17
+ h1,
18
+ h2,
19
+ h3,
20
+ h4,
21
+ h5,
22
+ h6 {
23
+ margin: 42px 0 18px;
24
+ color: @c-heading;
25
+ font-weight: 500;
26
+ line-height: 1.40625;
27
+
28
+ [data-prefers-color=dark] & {
29
+ color: @c-heading-dark;
30
+ }
31
+
32
+ // anchor link
33
+ &:hover > a[aria-hidden] {
34
+ float: left;
35
+ margin-top: 0.06em;
36
+ margin-left: -20px;
37
+ width: 20px;
38
+ padding-right: 4px;
39
+ line-height: 1;
40
+ box-sizing: border-box;
41
+
42
+ @media @mobile {
43
+ width: 14px;
44
+ margin-left: -14px;
45
+ }
46
+
47
+ &::after {
48
+ content: '#';
49
+ display: inline-block;
50
+ vertical-align: middle;
51
+ font-size: 20px;
52
+ }
53
+
54
+ span {
55
+ display: none;
56
+ }
57
+ }
58
+
59
+ + h1,
60
+ + h2,
61
+ + h3,
62
+ + h4,
63
+ + h5,
64
+ + h6 {
65
+ margin-top: 16px;
66
+ }
67
+ }
68
+
69
+ h1 {
70
+ margin-top: 48px;
71
+ margin-bottom: 32px;
72
+ font-size: 32px;
73
+ }
74
+
75
+ h2 {
76
+ font-size: 24px;
77
+ }
78
+
79
+ h3 {
80
+ font-size: 20px;
81
+ }
82
+
83
+ h4 {
84
+ font-size: 18px;
85
+ }
86
+
87
+ h5 {
88
+ font-size: 16px;
89
+ }
90
+
91
+ h6 {
92
+ font-size: 14px;
93
+ }
94
+
95
+ // paragraph
96
+ p {
97
+ margin: 16px 0;
98
+ }
99
+
100
+ // inline code
101
+ *:not(pre) code {
102
+ padding: 2px 5px;
103
+ color: #d56161;
104
+ background: darken(@c-light-bg, 1%);
105
+
106
+ [data-prefers-color=dark] & {
107
+ color: #ff7875;
108
+ background: @c-light-bg-dark;
109
+ }
110
+ }
111
+
112
+ code {
113
+ font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace;
114
+ }
115
+
116
+ // code block
117
+ pre {
118
+ font-size: 14px;
119
+ background: darken(@c-light-bg, 1%);
120
+
121
+ &:not([class^='language-']) {
122
+ padding: 1em;
123
+ }
124
+ }
125
+
126
+ // horizontal line
127
+ hr {
128
+ margin: 16px 0;
129
+ border: 0;
130
+ border-top: 1px solid @c-border;
131
+ }
132
+
133
+ // blockquote
134
+ blockquote {
135
+ margin: 16px 0;
136
+ padding: 0 24px;
137
+ color: fadeout(@c-text, 30%);
138
+ border-left: 4px solid @c-border;
139
+ overflow: hidden;
140
+
141
+ [data-prefers-color=dark] & {
142
+ color: fadeout(@c-text-dark, 30%);
143
+ border-color: @c-border-dark;
144
+ }
145
+ }
146
+
147
+ // list
148
+ ul,
149
+ ol {
150
+ margin: 8px 0 8px 32px;
151
+ padding: 0;
152
+
153
+ li {
154
+ margin-bottom: 4px;
155
+ }
156
+ }
157
+
158
+ // table
159
+ table {
160
+ width: 100%;
161
+ border-collapse: collapse;
162
+ border: 1px solid @c-border;
163
+
164
+ [data-prefers-color=dark] & {
165
+ border: 1px solid #3b434b;
166
+ }
167
+
168
+ th,
169
+ td {
170
+ padding: 10px 24px;
171
+ border: 1px solid @c-border;
172
+
173
+ [data-prefers-color=dark] & {
174
+ border: 1px solid #3b434b;
175
+ }
176
+ }
177
+
178
+ th {
179
+ font-weight: 600;
180
+ background: @c-light-bg;
181
+
182
+ [data-prefers-color=dark] & {
183
+ background: @c-light-bg-dark;
184
+ }
185
+ }
186
+
187
+ td:first-child {
188
+ font-weight: 500;
189
+ }
190
+
191
+ a {
192
+ svg {
193
+ display: none;
194
+ }
195
+ }
196
+ }
197
+
198
+ // links
199
+ a {
200
+ color: @c-link;
201
+ text-decoration: none;
202
+ transition: opacity 0.2s;
203
+ outline: none;
204
+
205
+ [data-prefers-color=dark] & {
206
+ color: @c-primary-dark;
207
+ }
208
+
209
+ &:hover {
210
+ opacity: 0.7;
211
+ text-decoration: underline;
212
+ }
213
+
214
+ &:active {
215
+ opacity: 0.9;
216
+ }
217
+ }
218
+
219
+ // images
220
+ img {
221
+ max-width: 100%;
222
+ }
223
+ }
224
+
225
+ .@{prefix} {
226
+ &-external-link-icon {
227
+ vertical-align: -0.155em;
228
+ margin-left: 2px;
229
+ }
230
+ }
231
+
232
+ // For demo
233
+ [data-prefers-color=dark] {
234
+ h1,
235
+ h2,
236
+ h3,
237
+ h4 {
238
+ color: @c-heading-dark;
239
+ }
240
+ }
@@ -0,0 +1,37 @@
1
+ /* 颜色表 */
2
+ @c-primary: #4569d4;
3
+ @c-heading: #454d64;
4
+ @c-text: #454d64;
5
+ @c-secondary: #717484;
6
+ @c-link: @c-primary;
7
+ @c-border: #ebedf1;
8
+ @c-btn-border: #dadadf;
9
+ @c-light-bg: #f9fafb;
10
+
11
+ /* 尺寸表 */
12
+ @s-nav-height: 64px;
13
+ @s-mobile-nav-height: 50px;
14
+ @s-menu-width: 260px;
15
+ @s-site-menu-width: 300px;
16
+ @s-menu-mobile-width: 240px;
17
+ @s-content-margin: 58px;
18
+
19
+ @img-logo: '';
20
+ @prefix: __dumi-default;
21
+ @mobile: ~'only screen and (max-width: 767px)';
22
+ @desktop: ~'only screen and (min-width: 768px)';
23
+ @icons: '';
24
+
25
+ .@{prefix}-icon {
26
+ background: url(@icons) no-repeat ~'0 0/230px auto';
27
+ }
28
+
29
+ /* 颜色表 - dark */
30
+ @c-bg-dark: #141414;
31
+ @c-light-bg-dark: rgba(255,255,255,0.08);
32
+ @c-primary-dark: #7395f7;
33
+ @c-heading-dark: rgba(255, 255, 255, 0.85);
34
+ @c-text-dark: rgba(255, 255, 255, 0.85);
35
+ @c-secondary-dark: rgba(255,255,255,0.65);
36
+ @c-border-dark: #6b6c6d;
37
+ @c-btn-border-dark: #464646;
@@ -0,0 +1,32 @@
1
+ import '@testing-library/jest-dom';
2
+
3
+ import { highlight } from '../components/SearchBar';
4
+
5
+ describe('test highlight', () => {
6
+ it('should render right', () => {
7
+ const element1 = highlight('1', '1234').props.children;
8
+ expect(element1[0]).toEqual('');
9
+ expect(element1[1].props).toEqual({ className: '__dumi-default-search-highlight', children: '1' });
10
+ expect(element1[2]).toEqual('234');
11
+
12
+ const element2 = highlight('2', '1234').props.children;
13
+ expect(element2[0]).toEqual('1');
14
+ expect(element2[1].props).toEqual({ className: '__dumi-default-search-highlight', children: '2' });
15
+ expect(element2[2]).toEqual('34');
16
+
17
+ const element3 = highlight('23', '1234').props.children;
18
+ expect(element3[0]).toEqual('1');
19
+ expect(element3[1].props).toEqual({ className: '__dumi-default-search-highlight', children: '23' });
20
+ expect(element3[2]).toEqual('4');
21
+
22
+ const element4 = highlight('34', '1234').props.children;
23
+ expect(element4[0]).toEqual('12');
24
+ expect(element4[1].props).toEqual({ className: '__dumi-default-search-highlight', children: '34' });
25
+ expect(element4[2]).toEqual('');
26
+
27
+ const element5 = highlight('1234', '1234').props.children;
28
+ expect(element5[0]).toEqual('');
29
+ expect(element5[1].props).toEqual({ className: '__dumi-default-search-highlight', children: '1234' });
30
+ expect(element5[2]).toEqual('');
31
+ });
32
+ });
@@ -0,0 +1,41 @@
1
+ import '@testing-library/jest-dom';
2
+ import { render, fireEvent, act } from '@testing-library/react';
3
+ import Table from '../builtins/Table';
4
+ import React from 'react';
5
+
6
+ describe('test Table', () => {
7
+ it('should render folded shadows', async () => {
8
+ const text = 'Cell';
9
+ const { container, queryByText } = render(
10
+ <Table>
11
+ <tbody>
12
+ <tr>
13
+ <td>{text}</td>
14
+ </tr>
15
+ </tbody>
16
+ </Table>,
17
+ );
18
+
19
+ // mock offset & scroll value
20
+ const content = container.querySelector('.__dumi-default-table-content');
21
+
22
+ Object.defineProperties(content, {
23
+ offsetWidth: { get: () => 100 },
24
+ scrollLeft: { get: () => 10 },
25
+ scrollWidth: { get: () => 120 },
26
+ });
27
+
28
+ // trigger scroll event to re-render
29
+ fireEvent(content, new Event('scroll'));
30
+
31
+ // wait for throttle
32
+ await act(() => new Promise(resolve => setTimeout(resolve, 200)));
33
+
34
+ // expect content be rendered
35
+ expect(queryByText(text)).not.toBeNull();
36
+
37
+ // expect folded shadows be rendered
38
+ expect(content.hasAttribute('data-left-folded')).toBeTruthy();
39
+ expect(content.hasAttribute('data-right-folded')).toBeTruthy();
40
+ });
41
+ });