addTargetDiaBase.vue 27 KB

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