cfel-base-components 2.5.49 → 2.5.50
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.
- package/package.json +1 -1
- package/src/components/layout/index.tsx +89 -171
package/package.json
CHANGED
|
@@ -64,7 +64,7 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
64
64
|
isHideHeader,
|
|
65
65
|
onCollapse,
|
|
66
66
|
type,
|
|
67
|
-
umiHistory
|
|
67
|
+
umiHistory,
|
|
68
68
|
} = props
|
|
69
69
|
|
|
70
70
|
const findKeyPath = (pathname: string) => {
|
|
@@ -88,9 +88,7 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
88
88
|
}
|
|
89
89
|
|
|
90
90
|
// 初始化选中菜单
|
|
91
|
-
const [selectKey, setSelectKey] = useState<any>(
|
|
92
|
-
findKeyPath('/' + location.pathname.split('/')[2])
|
|
93
|
-
)
|
|
91
|
+
const [selectKey, setSelectKey] = useState<any>(findKeyPath('/' + location.pathname.split('/')[2]))
|
|
94
92
|
|
|
95
93
|
const [infoOpen, setInfoOpen] = useState<string | null>(null)
|
|
96
94
|
|
|
@@ -135,7 +133,7 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
135
133
|
//在这里找到当前菜单的上层目录
|
|
136
134
|
const paMenu = findParentMenu(menuList, '/' + location.pathname.split('/')[2])
|
|
137
135
|
//去重
|
|
138
|
-
const set = new Set(paMenu.map(item => item.key))
|
|
136
|
+
const set = new Set(paMenu.map((item) => item.key))
|
|
139
137
|
openKeys.forEach((element: string) => {
|
|
140
138
|
set.add(element)
|
|
141
139
|
})
|
|
@@ -148,10 +146,10 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
148
146
|
account: false,
|
|
149
147
|
id: false,
|
|
150
148
|
tenantName: false,
|
|
151
|
-
tenantId: false
|
|
149
|
+
tenantId: false,
|
|
152
150
|
})
|
|
153
151
|
|
|
154
|
-
const onOpenChange: MenuProps['onOpenChange'] = keys => {
|
|
152
|
+
const onOpenChange: MenuProps['onOpenChange'] = (keys) => {
|
|
155
153
|
setOpenKeys(keys)
|
|
156
154
|
}
|
|
157
155
|
|
|
@@ -165,7 +163,7 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
165
163
|
// 菜单动画
|
|
166
164
|
const collapseNode = () => {
|
|
167
165
|
return {
|
|
168
|
-
height: 0
|
|
166
|
+
height: 0,
|
|
169
167
|
}
|
|
170
168
|
}
|
|
171
169
|
const expandNode = (node: any) => {
|
|
@@ -179,26 +177,26 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
179
177
|
onEnterStart: collapseNode,
|
|
180
178
|
onEnterActive: expandNode,
|
|
181
179
|
onLeaveStart: expandNode,
|
|
182
|
-
onLeaveActive: collapseNode
|
|
180
|
+
onLeaveActive: collapseNode,
|
|
183
181
|
}
|
|
184
182
|
|
|
185
183
|
const verticalMotion = {
|
|
186
184
|
motionName: 'rc-menu-open-zoom',
|
|
187
185
|
motionAppear: true,
|
|
188
186
|
motionEnter: true,
|
|
189
|
-
motionLeave: true
|
|
187
|
+
motionLeave: true,
|
|
190
188
|
}
|
|
191
189
|
|
|
192
190
|
return (
|
|
193
|
-
<Layout className=
|
|
191
|
+
<Layout className="layout-warps">
|
|
194
192
|
{Array.isArray(menuList) && menuList.length > 0 && (
|
|
195
193
|
<Sider
|
|
196
|
-
className=
|
|
194
|
+
className="layout-side"
|
|
197
195
|
collapsible
|
|
198
196
|
trigger={null}
|
|
199
197
|
collapsed={collapsed}
|
|
200
198
|
width={260}
|
|
201
|
-
onCollapse={value => {
|
|
199
|
+
onCollapse={(value) => {
|
|
202
200
|
if (onCollapse) {
|
|
203
201
|
onCollapse(value)
|
|
204
202
|
}
|
|
@@ -206,21 +204,21 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
206
204
|
setCollapsed(value)
|
|
207
205
|
}}
|
|
208
206
|
>
|
|
209
|
-
<div className=
|
|
210
|
-
|
|
211
|
-
<div
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
207
|
+
<div className="layout-side-mask1"></div>
|
|
208
|
+
|
|
209
|
+
<div className="header-logo" style={{ justifyContent: collapsed ? 'center' : '', paddingLeft: collapsed ? '0' : '' }}>
|
|
210
|
+
{!collapsed && (
|
|
211
|
+
<img
|
|
212
|
+
style={{ zIndex: 99 }}
|
|
213
|
+
onClick={() => {
|
|
214
|
+
window.open('/home')
|
|
215
|
+
}}
|
|
216
|
+
className={`logo-base current-logo`}
|
|
217
|
+
src={logo || logoUrl}
|
|
218
|
+
/>
|
|
219
|
+
)}
|
|
220
|
+
{collapsed && <img className={`logo-sub`} src={subLogoUrl} />}
|
|
221
|
+
{/* {collapsed && <img className={`logo-base sub-logo`} src={logo || subLogoUrl} />} */}
|
|
224
222
|
|
|
225
223
|
{/* {!collapsed && (
|
|
226
224
|
<div
|
|
@@ -237,7 +235,7 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
237
235
|
{collapsed && (
|
|
238
236
|
<div style={{ width: '100%', display: 'flex', justifyContent: 'center' }}>
|
|
239
237
|
<div
|
|
240
|
-
className=
|
|
238
|
+
className="close-trigger"
|
|
241
239
|
onClick={() => {
|
|
242
240
|
setCollapsed(false)
|
|
243
241
|
}}
|
|
@@ -250,19 +248,12 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
250
248
|
<div style={{ height: 24 }}></div>
|
|
251
249
|
|
|
252
250
|
<div style={{ width: '100%', padding: '0 16px' }}>
|
|
253
|
-
<Search
|
|
254
|
-
menuList={menuList}
|
|
255
|
-
collapsed={collapsed}
|
|
256
|
-
type={type || ''}
|
|
257
|
-
umiHistory={umiHistory}
|
|
258
|
-
setSelectKey={setSelectKey}
|
|
259
|
-
findKeyPath={findKeyPath}
|
|
260
|
-
/>
|
|
251
|
+
<Search menuList={menuList} collapsed={collapsed} type={type || ''} umiHistory={umiHistory} setSelectKey={setSelectKey} findKeyPath={findKeyPath} />
|
|
261
252
|
</div>
|
|
262
253
|
|
|
263
254
|
{!collapsed && <div style={{ height: 12 }}></div>}
|
|
264
255
|
|
|
265
|
-
<div className=
|
|
256
|
+
<div className="layout-menu">
|
|
266
257
|
<RcMenu
|
|
267
258
|
mode={collapsed ? 'vertical' : 'inline'}
|
|
268
259
|
className={`menu${collapsed ? '-collapsed' : ''}`}
|
|
@@ -276,7 +267,7 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
276
267
|
onMenuClick(item)
|
|
277
268
|
}
|
|
278
269
|
}}
|
|
279
|
-
triggerSubMenuAction=
|
|
270
|
+
triggerSubMenuAction="hover"
|
|
280
271
|
>
|
|
281
272
|
{menuList.map((item: any) => {
|
|
282
273
|
const isSelected = selectKey.includes(item.key)
|
|
@@ -287,17 +278,13 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
287
278
|
}
|
|
288
279
|
return (
|
|
289
280
|
<SubMenu
|
|
290
|
-
popupClassName=
|
|
281
|
+
popupClassName="rc-menu-submenu-popup"
|
|
291
282
|
key={item.key}
|
|
292
|
-
className=
|
|
283
|
+
className="menu-item-content"
|
|
293
284
|
title={
|
|
294
|
-
<div className=
|
|
295
|
-
<div className=
|
|
296
|
-
<span
|
|
297
|
-
className={`menu-item-icon ${isSelected ? 'submenu-selected' : ''}`}
|
|
298
|
-
>
|
|
299
|
-
{item.icon}
|
|
300
|
-
</span>
|
|
285
|
+
<div className="sub-list">
|
|
286
|
+
<div className="menu-item-inner">
|
|
287
|
+
<span className={`menu-item-icon ${isSelected ? 'submenu-selected' : ''}`}>{item.icon}</span>
|
|
301
288
|
{!collapsed && <span className={classNames}>{item.label}</span>}
|
|
302
289
|
</div>
|
|
303
290
|
</div>
|
|
@@ -314,20 +301,10 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
314
301
|
if (child.children) {
|
|
315
302
|
return (
|
|
316
303
|
<SubMenu
|
|
317
|
-
popupClassName=
|
|
318
|
-
className=
|
|
304
|
+
popupClassName="rc-menu-submenu-popup"
|
|
305
|
+
className="menu-item-content sub-li"
|
|
319
306
|
key={child.key}
|
|
320
|
-
title={
|
|
321
|
-
<div className='sub-list'>
|
|
322
|
-
{!collapsed && (
|
|
323
|
-
<span
|
|
324
|
-
className={`menu-item-label ${isSelected ? 'submenu-selected' : ''}`}
|
|
325
|
-
>
|
|
326
|
-
{child.label}
|
|
327
|
-
</span>
|
|
328
|
-
)}
|
|
329
|
-
</div>
|
|
330
|
-
}
|
|
307
|
+
title={<div className="sub-list">{!collapsed && <span className={`menu-item-label ${isSelected ? 'submenu-selected' : ''}`}>{child.label}</span>}</div>}
|
|
331
308
|
>
|
|
332
309
|
{child.children.map((grandChild: any) => {
|
|
333
310
|
const isSelected = selectKey.includes(grandChild.key)
|
|
@@ -338,16 +315,8 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
338
315
|
}
|
|
339
316
|
}
|
|
340
317
|
return (
|
|
341
|
-
<MenuItem key={grandChild.key} className=
|
|
342
|
-
<div className=
|
|
343
|
-
{!collapsed && (
|
|
344
|
-
<span
|
|
345
|
-
className={`menu-item-label ${isSelected ? 'submenu-selected' : ''}`}
|
|
346
|
-
>
|
|
347
|
-
{grandChild.label}
|
|
348
|
-
</span>
|
|
349
|
-
)}
|
|
350
|
-
</div>
|
|
318
|
+
<MenuItem key={grandChild.key} className="grand-li">
|
|
319
|
+
<div className="menu-item-content">{!collapsed && <span className={`menu-item-label ${isSelected ? 'submenu-selected' : ''}`}>{grandChild.label}</span>}</div>
|
|
351
320
|
</MenuItem>
|
|
352
321
|
)
|
|
353
322
|
})}
|
|
@@ -355,16 +324,8 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
355
324
|
)
|
|
356
325
|
}
|
|
357
326
|
return (
|
|
358
|
-
<MenuItem key={child.key} className=
|
|
359
|
-
<div className=
|
|
360
|
-
{!collapsed && (
|
|
361
|
-
<span
|
|
362
|
-
className={`menu-item-label ${isSelected ? 'submenu-selected' : ''}`}
|
|
363
|
-
>
|
|
364
|
-
{child.label}
|
|
365
|
-
</span>
|
|
366
|
-
)}
|
|
367
|
-
</div>
|
|
327
|
+
<MenuItem key={child.key} className="sub-li">
|
|
328
|
+
<div className="menu-item-content">{!collapsed && <span className={`menu-item-label ${isSelected ? 'submenu-selected' : ''}`}>{child.label}</span>}</div>
|
|
368
329
|
</MenuItem>
|
|
369
330
|
)
|
|
370
331
|
})}
|
|
@@ -378,11 +339,9 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
378
339
|
classNames += ' submenu-selected'
|
|
379
340
|
}
|
|
380
341
|
return (
|
|
381
|
-
<MenuItem key={item.key} className=
|
|
342
|
+
<MenuItem key={item.key} className="menu-item-content">
|
|
382
343
|
<div>
|
|
383
|
-
<span className={`menu-item-icon ${isSelected ? 'submenu-selected' : ''}`}>
|
|
384
|
-
{item.icon}
|
|
385
|
-
</span>
|
|
344
|
+
<span className={`menu-item-icon ${isSelected ? 'submenu-selected' : ''}`}>{item.icon}</span>
|
|
386
345
|
{!collapsed && <span className={classNames}>{item.label}</span>}
|
|
387
346
|
</div>
|
|
388
347
|
</MenuItem>
|
|
@@ -394,21 +353,21 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
394
353
|
</Sider>
|
|
395
354
|
)}
|
|
396
355
|
|
|
397
|
-
<div className=
|
|
356
|
+
<div className="layout-main">
|
|
398
357
|
{!isHideHeader && (
|
|
399
|
-
<div className=
|
|
358
|
+
<div className="layout-header">
|
|
400
359
|
{appName && (
|
|
401
|
-
<div className=
|
|
360
|
+
<div className="app-name">
|
|
402
361
|
<strong>{appName}</strong>
|
|
403
362
|
</div>
|
|
404
363
|
)}
|
|
405
364
|
|
|
406
|
-
<div className=
|
|
365
|
+
<div className="layout-header-fill" />
|
|
407
366
|
|
|
408
|
-
<div className=
|
|
367
|
+
<div className="layout-header-actions">
|
|
409
368
|
{actions?.map((item, index) => {
|
|
410
369
|
return (
|
|
411
|
-
<div className=
|
|
370
|
+
<div className="actions-item" key={index}>
|
|
412
371
|
{item}
|
|
413
372
|
</div>
|
|
414
373
|
)
|
|
@@ -416,40 +375,33 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
416
375
|
</div>
|
|
417
376
|
|
|
418
377
|
<Popover
|
|
419
|
-
placement=
|
|
378
|
+
placement="bottom"
|
|
420
379
|
content={
|
|
421
|
-
<UserCard
|
|
422
|
-
myWalletInfo={myWalletInfo}
|
|
423
|
-
MyLoginInfo={MyLoginInfo}
|
|
424
|
-
amountInfo={amountInfo}
|
|
425
|
-
customAction={customAction}
|
|
426
|
-
isCopied={isCopied}
|
|
427
|
-
copyTextToClipboard={copyTextToClipboard}
|
|
428
|
-
/>
|
|
380
|
+
<UserCard myWalletInfo={myWalletInfo} MyLoginInfo={MyLoginInfo} amountInfo={amountInfo} customAction={customAction} isCopied={isCopied} copyTextToClipboard={copyTextToClipboard} />
|
|
429
381
|
}
|
|
430
382
|
arrow={false}
|
|
431
|
-
trigger=
|
|
432
|
-
onOpenChange={e => {
|
|
383
|
+
trigger="click"
|
|
384
|
+
onOpenChange={(e) => {
|
|
433
385
|
setInfoOpen(e ? 'up' : 'down')
|
|
434
386
|
if (!e) return
|
|
435
387
|
setIsCopied({
|
|
436
388
|
account: false,
|
|
437
389
|
id: false,
|
|
438
390
|
tenantName: false,
|
|
439
|
-
tenantId: false
|
|
391
|
+
tenantId: false,
|
|
440
392
|
})
|
|
441
393
|
if (myLoginInfoAction) {
|
|
442
394
|
myLoginInfoAction()
|
|
443
395
|
}
|
|
444
396
|
}}
|
|
445
397
|
>
|
|
446
|
-
<div className=
|
|
447
|
-
<img className=
|
|
448
|
-
<div className=
|
|
398
|
+
<div className="layout-header-user">
|
|
399
|
+
<img className="avatar" src={avatar} />
|
|
400
|
+
<div className="name">{name}</div>
|
|
449
401
|
<span
|
|
450
402
|
style={{
|
|
451
403
|
display: 'inline-block',
|
|
452
|
-
marginLeft: '8px'
|
|
404
|
+
marginLeft: '8px',
|
|
453
405
|
}}
|
|
454
406
|
className={`iconfont icon-zhankai ${infoOpen ? (infoOpen === 'up' ? 'up' : 'down') : ''}`}
|
|
455
407
|
></span>
|
|
@@ -457,7 +409,7 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
457
409
|
</Popover>
|
|
458
410
|
</div>
|
|
459
411
|
)}
|
|
460
|
-
<div className=
|
|
412
|
+
<div className="layout-content">{props.children}</div>
|
|
461
413
|
</div>
|
|
462
414
|
</Layout>
|
|
463
415
|
)
|
|
@@ -465,17 +417,10 @@ export default function LiosLayout(props: LiosLayoutlProps) {
|
|
|
465
417
|
|
|
466
418
|
function Arrow({ collapsed, type }: { collapsed?: boolean; type?: string }) {
|
|
467
419
|
return (
|
|
468
|
-
<svg
|
|
469
|
-
style={{ transform: !collapsed ? 'rotate(180deg)' : 'rotate(0deg)' }}
|
|
470
|
-
viewBox='0 0 1024 1024'
|
|
471
|
-
version='1.1'
|
|
472
|
-
xmlns='http://www.w3.org/2000/svg'
|
|
473
|
-
width='20'
|
|
474
|
-
height='20'
|
|
475
|
-
>
|
|
420
|
+
<svg style={{ transform: !collapsed ? 'rotate(180deg)' : 'rotate(0deg)' }} viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" width="20" height="20">
|
|
476
421
|
<path
|
|
477
422
|
fill={type === 'console' ? '#FFFFFF' : '#817F9B'}
|
|
478
|
-
d=
|
|
423
|
+
d="M564.6336 775.168a41.5744 41.5744 0 0 0-13.312-28.672l-230.4-234.4448 229.9904-234.1888a42.0864 42.0864 0 0 0-26.3168-73.0112 42.0864 42.0864 0 0 0-30.6176 11.264L231.0656 481.024a41.984 41.984 0 0 0-2.4576 59.5968l1.9968 2.048 263.7824 265.6256a41.984 41.984 0 0 0 70.2464-33.0752z m254.5152 0a41.472 41.472 0 0 0-13.312-28.672L575.488 512l229.9904-234.1376a41.984 41.984 0 1 0-56.9344-61.7984L485.632 480.9728a42.0864 42.0864 0 0 0-2.4064 59.6992l0.8704 0.9216 0.8704 0.8192 0.4096 0.4096 263.5776 265.4208a41.984 41.984 0 0 0 70.1952-33.0752z"
|
|
479
424
|
></path>
|
|
480
425
|
</svg>
|
|
481
426
|
)
|
|
@@ -492,10 +437,7 @@ type SearchProps = {
|
|
|
492
437
|
function Search({ menuList, collapsed, type, umiHistory, setSelectKey, findKeyPath }: SearchProps) {
|
|
493
438
|
useEffect(() => {
|
|
494
439
|
const handleKeyDown = (event: KeyboardEvent) => {
|
|
495
|
-
if (
|
|
496
|
-
(navigator.platform.toLowerCase().includes('mac') ? event.metaKey : event.ctrlKey) &&
|
|
497
|
-
event.key.toLowerCase() === 'k'
|
|
498
|
-
) {
|
|
440
|
+
if ((navigator.platform.toLowerCase().includes('mac') ? event.metaKey : event.ctrlKey) && event.key.toLowerCase() === 'k') {
|
|
499
441
|
event.preventDefault()
|
|
500
442
|
const searchInput = document.querySelector('#menu-input') as HTMLInputElement
|
|
501
443
|
if (searchInput) {
|
|
@@ -554,7 +496,7 @@ function Search({ menuList, collapsed, type, umiHistory, setSelectKey, findKeyPa
|
|
|
554
496
|
search(menuList as Router[])
|
|
555
497
|
setSearchResult(searchResults)
|
|
556
498
|
function search(data: Router[]) {
|
|
557
|
-
data.forEach(item => {
|
|
499
|
+
data.forEach((item) => {
|
|
558
500
|
if (typeof item.label === 'string' && item.label.includes(value.toLocaleUpperCase())) {
|
|
559
501
|
searchResults.push(item)
|
|
560
502
|
}
|
|
@@ -568,7 +510,7 @@ function Search({ menuList, collapsed, type, umiHistory, setSelectKey, findKeyPa
|
|
|
568
510
|
const enter = (item: Router) => {
|
|
569
511
|
setIsFocused(false)
|
|
570
512
|
//如果搜索历史里面有这个item,就不再添加
|
|
571
|
-
if (searchHistory.findIndex(i => i.key === item.key) === -1) {
|
|
513
|
+
if (searchHistory.findIndex((i) => i.key === item.key) === -1) {
|
|
572
514
|
setSearchHistory([...searchHistory, item])
|
|
573
515
|
}
|
|
574
516
|
//如果是目录就找到目录下第一个菜单进入
|
|
@@ -595,60 +537,45 @@ function Search({ menuList, collapsed, type, umiHistory, setSelectKey, findKeyPa
|
|
|
595
537
|
}
|
|
596
538
|
|
|
597
539
|
const deleteHistory = (item: Router) => {
|
|
598
|
-
setSearchHistory(searchHistory.filter(i => i.key !== item.key))
|
|
540
|
+
setSearchHistory(searchHistory.filter((i) => i.key !== item.key))
|
|
599
541
|
}
|
|
600
542
|
return (
|
|
601
543
|
<>
|
|
602
544
|
{collapsed ? (
|
|
603
|
-
<div className=
|
|
604
|
-
<div className=
|
|
605
|
-
<svg
|
|
606
|
-
viewBox='0 0 1024 1024'
|
|
607
|
-
version='1.1'
|
|
608
|
-
xmlns='http://www.w3.org/2000/svg'
|
|
609
|
-
width='18'
|
|
610
|
-
height='18'
|
|
611
|
-
>
|
|
545
|
+
<div className="search-mobile-console">
|
|
546
|
+
<div className="search-icon">
|
|
547
|
+
<svg viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" width="18" height="18">
|
|
612
548
|
<path
|
|
613
549
|
fill={type === 'console' ? '#C2B7F6' : '#817F9B'}
|
|
614
|
-
d=
|
|
550
|
+
d="M962.048 907.776l-229.0176-229.0176a384.3072 384.3072 0 1 0-54.272 54.272l229.0176 229.0176a38.4 38.4 0 0 0 54.272-54.272zM436.1216 743.0656a306.944 306.944 0 1 1 306.944-306.944 307.3024 307.3024 0 0 1-306.944 306.944z"
|
|
615
551
|
></path>
|
|
616
552
|
</svg>
|
|
617
553
|
</div>
|
|
618
554
|
</div>
|
|
619
555
|
) : (
|
|
620
|
-
<div className=
|
|
621
|
-
<div className=
|
|
622
|
-
<div className=
|
|
623
|
-
<img src=
|
|
556
|
+
<div className="search-container">
|
|
557
|
+
<div className="search">
|
|
558
|
+
<div className="search-bg-mask">
|
|
559
|
+
<img src="https://cfel-front.oss-cn-hangzhou.aliyuncs.com/logo/base-component/menu-search-bg.png" />
|
|
624
560
|
</div>
|
|
625
561
|
<input
|
|
626
|
-
autoComplete=
|
|
627
|
-
id=
|
|
562
|
+
autoComplete="off"
|
|
563
|
+
id="menu-input"
|
|
628
564
|
value={searchTerm}
|
|
629
|
-
onChange={e => handleSearch(e.target.value)}
|
|
630
|
-
className=
|
|
631
|
-
placeholder=
|
|
565
|
+
onChange={(e) => handleSearch(e.target.value)}
|
|
566
|
+
className="search-input"
|
|
567
|
+
placeholder="搜索菜单..."
|
|
632
568
|
onFocus={() => setIsFocused(true)}
|
|
633
569
|
/>
|
|
634
|
-
<div className=
|
|
635
|
-
<svg
|
|
636
|
-
viewBox='0 0 1024 1024'
|
|
637
|
-
version='1.1'
|
|
638
|
-
xmlns='http://www.w3.org/2000/svg'
|
|
639
|
-
width='18'
|
|
640
|
-
height='18'
|
|
641
|
-
>
|
|
570
|
+
<div className="search-icon">
|
|
571
|
+
<svg viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" width="18" height="18">
|
|
642
572
|
<path
|
|
643
573
|
fill={type === 'console' ? '#C2B7F6' : '#817F9B'}
|
|
644
|
-
d=
|
|
574
|
+
d="M962.048 907.776l-229.0176-229.0176a384.3072 384.3072 0 1 0-54.272 54.272l229.0176 229.0176a38.4 38.4 0 0 0 54.272-54.272zM436.1216 743.0656a306.944 306.944 0 1 1 306.944-306.944 307.3024 307.3024 0 0 1-306.944 306.944z"
|
|
645
575
|
></path>
|
|
646
576
|
</svg>
|
|
647
577
|
</div>
|
|
648
|
-
<div
|
|
649
|
-
className='search-command'
|
|
650
|
-
style={{ width: navigator.platform.toLowerCase().includes('mac') ? '' : '50px' }}
|
|
651
|
-
>
|
|
578
|
+
<div className="search-command" style={{ width: navigator.platform.toLowerCase().includes('mac') ? '' : '50px' }}>
|
|
652
579
|
{navigator.platform.toLowerCase().includes('mac') ? '⌘' : 'Ctrl+'}K
|
|
653
580
|
</div>
|
|
654
581
|
</div>
|
|
@@ -656,32 +583,23 @@ function Search({ menuList, collapsed, type, umiHistory, setSelectKey, findKeyPa
|
|
|
656
583
|
{isFocused && (
|
|
657
584
|
<>
|
|
658
585
|
{searchTerm ? (
|
|
659
|
-
<List
|
|
660
|
-
split={false}
|
|
661
|
-
className='lists'
|
|
662
|
-
size='small'
|
|
663
|
-
bordered
|
|
664
|
-
dataSource={searchResult}
|
|
665
|
-
renderItem={item => (
|
|
666
|
-
<List.Item onClick={() => enter(item)}>{item.label}</List.Item>
|
|
667
|
-
)}
|
|
668
|
-
/>
|
|
586
|
+
<List split={false} className="lists" size="small" bordered dataSource={searchResult} renderItem={(item) => <List.Item onClick={() => enter(item)}>{item.label}</List.Item>} />
|
|
669
587
|
) : (
|
|
670
588
|
<List
|
|
671
589
|
split={false}
|
|
672
|
-
className=
|
|
673
|
-
header=
|
|
674
|
-
size=
|
|
590
|
+
className="lists"
|
|
591
|
+
header="最近访问"
|
|
592
|
+
size="small"
|
|
675
593
|
bordered
|
|
676
594
|
dataSource={searchHistory}
|
|
677
|
-
renderItem={item => {
|
|
595
|
+
renderItem={(item) => {
|
|
678
596
|
return (
|
|
679
597
|
<div
|
|
680
598
|
className={'search-item'}
|
|
681
599
|
style={{
|
|
682
600
|
display: 'flex',
|
|
683
601
|
justifyContent: 'space-between',
|
|
684
|
-
alignItems: 'center'
|
|
602
|
+
alignItems: 'center',
|
|
685
603
|
}}
|
|
686
604
|
>
|
|
687
605
|
<List.Item onClick={() => enter(item)}>{item.label}</List.Item>
|