@antv/dumi-theme-antv 0.4.5 → 0.5.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 (40) hide show
  1. package/dist/layouts/DocLayout.d.ts +2 -1
  2. package/dist/layouts/entry/Index.js +2 -2
  3. package/dist/locales/en.json +13 -7
  4. package/dist/locales/zh.json +9 -3
  5. package/dist/model/index.d.ts +5 -0
  6. package/dist/model/index.js +6 -0
  7. package/dist/pages/Example/components/CollapsedIcon/index.d.ts +8 -0
  8. package/dist/pages/Example/components/CollapsedIcon/index.js +15 -0
  9. package/dist/pages/Example/components/CollapsedIcon/index.module.less +14 -0
  10. package/dist/pages/Example/index.js +28 -11
  11. package/dist/pages/Examples/components/Accouncement/index.js +2 -2
  12. package/dist/pages/Examples/components/GalleryPageContent/index.js +2 -2
  13. package/dist/plugin/api.d.ts +7 -0
  14. package/dist/plugin/api.js +82 -0
  15. package/dist/plugin/examples.d.ts +1 -1
  16. package/dist/plugin/examples.js +28 -21
  17. package/dist/plugin/index.js +2 -1
  18. package/dist/slots/API/index.d.ts +15 -0
  19. package/dist/slots/API/index.js +202 -0
  20. package/dist/slots/API/index.module.less +93 -0
  21. package/dist/slots/Banner/index.js +2 -2
  22. package/dist/slots/CodeEditor/Toolbar.js +2 -2
  23. package/dist/slots/CodeEditor/utils.js +7 -9
  24. package/dist/slots/CodeRunner/utils.js +4 -3
  25. package/dist/slots/Detail/News.d.ts +2 -0
  26. package/dist/slots/Detail/News.js +9 -2
  27. package/dist/slots/Detail/News.module.less +47 -18
  28. package/dist/slots/Detail/index.js +4 -6
  29. package/dist/slots/Detail/index.module.less +11 -4
  30. package/dist/slots/ExampleSider/index.js +2 -3
  31. package/dist/slots/Footer/index.js +24 -11
  32. package/dist/slots/Header/Navs.js +7 -3
  33. package/dist/slots/Header/Products/getProducts.js +2 -2
  34. package/dist/slots/Header/Products/index.js +2 -2
  35. package/dist/slots/Header/index.d.ts +9 -0
  36. package/dist/slots/Header/index.js +70 -68
  37. package/dist/slots/Header/index.module.less +17 -0
  38. package/dist/slots/ManualContent/index.js +10 -4
  39. package/dist/slots/ManualContent/index.module.less +39 -18
  40. package/package.json +36 -32
