Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
R
risk-monitor
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
蔡建
risk-monitor
Commits
2959b3ad
提交
2959b3ad
authored
4月 21, 2026
作者:
coderBryanFu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat:新增组件:时间排序选择框
上级
356f18c3
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
20 个修改的文件
包含
416 行增加
和
285 行删除
+416
-285
App copy.vue
src/App copy.vue
+0
-25
App.vue
src/App.vue
+0
-152
chart-bg.png
src/assets/images/chart-bg.png
+0
-0
index.vue
src/components/base/RelationCenterChart/index.vue
+14
-2
index.vue
src/components/base/RelationChart/index.vue
+30
-25
index.vue
src/components/base/RelationForceChart/index.vue
+17
-21
down.svg
src/components/base/TimeSortSelectBox/down.svg
+8
-0
index.vue
src/components/base/TimeSortSelectBox/index.vue
+40
-0
up.svg
src/components/base/TimeSortSelectBox/up.svg
+8
-0
index.vue
src/styles/components/TimeSortSelectBox/index.vue
+42
-0
index.vue
src/styles/components/index.vue
+5
-0
goToPage.js
src/utils/goToPage.js
+140
-3
index.vue
src/views/bill/billHome/index.vue
+3
-3
index.vue
src/views/comprehensiveSearch/searchResults/index.vue
+84
-41
barChart.js
src/views/dataLibrary/components/BarChart/barChart.js
+4
-0
lineChart.js
src/views/dataLibrary/components/LineChart/lineChart.js
+3
-0
index.vue
src/views/dataLibrary/financeControl/mREList/index.vue
+5
-5
index.vue
src/views/dataLibrary/financeControl/sDNList/index.vue
+8
-8
info.vue
src/views/exportControl/components/info.vue
+5
-0
index.vue
src/views/exportControl/index.vue
+0
-0
没有找到文件。
src/App copy.vue
浏览文件 @
2959b3ad
...
...
@@ -225,31 +225,6 @@ const menuList = ref([
}
]);
const
handleToModule
=
item
=>
{
const
curRoute
=
router
.
resolve
({
path
:
item
.
path
});
window
.
open
(
curRoute
.
href
,
"_blank"
);
};
const
searchText
=
ref
(
""
);
const
handleSearch
=
()
=>
{
const
curRoute
=
router
.
resolve
({
path
:
"/searchResults"
,
query
:
{
searchText
:
searchText
.
value
}
});
window
.
open
(
curRoute
.
href
,
"_blank"
);
};
const
handleClickTitle
=
item
=>
{
if
(
item
.
name
===
"主要国家科技动向感知"
||
item
.
name
===
"主要国家竞争科技安全"
)
{
ElMessage
.
warning
(
"当前功能正在开发中,敬请期待!"
);
}
};
const
handleOpenPage
=
page
=>
{
const
pageObj
=
{
znwd
:
"/chat"
,
...
...
src/App.vue
浏览文件 @
2959b3ad
...
...
@@ -27,7 +27,6 @@ import Menu12 from "@/assets/icons/overview/menu12.png";
import
{
ElMessage
}
from
"element-plus"
;
const
router
=
useRouter
();
const
route
=
useRoute
();
import
useTagsViewStore
from
'@/stores/tagsView.js'
...
...
@@ -48,17 +47,6 @@ router.beforeEach((to, from, next) => {
next
()
})
const
isShowAiBox
=
ref
(
false
);
const
closeAiBox
=
()
=>
{
isShowAiBox
.
value
=
false
;
};
const
openAiBox
=
()
=>
{
isShowAiBox
.
value
=
true
;
};
const
personTypeList
=
ref
([]);
// 获取人物类别
...
...
@@ -75,146 +63,6 @@ const handleGetPersonType = async () => {
}
catch
(
error
)
{}
};
const
isCurrentOverview
=
computed
(()
=>
{
if
(
route
.
path
===
"/ZMOverView"
)
{
return
true
;
}
else
{
return
false
;
}
});
// 概览页标题列表
const
homeTitleList
=
ref
([
{
name
:
"中美科技博弈"
,
path
:
"/ZMOverView"
,
disabled
:
false
},
{
name
:
"主要国家科技动向感知"
,
path
:
""
,
disabled
:
true
},
{
name
:
"主要国家竞争科技安全"
,
path
:
""
,
disabled
:
true
}
]);
const
homeActiveTitleIndex
=
ref
(
0
);
const
isShowMenu
=
ref
(
false
);
const
handleShowMenu
=
(
index
,
isShow
)
=>
{
if
(
index
===
0
)
{
isShowMenu
.
value
=
isShow
;
}
};
const
handleHoverMenu
=
isShow
=>
{
isShowMenu
.
value
=
isShow
;
};
const
menuList
=
ref
([
{
title
:
"中美科技博弈概览"
,
icon
:
Menu1
,
path
:
"/ZMOverView"
},
{
title
:
"科技法案"
,
icon
:
Menu2
,
path
:
"/billHome"
},
{
title
:
"科技政令"
,
icon
:
Menu3
,
path
:
"/decree"
},
{
title
:
"美国科技智库"
,
icon
:
Menu4
,
path
:
"/thinkTank"
},
{
title
:
"出口管制"
,
icon
:
Menu5
,
path
:
"/exportControl"
},
{
title
:
"科研合作限制"
,
icon
:
Menu6
,
path
:
"/cooperationRestrictions"
},
{
title
:
"投融资限制"
,
icon
:
Menu7
,
path
:
"/finance"
},
{
title
:
"市场准入限制"
,
icon
:
Menu8
,
path
:
"/marketAccessRestrictions"
},
{
title
:
"规则限制"
,
icon
:
Menu9
,
path
:
"/ruleRestrictions"
},
{
title
:
"美国科技人物观点"
,
icon
:
Menu10
,
path
:
"/technologyFigures"
},
{
title
:
"美国主要创新主体动向"
,
icon
:
Menu11
,
path
:
"/innovationSubject"
},
{
title
:
"美国科研资助体系"
,
icon
:
Menu12
,
path
:
"/scientificFunding"
}
]);
const
handleToModule
=
item
=>
{
const
curRoute
=
router
.
resolve
({
path
:
item
.
path
});
window
.
open
(
curRoute
.
href
,
"_blank"
);
};
const
searchText
=
ref
(
""
);
const
handleSearch
=
()
=>
{
const
curRoute
=
router
.
resolve
({
path
:
"/searchResults"
,
query
:
{
searchText
:
searchText
.
value
}
});
window
.
open
(
curRoute
.
href
,
"_blank"
);
};
const
handleClickTitle
=
item
=>
{
if
(
item
.
name
===
"主要国家科技动向感知"
||
item
.
name
===
"主要国家竞争科技安全"
)
{
ElMessage
.
warning
(
"当前功能正在开发中,敬请期待!"
);
}
};
const
handleOpenPage
=
page
=>
{
const
pageObj
=
{
znwd
:
"/chat"
,
znxb
:
"/writtingAsstaint"
};
window
.
open
(
pageObj
[
page
],
"_blank"
);
};
const
handleClickToolBox
=
()
=>
{
ElMessage
.
warning
(
"当前功能正在开发中,敬请期待!"
);
};
onMounted
(()
=>
{
handleGetPersonType
();
});
...
...
src/assets/images/chart-bg.png
0 → 100644
浏览文件 @
2959b3ad
179.7 KB
src/components/base/RelationCenterChart/index.vue
浏览文件 @
2959b3ad
<
template
>
<RelationGraph
style=
"width: 100%; height: 100%;"
ref=
"graphRef"
:options=
"graphOptions"
@
node-click=
"onNodeClick"
<RelationGraph
class=
"graph-box"
style=
"width: 100%; height: 100%;"
ref=
"graphRef"
:options=
"graphOptions"
@
node-click=
"onNodeClick"
@
line-click=
"onLineClick"
/>
</
template
>
...
...
@@ -18,6 +18,13 @@ const graphOptions = {
allowSwitchJunctionPoint
:
true
,
defaultLineShape
:
1
,
distance_coefficient
:
1
,
// 背景图配置
backgroundImage
:
new
URL
(
'@/assets/images/bg/companyGraph-bg.png'
,
import
.
meta
.
url
).
href
,
// Vite 引入本地图片
// backgroundImage: 'https://example.com/your-bg-image.png', // 或者直接用网络图片
backgroundImageNoRepeat
:
true
,
// 图片不重复
backgroundImageOffsetX
:
0
,
// X轴偏移
backgroundImageOffsetY
:
0
,
// Y轴偏移
// backgroundColor: '#f5f5f5', // 背景底色
layouts
:
[
{
layoutName
:
'center'
,
...
...
@@ -123,4 +130,9 @@ onMounted(() => {
});
</
script
>
<
style
scoped
lang=
"scss"
></
style
>
<
style
scoped
lang=
"scss"
>
// .graph-box{
// background: url('@/assets/images/bg/chart-bg.png');
// background: orange;
// }
</
style
>
src/components/base/RelationChart/index.vue
浏览文件 @
2959b3ad
<
template
>
<RelationGraph
style=
"width: 100%; height: 100%"
ref=
"graphRef"
:options=
"currentGraphOptions"
:on-node-click=
"onNodeClick"
:on-line-click=
"onLineClick"
>
<RelationGraph
style=
"width: 100%; height: 100%"
ref=
"graphRef"
:options=
"currentGraphOptions"
:on-node-click=
"onNodeClick"
:on-line-click=
"onLineClick"
>
<template
#
node=
"
{ node }">
<div
class=
"custom-node"
:style=
"
{
backgroundColor: node.color || 'var(--color-primary-50)'
}"
>
<span
:style=
"
{
color: node.fontColor || '#ffffff',
fontSize: node.customFontSize || '24px',
fontWeight: 'normal',
textAlign: 'center',
wordBreak: 'break-word',
padding: '0 8px'
}"
>
<div
class=
"custom-node"
:style=
"
{
backgroundColor: node.color || 'var(--color-primary-50)'
}">
<span
:style=
"
{
color: node.fontColor || '#ffffff',
fontSize: node.customFontSize || '24px',
fontWeight: 'normal',
textAlign: 'center',
wordBreak: 'break-word',
padding: '0 8px'
}">
{{
node
.
text
}}
</span>
</div>
...
...
@@ -76,7 +66,14 @@ const baseGraphOptionsH = {
defaultNodeBorderColor
:
"var(--color-primary-100)"
,
defaultLineColor
:
"var(--color-primary-50)"
,
defaultNodeColor
:
"var(--color-primary-50)"
,
defaultNodeFontColor
:
"var(--text-primary-90-color)"
defaultNodeFontColor
:
"var(--text-primary-90-color)"
,
// 背景图配置
backgroundImage
:
new
URL
(
'@/assets/images/bg/companyGraph-bg.png'
,
import
.
meta
.
url
).
href
,
// Vite 引入本地图片
// backgroundImage: 'https://example.com/your-bg-image.png', // 或者直接用网络图片
backgroundImageNoRepeat
:
true
,
// 图片不重复
backgroundImageOffsetX
:
0
,
// X轴偏移
backgroundImageOffsetY
:
0
,
// Y轴偏移
// backgroundColor: '#f5f5f5', // 背景底色
};
// 基础垂直配置
...
...
@@ -102,7 +99,14 @@ const baseGraphOptionsV = {
defaultNodeBorderWidth
:
2
,
defaultLineColor
:
"var(--color-primary-50)"
,
defaultNodeColor
:
"var(--color-primary-50)"
,
defaultNodeFontColor
:
"var(--bg-white-100)"
defaultNodeFontColor
:
"var(--bg-white-100)"
,
// 背景图配置
backgroundImage
:
new
URL
(
'@/assets/images/bg/companyGraph-bg.png'
,
import
.
meta
.
url
).
href
,
// Vite 引入本地图片
// backgroundImage: 'https://example.com/your-bg-image.png', // 或者直接用网络图片
backgroundImageNoRepeat
:
true
,
// 图片不重复
backgroundImageOffsetX
:
0
,
// X轴偏移
backgroundImageOffsetY
:
0
,
// Y轴偏移
// backgroundColor: '#f5f5f5', // 背景底色
};
// 【核心修改】根据 isReversed 动态计算配置
...
...
@@ -184,6 +188,7 @@ onMounted(() => {
justify-content
:
center
;
}
}
.custom-node
{
border-radius
:
50%
;
display
:
flex
;
...
...
src/components/base/RelationForceChart/index.vue
浏览文件 @
2959b3ad
<
template
>
<RelationGraph
style=
"width: 100%; height: 100%"
ref=
"graphRef"
:options=
"graphOptions"
@
node-click=
"onNodeClick"
@
line-click=
"onLineClick"
>
<RelationGraph
style=
"width: 100%; height: 100%"
ref=
"graphRef"
:options=
"graphOptions"
@
node-click=
"onNodeClick"
@
line-click=
"onLineClick"
>
<!-- 自定义节点插槽 - 这是官方推荐的方式 -->
<template
#
node=
"
{ node }">
<div
class=
"custom-node"
:style=
"
{
backgroundColor: node.color || 'var(--color-primary-50)'
}"
>
<div
class=
"custom-node"
:style=
"
{
backgroundColor: node.color || 'var(--color-primary-50)'
}">
{{
console
.
log
(
node
)
}}
<!-- 在这里自由控制文字样式 -->
<div
class=
"img"
v-if=
"node.data.pic"
>
<img
:src=
"node.data.pic"
alt=
""
/>
</div>
<span
class=
"text"
:style=
"
{
color: node.fontColor || 'var(--text-primary-80-color)',
fontSize: node.customFontSize || '24px' // 可以从数据中读取
}"
>
<span
class=
"text"
:style=
"
{
color: node.fontColor || 'var(--text-primary-80-color)',
fontSize: node.customFontSize || '24px' // 可以从数据中读取
}">
{{
node
.
text
}}
</span>
</div>
...
...
@@ -57,7 +46,14 @@ const graphOptions = ref({
layout
:
{
layoutName
:
"force"
},
defaultJunctionPoint
:
"border"
defaultJunctionPoint
:
"border"
,
// 背景图配置
backgroundImage
:
new
URL
(
'@/assets/images/bg/companyGraph-bg.png'
,
import
.
meta
.
url
).
href
,
// Vite 引入本地图片
// backgroundImage: 'https://example.com/your-bg-image.png', // 或者直接用网络图片
backgroundImageNoRepeat
:
true
,
// 图片不重复
backgroundImageOffsetX
:
0
,
// X轴偏移
backgroundImageOffsetY
:
0
,
// Y轴偏移
// backgroundColor: '#f5f5f5', // 背景底色
// defaultNodeWidth: 150, // 全局默认节点宽度
// defaultNodeHeight: 150, // 全局默认节点高度
});
...
...
src/components/base/TimeSortSelectBox/down.svg
0 → 100644
浏览文件 @
2959b3ad
<svg
viewBox=
"0 0 16 16"
xmlns=
"http://www.w3.org/2000/svg"
xmlns:xlink=
"http://www.w3.org/1999/xlink"
width=
"16.000000"
height=
"16.000000"
fill=
"none"
>
<rect
id=
"降序 6"
width=
"16.000000"
height=
"16.000000"
x=
"0.000000"
y=
"0.000000"
/>
<path
id=
"椭圆 465"
d=
"M8 14.5C6.20507 14.5 4.67301 13.8654 3.40381 12.5962C2.1346 11.327 1.5 9.79492 1.5 8C1.5 6.20507 2.1346 4.67301 3.40381 3.40381C4.67301 2.1346 6.20507 1.5 8 1.5C9.79492 1.5 11.327 2.1346 12.5962 3.40381C13.8654 4.67301 14.5 6.20507 14.5 8L13.5 8C13.5 6.48122 12.963 5.18485 11.8891 4.11091C10.8151 3.03697 9.51878 2.5 8 2.5C6.48122 2.5 5.18485 3.03697 4.11091 4.11091C3.03697 5.18486 2.5 6.48122 2.5 8C2.5 9.51878 3.03697 10.8151 4.11091 11.8891C5.18485 12.963 6.48122 13.5 8 13.5L8 14.5ZM14.48 7.98L14.5 8C14.5 8.28 14.28 8.5 14 8.5C13.72 8.5 13.5 8.28 13.5 8L13.52 7.98L14.48 7.98ZM7.98 13.52L8 13.5C8.28 13.5 8.5 13.72 8.5 14C8.5 14.28 8.28 14.5 8 14.5L7.98 14.48L7.98 13.52Z"
fill=
"rgb(95, 101, 108)"
fill-rule=
"nonzero"
/>
<path
id=
"矢量 1981"
d=
"M4 8L8 8"
stroke=
"rgb(95, 101, 108)"
stroke-linecap=
"round"
stroke-linejoin=
"round"
stroke-width=
"1.000000"
/>
<path
id=
"矢量 1982"
d=
"M0 0L4 0"
stroke=
"rgb(95, 101, 108)"
stroke-linecap=
"round"
stroke-linejoin=
"round"
stroke-width=
"1.000000"
transform=
"matrix(0,1,-1,0,8,4)"
/>
<path
id=
"矢量 1983"
d=
"M0 0L4 0"
stroke=
"rgb(95, 101, 108)"
stroke-linecap=
"round"
stroke-linejoin=
"round"
stroke-width=
"1.000000"
transform=
"matrix(0,1,-1,0,12,9)"
/>
<path
id=
"矢量 1984"
d=
"M10 12L12 14L14 12"
stroke=
"rgb(95, 101, 108)"
stroke-linecap=
"round"
stroke-linejoin=
"round"
stroke-width=
"1.000000"
/>
</svg>
src/components/base/TimeSortSelectBox/index.vue
0 → 100644
浏览文件 @
2959b3ad
<
template
>
<div
class=
"time-sort-select-box"
>
<el-select
v-model=
"isSort"
placeholder=
"发布时间"
style=
"width: 130px"
@
change=
"handlePxChange"
>
<template
#
prefix
>
<div
style=
"display: flex; align-items: center; height: 100%"
>
<img
v-if=
"isSort"
src=
"./down.svg"
style=
"width: 16px; height: 16px"
/>
<img
v-else
src=
"./up.svg"
style=
"width: 16px; height: 16px"
/>
</div>
</
template
>
<el-option
v-for=
"item in timeList"
:key=
"item.value"
:label=
"item.label"
:value=
"item.value"
/>
</el-select>
</div>
</template>
<
script
setup
>
import
{
ref
}
from
'vue'
const
isSort
=
ref
(
true
)
const
timeList
=
ref
([
{
label
:
"时间倒序"
,
value
:
true
},
{
label
:
"时间正序"
,
value
:
false
}
])
const
emits
=
defineEmits
([
'handlePxChange'
])
const
handlePxChange
=
()
=>
{
emits
(
'handlePxChange'
,
isSort
.
value
)
}
</
script
>
<
style
scoped
>
.time-sort-select-box
{
height
:
42px
;
box-sizing
:
border-box
;
padding
:
5px
0
;
}
</
style
>
\ No newline at end of file
src/components/base/TimeSortSelectBox/up.svg
0 → 100644
浏览文件 @
2959b3ad
<svg
viewBox=
"0 0 16 16"
xmlns=
"http://www.w3.org/2000/svg"
xmlns:xlink=
"http://www.w3.org/1999/xlink"
width=
"16.000000"
height=
"16.000000"
fill=
"none"
>
<rect
id=
"降序 7"
width=
"16.000000"
height=
"16.000000"
x=
"0.000000"
y=
"0.000000"
/>
<path
id=
"椭圆 465"
d=
"M8 14.5C6.20507 14.5 4.67301 13.8654 3.40381 12.5962C2.1346 11.327 1.5 9.79492 1.5 8C1.5 6.20507 2.1346 4.67301 3.40381 3.40381C4.67301 2.1346 6.20507 1.5 8 1.5C9.79492 1.5 11.327 2.1346 12.5962 3.40381C13.8654 4.67301 14.5 6.20507 14.5 8L13.5 8C13.5 6.48122 12.963 5.18485 11.8891 4.11091C10.8151 3.03697 9.51878 2.5 8 2.5C6.48122 2.5 5.18485 3.03697 4.11091 4.11091C3.03697 5.18486 2.5 6.48122 2.5 8C2.5 9.51878 3.03697 10.8151 4.11091 11.8891C5.18485 12.963 6.48122 13.5 8 13.5L8 14.5ZM14.48 7.98L14.5 8C14.5 8.28 14.28 8.5 14 8.5C13.72 8.5 13.5 8.28 13.5 8L13.52 7.98L14.48 7.98ZM7.98 13.52L8 13.5C8.28 13.5 8.5 13.72 8.5 14C8.5 14.28 8.28 14.5 8 14.5L7.98 14.48L7.98 13.52Z"
fill=
"rgb(95, 101, 108)"
fill-rule=
"nonzero"
/>
<path
id=
"矢量 1981"
d=
"M4 8L8 8"
stroke=
"rgb(95, 101, 108)"
stroke-linecap=
"round"
stroke-linejoin=
"round"
stroke-width=
"1.000000"
/>
<path
id=
"矢量 1982"
d=
"M0 0L4 0"
stroke=
"rgb(95, 101, 108)"
stroke-linecap=
"round"
stroke-linejoin=
"round"
stroke-width=
"1.000000"
transform=
"matrix(0,1,-1,0,8,4)"
/>
<path
id=
"矢量 1983"
d=
"M0 0L4 0"
stroke=
"rgb(95, 101, 108)"
stroke-linecap=
"round"
stroke-linejoin=
"round"
stroke-width=
"1.000000"
transform=
"matrix(0,1,-1,0,12,10)"
/>
<path
id=
"矢量 1984"
d=
"M10 10.9969L12.0003 9L14 10.9969"
stroke=
"rgb(95, 101, 108)"
stroke-linecap=
"round"
stroke-linejoin=
"round"
stroke-width=
"1.000000"
/>
</svg>
src/styles/components/TimeSortSelectBox/index.vue
0 → 100644
浏览文件 @
2959b3ad
<
template
>
<el-row
class=
"wrapper layout-grid-line"
>
<el-col
:span=
"span"
>
<pre>
{{
`
`
}}
</pre>
<div
class=
"time-box"
>
<TimeSortSelectBox
@
handle-px-change=
"handlePx"
/>
</div>
</el-col>
</el-row>
</
template
>
<
script
setup
>
import
{
ref
}
from
'vue'
import
'@/styles/common.scss'
import
TimeSortSelectBox
from
'@/components/base/TimeSortSelectBox/index.vue'
const
span
=
12
const
handlePx
=
(
val
)
=>
{
alert
(
val
)
}
</
script
>
<
style
lang=
"scss"
scoped
>
.time-box
{
width
:
700px
;
height
:
400px
;
padding
:
100px
;
background
:
#F2F8FF
;
border
:
1px
solid
var
(
--
bg-black-5
);
}
</
style
>
\ No newline at end of file
src/styles/components/index.vue
浏览文件 @
2959b3ad
...
...
@@ -73,6 +73,10 @@
<el-tab-pane
label=
"激活工作框"
lazy
>
<WorkingBox
/>
</el-tab-pane>
<el-tab-pane
label=
"时间排序"
lazy
>
<TimeSortSelectBox
/>
</el-tab-pane>
</el-tabs>
</div>
</el-space>
...
...
@@ -107,6 +111,7 @@ import RelationChart from './RelationChart/index.vue'
import
RelationCenterChart
from
'./RelationCenterChart/index.vue'
import
RelationForceChart
from
'./RelationForceChart/index.vue'
import
WorkingBox
from
'./WorkingBox/index.vue'
import
TimeSortSelectBox
from
'./TimeSortSelectBox/index.vue'
</
script
>
<
style
lang=
"scss"
scoped
>
...
...
src/utils/goToPage.js
浏览文件 @
2959b3ad
import
{
useRouter
}
from
"vue-router"
;
import
{
getPersonSummaryInfo
}
from
"@/api/common/index"
;
const
router
=
useRouter
()
// 跳转法案详情
...
...
@@ -27,8 +28,20 @@ export const goToDecree = (id, tabName) => {
window
.
open
(
route
.
href
,
"_blank"
);
};
// 跳转智库
// 跳转智库
详情
export
const
goToThinkTank
=
(
id
,
tabName
)
=>
{
window
.
sessionStorage
.
setItem
(
"curTabName"
,
tabName
);
const
curRoute
=
router
.
resolve
({
name
:
"ThinkTankDetail"
,
params
:
{
id
:
id
}
});
window
.
open
(
curRoute
.
href
,
"_blank"
);
}
// 跳转智库报告详情
export
const
goToThinkTankReport
=
(
id
,
tabName
)
=>
{
window
.
sessionStorage
.
setItem
(
"curTabName"
,
tabName
);
const
route
=
router
.
resolve
({
name
:
"ReportDetail"
,
...
...
@@ -49,4 +62,129 @@ export const goToInstitution = (id, tabName) => {
}
});
window
.
open
(
curRoute
.
href
,
"_blank"
);
}
\ No newline at end of file
}
// 跳转人物详情
export
const
goToCharacterPage
=
async
(
id
,
tabName
)
=>
{
window
.
sessionStorage
.
setItem
(
'curTabName'
,
tabName
)
const
personTypeList
=
JSON
.
parse
(
window
.
sessionStorage
.
getItem
(
"personTypeList"
));
let
type
let
personTypeName
const
params
=
{
personId
:
id
}
// 先获取人物全局信息
try
{
const
res
=
await
getPersonSummaryInfo
(
params
)
if
(
res
.
code
===
200
&&
res
.
data
)
{
const
arr
=
personTypeList
.
filter
(
item
=>
{
return
item
.
typeId
===
res
.
data
.
personType
;
})
if
(
arr
&&
arr
.
length
)
{
personTypeName
=
arr
[
0
].
typeName
;
if
(
personTypeName
===
"科技企业领袖"
)
{
type
=
1
;
}
else
if
(
personTypeName
===
"国会议员"
)
{
type
=
2
;
}
else
if
(
personTypeName
===
"智库研究人员"
)
{
type
=
3
;
}
else
{
personTypeName
=
"其他类型"
;
const
route
=
router
.
resolve
({
path
:
"/characterPage"
,
query
:
{
personId
:
item
.
id
}
});
window
.
open
(
route
.
href
,
"_blank"
);
return
;
}
const
route
=
router
.
resolve
({
path
:
"/characterPage"
,
query
:
{
type
:
type
,
// type=1为科技企业领袖,2为国会议员,3为智库研究人员
personId
:
item
.
id
}
});
window
.
open
(
route
.
href
,
"_blank"
);
}
else
{
personTypeName
=
""
;
const
route
=
router
.
resolve
({
path
:
"/characterPage"
,
query
:
{
personId
:
item
.
id
}
});
window
.
open
(
route
.
href
,
"_blank"
);
return
;
}
}
else
{
const
route
=
router
.
resolve
({
path
:
"/characterPage"
,
query
:
{
personId
:
item
.
id
}
});
window
.
open
(
route
.
href
,
"_blank"
);
return
;
}
}
catch
(
error
)
{
const
route
=
router
.
resolve
({
path
:
"/characterPage"
,
query
:
{
personId
:
item
.
id
}
});
window
.
open
(
route
.
href
,
"_blank"
);
return
;
}
}
// 跳转企业
export
const
goToCompanyPage
=
(
id
,
tabName
)
=>
{
window
.
sessionStorage
.
setItem
(
'curTabName'
,
tabName
)
const
route
=
router
.
resolve
({
name
:
"companyPages"
,
params
:
{
id
:
id
}
});
window
.
open
(
route
.
href
,
"_blank"
);
}
// 跳转新闻详情
export
const
goToNewsPage
=
(
id
,
tabName
)
=>
{
window
.
sessionStorage
.
setItem
(
"curTabName"
,
tabName
);
const
route
=
router
.
resolve
({
path
:
"/newsAnalysis"
,
query
:
{
newsId
:
id
}
});
window
.
open
(
route
.
href
,
"_blank"
);
}
// 跳转搜索详情页
export
const
goToSearch
=
(
tabName
,
areaName
,
billSearchType
)
=>
{
window
.
sessionStorage
.
setItem
(
"curTabName"
,
tabName
);
// if (!areaName) return;
const
query
=
{
searchText
:
tabName
,
areaName
:
areaName
};
if
(
enableBillTypeSwitch
)
{
query
.
billSearchType
=
billSearchType
}
const
curRoute
=
router
.
resolve
({
path
:
"/searchResults"
,
query
});
window
.
open
(
curRoute
.
href
,
"_blank"
);
}
// 跳转数据资源库
src/views/bill/billHome/index.vue
浏览文件 @
2959b3ad
...
...
@@ -21,7 +21,7 @@
moreText=
"查看全部委员会"
:moreCardMinCount=
"1"
@
time-click=
"handleCommitteeTimeClick"
@
name-click=
"handleTo
DataLibrary
"
@
name-click=
"handleTo
Institution
"
@
count-click=
"handleToBillDataLibrary"
@
more-click=
"handleToCommitteeMore"
/>
...
...
@@ -1009,7 +1009,7 @@ const handleBox7Data = async () => {
watch
(
box7selectetedTime
,
()
=>
{
handleBox7Data
();
});
// 查看
社交媒体
详情
// 查看
人物
详情
const
handleToSocialDetail
=
item
=>
{
const
route
=
router
.
resolve
({
path
:
"/characterPage"
,
...
...
@@ -1428,7 +1428,7 @@ const handleResize = () => {
};
// 下钻至资源库
const
handleTo
DataLibrary
=
(
item
)
=>
{
const
handleTo
Institution
=
(
item
)
=>
{
const
orgId
=
item
?.
orgId
||
item
?.
id
;
if
(
!
orgId
)
return
;
...
...
src/views/comprehensiveSearch/searchResults/index.vue
浏览文件 @
2959b3ad
...
...
@@ -75,7 +75,7 @@
</div>
</div>
-->
</div>
<div
class=
"main"
v-if=
"curArea !== '实体清单'"
>
<div
class=
"main"
v-if=
"curArea !== '实体清单'"
>
<div
class=
"item"
v-for=
"(item, index) in searchResults"
:key=
"index"
@
click=
"handleToPage(item)"
>
<div
class=
"item-left"
v-if=
"item.img"
>
<img
:src=
"item?.img"
alt=
""
/>
...
...
@@ -93,7 +93,7 @@
</div>
<el-empty
v-if=
"!searchResults.length"
></el-empty>
</div>
<div
class=
"main1"
v-if=
"curArea === '实体清单'"
>
<div
class=
"main1"
v-if=
"curArea === '实体清单'"
>
<div
class=
"item"
v-for=
"(item, index) in searchResults"
:key=
"index"
@
click=
"handleToPage(item)"
>
<div
class=
"main-header"
>
<div
class=
"title"
v-html=
"item?.originalTitle"
></div>
...
...
@@ -358,9 +358,9 @@ const handleSearch = async (isShowResultTip) => {
}
}
}
catch
(
error
)
{
}
catch
(
error
)
{
console
.
error
(
'error'
,
error
);
}
finally
{
isLoading
.
value
=
false
}
...
...
@@ -397,25 +397,44 @@ const handleToPage = async item => {
}
else
if
(
personTypeName
===
"智库研究人员"
)
{
type
=
3
;
}
else
{
personTypeName
=
""
;
ElMessage
.
warning
(
"找不到当前人员的类型值!"
);
personTypeName
=
"其他类型"
;
const
route
=
router
.
resolve
({
path
:
"/characterPage"
,
query
:
{
personId
:
item
.
id
}
});
window
.
open
(
route
.
href
,
"_blank"
);
return
;
}
const
route
=
router
.
resolve
({
path
:
"/characterPage"
,
query
:
{
type
:
type
,
// type=1为科技企业领袖,2为国会议员,3为智库研究人员
personId
:
id
personId
:
i
tem
.
i
d
}
});
window
.
open
(
route
.
href
,
"_blank"
);
}
else
{
personTypeName
=
""
;
ElMessage
.
warning
(
"找不到当前人员的类型值!"
);
const
route
=
router
.
resolve
({
path
:
"/characterPage"
,
query
:
{
personId
:
item
.
id
}
});
window
.
open
(
route
.
href
,
"_blank"
);
return
;
}
}
else
{
ElMessage
.
warning
(
"获取人物全局信息错误"
);
// ElMessage.warning("获取人物全局信息错误");
const
route
=
router
.
resolve
({
path
:
"/characterPage"
,
query
:
{
personId
:
item
.
id
}
});
window
.
open
(
route
.
href
,
"_blank"
);
return
;
}
}
catch
(
error
)
{
}
...
...
@@ -445,7 +464,7 @@ const handleToPage = async item => {
break
;
case
"智库"
:
curRoute
=
router
.
resolve
({
name
:
"
Report
Detail"
,
name
:
"
ThinkTank
Detail"
,
params
:
{
id
:
item
.
id
}
...
...
@@ -517,36 +536,36 @@ const handleToPage = async item => {
}
});
break
case
"商业管制清单事件"
:
curRoute
=
router
.
resolve
({
path
:
"/exportControl/singleSanction"
,
query
:
{
id
:
item
.
id
,
sanTypeId
:
2
,
date
:
item
.
date
}
});
break
case
"SDN清单事件"
:
curRoute
=
router
.
resolve
({
path
:
"/exportControl/singleSanction"
,
query
:
{
id
:
item
.
id
,
sanTypeId
:
2
,
date
:
item
.
date
}
});
break
case
"涉军企业清单事件"
:
curRoute
=
router
.
resolve
({
path
:
"/exportControl/singleSanction"
,
query
:
{
id
:
item
.
id
,
sanTypeId
:
2
,
date
:
item
.
date
}
});
break
//
case "商业管制清单事件":
//
curRoute = router.resolve({
//
path: "/exportControl/singleSanction",
//
query: {
//
id: item.id,
//
sanTypeId: 2,
//
date: item.date
//
}
//
});
//
break
//
case "SDN清单事件":
//
curRoute = router.resolve({
//
path: "/exportControl/singleSanction",
//
query: {
//
id: item.id,
//
sanTypeId: 2,
//
date: item.date
//
}
//
});
//
break
//
case "涉军企业清单事件":
//
curRoute = router.resolve({
//
path: "/exportControl/singleSanction",
//
query: {
//
id: item.id,
//
sanTypeId: 2,
//
date: item.date
//
}
//
});
//
break
case
"机构"
:
curRoute
=
router
.
resolve
({
path
:
"/institution"
,
...
...
@@ -998,6 +1017,18 @@ const handleCompClick = item => {
letter-spacing
:
0px
;
text-align
:
left
;
overflow
:
hidden
;
/* 2. 关键属性:将元素转为弹性盒模型 */
display
:
-
webkit-box
;
/* 3. 限制显示的行数(修改数字即可改变行数) */
-webkit-line-clamp
:
2
;
/* 4. 设置文字垂直排列方向 */
-webkit-box-orient
:
vertical
;
/* 5. 隐藏超出部分 */
overflow
:
hidden
;
/* 6. 显示省略号 */
text-overflow
:
ellipsis
;
/* 可选:修复文字间距/换行问题 */
word-break
:
break-all
;
}
.item-right-footer
{
...
...
@@ -1164,7 +1195,7 @@ const handleCompClick = item => {
.content
{
margin-top
:
10px
;
min-height
:
0
;
//
max-height: 48px;
max-height
:
48px
;
font-family
:
Microsoft
YaHei
;
font-size
:
16px
;
color
:
rgba
(
59
,
65
,
75
,
1
);
...
...
@@ -1173,6 +1204,18 @@ const handleCompClick = item => {
letter-spacing
:
0px
;
text-align
:
left
;
overflow
:
hidden
;
/* 2. 关键属性:将元素转为弹性盒模型 */
display
:
-
webkit-box
;
/* 3. 限制显示的行数(修改数字即可改变行数) */
-webkit-line-clamp
:
2
;
/* 4. 设置文字垂直排列方向 */
-webkit-box-orient
:
vertical
;
/* 5. 隐藏超出部分 */
overflow
:
hidden
;
/* 6. 显示省略号 */
text-overflow
:
ellipsis
;
/* 可选:修复文字间距/换行问题 */
word-break
:
break-all
;
}
.time
{
...
...
src/views/dataLibrary/components/BarChart/barChart.js
浏览文件 @
2959b3ad
...
...
@@ -12,6 +12,10 @@ const getBarChart = (data) => {
},
yAxis
:
{
type
:
'value'
,
name
:
'数量'
,
nameTextStyle
:
{
padding
:
[
-
10
,
0
,
0
,
-
40
]
// [上, 右, 下, 左],向左移动10px
},
splitLine
:
{
show
:
true
,
lineStyle
:
{
...
...
src/views/dataLibrary/components/LineChart/lineChart.js
浏览文件 @
2959b3ad
...
...
@@ -24,6 +24,9 @@ const getLineChart = (dataX, dataY) => {
yAxis
:
{
type
:
'value'
,
name
:
'数量'
,
nameTextStyle
:
{
padding
:
[
-
10
,
0
,
0
,
-
40
]
// [上, 右, 下, 左],向左移动10px
},
splitLine
:
{
show
:
true
,
lineStyle
:
{
...
...
src/views/dataLibrary/financeControl/mREList/index.vue
浏览文件 @
2959b3ad
...
...
@@ -199,7 +199,7 @@ const staticsDemensionList = ref([
name
:
'制裁时间'
,
active
:
true
,
chartTypeList
:
[
'折线图'
,
'柱状图'
],
chartTitle
:
'
商业管制
清单制裁时间变化趋势'
,
chartTitle
:
'
涉军企业
清单制裁时间变化趋势'
,
data
:
{
dataX
:
[],
dataY
:
[]
...
...
@@ -217,14 +217,14 @@ const staticsDemensionList = ref([
name
:
'科技领域'
,
active
:
false
,
chartTypeList
:
[
'饼状图'
],
chartTitle
:
'
商业管制
清单科技领域分布'
,
chartTitle
:
'
涉军企业
清单科技领域分布'
,
data
:
[]
}
,
{
name
:
'物项类别'
,
active
:
false
,
chartTypeList
:
[
'饼状图'
],
chartTitle
:
'
商业管制
清单物项类别分布'
,
chartTitle
:
'
涉军企业
清单物项类别分布'
,
data
:
[]
}
...
...
@@ -908,13 +908,13 @@ const initParam = () => {
}
// 跳转
政令
详情
// 跳转
企业
详情
const
handleClickToDetail
=
(
curEntity
)
=>
{
window
.
sessionStorage
.
setItem
(
"curTabName"
,
curEntity
.
title
);
const
route
=
router
.
resolve
({
name
:
"companyPages"
,
params
:
{
id
:
curEntity
.
i
d
id
:
curEntity
.
organizationI
d
}
}
);
window
.
open
(
route
.
href
,
"_blank"
);
...
...
src/views/dataLibrary/financeControl/sDNList/index.vue
浏览文件 @
2959b3ad
...
...
@@ -234,7 +234,7 @@ const staticsDemensionList = ref([
name
:
'制裁时间'
,
active
:
true
,
chartTypeList
:
[
'折线图'
,
'柱状图'
],
chartTitle
:
'
实体
清单制裁时间变化趋势'
,
chartTitle
:
'
SDN
清单制裁时间变化趋势'
,
data
:
{
dataX
:
[],
dataY
:
[]
...
...
@@ -252,28 +252,28 @@ const staticsDemensionList = ref([
name
:
'科技领域'
,
active
:
false
,
chartTypeList
:
[
'饼状图'
],
chartTitle
:
'
实体
清单科技领域分布'
,
chartTitle
:
'
SDN
清单科技领域分布'
,
data
:
[]
}
,
{
name
:
'
实体
类型'
,
name
:
'
SDN
类型'
,
active
:
false
,
chartTypeList
:
[
'饼状图'
],
chartTitle
:
'
实体
类型分布'
,
chartTitle
:
'
SDN
类型分布'
,
data
:
[]
}
,
{
name
:
'
实体
国家地区'
,
name
:
'
SDN
国家地区'
,
active
:
false
,
chartTypeList
:
[
'饼状图'
],
chartTitle
:
'
实体
国家地区分布'
,
chartTitle
:
'
SDN
国家地区分布'
,
data
:
[]
}
,
{
name
:
'
实体
省份'
,
name
:
'
SDN
省份'
,
active
:
false
,
chartTypeList
:
[
'饼状图'
],
chartTitle
:
'
实体
省份分布'
,
chartTitle
:
'
SDN
省份分布'
,
data
:
[]
}
])
...
...
src/views/exportControl/components/info.vue
浏览文件 @
2959b3ad
...
...
@@ -157,6 +157,11 @@ const desMap = {
display
:
flex
;
flex-direction
:
column
;
align-items
:
flex-end
;
&
:hover
{
text-decoration
:
underline
;
background
:
var
(
--
color-primary-2
);
}
.quantity-title-des
{
display
:
flex
;
...
...
src/views/exportControl/index.vue
浏览文件 @
2959b3ad
差异被折叠。
点击展开。
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论