addChoiceness.vue 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756
  1. <template>
  2. <!-- 报告精选添加/编辑 -->
  3. <div class="add-choiceness">
  4. <el-card>
  5. <!-- 更新方式继承第几期 -->
  6. <el-row :gutter="24">
  7. <el-col :span="12">
  8. <el-select v-model="updateMode" placeholder="请选择更新方式" clearable @change="updateModeChange">
  9. <el-option label="重新编辑" value="重新编辑"></el-option>
  10. <el-option label="继承往期" value="继承往期"></el-option>
  11. </el-select>
  12. </el-col>
  13. <el-col :span="12">
  14. <el-select v-if="updateMode == '继承往期'" v-model="inheritNum" placeholder="选择继承第几期" clearable @change="getDetail">
  15. <el-option v-for="item in updateModeList" :key="item.Periods" :label="item.InheritPeriodsName" :value="item.Periods"></el-option>
  16. </el-select>
  17. </el-col>
  18. </el-row>
  19. <div v-show="updateMode">
  20. <el-form :model="ruleForm" :rules="rules" ref="ruleForm" class="demo-ruleForm">
  21. <!-- 标题 / 作者 /发布时间 -->
  22. <el-row :gutter="24" style="margin-top: 30px">
  23. <el-col :span="12">
  24. <el-form-item prop="title">
  25. <el-input v-model="ruleForm.title" placeholder="请输入标题"></el-input>
  26. </el-form-item>
  27. </el-col>
  28. <el-col :span="6">
  29. <el-form-item prop="author">
  30. <el-input v-model="ruleForm.author" placeholder="请输入作者"></el-input>
  31. </el-form-item>
  32. </el-col>
  33. <el-col :span="6">
  34. <el-form-item prop="time">
  35. <el-date-picker type="date" placeholder="选择发布时间" value-format="yyyy-MM-dd" v-model="ruleForm.time"></el-date-picker>
  36. </el-form-item>
  37. </el-col>
  38. </el-row>
  39. <!-- 产品说明 -->
  40. <el-form-item prop="explain" style="margin-top: 10px">
  41. <el-input v-model="ruleForm.explain" placeholder="请输入产品说明"></el-input>
  42. </el-form-item>
  43. <!-- 变更说明 -->
  44. <!-- 富文本 -->
  45. <rich-text ref="oneRich" v-model="marketStrategy" :spareId="contentValue" :isText="contentText" />
  46. <el-form-item prop="reportLink">
  47. <div style="display: flex; align-items: center; margin-top: 10px">
  48. <span style="flex-shrink: 0">详细报告链接:</span>
  49. <el-input style="margin: 10px 0" v-model="ruleForm.reportLink" placeholder="请输入报告链接(弘则研报管理栏目下)"></el-input>
  50. </div>
  51. </el-form-item>
  52. </el-form>
  53. <!-- 产业/标的 模块 -->
  54. <div class="content-module">
  55. <draggable v-model="industryList" animation="300" @update="sortChange">
  56. <div class="content-industry" v-for="(item, index) in industryList" :key="item.ChartPermissionId">
  57. <div class="content-name" :class="industryIndex == index ? 'active' : ''" @click="industryBtn(item, index)">{{ item.ChartPermissionName }}</div>
  58. </div>
  59. </draggable>
  60. <div v-for="(item, index) in industryList" :key="item.ChartPermissionId">
  61. <div v-show="industryIndex == index">
  62. <RichText v-model="item.BodyChartSummary" :ref="'logic' + index" :spareId="'logictest' + index" :isText="contentTextLogic" />
  63. <draggable :list="item.List" animation="300" class="classification" filter=".addIndustrial" :move="onMove" @update="ificationSortChange">
  64. <div v-for="(val, num) in item.List" :key="val.IndustrialSubjectId" class="industrial" @click="ificationIndustrialBtn(val, num)" :class="num == ificationIndustrial ? 'pitch' : ''">
  65. <span style="margin-right: 19px">{{ val.IndustrialSubjectName }}</span>
  66. <span v-if="num == ificationIndustrial">
  67. <img src="~@/assets/img/icons/edit1.png" style="width: 12px; height: 12px; marginright: 10px" @click="editText(val, num)" />
  68. <i class="el-icon-close" @click="deleteClassify(val, num)"></i>
  69. </span>
  70. </div>
  71. <div class="addIndustrial" @click="addMulti" v-if="industryIndex == index">
  72. <i class="el-icon-plus"></i>
  73. <span>添加标的</span>
  74. </div>
  75. </draggable>
  76. <template v-for="(val, num) in item.List">
  77. <div :key="val.IndustrialSubjectId" v-show="industryIndex == index">
  78. <div class="industrial-is-new" v-show="num == ificationIndustrial">
  79. <el-checkbox v-model="val.IsNew" :true-label="1" :false-label="0">显示new标签</el-checkbox>
  80. </div>
  81. <div style="margin-bottom: 20px; display: flex; align-items: center" v-show="num == ificationIndustrial">
  82. <div style="display: flex; align-items: center" v-for="(son, num) in val.CompanyLabel" :key="num">
  83. <el-input style="width: 260px; margin-right: 15px" v-model="son.name" placeholder="请输入公司标签"></el-input>
  84. <img class="delete-item-icon" v-if="num > 0" @click="deleteLabelItem(val, num)" src="~@/assets/img/icons/delete-Item.png" alt="" />
  85. </div>
  86. <el-tooltip class="item" effect="dark" content="添加标签" placement="top-start">
  87. <img @click="addLabelClick(val)" class="editsty" src="~@/assets/img/set_m/add_ico.png" />
  88. </el-tooltip>
  89. </div>
  90. <rich-text :ref="'twoRich' + num" v-model="val.Body" :spareId="contentValueTwo" :isText="contentTextTwo" v-show="num == ificationIndustrial" />
  91. </div>
  92. </template>
  93. </div>
  94. </div>
  95. </div>
  96. <div>
  97. <div class="content-resource">
  98. <span class="resource">产业资源包:</span>
  99. <span class="show">{{ industrialSubjectName }}</span>
  100. </div>
  101. <div class="content-resource">
  102. <span class="resource">综述报告:</span>
  103. <span class="show">{{ overviewList.Title }}</span>
  104. <div style="margin-left: 20px">
  105. <el-switch @change="switchChangeHandler" v-model="overviewList.IsShowOverviewArticle" :active-value="1" :inactive-value="0" active-text="显示链接" inactive-text="不显示链接">
  106. </el-switch>
  107. </div>
  108. </div>
  109. </div>
  110. <div class="content-bottom">
  111. <el-button type="primary" @click="confirm('预览')">预览</el-button>
  112. <el-button type="primary" @click="confirm('保存')">保存</el-button>
  113. <el-button v-if="isShowStatus" type="primary" @click="confirm('发布')">发布</el-button>
  114. <el-button type="" @click="cancel">取消</el-button>
  115. </div>
  116. </div>
  117. </el-card>
  118. <!-- 弹框部分 -->
  119. <el-dialog v-dialogDrag :close-on-click-modal="false" :modal-append-to-body="false" center :visible.sync="addDialogVisible" width="560px" :before-close="handleClose">
  120. <div slot="title" style="display: flex; align-items: center">
  121. <img :src="dialogText == '编辑' ? $icons.editicon : $icons.add" style="color: #fff; width: 16px; height: 16px; margin-right: 5px" />
  122. <span style="font-size: 16px">{{ dialogText }}</span>
  123. </div>
  124. <div class="dlg-content">
  125. <el-autocomplete class="inline-input" v-model="stateValue" :trigger-on-focus="false" :fetch-suggestions="handleSearchResult" placeholder="请输入标的名称" clearable></el-autocomplete>
  126. </div>
  127. <span slot="footer" class="dialog-footer">
  128. <el-button v-if="dialogText == '编辑'" type="primary" @click="editconfirmPerson">确定</el-button>
  129. <el-button v-else type="primary" @click="confirmPerson">确定</el-button>
  130. <el-button @click="handleClose">取消</el-button>
  131. </span>
  132. </el-dialog>
  133. </div>
  134. </template>
  135. <script>
  136. import RichText from "./richText.vue";
  137. import { raiInterface } from "@/api/api.js";
  138. import draggable from "vuedraggable";
  139. import TemplateMessage from "./apply/templateMessage.vue";
  140. export default {
  141. name: "",
  142. components: { RichText, draggable, TemplateMessage },
  143. props: {},
  144. data() {
  145. return {
  146. contentValue: "one",
  147. contentText: "市场策略核心逻辑汇总",
  148. contentValueTwo: "two",
  149. contentTextTwo: "公司核心逻辑汇总",
  150. contentTextLogic: "行业核心逻辑汇总",
  151. updateMode: "", //更新方式
  152. inheritNum: "", //继承第几
  153. ruleForm: {
  154. title: "", //标题
  155. author: "", //作者
  156. time: "", //时间
  157. explain: "", //说明
  158. reportLink: "", //变更
  159. },
  160. rules: {
  161. title: [{ required: true, message: "请输入标题", trigger: "blur" }],
  162. },
  163. industryList: [], //行业
  164. industryIndex: 0, //
  165. ificationIndustrial: 0,
  166. addDialogVisible: false,
  167. dialogText: "",
  168. stateValue: "",
  169. companyList: [],
  170. timeout: null,
  171. isShowStatus: true,
  172. industrialSubjectName: "",
  173. chartPermissionId: "", //分类id
  174. subjectList: [],
  175. updateModeList: [], //期数的数组
  176. editNum: "",
  177. overviewList: {},
  178. marketStrategy: "",
  179. timeInterval: null, // 定时器
  180. };
  181. },
  182. computed: {},
  183. mounted() {
  184. if (this.$route.query.id) {
  185. this.isShowStatus = this.$route.query.status == 0;
  186. this.getDetail();
  187. } else {
  188. this.getNoTacticsfirst();
  189. this.dataInit();
  190. }
  191. this.getListPeriods();
  192. },
  193. methods: {
  194. // 报告的缓存处理数据
  195. dataInit() {
  196. if (sessionStorage.getItem("addChoicenessQY")) {
  197. let data = JSON.parse(sessionStorage.getItem("addChoicenessQY"));
  198. setTimeout(async () => {
  199. this.industryList = data.industryList;
  200. this.industryIndex = data.industryIndex;
  201. this.ificationIndustrial = data.ificationIndustrial;
  202. this.updateMode = data.updateMode;
  203. this.inheritNum = data.inheritNum;
  204. this.companyList = data.companyList;
  205. this.industrialSubjectName = data.industrialSubjectName;
  206. this.chartPermissionId = data.chartPermissionId;
  207. this.subjectList = data.subjectList;
  208. this.updateModeList = data.updateModeList;
  209. this.editNum = data.editNum;
  210. this.overviewList = data.overviewList;
  211. this.ruleForm = data.ruleForm;
  212. this.marketStrategy = data.MarketStrategy;
  213. }, 200);
  214. }
  215. this.timeInterval = setInterval(() => {
  216. let params = {
  217. industryList: this.industryList,
  218. industryIndex: this.industryIndex,
  219. ificationIndustrial: this.ificationIndustrial,
  220. updateMode: this.updateMode,
  221. inheritNum: this.inheritNum,
  222. companyList: this.companyList,
  223. industrialSubjectName: this.industrialSubjectName,
  224. chartPermissionId: this.chartPermissionId,
  225. subjectList: this.subjectList,
  226. updateModeList: this.updateModeList,
  227. editNum: this.editNum,
  228. overviewList: this.overviewList,
  229. ruleForm: this.ruleForm,
  230. MarketStrategy: this.marketStrategy,
  231. };
  232. sessionStorage.setItem("addChoicenessQY", JSON.stringify(params));
  233. }, 120000);
  234. },
  235. updateModeChange() {
  236. if (this.updateMode == "重新编辑") {
  237. this.init();
  238. this.industryList = [];
  239. this.getNoTacticsfirst();
  240. }
  241. },
  242. //获取编辑详情
  243. async getDetail() {
  244. const res = await raiInterface.reportSelectionDetail({ ArticleId: this.$route.query.id || "", Periods: this.inheritNum || "" });
  245. if (res.Ret === 200) {
  246. res.Data.List.forEach((item) => {
  247. if (!item.List || !item.List.length > 0) {
  248. item.List = [];
  249. }
  250. });
  251. this.updateMode = this.inheritNum ? this.updateMode : res.Data.AddType == "1" ? "重新编辑" : "继承往期";
  252. this.ruleForm = {
  253. title: res.Data.Title, //标题
  254. author: res.Data.Department, //作者
  255. time: res.Data.PublishDate, //时间
  256. explain: res.Data.ProductDescription, //说明
  257. reportLink: res.Data.ReportLink, //变更
  258. };
  259. this.marketStrategy = res.Data.MarketStrategy;
  260. this.inheritNum = this.inheritNum ? this.inheritNum : res.Data.InheritPeriods;
  261. this.industryList = res.Data.List;
  262. setTimeout(() => {
  263. res.Data.List.forEach((item, index) => {
  264. item.List.forEach((key, i) => {
  265. key.CompanyLabel = key.CompanyLabel
  266. ? key.CompanyLabel.map((val, i) => {
  267. let obj = {
  268. name: val,
  269. value: i + 1,
  270. };
  271. return obj;
  272. })
  273. : [
  274. {
  275. name: "",
  276. value: 1,
  277. },
  278. ];
  279. });
  280. });
  281. }, 300);
  282. this.chartPermissionId = res.Data.List[0].ChartPermissionId;
  283. this.industrialSubjectName = res.Data.List[0].List ? res.Data.List[0].List[0].IndustrialManagementName : "";
  284. this.overviewList = {
  285. ArticleId: res.Data.List[0].List && res.Data.List[0].List[0].OverviewArticleId,
  286. Title: res.Data.List[0].List && res.Data.List[0].List[0].OverviewArticleTitle,
  287. IsShowOverviewArticle: res.Data.List[0].List && res.Data.List[0].List[0].IsShowOverviewArticle,
  288. };
  289. }
  290. },
  291. //获取模版
  292. async getNoTacticsfirst() {
  293. const res = await raiInterface.reportSereportSelectiondDetailTemplate();
  294. if (res.Ret === 200) {
  295. this.industryList = res.Data.List;
  296. this.chartPermissionId = res.Data.List[0].ChartPermissionId;
  297. }
  298. },
  299. //点击产业的事件
  300. industryBtn(item, index) {
  301. if (index !== this.industryIndex) {
  302. this.industryIndex = index;
  303. this.chartPermissionId = item.ChartPermissionId;
  304. this.ificationIndustrial = 0;
  305. }
  306. },
  307. //标的的点击事件 处理
  308. ificationIndustrialBtn(item, index) {
  309. if (index !== this.ificationIndustrial) {
  310. this.ificationIndustrial = index;
  311. this.industrialSubjectName = item.IndustrialManagementName || "";
  312. this.overviewList = {
  313. ArticleId: item.OverviewArticleId,
  314. Title: item.OverviewArticleTitle,
  315. IsShowOverviewArticle: item.IsShowOverviewArticle,
  316. };
  317. }
  318. },
  319. //编辑标的
  320. editText(item, index) {
  321. this.dialogText = "编辑";
  322. this.chartPermissionId = item.ChartPermissionId;
  323. this.stateValue = item.IndustrialSubjectName;
  324. this.addDialogVisible = true;
  325. this.editNum = index;
  326. },
  327. //删除标的
  328. deleteClassify(item, index) {
  329. this.$confirm("确定要删除该标的吗?", "提示", {
  330. confirmButtonText: "确定",
  331. cancelButtonText: "取消",
  332. type: "warning",
  333. })
  334. .then(() => {
  335. this.industryList[this.industryIndex].List.splice(index, 1);
  336. this.ificationIndustrial = 0;
  337. this.$message({
  338. type: "success",
  339. message: "删除成功!",
  340. });
  341. })
  342. .catch(() => {
  343. this.$message({
  344. type: "info",
  345. message: "已取消删除",
  346. });
  347. });
  348. },
  349. //添加产业
  350. addMulti() {
  351. this.dialogText = "添加标的";
  352. this.addDialogVisible = true;
  353. },
  354. //弹框的取消事件
  355. handleClose() {
  356. this.stateValue = "";
  357. this.addDialogVisible = false;
  358. },
  359. //弹框的确认事件
  360. async confirmPerson() {
  361. if (this.stateValue) {
  362. const arr = this.subjectList.find((item) => item.SubjectName === this.stateValue);
  363. if (!arr) {
  364. this.$message.error("输入正确的标的");
  365. return;
  366. }
  367. let overviewList = {};
  368. const res = await raiInterface.getReportSelectionArticle({
  369. IndustrialSubjectId: arr.IndustrialSubjectId,
  370. });
  371. if (res.Ret === 200) {
  372. overviewList = res.Data;
  373. }
  374. this.industryList.forEach((item) => {
  375. if (item.ChartPermissionId == this.chartPermissionId) {
  376. if (item.List.length > 0) {
  377. var isNext = item.List.some((item) => item.IndustrialSubjectName == arr.SubjectName);
  378. }
  379. if (isNext) return this.$message.error("标的重复!");
  380. item.List.push({
  381. Body: "",
  382. ChartPermissionId: this.chartPermissionId,
  383. IndustrialManagementId: arr.IndustrialManagementId + "",
  384. IndustrialManagementName: arr.IndustryName,
  385. IndustrialSubjectId: arr.IndustrialSubjectId + "",
  386. IndustrialSubjectName: arr.SubjectName,
  387. CompanyLabel: [{ name: "", value: item.List.length + 1 }],
  388. OverviewArticleId: overviewList.ArticleId,
  389. OverviewArticleTitle: overviewList.Title,
  390. IsShowOverviewArticle: overviewList.IsShowOverviewArticle,
  391. });
  392. }
  393. });
  394. }
  395. this.stateValue = "";
  396. this.addDialogVisible = false;
  397. },
  398. async editconfirmPerson() {
  399. if (this.stateValue) {
  400. const arr = this.subjectList.find((item) => item.SubjectName === this.stateValue);
  401. if (!arr) {
  402. this.$message.error("输入正确的标的");
  403. return;
  404. }
  405. let overviewList = {};
  406. const res = await raiInterface.getReportSelectionArticle({
  407. IndustrialSubjectId: arr.IndustrialSubjectId,
  408. });
  409. if (res.Ret === 200) {
  410. overviewList = res.Data;
  411. }
  412. this.industryList.forEach((item) => {
  413. if (item.ChartPermissionId == this.chartPermissionId) {
  414. if (item.List.length > 0) {
  415. var isNext = item.List.some((item) => item.IndustrialSubjectName == arr.SubjectName);
  416. }
  417. if (isNext) return this.$message.error("标的重复!");
  418. const obj = {
  419. Body: this.$refs.twoRich.value || "",
  420. ChartPermissionId: this.chartPermissionId,
  421. IndustrialManagementId: arr.IndustrialManagementId + "",
  422. IndustrialManagementName: arr.IndustryName,
  423. IndustrialSubjectId: arr.IndustrialSubjectId + "",
  424. IndustrialSubjectName: arr.SubjectName,
  425. CompanyLabel:
  426. item.List[this.editNum].CompanyLabel && item.List[this.editNum].CompanyLabel.length > 0 ? item.List[this.editNum].CompanyLabel : [{ name: "", value: item.List.length + 1 }],
  427. OverviewArticleId: overviewList.ArticleId,
  428. OverviewArticleTitle: overviewList.Title,
  429. IsShowOverviewArticle: overviewList.IsShowOverviewArticle,
  430. };
  431. item.List.splice(this.editNum, 1, obj);
  432. }
  433. });
  434. }
  435. this.stateValue = "";
  436. this.addDialogVisible = false;
  437. },
  438. // 申请内容搜索
  439. async handleSearchResult(data, cb) {
  440. if (data) {
  441. cb([]);
  442. let res = await raiInterface.industrialSubjectSearch({ KeyWord: data, ChartPermissionId: this.chartPermissionId });
  443. if (res.Ret === 200) {
  444. if (res.Data.List && res.Data.List.length > 0) {
  445. let arr = res.Data.List.map((item) => {
  446. return { value: item.SubjectName, ...item };
  447. });
  448. this.subjectList = arr;
  449. cb(arr);
  450. }
  451. }
  452. }
  453. },
  454. //保存 发布
  455. confirm: _.debounce(function (type) {
  456. this.$refs.ruleForm.validate(async (val) => {
  457. if (val) {
  458. let isText = [];
  459. this.industryList.forEach((item) => {
  460. item.List.forEach((key) => {
  461. key.CompanyLabel && key.CompanyLabel.length > 0 && isText.push(key.CompanyLabel.some((val) => val.name));
  462. });
  463. });
  464. if (isText && isText.includes(false)) {
  465. return this.$message.error("请输入公司标签");
  466. }
  467. let params = this.dataHandle(type);
  468. if (type == "预览") {
  469. sessionStorage.setItem("choicenessPre", JSON.stringify(params));
  470. let { href } = this.$router.resolve({ name: "预览报告精选" });
  471. window.open(href, "_blank");
  472. } else {
  473. const res = await raiInterface.industrialSubjectPreserveAndPublish(params);
  474. if (res.Ret === 200) {
  475. clearInterval(this.timeInterval);
  476. sessionStorage.removeItem("addChoicenessQY");
  477. this.$message.success("操作成功!");
  478. this.init();
  479. this.$router.back();
  480. }
  481. }
  482. }
  483. });
  484. }, 500),
  485. //取消
  486. cancel() {
  487. clearInterval(this.timeInterval);
  488. sessionStorage.removeItem("addChoicenessQY");
  489. this.$refs["ruleForm"].resetFields();
  490. this.$router.back();
  491. },
  492. async getListPeriods() {
  493. const res = await raiInterface.industrialSubjectListPeriods();
  494. if (res.Ret === 200) {
  495. this.updateModeList = res.Data.List || [];
  496. }
  497. },
  498. init() {
  499. this.ruleForm = {
  500. title: "", //标题
  501. author: "", //作者
  502. time: "", //时间
  503. explain: "", //说明
  504. reportLink: "", //变更
  505. };
  506. this.$refs["ruleForm"].resetFields();
  507. this.marketStrategy = "";
  508. },
  509. // 标的下添加公司标签
  510. addLabelClick(item) {
  511. item.CompanyLabel.push({ name: "", value: item.CompanyLabel.length + 1 });
  512. },
  513. // 处理保存的数据
  514. dataHandle(type) {
  515. let industryList = _.cloneDeep(this.industryList);
  516. const arr = [];
  517. let ListChartSummary = [];
  518. industryList.forEach((item) => {
  519. item.List.forEach((key) => {
  520. key.CompanyLabel && (key.CompanyLabel = key.CompanyLabel.map((val) => val.name));
  521. arr.push(key);
  522. });
  523. ListChartSummary.push({
  524. ChartPermissionId: item.ChartPermissionId,
  525. BodyChartSummary: item.BodyChartSummary,
  526. ChartPermissionName: item.ChartPermissionName,
  527. ListSubject: [...item.List],
  528. });
  529. });
  530. if (this.marketStrategy == "") {
  531. this.$message.error("市场策略核心逻辑汇总不能为空");
  532. }
  533. let params = {
  534. AddType: this.updateMode == "重新编辑" ? "1" : "2",
  535. ArticleId: this.$route.query.id ? Number(this.$route.query.id) : 0,
  536. Department: this.ruleForm.author,
  537. Title: this.ruleForm.title,
  538. DoType: type == "发布" ? 1 : 0,
  539. MarketStrategy: this.marketStrategy,
  540. InheritPeriods: this.inheritNum,
  541. List: arr,
  542. ProductDescription: this.ruleForm.explain,
  543. PublishDate: this.ruleForm.time,
  544. ReportLink: this.ruleForm.reportLink,
  545. ListChartSummary,
  546. };
  547. return params;
  548. },
  549. deleteLabelItem(item, index) {
  550. item.CompanyLabel.splice(index, 1);
  551. },
  552. switchChangeHandler(e) {
  553. this.industryList.forEach((_) => {
  554. _.List.forEach((item) => {
  555. if (item.OverviewArticleId === this.overviewList.ArticleId) {
  556. item.IsShowOverviewArticle = e;
  557. }
  558. });
  559. });
  560. },
  561. // 拖拽排序更新
  562. sortChange({ oldIndex, newIndex }) {
  563. this.industryIndex = this.sortChangeFun(this.industryIndex, oldIndex, newIndex);
  564. },
  565. //标的拖拽排序更新
  566. ificationSortChange({ oldIndex, newIndex }) {
  567. this.ificationIndustrial = this.sortChangeFun(this.ificationIndustrial, oldIndex, newIndex);
  568. },
  569. // 排序更新后的逻辑
  570. sortChangeFun(currentIndex, oldIndex, newIndex) {
  571. let bigger, smaller;
  572. if (oldIndex > newIndex) {
  573. bigger = oldIndex;
  574. smaller = newIndex;
  575. } else {
  576. bigger = newIndex;
  577. smaller = oldIndex;
  578. }
  579. // 当前算中tab的排序 小于较小的 大于较大的 则不用做变动
  580. if (currentIndex < smaller || currentIndex > bigger) return currentIndex;
  581. // 移动的是当前选中的
  582. if (currentIndex == oldIndex) return newIndex;
  583. if (oldIndex > newIndex) {
  584. // 向左移 加加
  585. currentIndex++;
  586. } else if (oldIndex < newIndex) {
  587. // 向右移 减减
  588. currentIndex--;
  589. }
  590. return currentIndex;
  591. },
  592. onMove(e) {
  593. // 返回false表示不允许停靠
  594. return !!e.relatedContext.element;
  595. },
  596. },
  597. // 路由离开了 清除定时器
  598. beforeRouteLeave(to, from, next) {
  599. clearInterval(this.timeInterval);
  600. next();
  601. },
  602. };
  603. </script>
  604. <style lang="scss">
  605. .add-choiceness {
  606. .el-date-editor.el-input,
  607. .el-select {
  608. width: 100%;
  609. }
  610. .content-resource {
  611. margin: 30px 0 60px;
  612. display: flex;
  613. line-height: 40px;
  614. .resource {
  615. width: 105px;
  616. }
  617. .show {
  618. flex: 1;
  619. height: 40px;
  620. border: 1px solid #aab4cc;
  621. border-radius: 4px;
  622. padding-left: 20px;
  623. }
  624. }
  625. .content-bottom {
  626. width: 100%;
  627. display: flex;
  628. justify-content: center;
  629. .el-button {
  630. padding: 0 30px;
  631. height: 40px;
  632. margin-left: 30px;
  633. }
  634. }
  635. .dlg-content {
  636. width: 100%;
  637. margin: 40px 0 70px;
  638. .inline-input {
  639. width: 100% !important;
  640. }
  641. .el-input {
  642. width: 100% !important;
  643. }
  644. }
  645. .content-module {
  646. margin-top: 30px;
  647. .content-industry {
  648. display: inline-block;
  649. margin: 30px 0;
  650. .content-name {
  651. display: inline-block;
  652. box-sizing: border-box;
  653. padding: 0 24px;
  654. line-height: 38px;
  655. height: 40px;
  656. background: #ecf5ff;
  657. border: 1px solid #b3d8ff;
  658. opacity: 1;
  659. font-weight: 500;
  660. font-size: 16px;
  661. color: #409eff;
  662. border-radius: 4px;
  663. margin-right: 30px;
  664. }
  665. .active {
  666. background-color: #409eff;
  667. color: #fff;
  668. }
  669. }
  670. .addIndustrial {
  671. box-sizing: border-box;
  672. width: 96px;
  673. height: 60px;
  674. padding-top: 10px;
  675. text-align: center;
  676. background: #ecf5ff;
  677. border: 1px solid #b3d8ff;
  678. opacity: 1;
  679. border-radius: 4px;
  680. color: #409eff;
  681. i {
  682. color: #409eff;
  683. font-weight: 700;
  684. padding-bottom: 5px;
  685. }
  686. span {
  687. display: inline-block;
  688. width: 100%;
  689. }
  690. }
  691. }
  692. .classification {
  693. display: flex;
  694. flex-wrap: wrap;
  695. margin-top: 20px;
  696. .industrial {
  697. position: relative;
  698. box-sizing: border-box;
  699. margin-bottom: 15px;
  700. width: 290px;
  701. height: 60px;
  702. line-height: 60px;
  703. text-align: center;
  704. background: #ecf5ff;
  705. font-size: 14px;
  706. margin-right: 30px;
  707. color: #409eff;
  708. border-radius: 4px;
  709. border: 1px solid #b3d8ff;
  710. }
  711. .pitch {
  712. display: flex;
  713. padding: 0 20px;
  714. justify-content: space-between;
  715. background-color: #409eff;
  716. border: none;
  717. color: #fff !important;
  718. }
  719. .addIndustrial {
  720. box-sizing: border-box;
  721. width: 96px;
  722. height: 60px;
  723. padding-top: 10px;
  724. text-align: center;
  725. background: #ecf5ff;
  726. border: 1px solid #b3d8ff;
  727. opacity: 1;
  728. border-radius: 4px;
  729. color: #409eff;
  730. margin-bottom: 15px;
  731. i {
  732. color: #409eff;
  733. font-weight: 700;
  734. padding-bottom: 5px;
  735. }
  736. span {
  737. display: inline-block;
  738. width: 100%;
  739. }
  740. }
  741. }
  742. .industrial-is-new {
  743. margin-bottom: 20px;
  744. }
  745. .delete-item-icon {
  746. width: 20px;
  747. height: 20px;
  748. margin-right: 20px;
  749. }
  750. }
  751. </style>