index.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422
  1. <template>
  2. <div class="app-container">
  3. <div style="padding-bottom: 8px">
  4. <el-select v-model="use_scene" placeholder="请选择使用场景" style="padding-right: 14px">
  5. <el-option
  6. v-for="item in options"
  7. :key="item.value"
  8. :label="item.label"
  9. :value="item.value">
  10. </el-option>
  11. </el-select>
  12. <span>
  13. <el-input placeholder="请输入查询条件" v-model="searchCondition" style="width:250px"/>
  14. <el-button type="primary" @click="recommend" style="margin-left: 20px">推荐</el-button>
  15. </span>
  16. </div>
  17. <el-table v-loading="loading" :data="componentList" >
  18. <el-table-column label="元器件名称" align="center" prop="componentName" :show-overflow-tooltip="true"/>
  19. <el-table-column label="型号规格" align="center" prop="componentModel" :show-overflow-tooltip="true"/>
  20. <el-table-column label="质量等级" align="center" prop="qualityGrade" :show-overflow-tooltip="true"/>
  21. <el-table-column label="国产替代型号" align="center" prop="replaceDomesticModel" :show-overflow-tooltip="true"/>
  22. <!-- <el-table-column label="元器件应用" align="center" prop="applications"/>-->
  23. <el-table-column label="元器件应用" align="center" :show-overflow-tooltip="true">
  24. <template slot-scope="scope">
  25. {{ scope.row.applications }}
  26. </template>
  27. </el-table-column>
  28. <el-table-column label="相关推荐" align="center" :show-overflow-tooltip="true">
  29. <span>1,2,3...</span>
  30. </el-table-column>
  31. <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
  32. <template slot-scope="scope">
  33. <el-button
  34. size="mini"
  35. type="text"
  36. @click="handleDetail(scope.row)"
  37. v-hasPermi="['biz:component:query']"
  38. >查看详情<i class="el-icon-more"></i></el-button>
  39. <el-button
  40. size="mini"
  41. type="text"
  42. icon="el-icon-star-off"
  43. @click="getevaluationdata(scope.row)"
  44. >评分</el-button>
  45. </template>
  46. </el-table-column>
  47. </el-table>
  48. <pagination
  49. v-show="total>0"
  50. :total="total"
  51. :page.sync="queryParams.pageNum"
  52. :limit.sync="queryParams.pageSize"
  53. @pagination="getList"
  54. />
  55. <el-dialog title="评分" :visible.sync="showevalatedialog" width="30%">
  56. <el-rate
  57. v-model="escore"
  58. :show-score="true"
  59. text-color="#ff9900"
  60. >
  61. </el-rate>
  62. <el-input
  63. type="textarea"
  64. :rows="2"
  65. placeholder="请输入备注"
  66. v-model="eremark">
  67. </el-input>
  68. <div slot="footer" class="dialog-footer">
  69. <el-button @click="showevalatedialog = false">取 消</el-button>
  70. <el-button type="primary" @click="evaluate">确 定</el-button>
  71. </div>
  72. </el-dialog>
  73. <el-dialog :title="title" :visible.sync="open" width="800px" append-to-body @close="closedialog">
  74. <el-form style="border:1px solid #C0C0C0;padding: 5px;margin: auto" ref="form" :model="form" :rules="rules" label-width="200px">
  75. <h2><b>元器件基本信息</b></h2>
  76. <el-form-item label="元器件名称" prop="componentName">
  77. <el-input v-model="form.componentName" readonly='true' />
  78. </el-form-item>
  79. <el-form-item label="生产厂家" prop="manufacturer">
  80. <el-input v-model="form.manufacturer" readonly='true' />
  81. </el-form-item>
  82. <el-form-item label="型号规格" prop="componentModel">
  83. <el-input v-model="form.componentModel" readonly='true' />
  84. </el-form-item>
  85. <el-form-item label="国产替代型号" prop="replaceDomesticModel">
  86. <el-input v-model="form.replaceDomesticModel" readonly='true' />
  87. </el-form-item>
  88. <el-form-item label="质量等级" prop="qualityGrade">
  89. <el-input v-model="form.qualityGrade" readonly='true' />
  90. </el-form-item>
  91. <el-form-item label="供货周期" prop="deliveryCycle">
  92. <el-input v-model="form.deliveryCycle" readonly='true' />
  93. </el-form-item>
  94. <el-form-item label="供货量(个/年)" prop="supplyQuantity">
  95. <el-input v-model="form.supplyQuantity" readonly='true' />
  96. </el-form-item>
  97. <el-form-item label="价格" prop="unitPrice">
  98. <el-input v-model="form.unitPrice" readonly='true' />
  99. </el-form-item>
  100. <el-form-item label="ZZKK等级" prop="zzkkLevel">
  101. <el-input v-model="form.zzkkLevel" readonly='true' />
  102. </el-form-item>
  103. <el-form-item label="是否在优选目录内" prop="inPreference">
  104. <el-input v-model="form.inPreference" readonly='true' />
  105. </el-form-item>
  106. <el-form-item label="停产断档日期" prop="shutdownDate">
  107. <el-date-picker clearable
  108. v-model="form.shutdownDate"
  109. type="date"
  110. value-format="yyyy-MM-dd"
  111. readonly='true'>
  112. </el-date-picker>
  113. </el-form-item>
  114. <el-form-item label="封装形式" prop="encapsulationMode">
  115. <el-input v-model="form.encapsulationMode" readonly='true' />
  116. </el-form-item>
  117. <el-form-item label="最大正向电流IFM" prop="paramIfm" v-if="form.paramIfm!==null && form.paramIfm!==''">
  118. <el-input v-model="form.paramIfm" readonly='true' />
  119. </el-form-item>
  120. <el-form-item label="最大反向工作电压VRRM" prop="paramVrrm" v-if="form.paramVrrm!==null && form.paramVrrm!==''">
  121. <el-input v-model="form.paramVrrm" readonly='true' />
  122. </el-form-item>
  123. <el-form-item label="最大浪涌电流IFSM" prop="paramIfsm" v-if="form.paramIfsm!==null && form.paramIfsm!==''">
  124. <el-input v-model="form.paramIfsm" readonly='true' />
  125. </el-form-item>
  126. <el-form-item label="稳压状态下的动态电阻ZZ" prop="paramZz" v-if="form.paramZz!==null && form.paramZz!==''">
  127. <el-input v-model="form.paramZz" readonly='true' />
  128. </el-form-item>
  129. <el-form-item label="最大额定功率PCM" prop="paramPcm" v-if="form.paramPcm!==null && form.paramPcm!==''">
  130. <el-input v-model="form.paramPcm" readonly='true' />
  131. </el-form-item>
  132. <el-form-item label="最大集电极电流ICM" prop="paramIcm" v-if="form.paramIcm!==null && form.paramIcm!==''">
  133. <el-input v-model="form.paramIcm" readonly='true' />
  134. </el-form-item>
  135. <el-form-item label="最大集电极-基极电压VCBO" prop="paramVcbo" v-if="form.paramVcbo!==null && form.paramVcbo!==''">
  136. <el-input v-model="form.paramVcbo" readonly='true' />
  137. </el-form-item>
  138. <el-form-item label="集电极-发射极电压VCEO" prop="paramVceo" v-if="form.paramVceo!==null && form.paramVceo!==''">
  139. <el-input v-model="form.paramVceo" readonly='true' />
  140. </el-form-item>
  141. <el-form-item label="发射极-基极电压VEBO" prop="paramVebo" v-if="form.paramVebo!==null && form.paramVebo!==''">
  142. <el-input v-model="form.paramVebo" readonly='true' />
  143. </el-form-item>
  144. <el-form-item label="漏源电压VDSS" prop="paramVdss" v-if="form.paramVdss!==null && form.paramVdss!==''">
  145. <el-input v-model="form.paramVdss" readonly='true' />
  146. </el-form-item>
  147. <el-form-item label="漏极直流电流ID" prop="paramId" v-if="form.paramId!==null && form.paramId!==''">
  148. <el-input v-model="form.paramId" readonly='true' />
  149. </el-form-item>
  150. <el-form-item label="漏-源通态电阻RDS(on)" prop="paramRdsOn" v-if="form.paramRdsOn!==null && form.paramRdsOn!==''">
  151. <el-input v-model="form.paramRdsOn" readonly='true' />
  152. </el-form-item>
  153. <el-form-item label="抗静电能力" prop="antistaticCapacity">
  154. <el-input v-model="form.antistaticCapacity" readonly='true' />
  155. </el-form-item>
  156. <el-form-item label="抗辐照能力" prop="radiationResistance">
  157. <el-input v-model="form.radiationResistance" readonly='true' />
  158. </el-form-item>
  159. <el-form-item label="材料" prop="materials">
  160. <el-input v-model="form.materials" type="textarea" readonly='true'/>
  161. </el-form-item>
  162. <el-form-item label="工艺" prop="craft">
  163. <el-input v-model="form.craft" type="textarea" readonly='true' />
  164. </el-form-item>
  165. <el-form-item label="重量" prop="weight">
  166. <el-input v-model="form.weight" readonly='true' />
  167. </el-form-item>
  168. <el-form-item label="备注" prop="remark">
  169. <el-input v-model="form.remark" type="textarea" readonly='true' />
  170. </el-form-item>
  171. </el-form>
  172. <el-table style="margin-top: 20px" :header-cell-style="{background:'#87CEEB',color:'#606266'}" :data="useInfoList">
  173. <el-table-column label="应用场景" align="center" prop="usedBy" />
  174. <el-table-column label="应用时间" align="center" prop="usedDate" />
  175. </el-table>
  176. </el-dialog>
  177. </div>
  178. </template>
  179. <script>
  180. import { RecommendlistComponent,getComponent,getBycomponentId,addEvaluation,addTime,getscore } from "@/api/biz/recommend";
  181. import { recommend } from "@/api/biz/train";
  182. export default {
  183. name: "recommend",
  184. data() {
  185. return {
  186. useInfoList:[],
  187. eremark:'',//评分的备注
  188. // 遮罩层
  189. loading: false,
  190. // 选中数组
  191. ids: [],
  192. // 非单个禁用
  193. single: true,
  194. // 非多个禁用
  195. multiple: true,
  196. // 显示搜索条件
  197. showSearch: true,
  198. // 总条数
  199. total: 0,
  200. // 元器件数据
  201. componentList: [
  202. ],
  203. // 弹出层标题
  204. title: "",
  205. // 是否显示弹出层
  206. open: false,
  207. searchCondition:'',
  208. // 查询参数 元器件规格 元器件名称 国产替代型号 元器件应用 相关推荐 操作
  209. queryParams: {
  210. pageNum: 1,
  211. pageSize: 10,
  212. useScene: '',
  213. searchCondition: '',
  214. result1Id: null,
  215. result2Id: null,
  216. result3Id: null,
  217. result4Id: null,
  218. result5Id: null,
  219. },
  220. use_scene:'',
  221. evaluation: {
  222. id: null,
  223. searchCondition: null,
  224. componentId: null,
  225. mark: null,
  226. usedBy: null,
  227. createBy: null,
  228. createTime: null,
  229. updateBy: null,
  230. updateTime: null,
  231. remark: null
  232. },
  233. escore:0,
  234. showevalatedialog: false,
  235. // 表单参数
  236. form: {},
  237. // 表单校验
  238. rules: {
  239. },
  240. options:[
  241. {
  242. value: '质量最优',
  243. label: '质量最优'
  244. }, {
  245. value: '成本最优',
  246. label: '成本最优'
  247. }, {
  248. value: '供货周期最优',
  249. label: '供货周期最优'
  250. }, {
  251. value: '供货量最优',
  252. label: '供货量最优'
  253. }
  254. ],
  255. currentTime:0,
  256. startTime:0,
  257. pageviewTime:{},
  258. modelPath: 'D:\\checkpoint\\mymodel.pth',
  259. recommmend_args:{
  260. useScene: '',
  261. searchCondition: '',
  262. result1Id: null,
  263. result2Id: null,
  264. result3Id: null,
  265. result4Id: null,
  266. result5Id: null,
  267. }
  268. };
  269. },
  270. // created() {
  271. // this.getList();
  272. // },
  273. methods: {
  274. // 得到evaluation
  275. getevaluationdata(row){
  276. getscore(row.id.toString()).then(score=>{
  277. console.log(score)
  278. this.escore = score.data
  279. this.showevalatedialog=true
  280. this.evaluation.componentId = row.id
  281. this.evaluation.usedBy = row.applications.toString()
  282. })
  283. },
  284. //调用推荐算法
  285. recommend() {
  286. this.recommmend_args.useScene = this.use_scene
  287. this.recommmend_args.searchCondition = this.searchCondition
  288. recommend(this.recommmend_args, {modelPath: this.modelPath}).then(res=>{
  289. if(res.code===200) {
  290. this.recommmend_args = res.data
  291. // this.queryParams.result1Id = this.recommmend_args.result1Id
  292. this.queryParams.result1Id = this.recommmend_args.result1Id
  293. this.queryParams.result2Id = this.recommmend_args.result2Id
  294. this.queryParams.result3Id = this.recommmend_args.result3Id
  295. this.queryParams.result4Id = this.recommmend_args.result4Id
  296. this.queryParams.result5Id = this.recommmend_args.result5Id
  297. this.$modal.msgSuccess("调用推荐算法成功")
  298. console.log(this.recommmend_args)
  299. this.getList()
  300. } else {
  301. this.$modal.msgError(res.msg)
  302. }
  303. })
  304. },
  305. /** 查询元器件列表 */
  306. getList() {
  307. console.log(this.queryParams)
  308. this.loading = true;
  309. this.evaluation.searchCondition = this.searchCondition
  310. RecommendlistComponent(this.queryParams).then(response => {//queryParams中分页的信息应该是在session中保存,在请求的时候通过session封装到了pagedomain中了
  311. this.componentList = response.rows;
  312. let clist = response.rows;
  313. for(let i=0; i< clist.length;i++){
  314. getBycomponentId(clist[i].id).then(res=>{
  315. // console.log(res.data)
  316. let apps = []
  317. for(let one of res.data){
  318. apps.push(one.usedBy)
  319. }
  320. // console.log("apps:")
  321. if (apps && apps.length > 3) {
  322. this.$set(this.componentList[i], 'applications', apps.slice(0, 3).join(', ') + '...');
  323. } else {
  324. this.$set(this.componentList[i], 'applications', apps.join(', '));
  325. }
  326. // this.componentList[i].applications = apps
  327. })
  328. }
  329. this.total = response.total;
  330. this.loading = false;
  331. });
  332. },
  333. //评分
  334. evaluate(){
  335. this.evaluation.mark = this.escore
  336. this.evaluation.remark = this.eremark
  337. this.evaluation.useScene = this.use_scene
  338. addEvaluation(this.evaluation).then(response => {
  339. // this.$modal.msgSuccess("评分成功");
  340. this.showevalatedialog = false
  341. });
  342. },
  343. /** 搜索按钮操作 */
  344. handleDetail(row) {
  345. const id = row.id || this.ids
  346. getComponent(id).then(response => {
  347. this.form = response.data;
  348. this.title = "元器件详情";
  349. });
  350. getBycomponentId(id).then(res=>{
  351. this.useInfoList = res.data
  352. })
  353. this.open = true;
  354. this.startTime = Date.now()
  355. this.pageviewTime.componentId = row.id
  356. },
  357. //监听元器件详情dialog关闭
  358. closedialog(){
  359. this.currentTime = Date.now()
  360. this.pageviewTime.viewTime = this.currentTime - this.startTime
  361. this.pageviewTime.useScene = this.use_scene
  362. console.log(this.use_scene)
  363. this.pageviewTime.searchCondition = this.searchCondition
  364. addTime(this.pageviewTime).then(res=>{
  365. // this.$modal.msgSuccess("详情浏览时间成功")
  366. })
  367. console.log("详情关闭")
  368. this.open=false
  369. }
  370. }
  371. };
  372. </script>
  373. <style>
  374. .el-checkbox__inner {
  375. border-color: #8492a6 !important;
  376. }
  377. .app-container {
  378. min-height: 100vh;
  379. background: radial-gradient(circle at 10% 20%, #3A71A8 0%, rgb(239, 249, 249) 90%);
  380. }
  381. </style>