@@ -0,0 +1,202 @@
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
3
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
4
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
5
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
6
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
7
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
8
+ import { ZoomInOutlined, ZoomOutOutlined } from '@ant-design/icons';
9
+ import { Collapse, Popover } from 'antd';
10
+ import { get, uniq, sortBy } from 'lodash-es';
11
+ import React from 'react';
12
+ import Markdown from 'react-markdown';
13
+ import remarkGfm from 'remark-gfm';
14
+ import rehypeRaw from 'rehype-raw';
15
+ import { useSnapshot } from 'valtio';
16
+ import { store } from "../../model";
17
+ import { CollapsedIcon } from "../../pages/Example/components/CollapsedIcon";
18
+ import { getDemoInfo } from "../CodeRunner/utils";
19
+ import styles from "./index.module.less";
20
+ var Panel = Collapse.Panel;
21
+ var EMPTY = /^\s*$/;
22
+ /**
23
+ * API 预览
24
+ */
25
+ export var API = function API(_ref) {
26
+ var exampleTopics = _ref.exampleTopics,
27
+ topic = _ref.topic,
28
+ example = _ref.example,
29
+ demo = _ref.demo,
30
+ _ref$language = _ref.language,
31
+ language = _ref$language === void 0 ? 'zh' : _ref$language;
32
+ var state = useSnapshot(store);
33
+ var demoInfo = getDemoInfo(exampleTopics, topic, example, demo);
34
+ var APIContent = get(demoInfo, ['api', language]);
35
+
36
+ /** 从 MD 中解析出层级数据(eg: #、##、###)作为折叠分组条件 */
37
+ var findHashTag = function findHashTag(lines) {
38
+ var tagLines = lines.filter(function (line) {
39
+ return line.startsWith('#');
40
+ });
41
+ var tagReg = /^#+/g;
42
+ var tagLengths = tagLines.map(function (line) {
43
+ return line.match(tagReg)[0].length;
44
+ });
45
+ return sortBy(uniq(tagLengths));
46
+ };
47
+ var getRegex = function getRegex(tagLength) {
48
+ return new RegExp("^".concat(new Array(tagLength).fill('#').join(''), "\\s+([^\\n]*)"));
49
+ };
50
+
51
+ /** 根据正则将内容切片 */
52
+ var setIndexTag = function setIndexTag(lines, regex) {
53
+ var start = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0;
54
+ var result = [];
55
+ lines.forEach(function (line, index) {
56
+ if (regex.exec(line)) {
57
+ var header = regex.exec(line)[1];
58
+ result.push({
59
+ header: header,
60
+ start: index + start,
61
+ maxEndIndex: start + lines.length
62
+ });
63
+ }
64
+ });
65
+ return result;
66
+ };
67
+
68
+ /** 从 MD 中解析出嵌套结构, 最多支持 2 层 */
69
+ var getNestedDOM = function getNestedDOM(lines) {
70
+ var tags = findHashTag(lines);
71
+ var result = setIndexTag(lines, getRegex(tags[0]));
72
+ if (tags.length > 2) {
73
+ result = result.map(function (item, index) {
74
+ var _result;
75
+ var start = item.start;
76
+ return _objectSpread(_objectSpread({}, item), {}, {
77
+ children: setIndexTag(lines.slice(start + 1, (_result = result[index + 1]) === null || _result === void 0 ? void 0 : _result.start), getRegex(tags[1]), start + 1)
78
+ });
79
+ });
80
+ }
81
+ return result;
82
+ };
83
+ var MarkdownComponent = function MarkdownComponent(_ref2) {
84
+ var content = _ref2.content;
85
+ return /*#__PURE__*/React.createElement(Markdown, {
86
+ rehypePlugins: [rehypeRaw, remarkGfm],
87
+ components: {
88
+ // @ts-expect-error
89
+ description: function description(props) {
90
+ return /*#__PURE__*/React.createElement("span", _extends({
91
+ style: {
92
+ fontSize: 12,
93
+ color: '#777'
94
+ }
95
+ }, props));
96
+ }
97
+ }
98
+ }, content);
99
+ };
100
+
101
+ /** 将扁平状态的 MD 解析为嵌套结构 */
102
+ var renderNestedDom = function renderNestedDom(content) {
103
+ var _result$;
104
+ if (!content) {
105
+ return null;
106
+ }
107
+ var lines = content.split('\n');
108
+ var result = getNestedDOM(lines);
109
+
110
+ /** 避免无标题的情况内容丢失,内层嵌套的不做处理(不合理) */
111
+ var minStart = get(result, [0, 'start']);
112
+ return /*#__PURE__*/React.createElement(React.Fragment, null, minStart > 0 && /*#__PURE__*/React.createElement("div", {
113
+ className: styles.disorganized
114
+ }, /*#__PURE__*/React.createElement(MarkdownComponent, {
115
+ content: lines.slice(0, minStart).join('\n')
116
+ })), /*#__PURE__*/React.createElement(Collapse, {
117
+ bordered: false,
118
+ defaultActiveKey: [(_result$ = result[0]) === null || _result$ === void 0 ? void 0 : _result$.header],
119
+ ghost: true
120
+ }, result.map(function (item, index) {
121
+ var _children$;
122
+ var start = item.start,
123
+ header = item.header,
124
+ _item$children = item.children,
125
+ children = _item$children === void 0 ? [] : _item$children;
126
+ var end = index === result.length - 1 ? lines.length : result[index + 1].start;
127
+ return /*#__PURE__*/React.createElement(Panel, {
128
+ header: /*#__PURE__*/React.createElement("b", {
129
+ style: {
130
+ lineHeight: '22px',
131
+ fontSize: 16
132
+ }
133
+ }, header),
134
+ key: header
135
+ }, children.length > 0 ? /*#__PURE__*/React.createElement(Collapse, {
136
+ bordered: false,
137
+ defaultActiveKey: [(_children$ = children[0]) === null || _children$ === void 0 ? void 0 : _children$.header],
138
+ ghost: true
139
+ }, children.map(function (nestedItem, nestedIndex) {
140
+ var nestedStart = nestedItem.start,
141
+ nestedHeader = nestedItem.header,
142
+ maxEndIndex = nestedItem.maxEndIndex;
143
+ var nestEnd = nestedIndex === children.length - 1 ? maxEndIndex : children[nestedIndex + 1].start;
144
+ return /*#__PURE__*/React.createElement(Panel, {
145
+ header: /*#__PURE__*/React.createElement("b", {
146
+ style: {
147
+ lineHeight: '22px',
148
+ fontSize: 14
149
+ }
150
+ }, nestedHeader),
151
+ key: nestedHeader
152
+ }, /*#__PURE__*/React.createElement(MarkdownComponent, {
153
+ content: lines.slice(nestedStart + 1, nestEnd).join('\n')
154
+ }));
155
+ })) : /*#__PURE__*/React.createElement(MarkdownComponent, {
156
+ content: lines.slice(start + 1, end).join('\n')
157
+ }));
158
+ })));
159
+ };
160
+ return /*#__PURE__*/React.createElement("div", {
161
+ className: styles.api,
162
+ style: {
163
+ width: state.showAPI ? state.apiContainerWidth : 24
164
+ }
165
+ }, /*#__PURE__*/React.createElement("div", {
166
+ className: styles.header
167
+ }, /*#__PURE__*/React.createElement("p", null, "API"), /*#__PURE__*/React.createElement("div", {
168
+ className: styles.zoom
169
+ }, /*#__PURE__*/React.createElement(ZoomInOutlined, {
170
+ onClick: function onClick() {
171
+ store.apiContainerWidth += 100;
172
+ }
173
+ }), /*#__PURE__*/React.createElement(ZoomOutOutlined, {
174
+ style: {
175
+ marginLeft: 8
176
+ },
177
+ onClick: function onClick() {
178
+ if (state.apiContainerWidth > 150) {
179
+ store.apiContainerWidth -= 100;
180
+ }
181
+ }
182
+ })), /*#__PURE__*/React.createElement(Popover, {
183
+ content: language === 'zh' ? '展示文档' : 'Show docs',
184
+ placement: "right"
185
+ }, /*#__PURE__*/React.createElement(CollapsedIcon, {
186
+ isCollapsed: state.showAPI,
187
+ onClick: function onClick(show) {
188
+ store.showAPI = show;
189
+ },
190
+ style: {
191
+ left: 0,
192
+ top: 0
193
+ }
194
+ }))), /*#__PURE__*/React.createElement("div", {
195
+ className: styles.content
196
+ }, !EMPTY.test(APIContent) ? renderNestedDom(APIContent) : /*#__PURE__*/React.createElement("div", {
197
+ style: {
198
+ textAlign: 'center',
199
+ padding: 12
200
+ }
201
+ }, /*#__PURE__*/React.createElement("h1", null, "404"), /*#__PURE__*/React.createElement("p", null, "Sorry, the API you visited does not exist."))));
202
+ };
@@ -0,0 +1,93 @@
1
+ .api {
2
+ height: 100%;
3
+ color: rgba(0,0,0, 85%);
4
+
5
+ .header {
6
+ position: relative;
7
+ height: 36px;
8
+ background-color: #f8f9fc;
9
+ display: flex;
10
+ justify-content: space-between;
11
+ overflow: hidden;
12
+ padding-right: 12px;
13
+ padding-left: 36px;
14
+ color: #777;
15
+ line-height: 36px;
16
+ }
17
+
18
+ .content {
19
+ overflow: hidden;
20
+ border-left: 1px solid #ececec;
21
+ height: calc(100% - 36px);
22
+ overflow-y: scroll;
23
+
24
+ .disorganized {
25
+ padding: 0 12px;
26
+
27
+ > :first-child {
28
+ margin-top: 12px;
29
+ }
30
+ }
31
+
32
+ > hr {
33
+ display: none;
34
+ }
35
+
36
+ p {
37
+ margin-bottom: 0;
38
+ }
39
+
40
+ h1, h2, h3, h4, h5, h6 {
41
+ font-weight: 400;
42
+ margin-bottom: 0;
43
+ margin-top: 8px;
44
+ color: rgba(0,0,0, 85%);
45
+ border-top: 1px solid #F8F9FC;
46
+
47
+ &:first-child {
48
+ margin-top: 0;
49
+ border-top: none;
50
+ }
51
+ }
52
+
53
+ .border() {
54
+ border-width: 1px;
55
+ border-color: #ececec
56
+ }
57
+
58
+ table {
59
+ .border();
60
+
61
+ border-right-style: solid;
62
+ border-top-style: solid;
63
+ margin-bottom: 6px;
64
+ }
65
+
66
+ td, th {
67
+ .border();
68
+
69
+ text-align: left;
70
+ border-left-style: solid;
71
+ border-bottom-style: solid;
72
+ padding: 4px;
73
+ }
74
+ }
75
+
76
+ img {
77
+ max-width: 100%;
78
+ }
79
+
80
+ :global {
81
+ .ant-collapse-ghost > .ant-collapse-item > .ant-collapse-content > .ant-collapse-content-box {
82
+ padding: 0 4px 0 24px;
83
+ }
84
+
85
+ .ant-collapse > .ant-collapse-item > .ant-collapse-header {
86
+ padding: 8px;
87
+
88
+ .ant-collapse-arrow {
89
+ margin-right: 6px;
90
+ }
91
+ }
92
+ }
93
+ }
@@ -2,8 +2,8 @@ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" ==
2
2
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
3
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
4
4
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
6
- function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
5
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
6
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
7
  function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
