addTargetDiaBase.vue 28 KB

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