index.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445
  1. <template>
  2. <el-drawer
  3. v-bind="$attrs"
  4. v-on="$listeners"
  5. :size="width"
  6. :visible.sync="visible"
  7. destroy-on-close
  8. :show-close="false"
  9. @close="useBack"
  10. @open="beforeOpen"
  11. v-loading="loading"
  12. >
  13. <div
  14. slot="title"
  15. style="display: flex; justify-content: space-between; align-items: center"
  16. >
  17. <h3>{{ title }}</h3>
  18. <div>
  19. <el-button
  20. v-if="openMode !== 'see'"
  21. type="primary"
  22. :size="size"
  23. @click="useSave('superForm')"
  24. >保存</el-button
  25. >
  26. <el-button :size="size" @click="useBack">取消</el-button>
  27. </div>
  28. </div>
  29. <el-super-form
  30. v-model="form"
  31. :dict="dict"
  32. :rules="rules"
  33. :size="$attrs.size"
  34. :columns="FormColumns"
  35. ref="superForm"
  36. label-width="auto"
  37. label-position="right"
  38. style="padding: 20px"
  39. :disabled="openMode == 'see'"
  40. >
  41. </el-super-form>
  42. <el-card style="margin: 10px 20px">
  43. <div style="position: relative">
  44. <el-tabs v-model="activeName" @tab-click="useSwitchTab">
  45. <el-tab-pane
  46. v-for="({ item, TableColumns: columns }, index) in TabColumns"
  47. :key="index"
  48. :label="item.title"
  49. :name="item.key"
  50. lazy
  51. >
  52. <el-super-ux-table
  53. index
  54. v-model="form[item.key]"
  55. :dict="dict"
  56. :ref="activeName"
  57. :columns="columns"
  58. :size="$attrs.size"
  59. :height="500"
  60. >
  61. <ux-table-column
  62. fixed="right"
  63. title="操作"
  64. align="center"
  65. width="120"
  66. >
  67. <template slot-scope="scope">
  68. <el-button
  69. v-if="openMode !== 'see'"
  70. type="text"
  71. :size="size"
  72. @click="useRowRemove(scope.$index, scope.row)"
  73. >删 行</el-button
  74. >
  75. </template>
  76. </ux-table-column>
  77. </el-super-ux-table>
  78. </el-tab-pane>
  79. </el-tabs>
  80. <el-button
  81. @click="useResetCycle"
  82. v-if="activeName == 'cycles' && openMode !== 'see'"
  83. :size="size"
  84. style="position: absolute; right: 10px; top: 5px"
  85. >重算周期</el-button
  86. >
  87. <el-button
  88. @click="useRowAdd"
  89. v-if="
  90. (activeName == 'indexs' || activeName == 'dimensionalitys') &&
  91. openMode !== 'see'
  92. "
  93. :size="size"
  94. type="primary"
  95. style="position: absolute; right: 10px; top: 5px"
  96. >增行</el-button
  97. >
  98. </div>
  99. </el-card>
  100. </el-drawer>
  101. </template>
  102. <script>
  103. import {
  104. addTargetTemplate,
  105. updateTargetTemplate,
  106. getTargetTemplate,
  107. } from "@/api/business/spd/starget/targetTemplate";
  108. import useColumns from "./columns";
  109. export default {
  110. name: "targettemplateDetail",
  111. components: {
  112. ElSuperForm: () => import("@/components/super-form/index.vue"),
  113. ElSuperUxTable: () => import("@/components/super-ux-table/index.vue"),
  114. },
  115. props: {
  116. openMode: {
  117. type: String,
  118. default: "add",
  119. },
  120. row: {
  121. type: [Object, Array],
  122. required: true,
  123. },
  124. dict: {
  125. type: Object,
  126. },
  127. },
  128. data() {
  129. const { FormColumns, TabColumns } = useColumns();
  130. const rules = this.$init.rules(FormColumns);
  131. const params = this.$init.params(FormColumns);
  132. return {
  133. visible: false,
  134. loading: false,
  135. width: "100%",
  136. size: "mini",
  137. rules,
  138. TabColumns,
  139. FormColumns,
  140. form: {
  141. ...params,
  142. indexs: [],
  143. dimensionalitys: [],
  144. cycles: [],
  145. },
  146. activeName: "indexs",
  147. };
  148. },
  149. computed: {
  150. title: {
  151. get() {
  152. const { openMode } = this;
  153. if (openMode === "edit") {
  154. return "编 辑";
  155. }
  156. if (openMode === "see") {
  157. return "查 看";
  158. }
  159. if (openMode === "add") {
  160. return "新 增";
  161. }
  162. },
  163. set() {},
  164. },
  165. indexs() {
  166. return this.form.indexs.filter(({ delFlag }) => delFlag !== "2");
  167. },
  168. dimensionalitys() {
  169. return this.form.dimensionalitys.filter(({ delFlag }) => delFlag !== "2");
  170. },
  171. },
  172. async created() {},
  173. methods: {
  174. setVisible(prop) {
  175. this.visible = prop;
  176. },
  177. async beforeOpen() {
  178. switch (this.openMode) {
  179. case "add":
  180. var date = new Date();
  181. this.form.year = date.getFullYear() + "-" + "01" + "-" + "01";
  182. this.form.startTime = date.getFullYear() + "-" + "01" + "-" + "01";
  183. this.form.deadlineTime = date.getFullYear() + "-" + "12" + "-" + "31";
  184. this.form.cycle = "month";
  185. break;
  186. case "edit":
  187. await this.fetchTemplate(this.row.id);
  188. break;
  189. case "see":
  190. let columns = _.cloneDeep(this.TabColumns);
  191. this.TabColumns = columns.map(({ item, attr, TableColumns }) => ({
  192. item,
  193. attr,
  194. TableColumns: TableColumns.map(({ item, attr }) => ({
  195. item,
  196. attr: {
  197. ...attr,
  198. disabled: true,
  199. },
  200. })),
  201. }));
  202. await this.fetchTemplate(this.row.id);
  203. break;
  204. }
  205. },
  206. //保存
  207. async useSave(prop) {
  208. this.$refs[prop].validate(async (valid) => {
  209. if (valid) {
  210. try {
  211. let checkRes = this.checkBeforeSave(this.form);
  212. if (!checkRes) {
  213. return;
  214. }
  215. this.loading = true;
  216. let res = null;
  217. if (this.openMode === "add") {
  218. res = await addTargetTemplate(this.form);
  219. }
  220. if (this.openMode === "edit") {
  221. res = await updateTargetTemplate(this.form);
  222. }
  223. if (res.code === 200) {
  224. this.$modal.msgSuccess("保存成功");
  225. this.useBack();
  226. }
  227. } catch (err) {
  228. console.error(err);
  229. } finally {
  230. this.loading = false;
  231. }
  232. } else {
  233. return false;
  234. }
  235. });
  236. },
  237. //保存前校验
  238. checkBeforeSave(form) {
  239. if (form.indexs) {
  240. let arr = form.indexs.filter((item) => item.delFlag != "2");
  241. if (arr.length < 1) {
  242. this.$modal.msgError("指标页签不能为空!");
  243. return false;
  244. }
  245. arr = arr.filter((item) => !item.target);
  246. if (arr.length > 0) {
  247. this.$modal.msgError("指标页签不能存在空数据!");
  248. return false;
  249. }
  250. } else {
  251. this.$modal.msgError("指标页签不能为空!");
  252. return false;
  253. }
  254. if (form.dimensionalitys) {
  255. let arr = form.dimensionalitys.filter((item) => item.delFlag != "2");
  256. if (arr.length < 1) {
  257. this.$modal.msgError("维度页签不能为空!");
  258. return false;
  259. }
  260. arr = arr.filter((item) => !item.dimensionality);
  261. if (arr.length > 0) {
  262. this.$modal.msgError("维度页签不能存在空数据!");
  263. return false;
  264. }
  265. } else {
  266. this.$modal.msgError("维度页签不能为空!");
  267. return false;
  268. }
  269. if (form.cycles) {
  270. let arr = form.cycles.filter((item) => item.delFlag != "2");
  271. if (arr.length < 1) {
  272. this.$modal.msgError("周期页签不能为空!");
  273. return false;
  274. }
  275. } else {
  276. this.$modal.msgError("周期页签不能为空!");
  277. return false;
  278. }
  279. return true;
  280. },
  281. //查询详情
  282. async fetchTemplate(id) {
  283. try {
  284. // try
  285. this.loading = true;
  286. const { code, data } = await getTargetTemplate(id);
  287. if (code === 200) {
  288. this.form = data;
  289. return true;
  290. } else {
  291. return false;
  292. }
  293. } catch (err) {
  294. // catch
  295. console.error(err);
  296. } finally {
  297. // finally
  298. this.loading = false;
  299. }
  300. },
  301. //增行
  302. async useRowAdd() {
  303. let row = {};
  304. if (this.activeName == "indexs") {
  305. row = {
  306. target: null,
  307. };
  308. }
  309. if (this.activeName == "dimensionalitys") {
  310. row = {
  311. dimensionality: null,
  312. };
  313. }
  314. this.form[this.activeName].push({
  315. delFlag: "0",
  316. $index: new Date().getTime(),
  317. ...row,
  318. });
  319. console.log("this.form[this.activeName]", this.form[this.activeName]);
  320. },
  321. //删行
  322. async useRowRemove(index, row) {
  323. if (row.id) {
  324. this.form[this.activeName].forEach((e) => {
  325. if (e.id == row.id) {
  326. e.delFlag = "2";
  327. }
  328. });
  329. } else {
  330. this.form[this.activeName].splice(index, 1);
  331. }
  332. console.log("this.form[this.activeName]", this.form[this.activeName]);
  333. },
  334. //切换多页签
  335. useSwitchTab() {},
  336. //返回
  337. useBack() {
  338. const params = this.$init.params(this.FormColumns);
  339. this.from = {
  340. ...params,
  341. indexs: [],
  342. dimensionalitys: [],
  343. cycles: [],
  344. };
  345. this.visible = false;
  346. const { FormColumns, TabColumns } = useColumns();
  347. this.TabColumns = TabColumns;
  348. this.activeName = "indexs";
  349. this.$emit("success");
  350. },
  351. //重算周期
  352. useResetCycle() {
  353. if (!this.form.startTime || !this.form.deadlineTime || !this.form.cycle) {
  354. this.$modal.msgError("开始日期、结束日期、周期不能存在空值!");
  355. return;
  356. }
  357. if (this.form.startTime > this.form.deadlineTime) {
  358. this.$modal.msgError("开始日期不能大于结束日期!");
  359. return;
  360. }
  361. this.form.cycles = [];
  362. var cycles = [];
  363. var start = new Date(this.form.startTime);
  364. var deadline = new Date(this.form.deadlineTime);
  365. start.setHours(0, 0, 0);
  366. deadline.setHours(0, 0, 0);
  367. if (this.form.cycle == "period") {
  368. cycles.push({
  369. name:
  370. new Date(start).Format("yyyy-MM-dd") +
  371. "到" +
  372. new Date(deadline).Format("yyyy-MM-dd"),
  373. startTime: new Date(start).Format("yyyy-MM-dd"),
  374. deadlineTime: new Date(deadline).Format("yyyy-MM-dd"),
  375. });
  376. } else {
  377. while (deadline >= start) {
  378. if (this.form.cycle == "day") {
  379. var cy = {
  380. name: new Date(start).Format("yyyy-MM-dd"),
  381. startTime: new Date(start).Format("yyyy-MM-dd"),
  382. deadlineTime: new Date(start).Format("yyyy-MM-dd"),
  383. };
  384. cycles.push(cy);
  385. start.setDate(start.getDate() + 1);
  386. }
  387. if (this.form.cycle == "week") {
  388. var cy = {};
  389. let date = new Date(start).Format("yyyy-MM-dd");
  390. cy.startTime = new Date(start).Format("yyyy-MM-dd");
  391. start.setDate(start.getDate() + 6);
  392. cy.deadlineTime = new Date(start).Format("yyyy-MM-dd");
  393. cy.name = date + "到" + new Date(start).Format("yyyy-MM-dd");
  394. cycles.push(cy);
  395. start.setDate(start.getDate() + 1);
  396. }
  397. if (this.form.cycle == "month") {
  398. var cy = {};
  399. cy.name = new Date(start).Format("yyyy-MM");
  400. cy.startTime = new Date(start).Format("yyyy-MM-dd");
  401. let arr = cy.startTime.split("-");
  402. start = this.getLastDay(arr[0], arr[1]);
  403. console.log("start", start);
  404. cy.deadlineTime = new Date(start).Format("yyyy-MM-dd");
  405. cycles.push(cy);
  406. start.setDate(start.getDate() + 1);
  407. }
  408. if (this.form.cycle == "season") {
  409. var cy = {};
  410. let date = new Date(start).Format("yyyy-MM");
  411. cy.startTime = new Date(start).Format("yyyy-MM-dd");
  412. start.setDate(start.getDate() + 90);
  413. cy.deadlineTime = new Date(start).Format("yyyy-MM-dd");
  414. cy.name = date + "到" + new Date(start).Format("yyyy-MM");
  415. cycles.push(cy);
  416. start.setDate(start.getDate() + 1);
  417. }
  418. }
  419. cycles[cycles.length - 1].deadlineTime = deadline;
  420. }
  421. this.form.cycles = cycles;
  422. console.log("this.form.cycles", this.form.cycles);
  423. },
  424. getLastDay(year, month) {
  425. return new Date(
  426. new Date(
  427. `${month < 12 ? year : ++year}-${month == 12 ? 1 : ++month} 00:00`
  428. ).getTime() - 1
  429. );
  430. },
  431. },
  432. };
  433. </script>
  434. <style scoped>
  435. >>> .el-drawer__header {
  436. margin-bottom: 0;
  437. padding: 5px 20px;
  438. }
  439. </style>