config.vue 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793
  1. <template>
  2. <div class="app-container">
  3. <el-tabs v-model="activeName" @tab-click="handleClick" >
  4. <el-tab-pane label="商城配置" name="store.config">
  5. <el-form ref="form1" :model="form1" :rules="rules1" label-width="180px">
  6. <el-form-item label="搜索关键字" prop="hotSearch">
  7. <el-input v-model="form1.hotSearch" label="请输入搜索关键字,多个用,号分隔"></el-input>
  8. </el-form-item>
  9. <el-form-item label="资质证明" prop="certs">
  10. <Material v-model="photoArr" type="image" :num="10" :width="150" :height="150" />
  11. </el-form-item>
  12. <el-form-item label="货到付款支付比例" prop="payRate">
  13. <el-tooltip class="item" effect="dark" content="货到付款支付比例(%)" placement="top-end">
  14. <el-input-number v-model="form1.payRate" ></el-input-number>
  15. </el-tooltip>
  16. </el-form-item>
  17. <el-form-item label="待支付订单取消时间" prop="unPayTime">
  18. <el-tooltip class="item" effect="dark" content="待支付订单取消时间(分钟)" placement="top-end">
  19. <el-input-number v-model="form1.unPayTime" :min="1" ></el-input-number>
  20. </el-tooltip>
  21. </el-form-item>
  22. <el-form-item label="公司推广佣金比例" prop="tuiMoneyRate">
  23. <el-tooltip class="item" effect="dark" content="公司推广佣金比例(%)" placement="top-end">
  24. <el-input-number v-model="form1.tuiMoneyRate" :min="1" :max="100" ></el-input-number>
  25. </el-tooltip>
  26. </el-form-item>
  27. <el-form-item label="服务费" prop="serviceFee">
  28. <el-tooltip class="item" effect="dark" content="服务费(元)" placement="top-end">
  29. <el-input-number v-model="form1.serviceFee" :min="0" ></el-input-number>
  30. </el-tooltip>
  31. </el-form-item>
  32. <el-form-item label="成本售价比例" prop="salesPriceRate">
  33. <el-tooltip class="item" effect="dark" content="成本售价比例(%)" placement="top-end">
  34. <el-input-number v-model="form1.salesPriceRate" :min="1" :max="300" ></el-input-number>
  35. </el-tooltip>
  36. </el-form-item>
  37. <el-form-item label="公司制单金额最低比例" prop="createMoneyRate">
  38. <el-tooltip class="item" effect="dark" content="公司制单金额最低比例(%)" placement="top-end">
  39. <el-input-number v-model="form1.createMoneyRate" :min="1" :max="100" ></el-input-number>
  40. </el-tooltip>
  41. </el-form-item>
  42. <el-form-item label="申请售后有效天数" prop="storeAfterSalesDay">
  43. <el-tooltip class="item" effect="dark" content="确认收货后申请售后天数" placement="top-end">
  44. <el-input-number v-model="form1.storeAfterSalesDay" :min="0" :max="100" ></el-input-number>
  45. </el-tooltip>
  46. </el-form-item>
  47. <el-form-item label="退货收货人" prop="refundConsignee">
  48. <el-tooltip class="item" effect="dark" content="退货收货人" placement="top-end">
  49. <el-input style="width:200px" v-model="form1.refundConsignee" ></el-input>
  50. </el-tooltip>
  51. </el-form-item>
  52. <el-form-item label="退货手机号" prop="refundPhoneNumber">
  53. <el-tooltip class="item" effect="dark" content="退货手机号" placement="top-end">
  54. <el-input style="width:200px" v-model="form1.refundPhoneNumber" ></el-input>
  55. </el-tooltip>
  56. </el-form-item>
  57. <el-form-item label="退货地址" prop="refundAddress">
  58. <el-tooltip class="item" effect="dark" content="退货地址" placement="top-end">
  59. <el-input v-model="form1.refundAddress" ></el-input>
  60. </el-tooltip>
  61. </el-form-item>
  62. <div class="footer">
  63. <el-button type="primary" @click="submitForm1">提 交</el-button>
  64. </div>
  65. </el-form>
  66. </el-tab-pane>
  67. <el-tab-pane label="企业理念" name="store.concept">
  68. <el-form ref="form3" :model="form7" :rules="rules7" label-width="160px">
  69. <el-form-item label="企业理念图片" prop="images">
  70. <Material v-model="images" type="image" :num="10" :width="150" :height="150" />
  71. </el-form-item>
  72. <el-form-item label="企业理念视频" prop="videoUrl">
  73. <div>
  74. <el-upload
  75. ref="upload"
  76. class="upload-demo"
  77. :action="uploadUrl"
  78. :on-success="handleSuccess"
  79. :before-upload="beforeUpload"
  80. :limit="1"
  81. :accept="videoAccept"
  82. >
  83. <el-button size="small" type="primary">点击上传视频</el-button>
  84. </el-upload>
  85. <video :src="form7.videoUrl" controls style="max-width: 400px; max-height: 400px;"></video>
  86. </div>
  87. </el-form-item>
  88. <div class="footer">
  89. <el-button type="primary" @click="submitForm7">提 交</el-button>
  90. </div>
  91. </el-form>
  92. </el-tab-pane>
  93. <el-tab-pane label="云存储桶配置" name="sys.oss.cloudStorage">
  94. <el-form ref="form2" :model="form2" :rules="rules2" label-width="140px">
  95. <el-form-item label="类型" prop="type">
  96. <el-radio-group v-model="form2.type">
  97. <el-radio :label="1">七牛云</el-radio>
  98. <el-radio :label="2">阿里云</el-radio>
  99. <el-radio :label="3">腾讯云</el-radio>
  100. <el-radio :label="4">华为云</el-radio>
  101. </el-radio-group>
  102. </el-form-item>
  103. <el-form-item v-if="form2.type==1" label="七牛绑定的域名" prop="qiniuDomain">
  104. <el-input v-model="form2.qiniuDomain" label="请输入七牛绑定的域名"></el-input>
  105. </el-form-item>
  106. <el-form-item v-if="form2.type==1" label="七牛路径前缀" prop="qiniuPrefix">
  107. <el-input v-model="form2.qiniuPrefix" label="请输入七牛路径前缀"></el-input>
  108. </el-form-item>
  109. <el-form-item v-if="form2.type==1" label="七牛ACCESS_KEY" prop="qiniuAccessKey">
  110. <el-input v-model="form2.qiniuAccessKey" label="请输入七牛ACCESS_KEY"></el-input>
  111. </el-form-item>
  112. <el-form-item v-if="form2.type==1" label="七牛SecretKey" prop="qiniuSecretKey">
  113. <el-input v-model="form2.qiniuSecretKey" label="七牛SecretKey不能为空"></el-input>
  114. </el-form-item>
  115. <el-form-item v-if="form2.type==1" label="七牛空间名" prop="qiniuBucketName">
  116. <el-input v-model="form2.qiniuBucketName" label="七牛空间名不能为空"></el-input>
  117. </el-form-item>
  118. <el-form-item v-if="form2.type==2" label="阿里云绑定的域名" prop="aliyunDomain">
  119. <el-input v-model="form2.aliyunDomain" label="阿里云绑定的域名不能为空"></el-input>
  120. </el-form-item>
  121. <el-form-item v-if="form2.type==2" label="阿里云路径前缀" prop="aliyunPrefix">
  122. <el-input v-model="form2.aliyunPrefix" label="阿里云路径前缀不能为空"></el-input>
  123. </el-form-item>
  124. <el-form-item v-if="form2.type==2" label="阿里云EndPoint" prop="aliyunEndPoint">
  125. <el-input v-model="form2.aliyunEndPoint" label="阿里云EndPoint不能为空"></el-input>
  126. </el-form-item>
  127. <el-form-item v-if="form2.type==2" label="阿里云AccessKeyId" prop="aliyunAccessKeyId">
  128. <el-input v-model="form2.aliyunAccessKeyId" label="阿里云AccessKeyId不能为空"></el-input>
  129. </el-form-item>
  130. <el-form-item v-if="form2.type==2" label="阿里云AccessKeySecret" prop="aliyunAccessKeySecret">
  131. <el-input v-model="form2.aliyunAccessKeySecret" label="阿里云AccessKeySecret不能为空"></el-input>
  132. </el-form-item>
  133. <el-form-item v-if="form2.type==2" label="阿里云BucketName" prop="aliyunBucketName">
  134. <el-input v-model="form2.aliyunBucketName" label="阿里云BucketName不能为空"></el-input>
  135. </el-form-item>
  136. <el-form-item v-if="form2.type==3" label="腾讯云绑定的域名" prop="qcloudDomain">
  137. <el-input v-model="form2.qcloudDomain" label="腾讯云绑定的域名格式不正确"></el-input>
  138. </el-form-item>
  139. <el-form-item v-if="form2.type==3" label="腾讯云前缀" prop="qcloudPrefix">
  140. <el-input v-model="form2.qcloudPrefix" label="腾讯云前缀不能为空"></el-input>
  141. </el-form-item>
  142. <el-form-item v-if="form2.type==3" label="腾讯云SecretId" prop="qcloudSecretId">
  143. <el-input v-model="form2.qcloudSecretId" label="腾讯云SecretId不能为空"></el-input>
  144. </el-form-item>
  145. <el-form-item v-if="form2.type==3" label="腾讯云SecretKey" prop="qcloudSecretKey">
  146. <el-input v-model="form2.qcloudSecretKey" label="腾讯云SecretKey不能为空"></el-input>
  147. </el-form-item>
  148. <el-form-item v-if="form2.type==3" label="腾讯云BucketName" prop="qcloudBucketName">
  149. <el-input v-model="form2.qcloudBucketName" label="腾讯云BucketName不能为空"></el-input>
  150. </el-form-item>
  151. <el-form-item v-if="form2.type==3" label="所属地区" prop="qcloudRegion">
  152. <el-input v-model="form2.qcloudRegion" label="所属地区不能为空"></el-input>
  153. </el-form-item>
  154. <el-form-item v-if="form2.type==4" label="华为云绑定的域名" prop="huaweiDomain">
  155. <el-input v-model="form2.huaweiDomain" label="华为云绑定的域名格式不正确"></el-input>
  156. </el-form-item>
  157. <el-form-item v-if="form2.type==4" label="华为云Endpoint" prop="huaweiBucketName">
  158. <el-input v-model="form2.huaweiEndpoint" label="华为云Endpoint不能为空"></el-input>
  159. </el-form-item>
  160. <el-form-item v-if="form2.type==4" label="华为云AK" prop="huaweiAK">
  161. <el-input v-model="form2.huaweiAK" label="华为云AK不能为空"></el-input>
  162. </el-form-item>
  163. <el-form-item v-if="form2.type==4" label="华为云SK" prop="huaweiSK">
  164. <el-input v-model="form2.huaweiSK" label="华为云SK不能为空"></el-input>
  165. </el-form-item>
  166. <el-form-item v-if="form2.type==4" label="华为云BucketName" prop="huaweiBucketName">
  167. <el-input v-model="form2.huaweiBucketName" label="华为云BucketName不能为空"></el-input>
  168. </el-form-item>
  169. <div class="footer">
  170. <el-button type="primary" @click="submitForm2">提 交</el-button>
  171. </div>
  172. </el-form>
  173. </el-tab-pane>
  174. <el-tab-pane label="积分配置" name="store.integral">
  175. <el-form ref="form3" :model="form3" :rules="rules3" label-width="160px">
  176. <el-form-item label="积分抵用比例" prop="integralRatio">
  177. <el-tooltip class="item" effect="dark" content="1积分抵多少金额" placement="top-end">
  178. <el-input-number v-model="form3.integralRatio" ></el-input-number>
  179. </el-tooltip>
  180. </el-form-item>
  181. <el-form-item label="满多少可以抵扣" prop="integralFull">
  182. <el-tooltip class="item" effect="dark" content="消费必须满一定额度才可使用,0代表无限制" placement="top-end">
  183. <el-input-number v-model="form3.integralFull" ></el-input-number>
  184. </el-tooltip>
  185. </el-form-item>
  186. <el-form-item label="单次最大抵扣积分" prop="integralMax">
  187. <el-tooltip class="item" effect="dark" content="限制一次只能使用多少积分,0代表无限制" placement="top-end">
  188. <el-input-number v-model="form3.integralMax" ></el-input-number>
  189. </el-tooltip>
  190. </el-form-item>
  191. <div class="footer">
  192. <el-button type="primary" @click="submitForm3">提 交</el-button>
  193. </div>
  194. </el-form>
  195. </el-tab-pane>
  196. <el-tab-pane label="签到配置" name="store.sign">
  197. <el-form ref="form4" :model="form4" label-width="160px">
  198. <el-table
  199. border
  200. :data="form4.sign"
  201. style="width: 100%">
  202. <el-table-column
  203. prop="day"
  204. label="名称"
  205. >
  206. </el-table-column>
  207. <el-table-column
  208. prop="signNum"
  209. label="获得积分"
  210. >
  211. </el-table-column>
  212. <el-table-column
  213. prop="sort"
  214. label="排序"
  215. >
  216. </el-table-column>
  217. <el-table-column
  218. label="操作"
  219. width="100">
  220. <template slot-scope="scope">
  221. <el-button type="text" size="small" @click="handleSignEdit(scope.row)">编辑</el-button>
  222. </template>
  223. </el-table-column>
  224. </el-table>
  225. <div class="footer" style="margin-top:10px;">
  226. <el-button type="primary" @click="submitForm4">提 交</el-button>
  227. </div>
  228. </el-form>
  229. </el-tab-pane>
  230. <el-tab-pane label="用户协议" name="store.agreement">
  231. <el-form ref="form5" :model="form5" :rules="rules5" label-width="100px">
  232. <el-form-item label="用户协议" prop="userAgreement">
  233. <editor ref="myeditor1" @on-text-change="updateText1" />
  234. </el-form-item>
  235. <el-form-item label="隐私政策" prop="privacyPolicy">
  236. <editor ref="myeditor2" @on-text-change="updateText2" />
  237. </el-form-item>
  238. <div class="footer">
  239. <el-button type="primary" @click="submitForm5">提 交</el-button>
  240. </div>
  241. </el-form>
  242. </el-tab-pane>
  243. <el-tab-pane label="支付配置" name="store.pay">
  244. <el-form ref="form6" :model="form6" label-width="160px">
  245. <el-form-item label="支付类型" prop="type">
  246. <el-radio-group v-model="form6.type">
  247. <el-radio label="wx">微信支付</el-radio>
  248. <el-radio label="hf">汇付</el-radio>
  249. </el-radio-group>
  250. </el-form-item>
  251. <el-form-item label="appId" prop="appId">
  252. <el-input v-model="form6.appId" label="请输入appId"></el-input>
  253. </el-form-item>
  254. <el-form-item v-if="form6.type=='wx'" label="微信商户号" prop="wxMchId">
  255. <el-input v-model="form6.wxMchId" label="请输入微信商户号"></el-input>
  256. </el-form-item>
  257. <el-form-item v-if="form6.type=='wx'" label="微信商户密钥" prop="wxMchKey">
  258. <el-input v-model="form6.wxMchKey" label="请输入商户密钥"></el-input>
  259. </el-form-item>
  260. <el-form-item v-if="form6.type=='wx'" label="微信商户V3密钥" prop="wxMchKey">
  261. <el-input v-model="form6.wxApiV3Key" label="请输入商户V3密钥"></el-input>
  262. </el-form-item>
  263. <el-form-item v-if="form6.type=='hf'" label="汇付产品号" prop="hfProductId">
  264. <el-input v-model="form6.hfProductId" label="汇付产品号"></el-input>
  265. </el-form-item>
  266. <el-form-item v-if="form6.type=='hf'" label="系统号" prop="hfSysId">
  267. <el-input v-model="form6.hfSysId" label="系统号Key"></el-input>
  268. </el-form-item>
  269. <el-form-item v-if="form6.type=='hf'" label="商户号" prop="huifuId">
  270. <el-input v-model="form6.huifuId" label="商户号"></el-input>
  271. </el-form-item>
  272. <el-form-item v-if="form6.type=='hf'" label="服务商私钥" prop="hfRsaPrivateKey">
  273. <el-input v-model="form6.hfRsaPrivateKey" label="服务商私钥"></el-input>
  274. </el-form-item>
  275. <el-form-item v-if="form6.type=='hf'" label="汇付公钥" prop="hfRsaPublicKey">
  276. <el-input v-model="form6.hfRsaPublicKey" label="汇付公钥"></el-input>
  277. </el-form-item>
  278. <el-form-item v-if="form6.type=='hf'" label="汇付支付回调地址" prop="hfPayNotifyUrl">
  279. <el-input v-model="form6.hfPayNotifyUrl" label="汇付支付回调地址"></el-input>
  280. </el-form-item>
  281. <el-form-item v-if="form6.type=='hf'" label="大额支付回调地址" prop="hfPayOnlineNotifyUrl">
  282. <el-input v-model="form6.hfPayOnlineNotifyUrl" label="汇付支付回调地址"></el-input>
  283. </el-form-item>
  284. <el-form-item v-if="form6.type=='hf'" label="汇付退款回调地址" prop="hfRefundNotifyUrl">
  285. <el-input v-model="form6.hfRefundNotifyUrl" label="汇付退款回调地址"></el-input>
  286. </el-form-item>
  287. <el-form-item v-if="form6.type=='hf'" label="汇付大额退款回调地址" prop="hfOnlineRefundNotifyUrl">
  288. <el-input v-model="form6.hfOnlineRefundNotifyUrl" label="汇付分账回调地址"></el-input>
  289. </el-form-item>
  290. <div class="footer">
  291. <el-button type="primary" @click="submitform6">提 交</el-button>
  292. </div>
  293. </el-form>
  294. </el-tab-pane>
  295. <el-tab-pane label="点播配置" name="course.config">
  296. <el-form ref="form18" :model="form18" label-width="120px">
  297. <el-form-item label="可答题进度(%)">
  298. <el-tooltip class="item" effect="dark" content="课程可答题进度(%)" placement="top-end">
  299. <el-input-number v-model="form18.answerRate" :min="1" :max="100" ></el-input-number>
  300. </el-tooltip>
  301. </el-form-item>
  302. <el-form-item label="短链有效期(天)">
  303. <el-tooltip class="item" effect="dark" content="短链有效期(天)" placement="top-end">
  304. <el-input-number v-model="form18.videoLinkExpireDate" :min="1" ></el-input-number>
  305. </el-tooltip>
  306. </el-form-item>
  307. <el-form-item label="答题允许错误次数(次)">
  308. <el-tooltip class="item" effect="dark" content="课程答题允许错误次数(次)" placement="top-end">
  309. <el-input-number v-model="form18.answerErrorCount" :min="1" ></el-input-number>
  310. </el-tooltip>
  311. </el-form-item>
  312. <el-form-item label="最大缓冲时长(秒)">
  313. <el-tooltip class="item" effect="dark" content="当前播放时间之后缓冲秒数(秒)" placement="top-end">
  314. <el-input-number v-model="form18.maxBufferLength" :min="1" ></el-input-number>
  315. </el-tooltip>
  316. </el-form-item>
  317. <el-form-item label="每十分钟获取积分">
  318. <el-tooltip class="item" effect="dark" content="每十分钟获取多少积分" placement="top-end">
  319. <el-input-number v-model="form18.videoIntegral" :min="1" ></el-input-number>
  320. </el-tooltip>
  321. </el-form-item>
  322. <el-form-item label="答题获得积分">
  323. <el-tooltip class="item" effect="dark" content="答题获得积分" placement="top-end">
  324. <el-input-number v-model="form18.answerIntegral" :min="1" ></el-input-number>
  325. </el-tooltip>
  326. </el-form-item>
  327. <el-form-item label="看课域名">
  328. <el-tooltip class="item" effect="dark" content="看课域名" placement="top-end">
  329. <el-input style="width: 300px" v-model="form18.realLinkDomainName" ></el-input>
  330. </el-tooltip>
  331. </el-form-item>
  332. <el-form-item label="注册域名">
  333. <el-tooltip class="item" effect="dark" content="注册域名" placement="top-end">
  334. <el-input style="width: 300px" v-model="form18.registerDomainName" ></el-input>
  335. </el-tooltip>
  336. </el-form-item>
  337. <el-form-item label="主域名">
  338. <el-tooltip class="item" effect="dark" content="所有销售的看课二级域名根据此主域名来发放" placement="top-end">
  339. <el-input style="width: 200px" v-model="form18.courseDomainName" label="看课主域名"></el-input>
  340. </el-tooltip>
  341. </el-form-item>
  342. <el-form-item label="看课默认线路">
  343. <el-radio-group v-model="form18.defaultLine">
  344. <el-radio label="0">线路一</el-radio>
  345. <el-radio label="1">线路二</el-radio>
  346. </el-radio-group>
  347. </el-form-item>
  348. <el-form-item label="奖励类型">
  349. <el-radio-group v-model="form18.rewardType">
  350. <el-radio label="1">红包</el-radio>
  351. <el-radio label="2">积分</el-radio>
  352. </el-radio-group>
  353. </el-form-item>
  354. <el-form-item label="红包模式">
  355. <el-radio-group v-model="form18.redPacketMode">
  356. <el-radio label="1">总公司</el-radio>
  357. <el-radio label="2">分公司</el-radio>
  358. </el-radio-group>
  359. </el-form-item>
  360. <div class="line"></div>
  361. <div style="float:right;margin-right:20px">
  362. <el-button type="primary" @click="submitForm18">提交</el-button>
  363. </div>
  364. </el-form>
  365. </el-tab-pane>
  366. <el-tab-pane label="红包商户配置" name="redPacket.config" >
  367. <el-form ref="form19" :model="form19" label-width="150px">
  368. <el-form-item label="红包接口类型" prop="isNew">
  369. <el-radio-group v-model="form19.isNew">
  370. <el-radio label="0">商家转账到零钱(旧)</el-radio>
  371. <el-radio label="1">商家转账(新)</el-radio>
  372. </el-radio-group>
  373. </el-form-item>
  374. <el-form-item label="公众号appid" prop="appId">
  375. <el-input v-model="form19.appId" label="请输入appId"></el-input>
  376. </el-form-item>
  377. <el-form-item label="小程序appid" prop="appId">
  378. <el-input v-model="form19.miniappId" label="请输入appId"></el-input>
  379. </el-form-item>
  380. <el-form-item label="商户号" prop="mchId">
  381. <el-input v-model="form19.mchId" label="请输入mchId"></el-input>
  382. </el-form-item>
  383. <el-form-item label="商户密钥" prop="mchKey">
  384. <el-input v-model="form19.mchKey" label="mchKey"></el-input>
  385. </el-form-item>
  386. <el-form-item label="p12证书路径" prop="keyPath">
  387. <el-input v-model="form19.keyPath" label="请输入keyPath"></el-input>
  388. </el-form-item>
  389. <el-form-item label="apiV3密钥" prop="apiV3Key">
  390. <el-input v-model="form19.apiV3Key" label="请输入apiV3Key"></el-input>
  391. </el-form-item>
  392. <el-form-item label="公钥ID" prop="publicKeyId">
  393. <el-input v-model="form19.publicKeyId" label="请输入公钥ID"></el-input>
  394. </el-form-item>
  395. <el-form-item label="公钥证书" prop="publicKeyPath">
  396. <el-input v-model="form19.publicKeyPath" label="请输入publicKeyPath"></el-input>
  397. </el-form-item>
  398. <el-form-item label="key路径" prop="privateKeyPath">
  399. <el-input v-model="form19.privateKeyPath" label="请输入"></el-input>
  400. </el-form-item>
  401. <el-form-item label="cert路径" prop="privateCertPath">
  402. <el-input v-model="form19.privateCertPath" label="请输入"></el-input>
  403. </el-form-item>
  404. <el-form-item label="回调地址" prop="notifyUrl">
  405. <el-input v-model="form19.notifyUrl" label="请输入"></el-input>
  406. </el-form-item>
  407. <div class="footer">
  408. <el-button type="primary" @click="submitForm19">提 交</el-button>
  409. </div>
  410. </el-form>
  411. </el-tab-pane>
  412. <el-tab-pane label="布局配置" name="store.appShow" >
  413. <div >
  414. <el-table border :data="form10">
  415. <el-table-column prop="name" label="模块名称" width="300">
  416. <template slot-scope="scope"> <el-input v-model="scope.row.name" ></el-input></template>
  417. </el-table-column>
  418. <el-table-column prop="sort"label="排序号" width="300">
  419. <template slot-scope="scope"><el-input-number v-model="scope.row.sort" :min="0" :max="100" ></el-input-number> </template>
  420. </el-table-column>
  421. <el-table-column prop="isShow" label="是否展示" width="100">
  422. <template slot-scope="scope"> <el-switch
  423. v-model="scope.row.isShow"
  424. active-color="#13ce66"
  425. inactive-color="#ff4949">
  426. </el-switch> </template>
  427. </el-table-column>
  428. </el-table>
  429. <div class="footer">
  430. <el-button type="primary" @click="submitForm10">提 交</el-button>
  431. </div>
  432. </div>
  433. </el-tab-pane>
  434. </el-tabs>
  435. <el-dialog :title="sign.title" :visible.sync="sign.open" width="500px" append-to-body>
  436. <el-form ref="signform" :model="signform" label-width="80px">
  437. <el-form-item label="名称" prop="day">
  438. <el-input v-model="signform.day" placeholder="请输入名称" />
  439. </el-form-item>
  440. <el-form-item label="获得积分" prop="signNum">
  441. <el-input-number v-model="signform.signNum" placeholder="请输入获得积分" />
  442. </el-form-item>
  443. <el-form-item label="排序" prop="sort">
  444. <el-input-number v-model="signform.sort" placeholder="请输入排序" />
  445. </el-form-item>
  446. </el-form>
  447. <div slot="footer" class="dialog-footer">
  448. <el-button type="primary" @click="submitSignForm">确 定</el-button>
  449. </div>
  450. </el-dialog>
  451. </div>
  452. </template>
  453. <script>
  454. import Editor from '@/components/Editor/wang';
  455. import { getConfigByKey,updateConfigByKey, clearCache } from "@/api/system/config";
  456. import Material from '@/components/Material'
  457. export default {
  458. name: "Config",
  459. components: {
  460. Material,
  461. Editor
  462. },
  463. watch: {
  464. photoArr: function(val) {
  465. this.form1.certs = val.join(',')
  466. },
  467. images: function(val) {
  468. this.form7.images = val.join(',')
  469. }
  470. },
  471. data() {
  472. return {
  473. uploadUrl:process.env.VUE_APP_BASE_API+"/common/uploadOSS",
  474. videoAccept:"video/*",
  475. sign:{
  476. title:"修改签到",
  477. open:false,
  478. },
  479. signform: {
  480. },
  481. photoArr:[],
  482. images:[],
  483. activeName:"store.config",
  484. configId:null,
  485. configKey:null,
  486. // 表单参数
  487. form1: {
  488. hotSearch:"",
  489. },
  490. // 表单校验
  491. rules1: {
  492. },
  493. form2: {
  494. },
  495. // 表单校验
  496. rules2: {
  497. },
  498. form3: {
  499. },
  500. // 表单校验
  501. rules3: {
  502. },
  503. form4: {
  504. sign:[],
  505. },
  506. // 表单校验
  507. rules4: {
  508. },
  509. form5: {
  510. },
  511. form6: {
  512. },
  513. form7: {
  514. },
  515. rules7: {
  516. },
  517. form18:{
  518. },
  519. form10:[],
  520. form19:{
  521. },
  522. // 表单校验
  523. rules5: {
  524. }
  525. };
  526. },
  527. created() {
  528. this.getConfigByKey(this.activeName);
  529. },
  530. methods: {
  531. handleSuccess(response, file) {
  532. // 上传成功后的回调函数
  533. this.myloading.close();
  534. this.form7.videoUrl = response.url;
  535. this.$refs.upload.clearFiles();
  536. },
  537. beforeUpload(file) {
  538. // 上传前的钩子函数,可以在这里对文件进行处理
  539. // 返回 false 则取消上传
  540. // 例如限制文件大小
  541. const isLt2M = file.size / 1024 / 1024 < 200;
  542. if (!isLt2M) {
  543. this.$message.error('上传视频文件大小不能超过 200MB!');
  544. return false;
  545. }
  546. this.myloading = this.$loading({
  547. lock: true,
  548. text: '上传中',
  549. spinner: 'el-icon-loading',
  550. background: 'rgba(0, 0, 0, 0.7)'
  551. });
  552. },
  553. handleSignEdit(item){
  554. this.signform=item;
  555. this.sign.open=true;
  556. },
  557. submitSignForm(){
  558. this.sign.open=false;
  559. },
  560. updateText1(text){
  561. this.form5.userAgreement=text
  562. },
  563. updateText2(text){
  564. this.form5.privacyPolicy=text
  565. },
  566. handleClick(tab, event){
  567. console.log(tab.name)
  568. this.getConfigByKey(tab.name);
  569. },
  570. getConfigByKey(key){
  571. getConfigByKey(key).then(response => {
  572. console.log(response)
  573. if(key=="store.config"){
  574. this.configId=response.data.configId;
  575. this.configKey=response.data.configKey;
  576. this.form1 =JSON.parse(response.data.configValue);
  577. if(this.form1.certs!=null){
  578. this.photoArr=this.form1.certs.split(",");
  579. }
  580. }
  581. else if(key=="store.concept"){
  582. this.configId=response.data.configId;
  583. this.configKey=response.data.configKey;
  584. this.form7 =JSON.parse(response.data.configValue);
  585. if(this.form7.images!=null){
  586. this.images=this.form7.images.split(",");
  587. }
  588. }
  589. else if(key=="store.integral"){
  590. this.configId=response.data.configId;
  591. this.configKey=response.data.configKey;
  592. console.log(response.data.configValue)
  593. this.form3 =JSON.parse(response.data.configValue);
  594. console.log(this.form3.sign)
  595. }
  596. else if(key=="store.sign"){
  597. this.configId=response.data.configId;
  598. this.configKey=response.data.configKey;
  599. this.form4.sign =JSON.parse(response.data.configValue);
  600. console.log(this.form4.sign)
  601. }
  602. else if(key=="store.agreement"){
  603. this.configId=response.data.configId;
  604. this.configKey=response.data.configKey;
  605. this.form5 =JSON.parse(response.data.configValue);
  606. this.$refs.myeditor1.setText(this.form5.userAgreement);
  607. this.$refs.myeditor2.setText(this.form5.privacyPolicy);
  608. }
  609. else if(key=="sys.oss.cloudStorage"){
  610. this.configId=response.data.configId;
  611. this.configKey=response.data.configKey;
  612. this.form2 =JSON.parse(response.data.configValue);
  613. }
  614. else if(key=="store.pay"){
  615. this.configId=response.data.configId;
  616. this.configKey=response.data.configKey;
  617. this.form6 =JSON.parse(response.data.configValue);
  618. }
  619. if(key=="course.config"){
  620. this.configId=response.data.configId;
  621. this.configKey=response.data.configKey;
  622. this.form18 =JSON.parse(response.data.configValue);
  623. }
  624. if(key=="redPacket.config"){
  625. this.configId=response.data.configId;
  626. this.configKey=response.data.configKey;
  627. this.form19 =JSON.parse(response.data.configValue);
  628. }
  629. if(key=="store.appShow"){
  630. this.configId=response.data.configId;
  631. this.configKey=response.data.configKey;
  632. this.form10 =JSON.parse(response.data.configValue);
  633. }
  634. });
  635. },
  636. /** 提交按钮 */
  637. submitForm1: function() {
  638. this.$refs["form1"].validate(valid => {
  639. if (valid) {
  640. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form1)}
  641. updateConfigByKey(param).then(response => {
  642. if (response.code === 200) {
  643. this.msgSuccess("修改成功");
  644. }
  645. });
  646. }
  647. });
  648. },
  649. submitForm2: function() {
  650. this.$refs["form2"].validate(valid => {
  651. if (valid) {
  652. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form2)}
  653. updateConfigByKey(param).then(response => {
  654. if (response.code === 200) {
  655. this.msgSuccess("修改成功");
  656. }
  657. });
  658. }
  659. });
  660. },
  661. submitForm3: function() {
  662. this.$refs["form3"].validate(valid => {
  663. if (valid) {
  664. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form3)}
  665. updateConfigByKey(param).then(response => {
  666. if (response.code === 200) {
  667. this.msgSuccess("修改成功");
  668. }
  669. });
  670. }
  671. });
  672. },
  673. submitForm4: function() {
  674. this.$refs["form4"].validate(valid => {
  675. if (valid) {
  676. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form4.sign)}
  677. updateConfigByKey(param).then(response => {
  678. if (response.code === 200) {
  679. this.msgSuccess("修改成功");
  680. }
  681. });
  682. }
  683. });
  684. },
  685. submitForm5: function() {
  686. this.$refs["form5"].validate(valid => {
  687. if (valid) {
  688. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form5)}
  689. updateConfigByKey(param).then(response => {
  690. if (response.code === 200) {
  691. this.msgSuccess("修改成功");
  692. }
  693. });
  694. }
  695. });
  696. },
  697. submitform6: function() {
  698. this.$refs["form6"].validate(valid => {
  699. if (valid) {
  700. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form6)}
  701. updateConfigByKey(param).then(response => {
  702. if (response.code === 200) {
  703. this.msgSuccess("修改成功");
  704. }
  705. });
  706. }
  707. });
  708. },
  709. submitForm7(){
  710. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form7)}
  711. updateConfigByKey(param).then(response => {
  712. if (response.code === 200) {
  713. this.msgSuccess("修改成功");
  714. }
  715. });
  716. },
  717. submitForm18(){
  718. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form18)}
  719. updateConfigByKey(param).then(response => {
  720. if (response.code === 200) {
  721. this.msgSuccess("修改成功");
  722. }
  723. });
  724. },
  725. submitForm19(){
  726. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form19)}
  727. updateConfigByKey(param).then(response => {
  728. if (response.code === 200) {
  729. this.msgSuccess("修改成功");
  730. }
  731. });
  732. },
  733. submitForm10(){
  734. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form10)}
  735. updateConfigByKey(param).then(response => {
  736. if (response.code === 200) {
  737. this.msgSuccess("修改成功");
  738. }
  739. });
  740. },
  741. /** 清理缓存按钮操作 */
  742. handleClearCache() {
  743. clearCache().then(response => {
  744. if (response.code === 200) {
  745. this.msgSuccess("清理成功");
  746. }
  747. });
  748. }
  749. }
  750. };
  751. </script>
  752. <style scoped>
  753. .footer{
  754. width: 100%;
  755. display: flex;
  756. align-items: flex-end;
  757. justify-content: flex-end;
  758. }
  759. </style>