8
8
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
9
9
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
@@ -7,8 +7,8 @@ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
7
7
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
8
8
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
9
9
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
10
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
11
- function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
10
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
11
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
12
12
  function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
13
13
  import { CodeSandboxOutlined, PlayCircleOutlined, ThunderboltOutlined } from '@ant-design/icons';
14
14
  import stackblitzSdk from '@stackblitz/sdk';
@@ -2,8 +2,8 @@ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" ==
2
2
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
3
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
4
4
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
6
- function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
5
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
6
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
7
  function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
8
8
  function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
9
9
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
@@ -43,9 +43,8 @@ export function extractImportDeps(sourceCode) {
43
43
  return deps;
44
44
  }
45
45
  export function getCodeSandboxConfig(title, sourceCode, fileExtension, deps, devDependencies, playground) {
46
- var _files;
47
46
  return {
48
- files: (_files = {
47
+ files: _defineProperty(_defineProperty({
49
48
  'package.json': {
50
49
  content: {
51
50
  main: "index.".concat(fileExtension),
@@ -53,11 +52,11 @@ export function getCodeSandboxConfig(title, sourceCode, fileExtension, deps, dev
53
52
  devDependencies: devDependencies
54
53
  }
55
54
  }
56
- }, _defineProperty(_files, "index.".concat(fileExtension), {
55
+ }, "index.".concat(fileExtension), {
57
56
  content: replaceFetchUrl(sourceCode)
58
- }), _defineProperty(_files, 'index.html', {
57
+ }), 'index.html', {
59
58
  content: playground.container || '<div id="container" />'
60
- }), _files)
59
+ })
61
60
  };
62
61
  }
63
62
  export function getRiddleConfig(title, sourceCode, fileExtension, deps, devDependencies, playground) {
@@ -73,13 +72,12 @@ export function getRiddleConfig(title, sourceCode, fileExtension, deps, devDepen
73
72
  };
74
73
  }
75
74
  export function getStackblitzConfig(title, sourceCode, fileExtension, deps, devDependencies, playground) {
76
- var _files2;
77
75
  return {
78
76
  title: title || '',
79
77
  description: '',
80
78
  template: 'create-react-app',
81
79
  dependencies: deps,
82
- files: (_files2 = {}, _defineProperty(_files2, "index.".concat(fileExtension.startsWith('ts') ? 'ts' : 'js'), sourceCode), _defineProperty(_files2, 'index.html', playground.container || '<div id="container" />'), _files2)
80
+ files: _defineProperty(_defineProperty({}, "index.".concat(fileExtension.startsWith('ts') ? 'ts' : 'js'), sourceCode), 'index.html', playground.container || '<div id="container" />')
83
81
  };
84
82
  }
85
83
  export function getHtmlCodeTemplate(title, sourceCode, fileExtension, deps, devDependencies, playground) {
@@ -2,8 +2,8 @@ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" ==
2
2
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
3
3
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
4
4
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
5
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
6
- function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
5
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
6
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
7
7
  import { map } from 'lodash-es';
8
8
  /**
9
9
  * 将数据结构转化成 map,便于后续检索的速度
@@ -18,7 +18,8 @@ export function getExampleTopicMap(exampleTopics) {
18
18
  exampleTopicMap.set("".concat(topic.id, "-").concat(example.id, "-").concat(demo.id), _objectSpread(_objectSpread({}, demo), {}, {
19
19
  relativePath: "".concat(topic.id, "/").concat(example.id, "/demo/").concat(demo.filename),
20
20
  targetExample: example,
21
- targetTopic: topic
21
+ targetTopic: topic,
22
+ api: example.api
22
23
  }));
23
24
  });
24
25
  });
@@ -6,5 +6,7 @@ export interface NewsProps {
6
6
  title: IC;
7
7
  date: string;
8
8
  link: string;
9
+ subTitle?: string;
10
+ img?: string;
9
11
  }
10
12
  export declare const News: React.FC<NewsProps>;
@@ -9,6 +9,8 @@ export var News = function News(_ref) {
9
9
  type = _ref.type,
10
10
  title = _ref.title,
11
11
  date = _ref.date,
12
+ subTitle = _ref.subTitle,
13
+ img = _ref.img,
12
14
  _ref$link = _ref.link,
13
15
  link = _ref$link === void 0 ? '' : _ref$link;
14
16
  var lang = useLocale().id;
@@ -18,9 +20,14 @@ export var News = function News(_ref) {
18
20
  className: styles.content
19
21
  }, /*#__PURE__*/React.createElement("p", {
20
22
  className: styles.description
21
- }, ic(type), " \u2027 ", ic(title)), /*#__PURE__*/React.createElement("p", {
23
+ }, img && /*#__PURE__*/React.createElement("img", {
24
+ src: img,
25
+ alt: "message_title"
26
+ }), type ? "".concat(ic(type), " \u2027 ") : '', ic(title)), date && /*#__PURE__*/React.createElement("p", {
22
27
  className: styles.date
23
- }, date)));
28
+ }, date), subTitle && /*#__PURE__*/React.createElement("p", {
29
+ className: styles.subTitle
30
+ }, ic(subTitle))));
24
31
  if (link.startsWith('http')) {
25
32
  return /*#__PURE__*/React.createElement("a", {
26
33
  href: link,
@@ -32,14 +32,24 @@
32
32
  font-weight: 500;
33
33
  font-size: 20px;
34
34
  text-align: center;
35
+ position: relative;
36
+
37
+ >img {
38
+ width: 24px;
39
+ height: 24px;
40
+ position: relative;
41
+ top: -2px;
42
+ left: -4px;
43
+ }
35
44
  }
36
45
 
37
- .date {
46
+ .date,.subTitle {
38
47
  color: #424E66;
39
48
  bottom: 0;
40
49
  font-size: 1em;
41
50
  margin-top: 4px;
42
51
  margin-bottom: 0;
52
+ text-align: center;
43
53
  }
44
54
  }
45
55
  }
@@ -55,12 +65,17 @@
55
65
  width: 100%;
56
66
 
57
67
  &:nth-child(1) {
58
- animation: showAndHide0 6s infinite;
68
+ animation: showAndHide0 9s infinite;
59
69
  }
60
70
 
61
71
  &:nth-child(2) {
62
72
  top: 44px;
63
- animation: showAndHide1 6s infinite;
73
+ animation: showAndHide1 9s infinite;
74
+ }
75
+
76
+ &:nth-child(3) {
77
+ top: 44px;
78
+ animation: showAndHide2 9s infinite;
64
79
  }
65
80
  }
