operationDialog.vue 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832
  1. <template>
  2. <el-dialog
  3. :visible.sync="isOperation"
  4. :close-on-click-modal="false"
  5. :modal-append-to-body="false"
  6. @close="cancelHandle"
  7. custom-class="operation-dialog"
  8. center
  9. width="1200px"
  10. top="5vh"
  11. v-dialogDrag
  12. >
  13. <div slot="title" style="display: flex; align-items: center">
  14. <img
  15. :src="$icons.computed"
  16. style="color: #fff; width: 16px; height: 16px; margin-right: 5px"
  17. />
  18. <span style="font-size: 16px">{{ (operationForm.edb_id ? (operationForm.view ? $t('Dialog.title_prefix_view') : $t('Dialog.title_prefix_edit')) : '') + titleMap.get(type) }}</span>
  19. </div>
  20. <div class="dialog-main">
  21. <!-- 多选source -->
  22. <ul class="label-cont" v-if="!operationForm.view && !operationForm.edb_id">
  23. <li v-for="item in sourceList" :key="item.key" :class="{act: type === item.key}" @click="init();$emit('changeSource',item.key)">{{item.label}}</li>
  24. </ul>
  25. <div class="min-top">
  26. <label ><!-- 选择指标 -->{{$t('Edb.choose_edb')}}:</label>
  27. <el-select
  28. v-model="select_target"
  29. v-loadMore="searchLoad"
  30. :filterable="!select_target"
  31. clearable
  32. :placeholder="$t('Edb.InputHolderAll.input_name')"
  33. style="width: 85%"
  34. remote
  35. :remote-method="getTarget"
  36. @click.native="inputFocusHandle"
  37. @change="chooseTarget"
  38. @blur="search_have_more = false"
  39. :disabled="operationForm.view||[69,70].includes(type)"
  40. >
  41. <i slot="prefix" class="el-input__icon el-icon-search"></i>
  42. <el-option
  43. v-for="item in searchOptions"
  44. :key="item.EdbInfoId"
  45. :label="$parent.currentLang==='en'?(item.EdbNameEn||item.EdbName):item.EdbName"
  46. :value="item.EdbInfoId"
  47. :disabled="!item.HaveOperaAuth"
  48. >
  49. <div>
  50. <img
  51. :src="$icons.lock_ico2"
  52. width="18"
  53. height="18"
  54. style="vertical-align:middle"
  55. v-if="!item.HaveOperaAuth"
  56. />
  57. {{$parent.currentLang==='en'?(item.EdbNameEn||item.EdbName):item.EdbName}}
  58. </div>
  59. </el-option>
  60. </el-select>
  61. <i class="el-icon-tickets" style="color:#409EFF;font-size:18px" @click="$emit('lookHistory',select_target)" v-if="select_target"/>
  62. </div>
  63. <div class="middle">
  64. <label><!-- 已选指标: -->{{ $t('Edb.have_choose_edb') }}:</label>
  65. <el-table
  66. :data="tableData"
  67. style="box-shadow: 0px 3px 6px rgba(155, 170, 219, 0.2);margin-top:10px;"
  68. border>
  69. <el-table-column
  70. v-for="item in tableColums"
  71. :key="item.label"
  72. :label="item.label"
  73. :width="item.widthsty"
  74. :min-width="item.minwidthsty"
  75. align="center"
  76. >
  77. <template slot-scope="scope">
  78. <span>{{ scope.row[item.key] }}</span>
  79. </template>
  80. </el-table-column>
  81. <el-table-column
  82. width="110"
  83. align="center"
  84. :label="$t('Table.column_operations')"
  85. v-if="!operationForm.view"
  86. >
  87. <template slot-scope="scope">
  88. <span class="deletesty" @click="delTarget"><!-- 删除 -->{{$t('Table.delete_btn')}}</span>
  89. </template>
  90. </el-table-column>
  91. <div slot="empty" style="padding:20px 0 30px;">
  92. <tableNoData :text="$t('Table.no_edb_msg')" size="mini"/>
  93. </div>
  94. </el-table>
  95. <ul
  96. class="data-ul"
  97. ref="dataUl"
  98. @scroll="scrollHandle"
  99. v-if="dataList.length">
  100. <li
  101. class="value-item"
  102. v-for="item in dataList"
  103. :key="item.EdbDataId"
  104. >
  105. <span class="value-label">
  106. <i class="new-tag" v-if="tableData[0].LatestDate===item.DataTime"></i>
  107. {{ item.DataTime }}
  108. </span>
  109. <span
  110. :class="['value-label',{'predict-act': item.isPredic}]"
  111. style="min-width: 200px; text-align: center"
  112. >{{ item.Value }}</span
  113. >
  114. </li>
  115. </ul>
  116. <div class="form-cont">
  117. <el-form
  118. ref="form"
  119. label-position="right"
  120. inline
  121. label-width="120px"
  122. :model="formData"
  123. :rules="formRules"
  124. :disabled="operationForm.view"
  125. >
  126. <el-form-item :label="$t('EtaBasePage.label_move_way')" style="display: block;" v-if="type === 46" prop="moveVal">
  127. <el-select
  128. v-model="formData.moveType"
  129. style="width: 100px"
  130. placeholder=""
  131. size="mini"
  132. @change="refreshTarget"
  133. >
  134. <el-option
  135. v-for="item in moveTypeOpions"
  136. :key="item.key"
  137. :label="item.label"
  138. :value="item.key"
  139. >
  140. </el-option>
  141. </el-select>
  142. <el-input
  143. style="width: 80px"
  144. type="number"
  145. min="0"
  146. size="mini"
  147. v-model="formData.moveVal"
  148. @keyup.native="filterCode(formData)"
  149. ></el-input>
  150. <el-select
  151. v-model="formData.moveUnit"
  152. size="mini"
  153. placeholder=""
  154. style="width: 100px"
  155. @change="refreshTarget"
  156. >
  157. <el-option
  158. v-for="item in fre_options"
  159. :key="item"
  160. :label="item"
  161. :value="item"
  162. >
  163. </el-option>
  164. </el-select>
  165. </el-form-item>
  166. <el-form-item :label="$t('Edb.Detail.e_name')" prop="targetName">
  167. <el-input
  168. v-model="formData.targetName"
  169. style="width: 340px"
  170. :placeholder="$t('Edb.InputHolderAll.input_name')"
  171. />
  172. </el-form-item>
  173. <el-form-item :label="$t('Edb.Detail.e_unit')" prop="unit">
  174. <selectUnit
  175. v-model="formData.unit"
  176. style="width: 340px"
  177. :disabled="!operationForm.edb_id&&[32,33].includes(type)"
  178. />
  179. </el-form-item>
  180. <el-form-item :label="$t('Edb.Detail.e_menu')" prop="menu">
  181. <el-cascader
  182. v-model="formData.menu"
  183. :options="options"
  184. :props="{
  185. label: 'ClassifyName',
  186. value: 'ClassifyId',
  187. children: 'Children',
  188. checkStrictly: true
  189. }"
  190. style="width: 90%"
  191. :placeholder="$t('Edb.InputHolderAll.input_menu')"
  192. />
  193. </el-form-item>
  194. <el-form-item :label="$t('Edb.Detail.e_fre')" prop="frequency">
  195. <el-select
  196. v-model="formData.frequency"
  197. :placeholder="$t('Edb.InputHolderAll.input_fre')"
  198. style="width: 340px"
  199. clearable
  200. :disabled="[42,45,64,66].includes(type)||(!operationForm.edb_id&&[32,33].includes(type))"
  201. >
  202. <el-option
  203. v-for="item in frequencyArr"
  204. :key="item.value"
  205. :label="item.label"
  206. :value="item.value"
  207. >
  208. </el-option>
  209. </el-select>
  210. </el-form-item>
  211. <el-form-item :label="$t('EtaBasePage.label_n_val')" prop="n_num" v-if="[39,43,44,49].includes(type)">
  212. <el-input
  213. v-model="formData.n_num"
  214. style="width: 340px"
  215. :placeholder="$t('Edb.InputHolderAll.input_n_val')"
  216. type="number"
  217. @change="NchangeHandle"
  218. />
  219. </el-form-item>
  220. <el-form-item :label="$t('EtaBasePage.label_calendar')" prop="calendar_type" v-if="type===49">
  221. <el-select
  222. v-model="formData.calendar_type"
  223. placeholder="请选择日历"
  224. style="width: 340px"
  225. @change="NchangeHandle"
  226. >
  227. <el-option
  228. v-for="item in calendarOptions"
  229. :key="item.key"
  230. :label="item.label"
  231. :value="item.label"
  232. >
  233. </el-option>
  234. </el-select>
  235. </el-form-item>
  236. <el-form-item :label="$t('EtaBasePage.label_val_type')" prop="value_type" v-if="type===54">
  237. <el-select
  238. v-model="formData.value_type"
  239. placeholder="请选择数据取值类型"
  240. style="width: 340px"
  241. >
  242. <el-option :label="$t('EtaBasePage.val_type_end')" value="期末值"/>
  243. <el-option :label="$t('EtaBasePage.val_type_average')" value="平均值"/>
  244. </el-select>
  245. </el-form-item>
  246. <!-- 通过统计特征保存的指标 -->
  247. <el-form-item :label="$t('Edb.Detail.source')" v-if="[69,70].includes(type)" style="width:50%">
  248. <span>{{type===69?'标准差':'百分比'}}</span>
  249. </el-form-item>
  250. </el-form>
  251. </div>
  252. </div>
  253. </div>
  254. <div class="dia-bot" v-if="!operationForm.view">
  255. <el-button
  256. type="primary"
  257. style="margin-right: 20px"
  258. @click="saveHandle"
  259. :loading="loading"
  260. >{{loading ? $t('Edb.calculate_ing') : operationForm.edb_id ? $t('Dialog.confirm_save_btn') : saveBtnMap.get(type)}}</el-button
  261. >
  262. <el-button type="primary" plain @click="cancelHandle('cancel')"><!-- 取消 -->{{$t('Dialog.cancel_btn')}}</el-button>
  263. </div>
  264. <el-popover
  265. placement="top-start"
  266. width="500"
  267. trigger="click"
  268. v-show="$parent.tips.get(type)">
  269. <p style="padding:30px;line-height:25px;" v-html="$parent.tips.get(type)"/>
  270. <span slot="reference" class="tip-label"><!-- 公式说明 -->{{$t('Edb.formula_instru')}}</span>
  271. </el-popover>
  272. </el-dialog>
  273. </template>
  274. <script>
  275. import * as preDictEdbInterface from '@/api/modules/predictEdbApi.js';
  276. import { formRules } from '@/views/dataEntry_manage/databaseComponents/util';
  277. import { unitArr,frequencySelectList } from '@/utils/defaultOptions';
  278. export default {
  279. name:'',
  280. props: {
  281. isOperation: {
  282. type: Boolean,
  283. },
  284. type: {
  285. type: Number
  286. },
  287. operationForm: {
  288. type: Object,
  289. }
  290. },
  291. watch: {
  292. isOperation(newval) {
  293. newval && this.getMenu();
  294. if(newval && this.operationForm.edb_id) {
  295. const backData = _.cloneDeep(this.operationForm);
  296. this.select_target = backData.oldedb_id;
  297. this.formData = {
  298. edb_id: backData.edb_id,
  299. targetName: backData.targetName,
  300. unit: backData.unit,
  301. menu: backData.menu,
  302. frequency: backData.frequency,
  303. n_num: backData.formula,
  304. moveType:backData.moveType,
  305. moveUnit:backData.moveUnit,
  306. moveVal:backData.moveVal,
  307. calendar_type:backData.calendar_type,
  308. value_type: this.type === 54 ? backData.formula : '期末值',
  309. }
  310. this.getDataList();
  311. //回显时的默认options
  312. this.searchOptions = [
  313. {
  314. EdbInfoId: backData.oldedb_id,
  315. EdbName: backData.oldEdb_name,
  316. }
  317. ]
  318. }
  319. this.sourceList = [42,64].includes(this.type)
  320. ? [{ label: /* '累计值转月值' */this.$t('Edb.CalculatesAll.to_month'),key: 42 },{ label: /* '累计值转季值' */this.$t('Edb.CalculatesAll.to_quarter'),key: 64 }]
  321. : [65,66].includes(this.type)
  322. ? [{ label: /* '累计值' */this.$t('Edb.CalculatesAll.cumulate'),key: 65 },{ label: /* '年初至今累计值' */this.$t('Edb.CalculatesAll.cumulate_oneyear'),key: 66 }]
  323. : []
  324. }
  325. },
  326. computed: {
  327. tableColums(){
  328. return [
  329. {
  330. label: /* '指标ID' */this.$t('Edb.Detail.e_id'),
  331. key: 'EdbCode',
  332. },
  333. {
  334. label: /* '指标名称' */this.$t('Edb.Detail.e_name'),
  335. key: this.$parent.currentLang==='en'?'EdbNameEn':'EdbName',
  336. },
  337. {
  338. label: /* '频度' */ this.$t('Edb.Detail.e_fre'),
  339. key: 'Frequency',
  340. },
  341. {
  342. label: /* '单位' */this.$t('Edb.Detail.e_unit'),
  343. key: this.$parent.currentLang==='en'?'UnitEn':'Unit',
  344. },
  345. {
  346. label: /* '起始时间' */this.$t('Edb.Detail.e_start_time'),
  347. key: 'StartDate',
  348. minwidthsty: '100px'
  349. },
  350. {
  351. label: /* '更新时间' */this.$t('Edb.Detail.e_update_time'),
  352. key: 'ModifyTime',
  353. minwidthsty: '110px'
  354. },
  355. {
  356. label: /* '来源' */this.$t('Edb.Detail.source'),
  357. key: 'SourceName',
  358. },
  359. ]
  360. },
  361. formRules(){
  362. return formRules
  363. },
  364. unitArr() {
  365. return unitArr
  366. },
  367. frequencyArr(){
  368. return frequencySelectList()
  369. }
  370. },
  371. data () {
  372. return {
  373. select_target:'',
  374. searchOptions:[],//指标列表
  375. haveMore: true,
  376. dataList:[],
  377. page_no:1,
  378. titleMap: new Map([
  379. [42,this.$t('Edb.CalculatesAll.to_month_quarter')],/* '累计值转月/季值' */
  380. [32,this.$t('Edb.CalculatesAll.on_year')],/* '同比值' */
  381. [33,this.$t('Edb.CalculatesAll.differ')],/* '同差值' */
  382. [39,this.$t('Edb.CalculatesAll.n_move_average')],/* 'N数值移动平均计算' */
  383. [43,this.$t('Edb.CalculatesAll.n_rate')],/* 'N数值环比值' */
  384. [44,this.$t('Edb.CalculatesAll.n_differ')],/* 'N数值环差值' */
  385. [45,this.$t('Edb.CalculatesAll.up_conver')],/* 升频 */
  386. [46,this.$t('Edb.CalculatesAll.time_move')],/* '时间移位' */
  387. [49,this.$t('Edb.CalculatesAll.super_season')],/* '超季节性' */
  388. [55,this.$t('Edb.CalculatesAll.annual')],/* '年化' */
  389. [54,this.$t('Edb.CalculatesAll.down_conver')],/* '降频' */
  390. [64,this.$t('Edb.CalculatesAll.to_month_quarter')],/* '累计值转月/季值' */
  391. [65,this.$t('Edb.CalculatesAll.cumulate')],/* '累计值' */
  392. [66,this.$t('Edb.CalculatesAll.cumulate')],/* '累计值' */
  393. [69,this.$t('Edb.CalculatesAll.standard_differ')],/* 标准差 */
  394. [70,this.$t('Edb.CalculatesAll.percent')],/* 百分比 */
  395. ]),//标题
  396. saveBtnMap: new Map([
  397. [42,/* '转月值计算' */this.$t('Edb.CalculateBtns.to_month')],
  398. [32,/* '同比值计算' */this.$t('Edb.CalculateBtns.on_year')],
  399. [33,/* '同差值计算' */this.$t('Edb.CalculateBtns.differ')],
  400. [39,/* '移动平均计算' */this.$t('Edb.CalculateBtns.n_move_average')],
  401. [43,/* '环比值计算' */this.$t('Edb.CalculateBtns.n_rate')],
  402. [44,/* '环差值计算' */this.$t('Edb.CalculateBtns.n_differ')],
  403. [45,/* '升频计算' */this.$t('Edb.CalculateBtns.up_conver')],
  404. [46,/* '保存' */this.$t('Dialog.confirm_save_btn')],
  405. [49,/* '超季节性计算' */this.$t('Edb.CalculateBtns.super_season')],
  406. [55,/* '年化计算' */this.$t('Edb.CalculateBtns.annual')],
  407. [54,/* '降频计算' */this.$t('Edb.CalculateBtns.down_conver')],
  408. [64,/* '转季值计算' */this.$t('Edb.CalculateBtns.to_quarter')],
  409. [65,/* '累计值计算' */this.$t('Edb.CalculateBtns.cumulate')],
  410. [66,/* '年初至今计算' */this.$t('Edb.CalculateBtns.cumulate_oneyear')],
  411. ]),//保存文案
  412. formData: {
  413. targetName:'',
  414. unit:'',
  415. menu:'',
  416. frequency:'',
  417. n_num: 1,
  418. moveType: 1,
  419. moveUnit: '天',
  420. moveVal: '',
  421. calendar_type: '公历',
  422. value_type: '期末值'
  423. },
  424. options: [],
  425. //frequencyArr: ['日度', '周度','旬度', '月度', '季度', '年度'],
  426. fre_options: ['天','周','月','季','年'],
  427. moveTypeOpions: [
  428. {
  429. label: '领先',
  430. key: 1
  431. },
  432. {
  433. label: '滞后',
  434. key: 2
  435. },
  436. ],
  437. loading:false,
  438. tableData: [],
  439. search_have_more: false,
  440. search_page: 1,
  441. current_search: '',
  442. calendarOptions: [
  443. {label: '公历',key: 1},
  444. {label: '农历',key: 2},
  445. ],
  446. sourceList: []
  447. };
  448. },
  449. methods: {
  450. /* 指标列表 */
  451. getTarget(query) {
  452. this.search_page = 1;
  453. this.current_search = query;
  454. this.searchApi(this.current_search);
  455. },
  456. /* 聚焦获取当前检索 */
  457. inputFocusHandle(e) {
  458. this.search_page = 1;
  459. this.current_search = e.target.value;
  460. this.searchApi(this.current_search);
  461. },
  462. searchApi(query,page=1) {
  463. const filterMap = {
  464. 42: 2,
  465. 45: 3,
  466. 66: 6
  467. }
  468. preDictEdbInterface.edbSearch({
  469. Keyword: query,
  470. CurrentIndex: page,
  471. FilterSource: filterMap[this.type] ? filterMap[this.type] : 1,
  472. Frequency: this.type===64?'季度': ''
  473. })
  474. .then((res) => {
  475. if (res.Ret !== 200) return
  476. const { List,Paging } = res.Data;
  477. this.search_have_more = page < Paging.Pages;
  478. let arr = page === 1 ? List : this.searchOptions.concat(List);
  479. this.searchOptions = this.operationForm.edb_id ? arr.filter(item => item.EdbInfoId !== this.operationForm.edb_id) : arr;
  480. });
  481. },
  482. searchLoad() {
  483. if(!this.search_have_more) return;
  484. this.searchApi(this.current_search,++this.search_page)
  485. },
  486. // 递归改变目录结构
  487. filterNodes(arr) {
  488. arr.length &&
  489. arr.forEach((item) => {
  490. item.Children.length && this.filterNodes(item.Children);
  491. if (!item.Children.length) {
  492. delete item.Children;
  493. }
  494. });
  495. },
  496. /* 获取目录结构 */
  497. getMenu() {
  498. preDictEdbInterface.classifyListV2().then(res => {
  499. if(res.Ret !== 200) return
  500. this.filterNodes(res.Data.AllNodes||[]);
  501. this.options = res.Data.AllNodes || [];
  502. })
  503. },
  504. /* 获取指标数据 */
  505. getDataList() {
  506. preDictEdbInterface.edbDataInfo({
  507. PageSize: 10,
  508. EdbInfoId: this.select_target,
  509. CurrentIndex: this.page_no
  510. }).then(res => {
  511. if(res.Ret !== 200) return
  512. const { Item,Paging } = res.Data;
  513. this.tableData = [Item] || [];
  514. Item.PredictDataList && Item.PredictDataList.forEach(_ => {
  515. _.isPredic = true;
  516. })
  517. this.haveMore = this.page_no < Paging.Pages;
  518. this.dataList = this.page_no === 1 ? [...Item.PredictDataList,...Item.DataList] : [...this.dataList,...Item.DataList];
  519. })
  520. },
  521. /* 滚动加载 */
  522. scrollHandle(e) {
  523. const dom = e.target
  524. let scrollTop = dom.scrollTop; //滑入屏幕上方的高度
  525. let windowHeitht = dom.clientHeight; //页面的高度
  526. let scrollHeight = dom.scrollHeight; //整个div的高度
  527. let total = scrollTop + windowHeitht
  528. if(total >= scrollHeight && this.haveMore){
  529. this.page_no ++;
  530. this.getDataList();
  531. }
  532. },
  533. /* 选择指标 */
  534. chooseTarget(val) {
  535. if(val) {
  536. let obj = this.searchOptions.find(item => item.EdbInfoId === val);
  537. //频度 名称默认同步
  538. this.setDefaultOption(obj);
  539. this.page_no = 1;
  540. this.dataList.length ? this.$refs.dataUl.scrollTop = 0 : null;
  541. this.getDataList()
  542. }else {
  543. this.tableData = [];
  544. this.dataList = [];
  545. }
  546. },
  547. /* 删除已选指标 */
  548. delTarget() {
  549. this.tableData = [];
  550. this.dataList = [];
  551. this.select_target = '';
  552. this.page_no = 1;
  553. },
  554. /* 过滤负数 小数点*/
  555. filterCode(item) {
  556. item.moveVal=item.moveVal.replace(/[^\.\d]/g,'').replace('.','');
  557. },
  558. init() {
  559. this.page_no = 1;
  560. this.select_target = '';
  561. this.searchOptions = [];
  562. this.tableData = [];
  563. this.dataList = [];
  564. this.formData = {
  565. targetName:'',
  566. unit:'',
  567. menu:'',
  568. frequency:'',
  569. n_num: 1,
  570. moveType: 1,
  571. moveUnit: '天',
  572. moveVal: '',
  573. calendar_type: '公历',
  574. value_type: '期末值'
  575. };
  576. this.$refs.form.resetFields();
  577. },
  578. /* 保存 */
  579. async saveHandle() {
  580. if(!this.select_target) return this.$message.warning(/* '指标不能为空' */this.$t('Edb.Valids.no_edb'))
  581. // return
  582. await this.$refs.form.validate()
  583. this.loading = true;
  584. const valueMap = {
  585. 46: 'moveVal',
  586. 54: 'value_type'
  587. }
  588. let params ={
  589. Source: this.type,
  590. EdbName: this.formData.targetName,
  591. Unit: this.formData.unit,
  592. ClassifyId: this.formData.menu[this.formData.menu.length - 1],
  593. Frequency: this.formData.frequency,
  594. FromEdbInfoId: this.select_target,
  595. Formula: valueMap[this.type] ? String(this.formData[valueMap[this.type]]) : String(this.formData.n_num),
  596. MoveFrequency: this.formData.moveUnit,
  597. MoveType: this.formData.moveType,
  598. Calendar: this.formData.calendar_type,
  599. }
  600. /* 编辑 */
  601. let edit_params = { ...params,EdbInfoId: this.operationForm.edb_id }
  602. preDictEdbInterface.operateEdbSave(this.operationForm.edb_id ? edit_params : params)
  603. .then((res) => {
  604. this.loading = false;
  605. if(res.Ret !== 200) return
  606. this.$message.success(res.Msg);
  607. this.operationForm.edb_id ? this.$emit('addCallBack','edit') : this.$emit('addCallBack','add',{
  608. code:res.Data.UniqueCode,
  609. id:res.Data.EdbInfoId,
  610. classifyId:params.ClassifyId
  611. });
  612. this.init();
  613. })
  614. },
  615. /* 关闭弹窗 */
  616. cancelHandle(type) {
  617. this.init()
  618. this.$emit('cancel');
  619. type==='cancel' && !this.operationForm.edb_id && this.$emit('openPrev');
  620. },
  621. /* 单位默认同步基础指标
  622. 同比 同差 频度同步 单位无
  623. 转月 平均值 频度单位同步
  624. 同比 同差值:默认名称为指标名称+同比/同差
  625. n数值环比/环差值计算:默认名称为指标名称+N+频度+环比/环差
  626. 转月 平均计算 变频默认指标名称同步
  627. */
  628. setDefaultOption(obj) {
  629. const tMap=new Map([
  630. ['日度','D'],
  631. ['周度','W'],
  632. ['旬度','T'],
  633. ['月度','M'],
  634. ['季度','Q'],
  635. ['年度','Y'],
  636. ])
  637. let edbName = this.$parent.currentLang==='en'?obj.EdbNameEn:obj.EdbName;
  638. let unit = this.$parent.currentLang ==='en'?obj.UnitEn:obj.Unit;
  639. const name_map = {
  640. 42: edbName,
  641. 32: `${edbName}同比`,
  642. 33: `${edbName}同差`,
  643. 39: `${edbName}/${this.formData.n_num}${tMap.get(obj.Frequency)}MA`,
  644. 45: `${edbName}/${obj.Frequency}升频`,
  645. 43: `${edbName}${this.formData.n_num}${obj.Frequency.slice(0,1)}环比`,
  646. 44: `${edbName}${this.formData.n_num}${obj.Frequency.slice(0,1)}环差`,
  647. 49: `${edbName}超季节性/${this.formData.n_num}年${this.formData.calendar_type==='公历'?'':'/'+this.formData.calendar_type}`,
  648. 55: `${edbName}年化`,
  649. 54: `${edbName}/${obj.Frequency}降频`,
  650. 64: edbName,
  651. 65: edbName,
  652. 66: edbName,
  653. }
  654. this.formData = {
  655. targetName: name_map[this.type] || '',
  656. frequency: this.type === 45 ? '日度' : this.type === 64 ? '季度': this.type === 65 ? '': obj.Frequency,
  657. unit: [33,39,42,45,49].includes(this.type) ? unit : '无',
  658. menu:'',
  659. n_num: 1,
  660. moveType: 1,
  661. moveUnit: '天',
  662. moveVal: '',
  663. calendar_type: this.formData.calendar_type,
  664. value_type: this.formData.value_type
  665. }
  666. },
  667. // N数值变化,名称也变化
  668. NchangeHandle() {
  669. if(!this.select_target) return;
  670. let obj = this.searchOptions.find(item => item.EdbInfoId === this.select_target);
  671. let edbName = this.$parent.currentLang==='en'?obj.EdbNameEn:obj.EdbName;
  672. const tMap=new Map([
  673. ['日度','D'],
  674. ['周度','W'],
  675. ['旬度','T'],
  676. ['月度','M'],
  677. ['季度','Q'],
  678. ['年度','Y'],
  679. ])
  680. const name_map = {
  681. 43: `${edbName}${this.formData.n_num}${obj.Frequency.slice(0,1)}环比`,
  682. 44: `${edbName}${this.formData.n_num}${obj.Frequency.slice(0,1)}环差`,
  683. 49: `${edbName}超季节性/${this.formData.n_num}年${this.formData.calendar_type==='公历'?'':'/'+this.formData.calendar_type}`,
  684. 39: `${edbName}/${this.formData.n_num}${tMap.get(obj.Frequency)}MA`,
  685. }
  686. this.formData.targetName = name_map[this.type] || '';
  687. },
  688. },
  689. mounted() {},
  690. }
  691. </script>
  692. <style lang='scss'>
  693. .operation-dialog {
  694. position: relative;
  695. div::-webkit-scrollbar {
  696. width: 6px !important;
  697. }
  698. .el-input-number .el-input__inner {
  699. padding: 0 34px 0 4px;
  700. }
  701. .el-dialog__body {
  702. max-height: 780px;
  703. overflow: auto;
  704. }
  705. .dialog-main {
  706. .el-cascader .el-input {
  707. width: 340px;
  708. }
  709. .label-cont {
  710. display: flex;
  711. align-items: center;
  712. margin-bottom: 15px;
  713. li {
  714. cursor: pointer;
  715. font-size: 16px;
  716. margin-right: 24px;
  717. &:hover {
  718. color: #409EFF;
  719. }
  720. &.act {
  721. color: #409EFF;
  722. }
  723. }
  724. }
  725. .min-top {
  726. padding: 20px 30px;
  727. border: 1px solid #ECECEC;
  728. box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.05);
  729. border-radius:4px;
  730. }
  731. .middle {
  732. margin-top: 20px;
  733. .data-ul {
  734. margin-top: 5px;
  735. border-bottom: 1px solid #dcdfe6;
  736. max-height: 140px;
  737. overflow-y: auto;
  738. .value-item {
  739. /* width: 100%; */
  740. padding: 14px 0;
  741. border: 1px solid #dcdfe6;
  742. border-bottom: none;
  743. display: flex;
  744. justify-content: space-around;
  745. .value-label {
  746. position: relative;
  747. color: #666;
  748. }
  749. .predict-act {
  750. color: orange;
  751. }
  752. .new-tag {
  753. width: 6px;
  754. height: 6px;
  755. display: inline-block;
  756. position: absolute;
  757. left: -12px;
  758. top: 50%;
  759. transform: translateY(-50%);
  760. border-radius: 50%;
  761. background: #f00;
  762. }
  763. }
  764. }
  765. .form-cont {
  766. padding-top: 30px;
  767. margin-top: 30px;
  768. border-top: 1px dashed #AAB4CC;
  769. input::-webkit-outer-spin-button,
  770. input::-webkit-inner-spin-button {
  771. -webkit-appearance: none;
  772. }
  773. input[type="number"]{
  774. -moz-appearance: textfield;
  775. }
  776. }
  777. }
  778. }
  779. .dia-bot {
  780. padding: 20px 0 30px;
  781. display: flex;
  782. justify-content: center;
  783. }
  784. .tip-cont {
  785. padding: 30px;
  786. }
  787. .tip-label {
  788. position: absolute;
  789. bottom: 30px;
  790. right: 30px;
  791. color: #409EFF;
  792. cursor: pointer;
  793. }
  794. }
  795. </style>