addTargetDiaBase.vue 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829
  1. <template>
  2. <div class="addTargtDia-box" v-if="isAddTarget">
  3. <el-dialog :visible.sync="isAddTarget" :close-on-click-modal="false" :modal-append-to-body='false'
  4. @close="cancelHandle" custom-class="custom-dialog fit-screen-dialog" top="5vh" center width="85vw" v-dialogDrag>
  5. <div slot="title" style="display:flex;alignItems:center;">
  6. <img :src="$icons.add" style="color:#fff;width:16px;height:16px;marginRight:5px;">
  7. <span style="fontSize:16px;">添加指标</span>
  8. </div>
  9. <div v-if="wsdAddStep==1" v-loading="isLoadingData" element-loading-text="加载中······">
  10. <div class="dialog-top" >
  11. <div>
  12. <span>数据来源</span>
  13. <el-select v-model="fromType" placeholder="请选择来源" style="width:240px;margin-left:10px" @change="changeTrade"
  14. :disabled="haveResult">
  15. <el-option v-for="item in fromArr" :key="item" :label="item" :value="item">
  16. </el-option>
  17. </el-select>
  18. <el-select v-model="fromDatabase" placeholder="请选择数据库" style="width:240px;margin-left:10px"
  19. :disabled="haveResult" v-if="hasDateSequence">
  20. <el-option v-for="item in databaseType" :key="item.value" :label="item.label" :value="item.value">
  21. </el-option>
  22. </el-select>
  23. </div>
  24. <!-- 路透增加频度选择 -->
  25. <el-select v-model="rtrFromFrequency" placeholder="请选择频度" v-if="fromType==='路透'">
  26. <el-option :label="item" :value="item"
  27. v-for="item in frequencyArr" :key="item"></el-option>
  28. </el-select>
  29. <el-input v-show="isCompanyCode" placeholder="公司ID" v-model="search_company_txt" style="maxWidth:340px;"
  30. @keyup.enter.native="searchHandle" :disabled="haveResult" clearable>
  31. <i slot="prefix" class="el-input__icon el-icon-search"></i>
  32. </el-input>
  33. <el-input placeholder="指标ID" v-model="search_txt" style="maxWidth:300px" v-if="!(hasDateSequence && fromDatabase=='1')"
  34. @keyup.enter.native="searchHandle" :disabled="haveResult" clearable>
  35. <i slot="prefix" class="el-input__icon el-icon-search"></i>
  36. </el-input>
  37. </div>
  38. <div v-if="hasDateSequence && fromDatabase=='1'">
  39. <div class="wsd-index-box">
  40. <el-input placeholder="请输入证券代码,每次只查询一个证券代码" v-model.trim="securityCodeText" class="wsd-index-input"
  41. @blur="codeInputBlur('security')" style="margin-bottom: 20px;"></el-input>
  42. <div class="wsd-index-code">
  43. <el-input placeholder="请输入指标代码,多个指标代码用英文逗号分隔" v-model.trim="indexCodeText"
  44. class="wsd-index-input" @blur="codeInputBlur('index')"></el-input>
  45. <div class="index-code-hint">
  46. {{ indexCodeHintText }}
  47. </div>
  48. </div>
  49. <el-select v-model="THSIndexCodeType" placeholder="请选择常用指标类型" v-if="fromType=='同花顺'"
  50. @change="THSIndexCodeTypeChange" style="margin-bottom: 15px;" class="wsd-index-input">
  51. <el-option :label="item.label" :value="item.value"
  52. v-for="item in THSIndexCodeTypeArr" :key="item.value"></el-option>
  53. </el-select>
  54. <el-checkbox-group v-model="indexCodeSelected">
  55. <el-checkbox :label="item.value" v-for="item in indexCodeArr" :key="item.value">{{ item.label }}</el-checkbox>
  56. </el-checkbox-group>
  57. <div class="wsd-code-row" style="margin-top: -10px;">
  58. <div class="wsd-code-item" v-for="item in indexCode" :key="item">
  59. <div class="wsd-code-item-text">{{ item }}</div>
  60. <img src="~@/assets/img/icons/close_icon_black.png" @click="deleteCode(item)" />
  61. </div>
  62. </div>
  63. </div>
  64. <div class="dia-bot">
  65. <el-button type="primary" @click="wsdNextHandle" :disabled="!isCodeComplete"
  66. style="width: 120px;" :loading="isLoadingData" >下一步
  67. </el-button>
  68. </div>
  69. </div>
  70. <template v-else>
  71. <div class="warn_txt" v-if="status === 1">
  72. 该数据已存在数据库,名称为:{{have_edbobj.edb_name}},目录为:{{ have_edbobj.warnTip }},如需重新添加,请删除原指标
  73. </div>
  74. <div class="warn_txt" v-else-if="status === 3">
  75. 该数据已存在数据库,名称为:{{have_edbobj.edb_name}},目录为:{{ have_edbobj.warnTip }}
  76. </div>
  77. <div class="no-auth" v-if="status === 3">
  78. 您当前暂无权限查看该指标,如需查看,请联系管理员
  79. </div>
  80. <div class="dialog-main" v-else>
  81. <el-table ref="Table" :data="tableData" highlight-current-row border
  82. :style="(status === 1 || !tableData.length) ? 'height:350px' : ''">
  83. <el-table-column v-for="item in tableColums" :key="item.label" :label="item.label" align="center">
  84. <template slot-scope="scope">
  85. <span v-if="item.key == 'StartDate' || item.key == 'EndDate'">{{ scope.row[item.key] |
  86. formatTime
  87. }}</span>
  88. <span v-else>{{ scope.row[item.key] }}</span>
  89. </template>
  90. </el-table-column>
  91. <div slot="empty" style="padding:40px 0 120px;">
  92. <tableNoData text="未搜索到该指标" size="mini"/>
  93. </div>
  94. </el-table>
  95. <ul class="value-ul" v-show="dataList.length && status === 2">
  96. <li class="value-item" v-for="(item, index) in dataList" :key="index">
  97. <span>{{ item.DataTime }}</span>
  98. <span style="min-width:200px;text-align:center;">{{ item.Value }}</span>
  99. </li>
  100. </ul>
  101. </div>
  102. <div class="dia-bot">
  103. <el-button type="primary" v-if="status === 2" @click="addTargtHandler"
  104. :disabled="!tableData.length">下一步
  105. </el-button>
  106. <el-button type="primary" v-else-if="[1,3].includes(status)" @click="cancelHandle">知道了</el-button>
  107. </div>
  108. </template>
  109. </div>
  110. <template v-else>
  111. <div class="edb-table-preview">
  112. <table width="auto" border="0">
  113. <thead>
  114. <tr v-for="(item, index) in edbTableHeadKey" :key="item">
  115. <td class="sticky" style="left: 0;text-align: center;">
  116. {{ edbTableHeadData.get(item) }}
  117. </td>
  118. <td v-for="(data, sub_index) in edbIndexDatas" :key="sub_index" :colspan="2"
  119. :class="highLightIndex.includes(data.EdbName) && item=='EdbName' ?'exist-highlight':''">
  120. <template v-if="item === 'ClassifyId'">
  121. <el-cascader :options="options" v-model="data[item]" placeholder="请选择所属目录"
  122. size="mini" :disabled="!data.Source"
  123. :props="{label: 'ClassifyName',
  124. value: 'ClassifyId',
  125. children: 'Children',
  126. checkStrictly: true,
  127. emitPath:false}">
  128. </el-cascader>
  129. </template>
  130. <template v-else-if="item === 'Unit'">
  131. <el-autocomplete
  132. :disabled="!data.Source"
  133. v-model.trim="data[item]"
  134. :fetch-suggestions="querySearchUnit"
  135. placeholder="请输入单位"
  136. suffix-icon="el-icon-arrow-down"
  137. size="mini"
  138. ></el-autocomplete>
  139. </template>
  140. <template v-else-if="item === 'Frequency'">
  141. <el-select v-model="data[item]" placeholder="请选择频度" size="mini" :disabled="!data.Source">
  142. <el-option :label="item" :value="item"
  143. v-for="item in frequencyArr" :key="item"></el-option>
  144. </el-select>
  145. </template>
  146. <template v-else-if="item === 'EdbName'">
  147. <el-input v-model.trim="data[item]" placeholder="请输入指标名称" size="mini" :disabled="!data.Source"></el-input>
  148. </template>
  149. <template v-else>
  150. <div style="padding: 0 7px;">{{ data[item] }}</div>
  151. </template>
  152. </td>
  153. </tr>
  154. </thead>
  155. <tbody v-if="edbIndexDatas && edbIndexDatas.length>0">
  156. <tr v-for="(item,index) in edbIndexDatas[0].DataList.length" :key="index">
  157. <td :rowspan="edbIndexDatas[0].DataList.length" v-if="index==0"
  158. class="sticky" style="left: 0;text-align: center;">
  159. 数据详情
  160. </td>
  161. <template v-for="(item1,index1) in edbIndexDatas.length">
  162. <td>{{ edbIndexDatas[index1].DataList[index].DataTime }}</td>
  163. <td>{{ edbIndexDatas[index1].DataList[index].Value }}</td>
  164. </template>
  165. </tr>
  166. </tbody>
  167. </table>
  168. </div>
  169. <div class="dia-bot">
  170. <el-button @click="wsdPrevHandle" style="width: 120px;">上一步</el-button>
  171. <el-button type="primary" @click="wsdSaveHandle" style="width: 120px;margin-left: 50px;">保存</el-button>
  172. </div>
  173. </template>
  174. </el-dialog>
  175. <el-dialog :visible.sync="checkFailShow" :close-on-click-modal="false" :modal-append-to-body='false'
  176. width="600px" title="操作提示">
  177. <div class="check-fail-box">
  178. <div>
  179. <div style="margin-bottom: 20px;">指标库中已存在以下指标,请勿重新输入!</div>
  180. <div v-for="(item,index) in existIndexList" class="exist-index-item" @click="existIndexClick(item)">
  181. {{ index+1+'、'+item.text }}
  182. </div>
  183. </div>
  184. <div class="check-fail-button">
  185. <el-button type="primary" @click="checkFailShow=false" style="width: 120px;">知道了</el-button>
  186. </div>
  187. </div>
  188. </el-dialog>
  189. </div>
  190. </template>
  191. <script>
  192. import { dataBaseInterface,dataInterence } from '@/api/api.js'
  193. import { frequencyArr,windCommonIndexCodeArr,THSCommonIndexStockCodeArr,THSCommonIndexFuturesCodeArr} from './util';
  194. export default {
  195. name: '',
  196. props: {
  197. isAddTarget: {
  198. type: Boolean
  199. }
  200. },
  201. computed:{
  202. isCodeComplete(){
  203. return this.securityCodeText && (this.indexCode.length>0 || this.indexCodeSelected.length>0)
  204. },
  205. hasDateSequence(){
  206. return ["wind","同花顺"].includes(this.fromType)
  207. },
  208. // 常用的指标代码
  209. indexCodeArr(){
  210. if(this.fromType=='wind'){
  211. return windCommonIndexCodeArr
  212. }else if(this.fromType=='同花顺'){
  213. if(this.THSIndexCodeType==1){
  214. //期货常用
  215. return THSCommonIndexFuturesCodeArr
  216. }else{
  217. //股票常用
  218. return THSCommonIndexStockCodeArr
  219. }
  220. }
  221. },
  222. indexCodeHintText(){
  223. if(this.fromType=='wind'){
  224. return 'Wind金融终端输入“CG”会弹出代码生成器,可在代码生成器上获取其他指标的代码'
  225. }else if(this.fromType=='同花顺'){
  226. return '可用Excel同花顺插件/日期序列功能,根据所选指标获取指标代码,期货和股票常用代码可在下方勾选'
  227. }
  228. }
  229. },
  230. data() {
  231. this.prefixMap=new Map([
  232. ["wind","wsd"],
  233. ["同花顺","thsds"]
  234. ])
  235. return {
  236. search_txt: '',//搜素关键词 M001625518 M0001427
  237. fromType: 'wind',
  238. fromDatabase:'0',
  239. fromArr:[],
  240. indexCodeSelected:[],
  241. databaseType:[
  242. {value:'0',label:'经济数据库'},
  243. {value:'1',label:'日期序列'}
  244. ],
  245. wsdAddStep:1,
  246. fromCode:[],
  247. tableColums: [
  248. {
  249. label: '指标ID',
  250. key: 'EdbCode'
  251. },
  252. {
  253. label: '起始时间',
  254. key: 'StartDate'
  255. },
  256. {
  257. label: '终止时间',
  258. key: 'EndDate'
  259. },
  260. ],
  261. status: '',//指标状态
  262. tableData: [],
  263. dataList: [],
  264. add_params: {},
  265. haveResult: false,
  266. have_edbobj: {
  267. warnTip: '',//已存在提示文案
  268. edb_name: '',
  269. },
  270. isCompanyCode: false,
  271. search_company_txt: '',
  272. securityCodeText:"",
  273. indexCodeText:'',
  274. indexCode:[],
  275. edbIndexDatas:[],
  276. edbTableHeadKey: [
  277. "ClassifyId",
  278. "Unit",
  279. "Frequency",
  280. "EdbName",
  281. "StockCode",
  282. "EdbCode",
  283. ],
  284. edbTableHeadData:new Map([
  285. ["ClassifyId", "所属目录"],
  286. ["Unit", "单位"],
  287. ["Frequency", "频度"],
  288. ["EdbName", "指标名称"],
  289. ["StockCode", "证券代码"],
  290. ["EdbCode", "指标代码"],
  291. ]),
  292. BatchList:[],
  293. options:[],
  294. unitList:[],
  295. frequencyArr,
  296. checkFailShow:false,
  297. existIndexList:[],
  298. isLoadingData:false,
  299. highLightIndex:[],
  300. // 同花顺常用指标类型
  301. THSIndexCodeType:1,
  302. THSIndexCodeTypeArr:[
  303. {value:1,label:"期货常用指标"},
  304. {value:2,label:"股票常用指标"}
  305. ],
  306. rtrFromFrequency:frequencyArr[0],//路透频度
  307. };
  308. },
  309. watch:{
  310. isAddTarget(newVal){
  311. if(newVal){
  312. this.getTargetSource()
  313. this.getMenu()
  314. this.getTargetUnitList()
  315. }
  316. }
  317. },
  318. methods: {
  319. init() {
  320. this.fromType = 'wind'
  321. this.fromDatabase='0'
  322. this.status = ''
  323. this.tableData = []
  324. this.dataList = []
  325. this.add_params = {}
  326. this.search_txt = '';
  327. this.haveResult = false;
  328. this.search_company_txt = '';
  329. this.wsdAddStep=1
  330. this.securityCodeText=""
  331. this.indexCodeText=''
  332. this.indexCode=[]
  333. this.indexCodeSelected=[]
  334. this.THSIndexCodeType=1
  335. this.isCompanyCode = false;
  336. this.rtrFromFrequency=frequencyArr[0]
  337. },
  338. cancelHandle() {
  339. this.init();
  340. this.$emit('cancelHandle')
  341. },
  342. /* 搜索指标 */
  343. searchHandle: _.debounce(function () {
  344. console.info(this.fromType);
  345. console.info(this.search_company_txt);
  346. console.info(this.search_txt);
  347. if (this.fromType == "彭博财务") {
  348. if (!this.search_company_txt) {
  349. this.$message.warning('请输入公司ID')
  350. return
  351. }
  352. if (!this.search_txt) {
  353. this.$message.warning('请输入指标ID')
  354. return
  355. }
  356. } else {
  357. if (!this.search_txt) {
  358. this.$message.warning('请输入指标ID')
  359. return
  360. }
  361. }
  362. if (this.search_txt) {
  363. this.status = '';
  364. this.haveResult = true;
  365. this.loading = this.$loading({
  366. lock: true,
  367. target: '.dialog-main',
  368. text: '搜索数据中...',
  369. spinner: 'el-icon-loading',
  370. background: 'rgba(255, 255, 255, 0.8)'
  371. });
  372. dataBaseInterface.getTarget({
  373. Source: Number(this.fromCode.get(this.fromType)),
  374. EdbCode: this.search_txt,
  375. CompanyCode: this.search_company_txt,
  376. Frequency: this.rtrFromFrequency
  377. }).then(res => {
  378. if (res.Ret === 200) {
  379. this.haveResult = false;
  380. //隆众指标和手工指标、交易所等将名称 频度 单位带到下一步
  381. console.log(this.fromCode.get(this.fromType),'this.fromCode.get(this.fromType)');
  382. // let opther_params = ['9', '10', '11', '15', '16', '17', '18', '19', '20', '21', '26','38','41','57','60','71'].includes(this.fromCode.get(this.fromType)) ?
  383. let opther_params={
  384. edb_name: res.Data.SearchItem.EdbName || '',
  385. unit: res.Data.SearchItem.Unit || '',
  386. frequency: frequencyArr.includes(res.Data.SearchItem.Frequency)?res.Data.SearchItem.Frequency:'',
  387. }
  388. // : {}
  389. // let jy_params = Number(this.fromCode.get(this.fromType))>1000?{
  390. // edb_name:res.Data.SearchItem.EdbName,
  391. // unit:res.Data.SearchItem.Unit,
  392. // frequency:frequencyArr.includes(res.Data.SearchItem.Frequency)?res.Data.SearchItem.Frequency:''
  393. // }:{}
  394. this.add_params = {
  395. EdbCode: res.Data.SearchItem.EdbCode,
  396. EndDate: res.Data.SearchItem.EndDate,
  397. StartDate: res.Data.SearchItem.StartDate,
  398. Source: Number(this.fromCode.get(this.fromType)),
  399. ...opther_params,
  400. // ...jy_params
  401. }
  402. this.status = res.Data.Status;
  403. let classify_arr = res.Data.ClassifyList || [];
  404. let str = '';
  405. classify_arr.length && classify_arr.reverse().map((item) => str += item.ClassifyName + '/');
  406. //提示文案
  407. this.have_edbobj = {
  408. warnTip: [1,3].includes(res.Data.Status) ? str : '',//已存在提示文案
  409. edb_name: [1,3].includes(res.Data.Status) ? res.Data.SearchItem.EdbName : '',
  410. },
  411. this.tableData =
  412. res.Data.Status === 1 ? [res.Data.SearchItem]
  413. : res.Data.Status !== 1 && res.Data.SearchItem.DataList && res.Data.SearchItem.DataList.length
  414. ? [res.Data.SearchItem]
  415. : [];
  416. this.dataList = res.Data.SearchItem.DataList || [];
  417. this.$nextTick(() => {
  418. this.loading.close();
  419. this.tableData.length && this.$refs.Table.setCurrentRow(this.tableData[0]);
  420. })
  421. } else {
  422. this.haveResult = false;
  423. this.loading.close();
  424. this.status = '';
  425. this.tableData = [];
  426. this.dataList = [];
  427. }
  428. })
  429. } else {
  430. this.$message.warning('请输入指标ID')
  431. }
  432. }),
  433. addTargtHandler() {
  434. console.log(this.add_params);
  435. this.$parent.completeTargetHandle(this.add_params);
  436. },
  437. changeTrade(e) {
  438. if (e == "彭博财务") {
  439. this.isCompanyCode = true;
  440. } else {
  441. this.isCompanyCode = false;
  442. }
  443. if(this.fromDatabase=='1'){
  444. this.fromDatabase='0'
  445. this.securityCodeText=""
  446. this.indexCodeText=''
  447. this.indexCode=[]
  448. this.indexCodeSelected=[]
  449. this.THSIndexCodeType=1
  450. }
  451. this.search_txt = '';
  452. this.search_company_txt = '';
  453. this.loading && this.loading.close();
  454. },
  455. THSIndexCodeTypeChange(){
  456. this.indexCodeSelected=[]
  457. },
  458. getTargetSource(){
  459. this.fromArr = []
  460. this.fromCode = []
  461. dataBaseInterface.getDataSource({IsBase:1}).then(res=>{
  462. if(res.Ret!==200) return
  463. if(res.Data){
  464. this.fromArr = res.Data.map(i=>{
  465. return i.SourceName
  466. })
  467. this.fromCode = new Map(res.Data.map(i=>{
  468. return [i.SourceName,i.EdbSourceId]
  469. }))
  470. }
  471. })
  472. },
  473. codeInputBlur(type){
  474. if(type == 'security'){
  475. this.securityCodeText=this.securityCodeText.replaceAll(' ','')
  476. }else if(type == 'index'){
  477. if(!this.indexCodeText) return
  478. this.indexCodeText=this.indexCodeText.replaceAll(' ','')
  479. this.indexCode=Array.from(new Set([...this.indexCode,...this.indexCodeText.split(',')]))
  480. this.indexCodeText=''
  481. }
  482. },
  483. deleteCode(code){
  484. this.indexCode = this.indexCode.filter(it => it!=code)
  485. },
  486. /* 获取目录结构 */
  487. getMenu() {
  488. dataBaseInterface.menuListV3().then(res => {
  489. if(res.Ret === 200) {
  490. this.filterNodes(res.Data.AllNodes||[]);
  491. this.options = res.Data.AllNodes || [];
  492. }
  493. })
  494. },
  495. // 递归改变目录结构
  496. filterNodes(arr) {
  497. arr.length && arr.forEach(item => {
  498. item.Children.length && this.filterNodes(item.Children)
  499. if(!item.Children.length) {
  500. item.Children=null
  501. }
  502. })
  503. },
  504. // 获取指标单位
  505. async getTargetUnitList(){
  506. let res=await dataInterence.getTargetUnitList()
  507. if(res.Ret===200){
  508. this.unitList=res.Data&&res.Data.map(item=>{
  509. return {value:item}
  510. })
  511. }
  512. },
  513. //搜索单位
  514. querySearchUnit(queryString, cb){
  515. let results = queryString ? this.unitList.filter(item=>item.value.indexOf(queryString) === 0) : this.unitList;
  516. // 调用 callback 返回建议列表的数据
  517. cb(results);
  518. },
  519. wsdNextHandle(){
  520. this.getMenu()
  521. setTimeout(()=>{
  522. if(this.isCodeComplete){
  523. let params={
  524. Source:Number(this.fromCode.get(this.fromType)),
  525. SubSource:this.fromDatabase,
  526. EdbCode:Array.from(new Set([...this.indexCode,...this.indexCodeSelected])).join(','),
  527. StockCode:this.securityCodeText
  528. }
  529. dataBaseInterface.edbExistCheck(params).then(res=>{
  530. if(res.Ret == 200){
  531. // console.log(res,'res');
  532. // return
  533. if(res.Data.IndexExist){
  534. // 有重复
  535. this.existIndexList=[]
  536. let existEdbInfo=res.Data.ExistEdbInfo || []
  537. let text=''
  538. existEdbInfo.map(item =>{
  539. text=`${item.EdbName}(${item.EdbCode})`
  540. this.existIndexList.push({text,code:item.UniqueCode,id:item.EdbInfoId,classifyId:item.ClassifyId})
  541. })
  542. this.checkFailShow=true
  543. }else{
  544. // 没有重复
  545. this.isLoadingData=true
  546. dataBaseInterface.getTarget(params).then(res => {
  547. if(res.Ret == 200){
  548. let stockList = res.Data.SearchItem.StockList || []
  549. this.edbIndexDatas=[]
  550. this.BatchList=[]
  551. let Source = Number(this.fromCode.get(this.fromType))
  552. stockList.map((item,index) =>{
  553. let isCommon = this.indexCodeArr.find(it => it.value == item.EdbCode)
  554. let params={
  555. Source,
  556. ClassifyId:0,
  557. Unit:'',
  558. Frequency:'日度',
  559. EdbName:isCommon?`${item.StockCode}${isCommon.label}`:`${item.StockCode}${item.EdbCode}`,
  560. EdbCode:item.EdbCode,
  561. StockCode:item.StockCode
  562. }
  563. this.BatchList.push(params)
  564. let datas = item.DataList || []
  565. let datasLength = datas.length
  566. if( datasLength<10){
  567. for (let i = datasLength; i < 10; i++) {
  568. datas.push({DataTime:'',Value:''})
  569. }
  570. }
  571. this.edbIndexDatas.push({...params,DataList:datas})
  572. })
  573. let edbIndexDataLength = this.edbIndexDatas.length
  574. //填充空的列
  575. for (let i = edbIndexDataLength; i < 6; i++) {
  576. this.edbIndexDatas.push({
  577. Source:0,
  578. ClassifyId:0,
  579. Unit:'',
  580. Frequency:'',
  581. EdbName:'',
  582. EdbCode:'',
  583. StockCode:'',
  584. DataList:new Array(10).fill({DataTime:'',Value:''})
  585. })
  586. }
  587. this.wsdAddStep=2
  588. }
  589. }).finally(()=>{
  590. this.isLoadingData=false
  591. })
  592. }
  593. }
  594. })
  595. }
  596. },50)
  597. },
  598. existIndexClick({code,id,classifyId}){
  599. const { href } = this.$router.resolve({ path: '/database',query:{code,id,classifyId}});
  600. window.open(href, '_blank');
  601. },
  602. wsdPrevHandle(){
  603. this.wsdAddStep=1
  604. },
  605. wsdSaveHandle(){
  606. let flag = this.edbIndexDatas.some(it => {
  607. return (it.StockCode && it.EdbCode) && ((!it.ClassifyId) || (!it.Unit) || (!it.Frequency) || (!it.EdbName))
  608. })
  609. if(flag){
  610. this.$message.warning("指标信息未填写完整")
  611. return
  612. }
  613. this.BatchList.map((it,ind) => {
  614. it.ClassifyId = this.edbIndexDatas[ind].ClassifyId
  615. it.EdbCode = this.edbIndexDatas[ind].EdbCode
  616. it.EdbName = this.edbIndexDatas[ind].EdbName
  617. it.Frequency = this.edbIndexDatas[ind].Frequency
  618. it.StockCode = this.edbIndexDatas[ind].StockCode
  619. it.Unit = this.edbIndexDatas[ind].Unit
  620. })
  621. dataBaseInterface.edbAddBatch({BatchList:this.BatchList}).then(res=>{
  622. if(res.Ret == 200){
  623. this.$message.success("添加指标成功")
  624. this.$emit('addSuccessHandle',{ code:res.Data.UniqueCode,id:res.Data.EdbInfoId,classifyId:res.Data.ClassifyId })
  625. this.cancelHandle()
  626. }else if(res.Ret == 403){
  627. this.highLightIndex=res.Data?res.Data.ExistEdbName || []:[]
  628. }
  629. })
  630. }
  631. },
  632. created() { },
  633. mounted() {
  634. //this.getTargetSource()
  635. },
  636. }
  637. </script>
  638. <style lang="scss">
  639. .addTargtDia-box {
  640. .custom-dialog{
  641. max-width: 1200px !important;
  642. min-width: 1100px;
  643. .el-checkbox{
  644. margin-right: 20px;
  645. margin-bottom: 16px;
  646. }
  647. .edb-table-preview{
  648. border: 1px solid #dcdfe6;
  649. .el-cascader{
  650. width: 100%;
  651. }
  652. .el-autocomplete{
  653. width: 100%;
  654. }
  655. .el-select{
  656. width: 100%;
  657. }
  658. .el-input{
  659. width: 100%;
  660. input{
  661. border: none;
  662. padding-left: 7px;
  663. font-size: 14px;
  664. }
  665. }
  666. }
  667. }
  668. }
  669. </style>
  670. <style lang='scss' scoped>
  671. .addTargtDia-box {
  672. .dialog-top {
  673. padding: 20px 30px;
  674. display: flex;
  675. justify-content: space-between;
  676. border: 1px solid #ECECEC;
  677. box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.05);
  678. }
  679. .wsd-index-box{
  680. padding-top: 20px;
  681. .wsd-index-code{
  682. display: flex;
  683. align-items: center;
  684. margin-bottom: 20px;
  685. .index-code-hint{
  686. color: #C0C4CC;
  687. font-size: 15px;
  688. }
  689. }
  690. .wsd-code-row{
  691. margin-top: 10px;
  692. min-height: 60px;
  693. display: flex;
  694. align-items: center;
  695. flex-wrap: wrap;
  696. .wsd-code-item{
  697. height: 40px;
  698. background-color: #EBEFF6;
  699. display: flex;
  700. align-items: center;
  701. margin-right: 10px;
  702. padding: 10px;
  703. box-sizing: border-box;
  704. margin-bottom: 10px;
  705. .wsd-code-item-text{
  706. color: #333333;
  707. margin-right: 10px;
  708. }
  709. img{
  710. height: 16px;
  711. width: 16px;
  712. cursor: pointer;
  713. }
  714. }
  715. }
  716. .wsd-index-input{
  717. min-width: 400px;
  718. width:400px;
  719. margin-right: 10px;
  720. }
  721. }
  722. .warn_txt {
  723. font-size: 16px;
  724. color: #FF4E00;
  725. margin: 30px 0;
  726. text-align: center;
  727. }
  728. .dialog-main {
  729. margin-top: 20px;
  730. .value-ul {
  731. border: 1px solid #ECECEC;
  732. max-height: 320px;
  733. overflow-y: scroll;
  734. .value-item {
  735. color: #666;
  736. padding: 12px 0;
  737. display: flex;
  738. justify-content: space-around;
  739. }
  740. }
  741. }
  742. .dia-bot {
  743. margin: 30px 0;
  744. display: flex;
  745. justify-content: center;
  746. }
  747. .no-auth {
  748. width: 50%;
  749. padding: 40px;
  750. margin: 70px auto;
  751. text-align: center;
  752. background: #ECECEC;
  753. color: #FF4E00;
  754. border: 1px dashed #FF4E00;
  755. }
  756. // 预览表格
  757. .sticky {
  758. position: sticky;
  759. border-right: 1px solid #dcdfe6;
  760. z-index: 10;
  761. }
  762. .edb-table-preview {
  763. overflow: auto;
  764. height: calc(100% - 124px);
  765. &::-webkit-scrollbar {
  766. width: 5px !important;
  767. }
  768. table {
  769. border-color: #dcdfe6;
  770. border-bottom: 1px solid #dcdfe6;
  771. border-right: 1px solid #dcdfe6;
  772. border-collapse: separate;
  773. }
  774. thead {
  775. position: sticky;
  776. z-index: 2;
  777. top: 0;
  778. }
  779. td {
  780. min-width: 100px;
  781. max-width: 100px;
  782. height: 30px;
  783. // text-align: center;
  784. color: #333;
  785. box-sizing: border-box;
  786. padding: 0 5px;
  787. background-color: #fff;
  788. border-top: 1px solid #dcdfe6;
  789. border-left: 1px solid #dcdfe6;
  790. }
  791. .exist-highlight{
  792. border: red solid 1px;
  793. }
  794. }
  795. .check-fail-box{
  796. padding: 0 0 15px 40px;
  797. color: #333333;
  798. .exist-index-item{
  799. cursor: pointer;
  800. &:hover{
  801. text-decoration: underline;
  802. }
  803. }
  804. .check-fail-button{
  805. margin-top: 80px;
  806. display: flex;
  807. justify-content: flex-end;
  808. }
  809. }
  810. }
  811. </style>