etaBaseConfig.vue 59 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063
  1. <template>
  2. <div class="eta-base-config">
  3. <div class="nav-type-box">
  4. <span :class="[sectionType===1?'active':'']" @click="sectionType=1">{{$t('SystemManage.BaseConfig.tab01')}}</span>
  5. <span :class="[sectionType===2?'active':'']" @click="sectionType=2" v-if="isShowSource">{{$t('SystemManage.BaseConfig.tab02')}}</span>
  6. </div>
  7. <!-- 通用设置 -->
  8. <template v-if="sectionType==1">
  9. <el-form
  10. :model="formData"
  11. :rules="rules"
  12. label-position="top"
  13. class="base-config-form"
  14. label-width="120px"
  15. ref="baseConfigForm"
  16. >
  17. <div class="part-type-box" style="margin-bottom:40px">
  18. <el-button v-if="isShowLoginConfig" type="primary" :plain="partType===1?false:true" @click="partType=1" :style="{border:'none',color:partType==1?'#fff':'#333'}">{{$t('SystemManage.BaseConfig.sub_tab01')}}</el-button>
  19. <el-button type="primary" :plain="partType===2?false:true" @click="partType=2" :style="{border:'none',color:partType==2?'#fff':'#333'}">{{$t('SystemManage.BaseConfig.sub_tab02')}}</el-button>
  20. <el-button type="primary" :plain="partType===3?false:true" v-if="isShowPPT||isShowEnPPT" @click="partType=3" :style="{border:'none',color:partType==3?'#fff':'#333'}">{{$t('SystemManage.BaseConfig.sub_tab03')}}</el-button>
  21. <div class="btn-wrap" style="text-align: center;float:right">
  22. <el-button type="primary" plain style="width:120px;" @click="cancel">{{$t('Dialog.cancel_btn')}}</el-button>
  23. <el-button type="primary" style="margin-left:20px;width:120px;" @click="saveBaseConfig">{{$t('Dialog.confirm_save_btn')}}</el-button>
  24. </div>
  25. </div>
  26. <div class="scroll-cont">
  27. <!-- 登录设置模块 -->
  28. <div class="part" v-show="partType===1&&isShowLoginConfig">
  29. <div class="side">
  30. <!-- <el-form-item label="国内短信模板" prop="LoginSmsTpId" >
  31. <div class="form-item-type-two sms-type">
  32. <el-input type="text" v-model.trim="formData.LoginSmsTpId" placeholder="请输入国内短信模板ID" style="width: calc(50% - 10px);">
  33. <template slot="suffix">
  34. <el-tooltip content="登陆系统或找回密码或验证身份" placement="top">
  35. <div class="input-suffix">
  36. <img src="~@/assets/img/icons/warn-circle-gray.png" />
  37. </div>
  38. </el-tooltip>
  39. </template>
  40. </el-input>
  41. <el-input type="text" v-model.trim="formData.SmsJhgnAppKey" placeholder="请输入国内短信模板appkey" style="width: calc(50% - 10px);" />
  42. </div>
  43. </el-form-item>
  44. <el-form-item label="国外短信模板" prop="LoginSmsGjTpId" >
  45. <div class="form-item-type-two sms-type">
  46. <el-input type="text" v-model.trim="formData.LoginSmsGjTpId" placeholder="请输入国外短信模板ID" style="width: calc(50% - 10px);">
  47. <template slot="suffix">
  48. <el-tooltip content="登陆系统或找回密码或验证身份" placement="top">
  49. <div class="input-suffix">
  50. <img src="~@/assets/img/icons/warn-circle-gray.png" />
  51. </div>
  52. </el-tooltip>
  53. </template>
  54. </el-input>
  55. <el-input type="text" v-model.trim="formData.SmsJhgjAppKey" placeholder="请输入国外短信模板appkey" style="width: calc(50% - 10px);" />
  56. </div>
  57. </el-form-item> -->
  58. <el-form-item :label="$t('SystemManage.BaseConfig.email_tem')" prop="LoginEmailTemplateSubject" >
  59. <div class="form-item-type-two">
  60. <el-input type="text" v-model="formData.LoginEmailTemplateSubject" :placeholder="$t('SystemManage.BaseConfig.email_placeholder')" >
  61. <template slot="suffix">
  62. <el-tooltip :content="$t('SystemManage.BaseConfig.email_tips')" placement="top">
  63. <div class="input-suffix">
  64. <img src="~@/assets/img/icons/warn-circle-gray.png" />
  65. </div>
  66. </el-tooltip>
  67. </template>
  68. </el-input>
  69. </div>
  70. </el-form-item>
  71. <el-form-item prop="LoginEmailTemplateContent" >
  72. <froala id="email-content-editor"
  73. ref="emailContentEditor"
  74. tag="textarea"
  75. :config="{...disclaimerConfig,...emailEditorConfig}" v-model="formData.LoginEmailTemplateContent">
  76. </froala>
  77. <ConfigAnnotation picName="emailContentTemplate" @showImage="previewImage" picHintText="" :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  78. </el-form-item>
  79. </div>
  80. <div class="side">
  81. <el-form-item :label="$t('SystemManage.BaseConfig.login_info')" prop="ICPLicense">
  82. <el-input type="text" v-model="formData.ICPLicense" :placeholder="$t('SystemManage.BaseConfig.login_info_pld')" />
  83. <ConfigAnnotation picHintText="" picName="ICPLicense" @showImage="previewImage"/>
  84. </el-form-item>
  85. <el-form-item :label="$t('SystemManage.BaseConfig.login_title')" prop="ETATitle">
  86. <el-input type="text" v-model="formData.ETATitle" placeholder="$t('SystemManage.BaseConfig.login_title_pld')" />
  87. <ConfigAnnotation picHintText="" picName="ETATitle" @showImage="previewImage"/>
  88. </el-form-item>
  89. <!-- <el-form-item :label="login_name" prop="TabName">
  90. <el-input type="text" v-model="formData.TabName" placeholder="$t('SystemManage.BaseConfig.login_name_pld')" />
  91. <ConfigAnnotation picHintText="" picName="TabName" @showImage="previewImage"/>
  92. </el-form-item> -->
  93. <div class="inline-form-item-box" v-if="permissionBtn.isShowBtn('baseConfigPermission','etaBaseConfig_login_websiteName_pc') ||
  94. permissionBtn.isShowBtn('baseConfigPermission','etaBaseConfig_login_websiteName_mobile')">
  95. <div class="line-form-item-name">{{$t('SystemManage.BaseConfig.website_name')}}</div>
  96. <div class="line-form-item">
  97. <el-form-item :label="$t('SystemManage.BaseConfig.pc')" prop="TabName"
  98. v-permission="permissionBtn.baseConfigPermission.etaBaseConfig_login_websiteName_pc">
  99. <el-input type="text" v-model="formData.TabName" :placeholder="$t('SystemManage.BaseConfig.pc_website_title_Tip')" />
  100. <ConfigAnnotation picHintText="" picName="TabName" @showImage="previewImage"
  101. :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  102. </el-form-item>
  103. <el-form-item :label="$t('SystemManage.BaseConfig.mobile')" prop="TabNameMobile"
  104. v-permission="permissionBtn.baseConfigPermission.etaBaseConfig_login_websiteName_mobile">
  105. <el-input type="text" v-model="formData.TabNameMobile" :placeholder="$t('SystemManage.BaseConfig.mobile_website_title_Tip')" />
  106. <ConfigAnnotation picHintText="" picName="TabNameMobile" @showImage="previewImage"
  107. :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  108. </el-form-item>
  109. </div>
  110. </div>
  111. </div>
  112. <div class="side">
  113. <div class="inline-form-item-box" v-if="permissionBtn.isShowBtn('baseConfigPermission','etaBaseConfig_login_systemLogo_pc') ||
  114. permissionBtn.isShowBtn('baseConfigPermission','etaBaseConfig_login_systemLogo_mobile')">
  115. <div class="line-form-item-name">{{ $t('SystemManage.BaseConfig.system_logo') }}</div>
  116. <div class="line-form-item-name" style="line-height: 30px;" v-permission="permissionBtn.baseConfigPermission.etaBaseConfig_login_systemLogo_pc">{{ $t('SystemManage.BaseConfig.pc') }}</div>
  117. <div class="line-form-item" v-permission="permissionBtn.baseConfigPermission.etaBaseConfig_login_systemLogo_pc">
  118. <el-form-item :label="`${$t('SystemManage.BaseConfig.chinese_version')}(${$t('SystemManage.BaseConfig.recommended_ratio')})`" prop="LogoCN">
  119. <ImgUpload
  120. id="logo-image"
  121. :imgUrl="formData.LogoCN"
  122. :text="$t('SystemManage.BaseConfig.upload_image_tip')"
  123. @showImage="showImage"
  124. @upload="(file)=>handleUploadImage(file,'LogoCN')"
  125. @remove="deleteFormImg('LogoCN')"
  126. />
  127. <ConfigAnnotation picHintText="" picName="LogoCN" @showImage="previewImage" :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  128. </el-form-item>
  129. <el-form-item :label="`${$t('SystemManage.BaseConfig.english_version')}(${$t('SystemManage.BaseConfig.recommended_ratio')})`" prop="LogoEN">
  130. <ImgUpload
  131. id="logo-image"
  132. :imgUrl="formData.LogoEN"
  133. :text="$t('SystemManage.BaseConfig.upload_image_tip')"
  134. @showImage="showImage"
  135. @upload="(file)=>handleUploadImage(file,'LogoEN')"
  136. @remove="deleteFormImg('LogoEN')"
  137. />
  138. <ConfigAnnotation picHintText="" picName="LogoEN" @showImage="previewImage" :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  139. </el-form-item>
  140. </div>
  141. <div class="line-form-item" v-permission="permissionBtn.baseConfigPermission.etaBaseConfig_login_systemLogo_mobile">
  142. <el-form-item :label="$t('SystemManage.BaseConfig.mobile')" prop="LogoMobile" style="width: 50%;">
  143. <ImgUpload
  144. id="logo-image"
  145. :imgUrl="formData.LogoMobile"
  146. :text="$t('SystemManage.BaseConfig.upload_image_tip')"
  147. @showImage="showImage"
  148. @upload="(file)=>handleUploadImage(file,'LogoMobile')"
  149. @remove="deleteFormImg('LogoMobile')"
  150. />
  151. <ConfigAnnotation picHintText="" picName="LogoMobile" @showImage="previewImage" :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  152. </el-form-item>
  153. <div style="width: 50%;"></div>
  154. </div>
  155. </div>
  156. </div>
  157. </div>
  158. <!-- 研报设置 -->
  159. <div class="part" v-show="partType===2">
  160. <div class="side">
  161. <el-form-item :label="$t('SystemManage.BaseConfig.company_name')" prop="CompanyName">
  162. <el-input type="text" v-model="formData.CompanyName" :placeholder="$t('SystemManage.BaseConfig.company_name_placeholder')" />
  163. <ConfigAnnotation picHintText="" :buttonText="$t('SystemManage.BaseConfig.view_example_text')" picName="CompanyName" @showImage="previewImage"/>
  164. </el-form-item>
  165. <el-form-item :label="$t('SystemManage.BaseConfig.compay_mark')" prop="CompanyWatermark" class="watermark">
  166. <ImgUpload
  167. :imgUrl="formData.CompanyWatermark"
  168. @showImage="showImage"
  169. @upload="(file)=>handleUploadImage(file,'CompanyWatermark')"
  170. @remove="deleteFormImg('CompanyWatermark')"
  171. />
  172. <!-- 后面可能会有新的选项 -->
  173. <div style="position: absolute;top: -40px;left: 140px;display:flex;gap:0 20px">
  174. <el-checkbox-group v-if="isShowYBChart"
  175. v-model="checkList" >
  176. <el-checkbox label="研报图表">{{$t('SystemManage.BaseConfig.report_chart')}}</el-checkbox>
  177. </el-checkbox-group>
  178. <div v-if="isShowYBShare">
  179. <el-checkbox label="研报分享" v-model="formData.WatermarkReport">{{$t('SystemManage.BaseConfig.report_share')}}</el-checkbox>
  180. <el-tooltip
  181. effect="dark"
  182. :content="$t('SystemManage.BaseConfig.report_share_tips')"
  183. placement="top"
  184. >
  185. <i class="el-icon-warning"></i>
  186. </el-tooltip>
  187. </div>
  188. </div>
  189. <ConfigAnnotation :picHintText="$t('SystemManage.BaseConfig.upload_format')" :buttonText="$t('SystemManage.BaseConfig.view_example_text')" picName="CompanyWatermark" @showImage="previewImage"/>
  190. </el-form-item>
  191. <el-form-item>
  192. <template slot="label">
  193. <span><!-- 研报表格字体 -->{{$t('SystemManage.BaseConfig.report_sheet_size')}}</span>
  194. <el-tooltip class="item" effect="dark" :content="ReportSheetTip" placement="top-start">
  195. <i class="el-icon-warning"/>
  196. </el-tooltip>
  197. </template>
  198. <div class="flex-wrap">
  199. <div v-for="item in reportFromType" :key="item.type">
  200. <label>{{item.label}}</label>
  201. <el-select v-model="formData.SmartReportSheetSize" style="width:80px;" v-if="item.type==='smartReport'">
  202. <el-option
  203. v-for="size in sizeOptions"
  204. :key="size.val"
  205. :label="size.label"
  206. :value="size.val"
  207. />
  208. </el-select>
  209. <el-select v-model="formData.ReportSheetSize" style="width:80px;" v-else-if="item.type==='report'">
  210. <el-option
  211. v-for="size in sizeOptions"
  212. :key="size.val"
  213. :label="size.label"
  214. :value="size.val"
  215. />
  216. </el-select>
  217. <el-select v-model="formData.EnReportSheetSize" style="width:80px;" v-else-if="item.type==='enReport'">
  218. <el-option
  219. v-for="size in sizeOptions"
  220. :key="size.val"
  221. :label="size.label"
  222. :value="size.val"
  223. />
  224. </el-select>
  225. </div>
  226. </div>
  227. </el-form-item>
  228. <div v-if="isShowXunFei">
  229. <!-- 科大讯飞 -->
  230. <div style="width:100%;">
  231. <span style="color:#606266;">{{$t('SystemManage.BaseConfig.iFLYTEK_service')}}</span>
  232. <el-switch v-model="Iflytek"></el-switch>
  233. </div>
  234. <template v-if="Iflytek">
  235. <el-form-item label="APPID" prop="XfAppid">
  236. <el-input type="text" v-model="formData.XfAppid" :placeholder="$t('SystemManage.BaseConfig.please_enter')+'APPID'" />
  237. </el-form-item>
  238. <el-form-item label="APIKey" prop="XfApiKey">
  239. <el-input type="text" v-model="formData.XfApiKey" :placeholder="$t('SystemManage.BaseConfig.please_enter')+'APIKey'" />
  240. </el-form-item>
  241. <el-form-item label="APISecret" prop="XfApiSecret">
  242. <el-input type="text" v-model="formData.XfApiSecret" :placeholder="$t('SystemManage.BaseConfig.please_enter')+'APISecret'" />
  243. </el-form-item>
  244. <el-form-item label="vcn(voice_name)" prop="XfVcn">
  245. <el-input type="text" v-model="formData.XfVcn" :placeholder="$t('SystemManage.BaseConfig.please_enter')+'voice_name'" />
  246. </el-form-item>
  247. </template>
  248. </div>
  249. <!-- 研报审批 -->
  250. <div v-if="isShowApprove">
  251. <div style="width:100%;margin-bottom: 20px;">
  252. <span style="color:#606266;">{{$t('SystemManage.BaseConfig.report_approval')}}</span>
  253. <el-switch v-model="approve"></el-switch>
  254. </div>
  255. <div class="side" v-if="approve">
  256. <el-form-item label="" prop="ReportApproveType">
  257. <el-radio-group v-model="formData.ReportApproveType">
  258. <el-radio label="eta">{{$t('SystemManage.BaseConfig.internal_approval')}}</el-radio>
  259. <el-radio label="other">
  260. <span>{{$t('SystemManage.BaseConfig.third_approval')}}</span>
  261. <el-tooltip effect="dark" placement="top" :content="$t('SystemManage.BaseConfig.third_approval_tips')" >
  262. <span class="hint-text">
  263. <i class="el-icon-warning-outline"></i>
  264. </span>
  265. </el-tooltip>
  266. </el-radio>
  267. </el-radio-group>
  268. </el-form-item>
  269. </div>
  270. </div>
  271. </div>
  272. <div class="side">
  273. <el-form-item :label="$t('SystemManage.BaseConfig.disclaimer')" prop="Disclaimer" class="disclaimer">
  274. <div class="rich-editor-wrap">
  275. <froala :id="`disclaimer-editor`"
  276. :ref="`disclaimerEditor`"
  277. :tag="'textarea'"
  278. :config="disclaimerConfig" v-model="formData.Disclaimer">
  279. </froala>
  280. </div>
  281. <ConfigAnnotation picHintText="" :buttonText="$t('SystemManage.BaseConfig.view_example_text')" picName="Disclaimer" @showImage="previewImage"/>
  282. </el-form-item>
  283. <el-form-item :label="$t('SystemManage.BaseConfig.report_share_title_zh')" prop="H5ShareName">
  284. <el-input type="text" v-model="formData.H5ShareName" :placeholder="$t('SystemManage.BaseConfig.report_share_title_zh_placeholder')" />
  285. </el-form-item>
  286. <el-form-item :label="$t('SystemManage.BaseConfig.report_share_title_en')" prop="H5ShareEnName" v-if="isShowReportEnShare">
  287. <el-input type="text" v-model="formData.H5ShareEnName" :placeholder="$t('SystemManage.BaseConfig.report_share_title_en_placeholder')" />
  288. </el-form-item>
  289. <el-form-item :label="$t('SystemManage.BaseConfig.connect_wx')" prop="WxAppId">
  290. <el-input type="text" v-model.trim="formData.WxAppId" :placeholder="$t('SystemManage.BaseConfig.please_enter')+'AppID'" />
  291. </el-form-item>
  292. <el-form-item prop="WxAppSecret">
  293. <el-input type="text" v-model.trim="formData.WxAppSecret" :placeholder="$t('SystemManage.BaseConfig.please_enter')+'AppSecret'" />
  294. </el-form-item>
  295. <el-form-item prop="WxId">
  296. <el-input type="text" v-model.trim="formData.WxId" :placeholder="$t('SystemManage.BaseConfig.wx_original_id')" />
  297. </el-form-item>
  298. <div class="input-hint">{{$t('SystemManage.BaseConfig.wx_original_tips')}}</div>
  299. <el-form-item prop="H5ReportShareImg">
  300. <ImgUpload
  301. :imgUrl="formData.H5ReportShareImg"
  302. @showImage="showImage"
  303. @upload="(file)=>handleUploadImage(file,'H5ReportShareImg')"
  304. @remove="deleteFormImg('H5ReportShareImg')"
  305. />
  306. <!-- <ConfigAnnotation picName="OfficialAccountsLogoPic" @showImage="previewImage"
  307. picHintText=""/> -->
  308. </el-form-item>
  309. </div>
  310. </div>
  311. <!-- PPT配置 -->
  312. <div class="part" v-if="isShowPPT||isShowEnPPT" v-show="partType===3">
  313. <el-radio-group v-model="pptLang" style="margin-bottom: 22px;">
  314. <el-radio-button label="cn">{{$t('SystemManage.BaseConfig.ppt_zh')}}</el-radio-button>
  315. <el-radio-button label="en" v-permission="permissionBtn.enPPTPermission.pptEn_visible">{{$t('SystemManage.BaseConfig.ppt_en')}}</el-radio-button>
  316. </el-radio-group>
  317. <div v-if="isShowPPT" v-show="pptLang === 'cn'" class="ppt-form-item-wrap">
  318. <!-- <div class="inner-input-wrap">
  319. <el-form-item label="公司名称" prop="PptCompanyName" class="inline-form-item">
  320. <el-input type="text" v-model="formData.PptCompanyName"></el-input>
  321. </el-form-item>
  322. <el-form-item label="团队名称" prop="PptTeamName" class="inline-form-item">
  323. <el-input type="text" v-model="formData.PptTeamName"></el-input>
  324. </el-form-item>
  325. <el-form-item label="字体颜色" prop="PptFontColor" class="inline-form-item">
  326. <el-input type="color" style="width:64px;" v-model="formData.PptFontColor"></el-input>
  327. </el-form-item>
  328. </div> -->
  329. <el-form-item :label="$t('SystemManage.BaseConfig.ppt_type01')" prop="CnPptCoverImgs" style="min-width:400px;">
  330. <div class="input-line" style="display:flex;">
  331. <ImgUpload
  332. :imgUrl="formData.CnPptCoverImgs.length===3?formData.CnPptCoverImgs[2]:''"
  333. @showImage="(arr)=>{showImageOrder({list:formData.CnPptCoverImgs,item:arr[0]})}"
  334. @upload="(file)=>handleUploadImage(file,'CnPptCoverImgs')"
  335. @remove="deleteFormImg('CnPptCoverImgs',formData.CnPptCoverImgs.length-1)"
  336. />
  337. <ImgThumbnail
  338. :imgList="formData.CnPptCoverImgs.length===3?formData.CnPptCoverImgs.slice(0,2):formData.CnPptCoverImgs"
  339. @showImage="({item})=>{showImageOrder({list:formData.CnPptCoverImgs,item})}"
  340. @deleteImg="(index)=>{deleteFormImg('CnPptCoverImgs',index)}"/>
  341. </div>
  342. <ConfigAnnotation picName="pptCoverList" @showImage="previewImage"
  343. :picHintText="$t('SystemManage.BaseConfig.ppt_tip01')"
  344. :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  345. </el-form-item>
  346. <el-form-item :label="$t('SystemManage.BaseConfig.ppt_type02')" prop="CnPptBackgroundImg">
  347. <ImgUpload
  348. :imgUrl="formData.CnPptBackgroundImg"
  349. @showImage="showImage"
  350. @upload="(file)=>handleUploadImage(file,'CnPptBackgroundImg')"
  351. @remove="deleteFormImg('CnPptBackgroundImg')"
  352. />
  353. <ConfigAnnotation picName="pptBgPic" @showImage="previewImage"
  354. :picHintText="$t('SystemManage.BaseConfig.ppt_tip02')"
  355. :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  356. </el-form-item>
  357. <el-form-item :label="$t('SystemManage.BaseConfig.ppt_type03')" prop="CnPptBottomImg">
  358. <ImgUpload
  359. :imgUrl="formData.CnPptBottomImg"
  360. @showImage="showImage"
  361. @upload="(file)=>handleUploadImage(file,'CnPptBottomImg')"
  362. @remove="deleteFormImg('CnPptBottomImg')"
  363. />
  364. <ConfigAnnotation picName="pptBackPic" @showImage="previewImage"
  365. :picHintText="$t('SystemManage.BaseConfig.ppt_tip03')"
  366. :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  367. </el-form-item>
  368. <el-form-item label="PPT表格" prop="CnPptSheetSize">
  369. <template slot="label">
  370. <span>
  371. <!-- PPT表格 -->{{$t('SystemManage.BaseConfig.ppt_sheet')}}
  372. <el-tooltip class="item" effect="dark" :content="pptSheetTip" placement="top-start">
  373. <i class="el-icon-warning"/>
  374. </el-tooltip>
  375. </span>
  376. </template>
  377. <el-select v-model="formData.CnPptSheetSize" style="width:120px;">
  378. <el-option
  379. v-for="size in sizeOptions"
  380. :key="size.val"
  381. :label="size.label"
  382. :value="size.val"
  383. />
  384. </el-select>
  385. </el-form-item>
  386. </div>
  387. <div v-if="isShowEnPPT" v-show="pptLang === 'en'" class="ppt-form-item-wrap">
  388. <!-- <div class="inner-input-wrap">
  389. <el-form-item label="公司名称" prop="PptCompanyNameEn" class="inline-form-item">
  390. <el-input type="text" v-model="formData.PptCompanyNameEn"></el-input>
  391. </el-form-item>
  392. <el-form-item label="团队名称" prop="PptTeamNameEn" class="inline-form-item">
  393. <el-input type="text" v-model="formData.PptTeamNameEn"></el-input>
  394. </el-form-item>
  395. <el-form-item label="字体颜色" prop="PptFontColorEn" class="inline-form-item">
  396. <el-input type="color" style="width:64px;" v-model="formData.PptFontColorEn"></el-input>
  397. </el-form-item>
  398. </div> -->
  399. <el-form-item :label="$t('SystemManage.BaseConfig.ppt_type01')" prop="EnPptCoverImgs" style="min-width:400px;">
  400. <div class="input-line" style="display:flex;">
  401. <ImgUpload
  402. :imgUrl="formData.EnPptCoverImgs.length===3?formData.EnPptCoverImgs[2]:''"
  403. @showImage="(arr)=>{showImageOrder({list:formData.EnPptCoverImgs,item:arr[0]})}"
  404. @upload="(file)=>handleUploadImage(file,'EnPptCoverImgs')"
  405. @remove="deleteFormImg('EnPptCoverImgs',formData.EnPptCoverImgs.length-1)"
  406. />
  407. <ImgThumbnail
  408. :imgList="formData.EnPptCoverImgs.length===3?formData.EnPptCoverImgs.slice(0,2):formData.EnPptCoverImgs"
  409. @showImage="({item})=>{showImageOrder({list:formData.EnPptCoverImgs,item})}"
  410. @deleteImg="(index)=>{deleteFormImg('EnPptCoverImgs',index)}"/>
  411. </div>
  412. <ConfigAnnotation picName="pptCoverList" @showImage="previewImage"
  413. :picHintText="$t('SystemManage.BaseConfig.ppt_tip01')"
  414. :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  415. </el-form-item>
  416. <el-form-item :label="$t('SystemManage.BaseConfig.ppt_type02')" prop="EnPptBackgroundImg">
  417. <ImgUpload
  418. :imgUrl="formData.EnPptBackgroundImg"
  419. @showImage="showImage"
  420. @upload="(file)=>handleUploadImage(file,'EnPptBackgroundImg')"
  421. @remove="deleteFormImg('EnPptBackgroundImg')"
  422. />
  423. <ConfigAnnotation picName="pptBgPic" @showImage="previewImage"
  424. :picHintText="$t('SystemManage.BaseConfig.ppt_tip02')"
  425. :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  426. </el-form-item>
  427. <el-form-item :label="$t('SystemManage.BaseConfig.ppt_type03')" prop="EnPptBottomImg">
  428. <ImgUpload
  429. :imgUrl="formData.EnPptBottomImg"
  430. @showImage="showImage"
  431. @upload="(file)=>handleUploadImage(file,'EnPptBottomImg')"
  432. @remove="deleteFormImg('EnPptBottomImg')"
  433. />
  434. <ConfigAnnotation picName="pptBackPic" @showImage="previewImage"
  435. :picHintText="$t('SystemManage.BaseConfig.ppt_tip03')"
  436. :buttonText="$t('SystemManage.BaseConfig.view_example_text')"/>
  437. </el-form-item>
  438. <el-form-item label="PPT表格" prop="CnPptSheetSize">
  439. <template slot="label">
  440. <span>
  441. <!-- PPT表格 -->{{$t('SystemManage.BaseConfig.ppt_sheet')}}
  442. <el-tooltip class="item" effect="dark" :content="pptSheetTip" placement="top-start">
  443. <i class="el-icon-warning"/>
  444. </el-tooltip>
  445. </span>
  446. </template>
  447. <el-select v-model="formData.EnPptSheetSize" style="width:120px;">
  448. <el-option
  449. v-for="size in sizeOptions"
  450. :key="size.val"
  451. :label="size.label"
  452. :value="size.val"
  453. />
  454. </el-select>
  455. </el-form-item>
  456. </div>
  457. </div>
  458. </div>
  459. </el-form>
  460. </template>
  461. <template v-if="sectionType==2&&isShowSource">
  462. <div class="smart-report-title">{{$t('SystemManage.BaseConfig.smart_layout_resource_library')}}</div>
  463. <!-- 资源库 -->
  464. <smartReportImgSet />
  465. </template>
  466. <el-image-viewer
  467. v-if="showViewer"
  468. :on-close="()=>{this.picShowList=[];this.showViewer = false}"
  469. :url-list="picShowList" />
  470. </div>
  471. </template>
  472. <script>
  473. import ImgThumbnail from './components/imgThumbnail.vue';
  474. import ImgUpload from './components/imgUpload.vue';
  475. import ConfigAnnotation from './components/configAnnotation.vue';
  476. import ElImageViewer from 'element-ui/packages/image/src/image-viewer';
  477. import smartReportImgSet from './components/smartReportImgSet.vue'
  478. import {bannerupload} from '@/api/api.js';
  479. import {etaBaseConfigInterence} from '@/api/modules/etaBaseConfigApi.js';
  480. export default {
  481. components: { ConfigAnnotation , ElImageViewer , ImgThumbnail , ImgUpload,smartReportImgSet},
  482. data() {
  483. let ListValidator = (rule,value,callback)=>{
  484. if(!value.length){
  485. return callback(new Error('请至少选择一张封面图'))
  486. }else{
  487. return callback()
  488. }
  489. }
  490. return {
  491. /* base config */
  492. checkList:[],//水印应用
  493. Iflytek:false,//是否启用科大讯飞服务
  494. approve:false,//是否开启研报审批
  495. formData: {
  496. Disclaimer: '',//免责声明
  497. CompanyName:'',//公司名称
  498. CompanyWatermark:'',//公司水印
  499. WatermarkChart:0,//是否在研报图表中使用水印 0否 1是
  500. LoginSmsTpId:'',//国内短信模板Id
  501. SmsJhgnAppKey:'',//国内短信模板appKey
  502. LoginSmsGjTpId:'',// 国际短信模板Id
  503. SmsJhgjAppKey:'',//国内短信模板appKey
  504. LoginEmailTemplateSubject:'', // 邮件标题
  505. LoginEmailTemplateContent:'', // 邮件内容
  506. H5ShareName:'', // 中文研报分享标题
  507. H5ShareEnName:'', // 英文研报分享标题
  508. WxAppId:'',
  509. WxAppSecret:'',
  510. WxId:'',
  511. H5ReportShareImg:'',
  512. SmartReportSheetSize: '12',//智能研报表格字号
  513. ReportSheetSize: '12',//研报表格字号
  514. EnReportSheetSize: '12',//英文研报表格字号
  515. UseXf:0,//是否启用科大讯飞服务 0否 1是
  516. XfAppid:'',
  517. XfApiKey:'',
  518. XfApiSecret:'',
  519. XfVcn:'',
  520. CnPptCoverImgs:[],//ppt封面列表
  521. CnPptBackgroundImg:'',//ppt背景图
  522. CnPptBottomImg:'',//ppt封底图
  523. EnPptCoverImgs:[],//英文ppt封面列表
  524. EnPptBackgroundImg:'',//英文ppt背景图
  525. EnPptBottomImg:'',//英文ppt封底图
  526. CnPptSheetSize: '12',//中文ppt表格字号
  527. EnPptSheetSize: '12',//英文ppt表格字号
  528. WatermarkReport:false,//研报分享水印
  529. IsReportApprove:false,//是否开启研报审批
  530. ReportApproveType:'eta',//研报审批选项
  531. ICPLicense:'', //备案信息
  532. ETATitle:'', //登录页标题
  533. TabName:'',//网页名称-PC端
  534. TabNameMobile:'',//网页名称-移动端
  535. LogoCN:'',//logo-中文版
  536. LogoEN:'',//logo-英文版
  537. LogoMobile:'',//logo-移动端登录页
  538. },//表单预设值
  539. rules: {
  540. Disclaimer:[{ required: true, message: '请输入免责声明', trigger: 'blur' }],
  541. CompanyName:[{ required: true, message: '请输入公司名称', trigger: 'blur' }],
  542. LoginSmsTpId:[{ required: true, message: '请输入国内短信模板ID', trigger: 'blur' },
  543. {
  544. validator:(rules,value,callback)=>{
  545. if(!this.formData.SmsJhgnAppKey){
  546. callback(new Error("请输入国内短信模板appkey"))
  547. }else{
  548. callback()
  549. }
  550. },
  551. trigger: 'blur'
  552. }],
  553. LoginEmailTemplateSubject:[{ required: true, message: '请输入邮件标题', trigger: 'blur' }],
  554. LoginEmailTemplateContent:[{ required: true, message: '请输入邮件内容', trigger: 'blur' }],
  555. H5ShareName:[{ required: true, message: '请输入中文研报分享标题', trigger: 'blur' }],
  556. H5ShareEnName:[{ required: true, message: '请输入英文研报分享标题', trigger: 'blur' }],
  557. //CompanyWatermark:[{ required: true, message: '请选择水印图片', trigger: 'blur' }],
  558. CnPptBackgroundImg:[{ required: true, message: '请选择中文PPT背景图', trigger: 'blur' }],
  559. EnPptBackgroundImg:[{ required: true, message: '请选择英文PPT背景图', trigger: 'blur' }],
  560. XfAppid:[{ required: true, message: '请输入APPID', trigger: 'blur' }],
  561. XfApiKey:[{ required: true, message: '请输入APIKey', trigger: 'blur' }],
  562. XfApiSecret:[{ required: true, message: '请输入APISecret', trigger: 'blur' }],
  563. XfVcn:[{ required: true, message: '请输入voice_name', trigger: 'blur' }],
  564. CnPptCoverImgs:[{ required: true, validator:ListValidator}],
  565. EnPptCoverImgs:[{ required: true, validator:ListValidator}],
  566. ETATitle:[{ required: true, message: '请输入登录页标题', trigger: 'blur' }],
  567. TabName:[{ required: true, message: '请输入PC端网页名称', trigger: 'blur' }],
  568. TabNameMobile:[{ required: true, message: '请输入移动端网页名称', trigger: 'blur' }],
  569. LogoCN:[{ required: true, message: '请上传系统中文版Logo', trigger: 'blur' }],
  570. LogoEN:[{ required: true, message: '请上传系统英文版Logo', trigger: 'blur' }],
  571. LogoMobile:[{ required: true, message: '请上传系统移动端Logo', trigger: 'blur' }],
  572. },//表单校验
  573. disclaimerConfig:{
  574. toolbarButtons:[
  575. 'textColor',
  576. 'bold',
  577. 'italic',
  578. 'underline',
  579. 'fontFamily',
  580. 'fontSize',
  581. 'align',
  582. 'outdent',
  583. 'indent',
  584. 'specialCharacters',
  585. 'insertHR',
  586. 'selectAll',
  587. 'clearFormatting',
  588. 'undo',
  589. 'redo',
  590. ],
  591. height:300,
  592. fontSizeDefaultSelection: "16",
  593. quickInsertEnabled: false,
  594. pasteAllowedStyleProps: ['font-family', 'font-size', 'color'],
  595. language: "zh_cn",
  596. placeholderText:'请输入免责声明',
  597. wordPasteKeepFormatting:false,
  598. pastePlain:true,
  599. wordPasteModal:false,
  600. pluginsEnabled:['colors'],//定义可用插件
  601. },//富文本编辑器配置项
  602. emailEditorConfig:{
  603. placeholderText:'请输入邮件内容',
  604. },
  605. /* ppt config */
  606. pptLang:'cn',//切换中英文表单
  607. CnPptCoverImgs:[],//中文封面列表
  608. EnPptCoverImgs:[],//英文封面列表
  609. /* image preview */
  610. showViewer:false,//控制图片预览组件展示
  611. picShowList:[],//ElImageViewer组件展示图片的列表
  612. picShowMap:{ //查看示意图需要展示的图片 支持多张
  613. 'Disclaimer':[
  614. require('@/assets/img/eta_base_config/disclaimer_1.jpg'),
  615. require('@/assets/img/eta_base_config/disclaimer_2.jpg'),
  616. ],
  617. 'CompanyName':[require('@/assets/img/eta_base_config/company_1.jpg')],
  618. 'CompanyWatermark':[require('@/assets/img/eta_base_config/mark_1.jpg')],
  619. 'pptCoverList':[require('@/assets/img/eta_base_config/ppt_cover.jpg')],
  620. 'pptBgPic':[require('@/assets/img/eta_base_config/ppt_bgpic.jpg')],
  621. 'pptBackPic':[require('@/assets/img/eta_base_config/ppt_back.jpg')],
  622. 'emailContentTemplate':[require('@/assets/img/eta_base_config/email_content_template.png')],
  623. 'ICPLicense':[require('@/assets/img/eta_base_config/record_information.jpg')],
  624. 'ETATitle':[require('@/assets/img/eta_base_config/ETA_title.png')],
  625. 'TabName':[require('@/assets/img/eta_base_config/website_title.png')],
  626. 'TabNameMobile':[require('@/assets/img/eta_base_config/ETA_mobile_title.png')],
  627. 'LogoCN':[require('@/assets/img/eta_base_config/Logo_ch.png')],
  628. 'LogoEN':[require('@/assets/img/eta_base_config/Logo_en.png')],
  629. 'LogoMobile':[require('@/assets/img/eta_base_config/ETA_mobile_logo.png')],
  630. },
  631. /* loading */
  632. configLoading:null,
  633. partType:1,//1登陆设置 2研报设置 3PPT配置
  634. sectionType:1,//1通用设置 2资源库
  635. reportFromType: [
  636. // { type:'smartReport',label: /* '智能研报' */ this.$t('SystemManage.BaseConfig.report_type1') },
  637. { type:'report',label: /* '研报列表' */this.$t('SystemManage.BaseConfig.report_type2') },
  638. { type:'enReport',label: /* '英文研报' */this.$t('SystemManage.BaseConfig.report_type3') },
  639. ],
  640. pptSheetTip: /* `设置共享表格、时间序列表格、混合表格插入PPT的表格字号` */this.$t('SystemManage.BaseConfig.ppt_sheet_tip'),
  641. ReportSheetTip: /* `设置共享表格、时间序列表格、混合表格插入研报的表格字号` */this.$t('SystemManage.BaseConfig.report_sheet_tip'),
  642. sizeOptions: [
  643. { label:'5',val:'5' },
  644. { label:'6',val:'6' },
  645. { label:'7',val:'7' },
  646. { label:'8',val:'8' },
  647. { label:'9',val:'9' },
  648. { label:'10',val:'10' },
  649. { label:'11',val:'11' },
  650. { label:'12',val:'12' },
  651. { label:'13',val:'13' },
  652. { label:'14',val:'14' },
  653. { label:'15',val:'15' },
  654. { label:'16',val:'16' },
  655. { label:'17',val:'17' },
  656. { label:'18',val:'18' },
  657. ]
  658. };
  659. },
  660. computed:{
  661. //是否显示科大讯飞相关的表单项
  662. isShowXunFei(){
  663. return this.permissionBtn.checkPermissionBtn(
  664. this.permissionBtn.baseConfigPermission.etaBaseConfig_xunfei
  665. )
  666. },
  667. //是否显示研报审批相关表单项
  668. isShowApprove(){
  669. return this.permissionBtn.checkPermissionBtn(
  670. this.permissionBtn.baseConfigPermission.etaBaseConfig_approve
  671. )
  672. },
  673. //是否显示中文PPT相关的表单项
  674. isShowPPT(){
  675. return this.permissionBtn.checkPermissionBtn(
  676. this.permissionBtn.baseConfigPermission.etaBaseConfig_ppt
  677. )
  678. },
  679. //是否显示英文PPT相关的表单项
  680. isShowEnPPT(){
  681. return this.permissionBtn.checkPermissionBtn(
  682. this.permissionBtn.baseConfigPermission.etaBaseConfig_pptEn
  683. )
  684. },
  685. //是否显示公司水印旁的研报图表,目前只有一个选项,当选项多的时候,不要再单个单个判断
  686. isShowYBChart(){
  687. return this.permissionBtn.checkPermissionBtn(
  688. this.permissionBtn.baseConfigPermission.etaBaseConfig_watermark_ybChart
  689. )
  690. },
  691. // 是否有登录设置
  692. isShowLoginConfig(){
  693. return this.permissionBtn.checkPermissionBtn(
  694. this.permissionBtn.baseConfigPermission.etaBaseConfig_login
  695. )
  696. },
  697. isShowYBShare(){
  698. return this.permissionBtn.checkPermissionBtn(
  699. this.permissionBtn.baseConfigPermission.etaBaseConfig_watermark_ybShare
  700. )
  701. },
  702. isShowSource(){
  703. return this.permissionBtn.checkPermissionBtn(
  704. this.permissionBtn.baseConfigPermission.etaBaseConfig_source_see
  705. )
  706. },
  707. isShowReportEnShare(){
  708. return this.permissionBtn.checkPermissionBtn(
  709. this.permissionBtn.baseConfigPermission.etaBaseConfig_watermark_ybEnShare
  710. )
  711. },
  712. },
  713. watch: {
  714. 'isShowLoginConfig':{
  715. handler(){
  716. if(!this.isShowLoginConfig&&this.partType==1){
  717. this.partType=2
  718. }
  719. },
  720. immediate:true
  721. }
  722. },
  723. methods: {
  724. handleUploadImage(file,key){
  725. /* console.log('type',key)
  726. console.log('file',file) */
  727. //如果是封面图
  728. if(['CnPptCoverImgs','EnPptCoverImgs'].includes(key)&&this.formData[key].length===3){
  729. this.$message.warning('封面图最多只能上传三张')
  730. return
  731. }
  732. //图片大小和格式限制
  733. const {size,type} = file.file
  734. const sizeLimit = key==='CompanyWatermark'?50*1024:500*1024
  735. if(!['image/png','image/jpeg'].includes(type)){
  736. this.$message.warning('仅支持png、jpg格式的图片')
  737. return
  738. }
  739. if(size>sizeLimit){
  740. this.$message.warning(`${key==='CompanyWatermark'?'水印图大小不能超过50kb':'ppt配图大小不能超过500kb'}`)
  741. return
  742. }
  743. let form = new FormData();
  744. form.append('file',file.file);
  745. bannerupload(form).then(res=>{
  746. console.log(res);
  747. if(res.Ret!==200) return
  748. if(['CnPptCoverImgs','EnPptCoverImgs'].includes(key)){
  749. this.formData[key].push(res.Data.ResourceUrl)
  750. }else{
  751. this.$set(this.formData,key,res.Data.ResourceUrl)
  752. // this.formData[key] = res.Data.ResourceUrl
  753. }
  754. console.log(this.formData);
  755. })
  756. },
  757. previewImage(picName){
  758. this.picShowList = this.picShowMap[picName]||[]
  759. this.picShowList.length&&(this.showViewer = true)
  760. },
  761. deleteFormImg(key,index){
  762. if(['CnPptCoverImgs','EnPptCoverImgs'].includes(key)){
  763. this.formData[key].splice(index,1)
  764. }else{
  765. this.formData[key] = ''
  766. }
  767. },
  768. showImage(imgList){
  769. this.picShowList = imgList||[]
  770. this.picShowList.length&&(this.showViewer = true)
  771. },
  772. showImageOrder({list,item}){
  773. //改变list的顺序,当前点击的为第一个
  774. const index = list.findIndex(img=>img===item)
  775. this.picShowList = [...list.slice(index),...list.slice(0,index)]
  776. this.picShowList.length&&(this.showViewer = true)
  777. },
  778. getBaseConfig(){
  779. this.configLoading = this.$loading({
  780. lock: true,
  781. target: '.eta-base-config',
  782. text: '正在获取基本配置...',
  783. spinner: 'el-icon-loading',
  784. background: 'rgba(255, 255, 255, 0.8)',
  785. });
  786. //获取WatermarkChart的值,赋值checkList
  787. //获取UseXf的值,赋值Iflytek
  788. //获取IsReportApprove的值,赋值approve
  789. etaBaseConfigInterence.getBaseConfig().then(res=>{
  790. if(res.Ret!==200) return
  791. const {WatermarkChart='',UseXf='',IsReportApprove='',CnPptCoverImgs='',EnPptCoverImgs=''} = res.Data
  792. this.checkList = WatermarkChart==='true'?['研报图表']:[]
  793. this.Iflytek = UseXf==='true'?true:false
  794. this.approve = IsReportApprove==='true'?true:false
  795. if(res.Data){
  796. // this.$set(this,'formData',res.Data)
  797. this.formData = {...this.formData,...res.Data}
  798. this.formData.CnPptCoverImgs = CnPptCoverImgs.length?CnPptCoverImgs.split(','):[]
  799. this.formData.EnPptCoverImgs = EnPptCoverImgs.length?EnPptCoverImgs.split(','):[]
  800. this.formData.WatermarkReport=res.Data.WatermarkReport==='true'?true:false
  801. this.formData.LogoCN = res.Data.LogoCN || require('@/assets/img/login_logo.png')
  802. this.formData.LogoEN = res.Data.LogoEN || require('@/assets/img/en/logo.png')
  803. this.formData.LogoMobile = res.Data.LogoMobile || require('@/assets/img/logo_mobile.png')
  804. }
  805. this.configLoading&&this.configLoading.close()
  806. })
  807. },
  808. saveBaseConfig(){
  809. //rules验证
  810. this.$refs.baseConfigForm.validate((valid,obj)=>{
  811. console.log('valid',valid)
  812. console.log('obj',obj)
  813. //如果是中英文ppt没填写,切换标签栏
  814. const keys = Object.keys(obj)
  815. const cnProps = ['CnPptCoverImgs','CnPptBackgroundImg','CnPptBottomImg']
  816. const enProps = ['EnPptCoverImgs','EnPptBackgroundImg','EnPptBottomImg']
  817. for(let i = 0;i < keys.length;i++){
  818. if(cnProps.includes(keys[i])){
  819. this.pptLang = 'cn'
  820. break
  821. }
  822. if(enProps.includes(keys[i])){
  823. this.pptLang = 'en'
  824. break
  825. }
  826. }
  827. if(valid){
  828. if(this.formData.WxAppId || this.formData.WxAppSecret || this.formData.WxId){
  829. // 只要有一个填,其他必填
  830. if(!this.formData.WxAppId){
  831. this.$message.warning('AppID 不能为空')
  832. return
  833. }else if(!this.formData.WxAppSecret){
  834. this.$message.warning('AppSecret 不能为空')
  835. return
  836. }else if(!this.formData.WxId){
  837. this.$message.warning('原始Id 不能为空')
  838. return
  839. }
  840. }
  841. //froala 在非本地环境会有版权标识,在表单验证前去掉
  842. this.formData.Disclaimer = this.formData.Disclaimer.replace(/<p data-f-id=\"pbf\".*?<\/p>/g, "");
  843. this.formData.LoginEmailTemplateContent = this.formData.LoginEmailTemplateContent.replace(/<p data-f-id=\"pbf\".*?<\/p>/g, "");
  844. this.formData.WatermarkChart = ''+(this.checkList.includes('研报图表')?true:false)
  845. this.formData.UseXf = ''+(this.Iflytek?true:false)
  846. this.formData.IsReportApprove = ''+(this.approve?true:false)
  847. const CnPptCoverImgs = this.formData.CnPptCoverImgs.join(',')
  848. const EnPptCoverImgs = this.formData.EnPptCoverImgs.join(',')
  849. //通过验证后,提交数据前
  850. //根据isShowXunFei,isShowPPTisShowEnPPT这三个计算属性将对应的表单项隐藏
  851. etaBaseConfigInterence.saveBaseConfig({
  852. ...this.formData,
  853. ...{
  854. CnPptCoverImgs,
  855. EnPptCoverImgs,
  856. WatermarkReport:this.formData.WatermarkReport?'true':'false'
  857. }
  858. }).then(res=>{
  859. if(res.Ret!==200) return
  860. // 设置logo
  861. this.$store.commit('SET_BASE_INFO',
  862. {logoCh:this.formData.LogoCN,logoEn:this.formData.LogoEN}
  863. )
  864. this.$message.success(this.$t('SystemManage.BaseConfig.tip_msg01')||'保存成功,请稍后到对应页面/项目查看')
  865. })
  866. }
  867. })
  868. },
  869. cancel(){
  870. //取消就恢复原样
  871. this.getBaseConfig()
  872. }
  873. },
  874. mounted(){
  875. this.getBaseConfig()
  876. }
  877. };
  878. </script>
  879. <style lang="scss">
  880. .eta-base-config{
  881. .el-form-item{
  882. .el-form-item__content{line-height: normal;}
  883. }
  884. .inline-form-item{
  885. display: flex;
  886. align-items: center;
  887. label{
  888. height: 40px;
  889. margin-right: 10px;
  890. white-space: nowrap;
  891. }
  892. .el-form-item__content{
  893. flex-grow: 1;
  894. }
  895. }
  896. .el-input__inner[type="color"]{
  897. height: 32px;
  898. padding: 0;
  899. border: none;
  900. }
  901. .fr-wrapper{
  902. height: 220px!important;
  903. .fr-element{
  904. min-height: 220px!important;
  905. }
  906. }
  907. .el-input--suffix .el-input__inner{
  908. padding-right:34px ;
  909. }
  910. .el-radio-button__inner{
  911. width: 150px;
  912. }
  913. }
  914. </style>
  915. <style scoped lang="scss">
  916. .eta-base-config{
  917. box-sizing: border-box;
  918. // padding:30px;
  919. border-radius: 4px;
  920. background-color: #fff;
  921. .scroll-cont {
  922. height: calc(100vh - 310px);
  923. overflow-y: auto;
  924. }
  925. .nav-type-box{
  926. display: flex;
  927. align-items: center;
  928. border-bottom: 1px solid #E7E7E7;
  929. span{
  930. display: block;
  931. height: 100%;
  932. line-height: 32px;
  933. padding: 8px;
  934. cursor: pointer;
  935. margin-right: 10px;
  936. color: rgba($color: #000000, $alpha: 0.6);
  937. }
  938. .active{
  939. color: #0052D9;
  940. border-bottom: 2px solid #0052D9;
  941. }
  942. }
  943. .smart-report-title{
  944. padding: 20px 30px 0;
  945. font-size: 16px;
  946. line-height: 22px;
  947. color: #333333;
  948. }
  949. .base-config-form{
  950. padding: 30px;
  951. .el-form-item{
  952. width:100%;
  953. }
  954. .part{
  955. padding-bottom: 30px;
  956. display: flex;
  957. justify-content: space-between;
  958. flex-wrap: wrap;
  959. .side{
  960. width:45%;
  961. .form-item-type-two{
  962. .input-suffix{
  963. display: flex;
  964. justify-content: center;
  965. align-items: center;
  966. height: 100%;
  967. padding-right: 6px;
  968. img{
  969. height: 16px;
  970. cursor: pointer;
  971. }
  972. }
  973. }
  974. .sms-type{
  975. display: flex;
  976. align-items: center;
  977. justify-content: space-between;
  978. }
  979. .input-hint{
  980. color: #999999;
  981. font-size: 14px;
  982. line-height: 20px;
  983. margin-bottom: 10px;
  984. margin-top: -3px;
  985. }
  986. .inline-form-item-box{
  987. .line-form-item-name{
  988. color: #606266;
  989. font-size: 14px;
  990. line-height: 40px;
  991. }
  992. .line-form-item{
  993. display: flex;
  994. gap: 40px;
  995. }
  996. }
  997. }
  998. .ppt-form-item-wrap{
  999. width:100%;
  1000. display: flex;
  1001. justify-content: space-between;
  1002. flex-wrap: wrap;
  1003. .inner-input-wrap{
  1004. width: 100%;
  1005. display: flex;
  1006. justify-content: space-between;
  1007. margin: 20px 0;
  1008. >.el-form-item{
  1009. width:30%;
  1010. }
  1011. }
  1012. >.el-form-item{
  1013. width:30%;
  1014. }
  1015. }
  1016. }
  1017. .flex-wrap {
  1018. display: flex;
  1019. flex-wrap: wrap;
  1020. gap: 10px;
  1021. }
  1022. }
  1023. }
  1024. </style>
  1025. <style lang="scss">
  1026. #logo-image{
  1027. .el-upload{
  1028. width: 100%;
  1029. height: 86px;
  1030. .upload-mask{
  1031. line-height: 86px;
  1032. }
  1033. }
  1034. .upload-box{
  1035. width: 100%;
  1036. height: 100%;
  1037. }
  1038. }
  1039. </style>