66
81
  }
@@ -79,18 +94,12 @@
79
94
  }
80
95
 
81
96
  33.3% {
82
- opacity: 1;
83
- top: 0px;
84
- z-index: 1;
85
- }
86
-
87
- 50% {
88
97
  opacity: 0;
89
- top: -30px;
98
+ top: 0px;
90
99
  z-index: 0;
91
100
  }
92
101
 
93
- 83.3% {
102
+ 66.6% {
94
103
  opacity: 0;
95
104
  top: 30px;
96
105
  z-index: 0;
@@ -103,7 +112,6 @@
103
112
  }
104
113
  }
105
114
 
106
- /* Standard syntax */
107
115
  @keyframes showAndHide1 {
108
116
  0% {
109
117
  opacity: 0;
@@ -112,18 +120,38 @@
112
120
  }
113
121
 
114
122
  33.3% {
123
+ opacity: 1;
124
+ top: 0px;
125
+ z-index: 1;
126
+ }
127
+
128
+ 66.6% {
129
+ opacity: 0;
130
+ top: 0px;
131
+ z-index: 0;
132
+ }
133
+
134
+ 100% {
115
135
  opacity: 0;
116
136
  top: 30px;
117
137
  z-index: 0;
118
138
  }
139
+ }
119
140
 
120
- 50% {
121
- opacity: 1;
122
- top: 0px;
123
- z-index: 1;
141
+ @keyframes showAndHide2 {
142
+ 0% {
143
+ opacity: 0;
144
+ top: 30px;
145
+ z-index: 0;
124
146
  }
125
147
 
126
- 83.3% {
148
+ 33.3% {
149
+ opacity: 0;
150
+ top: 30px;
151
+ z-index: 0;
152
+ }
153
+
154
+ 66.6% {
127
155
  opacity: 1;
128
156
  top: 0px;
129
157
  z-index: 1;
@@ -131,7 +159,8 @@
131
159
 
132
160
  100% {
133
161
  opacity: 0;
134
- top: -30px;
162
+ top: 0px;
135
163
  z-index: 0;
136
164
  }
137
165
  }
166
+
@@ -4,8 +4,8 @@ function _extends() { _extends = Object.assign ? Object.assign.bind() : function
4
4
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
5
5
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
6
6
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
7
- function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
8
- function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
7
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : String(i); }
8
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
9
9
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
10
10
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
11
11
  function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
@@ -22,8 +22,6 @@ import { useLocale } from 'dumi/dist/client/theme-api';
22
22
  import { ic } from "../hooks";
23
23
  import { News } from "./News";
24
24
  import styles from "./index.module.less";
25
- var AssetsNewsURL = 'https://assets.antv.antgroup.com/antv/news.json';
26
-
27
25
  /**
28
26
  * Index.技术栈的描述区域!
29
27
  * 各自配置
@@ -49,7 +47,7 @@ export var Detail = function Detail(_ref) {
49
47
  setRemoteNews = _useState2[1];
50
48
  var lang = useLocale().id;
51
49
  useEffect(function () {
52
- fetch(AssetsNewsURL).then(function (res) {
50
+ fetch('https://site-data-pre.alipay.com/antv/banner-messages.json').then(function (res) {
53
51
  return res.json();
54
52
  }).then(function (data) {
55
53
  setRemoteNews(data);
@@ -107,7 +105,7 @@ export var Detail = function Detail(_ref) {
107
105
  repo: githubObj.name
108
106
  })))), /*#__PURE__*/React.createElement("div", {
109
107
  className: cx(styles.news, 'news')
110
- }, (news || remoteNews).slice(0, 2).map(function (n, i) {
108
+ }, (news || remoteNews).slice(0, 3).map(function (n, i) {
111
109
  return /*#__PURE__*/React.createElement(News, _extends({
112
110
  key: i,
113
111
  index: i
@@ -66,11 +66,17 @@
66
66
  font-family: AlibabaPuHuiTiR;
67
67
  font-size: 18px;
68
68
  color: #424E66;
69
+ max-height: 145px;
70
+ overflow: hidden;
71
+ text-overflow: ellipsis;
72
+ -webkit-line-clamp: 4;
73
+ display: -webkit-box;
74
+ -webkit-box-orient: vertical;
69
75
  }
70
76
 
71
77
  .buttons {
72
78
  display: flex;
73
- margin-top: 5.56%;
79
+ margin-top: max(3%, 40px);
74
80
 
75
81
  .buttonLink {
76
82
  display: flex;
@@ -83,7 +89,8 @@
83
89
  transition: all 0.3s;
84
90
  text-align: center;
85
91
  height: 54px;
86
- width: 166px;
92
+ min-width: 166px;
93
+ padding: 0 10px;
87
94
  box-shadow: 0 8px 28px 0 rgba(0, 0, 0, 0.10);
88
95
  background-color: #691EFF;
89
96
  font-size: 18px;
@@ -194,10 +201,10 @@
194
201
  .news {
195
202
  width: 100%;
196
203
  display: flex;
197
- bottom: 40px;
204
+ bottom: 30px;
198
205
  position: absolute;
199
206
  z-index: 3;
200
- height: 108px;
207
+ height: 128px;
201
208
  box-sizing: border-box;
202
209
  padding: 0 4.5%;
203
210
  }