config.vue 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814
  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-tooltip class="item" effect="dark" content="公众号网页授权域名" placement="top-end">
  350. <el-input v-model="form18.authDomainName" ></el-input>
  351. </el-tooltip>
  352. </el-form-item>
  353. <el-form-item label="公众号appId">
  354. <el-tooltip class="item" effect="dark" content="授权公众号appId" placement="top-end">
  355. <el-input v-model="form18.mpAppId" ></el-input>
  356. </el-tooltip>
  357. </el-form-item>
  358. <el-form-item label="小程序appid">
  359. <el-tooltip class="item" effect="dark" content="小程序appid" placement="top-end">
  360. <el-input v-model="form18.miniprogramAppid" ></el-input>
  361. </el-tooltip>
  362. </el-form-item>
  363. <el-form-item label="小程序page路径">
  364. <el-tooltip class="item" effect="dark" content="小程序消息打开后的路径" placement="top-end">
  365. <el-input v-model="form18.miniprogramPage" ></el-input>
  366. </el-tooltip>
  367. </el-form-item>
  368. <el-form-item label="奖励类型">
  369. <el-radio-group v-model="form18.rewardType">
  370. <el-radio label="1">红包</el-radio>
  371. <el-radio label="2">积分</el-radio>
  372. </el-radio-group>
  373. </el-form-item>
  374. <el-form-item label="红包模式">
  375. <el-radio-group v-model="form18.redPacketMode">
  376. <el-radio label="1">总公司</el-radio>
  377. <el-radio label="2">分公司</el-radio>
  378. </el-radio-group>
  379. </el-form-item>
  380. <div class="line"></div>
  381. <div style="float:right;margin-right:20px">
  382. <el-button type="primary" @click="submitForm18">提交</el-button>
  383. </div>
  384. </el-form>
  385. </el-tab-pane>
  386. <el-tab-pane label="红包商户配置" name="redPacket.config" >
  387. <el-form ref="form19" :model="form19" label-width="150px">
  388. <el-form-item label="红包接口类型" prop="isNew">
  389. <el-radio-group v-model="form19.isNew">
  390. <el-radio label="0">商家转账到零钱(旧)</el-radio>
  391. <el-radio label="1">商家转账(新)</el-radio>
  392. </el-radio-group>
  393. </el-form-item>
  394. <el-form-item label="公众号appid" prop="appId">
  395. <el-input v-model="form19.appId" label="请输入appId"></el-input>
  396. </el-form-item>
  397. <el-form-item label="小程序appid" prop="appId">
  398. <el-input v-model="form19.miniappId" label="请输入appId"></el-input>
  399. </el-form-item>
  400. <el-form-item label="商户号" prop="mchId">
  401. <el-input v-model="form19.mchId" label="请输入mchId"></el-input>
  402. </el-form-item>
  403. <el-form-item label="商户密钥" prop="mchKey">
  404. <el-input v-model="form19.mchKey" label="mchKey"></el-input>
  405. </el-form-item>
  406. <el-form-item label="p12证书路径" prop="keyPath">
  407. <el-input v-model="form19.keyPath" label="请输入keyPath"></el-input>
  408. </el-form-item>
  409. <el-form-item label="apiV3密钥" prop="apiV3Key">
  410. <el-input v-model="form19.apiV3Key" label="请输入apiV3Key"></el-input>
  411. </el-form-item>
  412. <el-form-item label="公钥ID" prop="publicKeyId">
  413. <el-input v-model="form19.publicKeyId" label="请输入公钥ID"></el-input>
  414. </el-form-item>
  415. <el-form-item label="公钥证书" prop="publicKeyPath">
  416. <el-input v-model="form19.publicKeyPath" label="请输入publicKeyPath"></el-input>
  417. </el-form-item>
  418. <el-form-item label="key路径" prop="privateKeyPath">
  419. <el-input v-model="form19.privateKeyPath" label="请输入"></el-input>
  420. </el-form-item>
  421. <el-form-item label="cert路径" prop="privateCertPath">
  422. <el-input v-model="form19.privateCertPath" label="请输入"></el-input>
  423. </el-form-item>
  424. <el-form-item label="回调地址" prop="notifyUrl">
  425. <el-input v-model="form19.notifyUrl" label="请输入"></el-input>
  426. </el-form-item>
  427. <div class="footer">
  428. <el-button type="primary" @click="submitForm19">提 交</el-button>
  429. </div>
  430. </el-form>
  431. </el-tab-pane>
  432. <el-tab-pane label="布局配置" name="store.appShow" >
  433. <div >
  434. <el-table border :data="form10">
  435. <el-table-column prop="name" label="模块名称" width="300">
  436. <template slot-scope="scope"> <el-input v-model="scope.row.name" ></el-input></template>
  437. </el-table-column>
  438. <el-table-column prop="sort"label="排序号" width="300">
  439. <template slot-scope="scope"><el-input-number v-model="scope.row.sort" :min="0" :max="100" ></el-input-number> </template>
  440. </el-table-column>
  441. <el-table-column prop="isShow" label="是否展示" width="100">
  442. <template slot-scope="scope"> <el-switch
  443. v-model="scope.row.isShow"
  444. active-color="#13ce66"
  445. inactive-color="#ff4949">
  446. </el-switch> </template>
  447. </el-table-column>
  448. </el-table>
  449. <div class="footer">
  450. <el-button type="primary" @click="submitForm10">提 交</el-button>
  451. </div>
  452. </div>
  453. </el-tab-pane>
  454. </el-tabs>
  455. <el-dialog :title="sign.title" :visible.sync="sign.open" width="500px" append-to-body>
  456. <el-form ref="signform" :model="signform" label-width="80px">
  457. <el-form-item label="名称" prop="day">
  458. <el-input v-model="signform.day" placeholder="请输入名称" />
  459. </el-form-item>
  460. <el-form-item label="获得积分" prop="signNum">
  461. <el-input-number v-model="signform.signNum" placeholder="请输入获得积分" />
  462. </el-form-item>
  463. <el-form-item label="排序" prop="sort">
  464. <el-input-number v-model="signform.sort" placeholder="请输入排序" />
  465. </el-form-item>
  466. </el-form>
  467. <div slot="footer" class="dialog-footer">
  468. <el-button type="primary" @click="submitSignForm">确 定</el-button>
  469. </div>
  470. </el-dialog>
  471. </div>
  472. </template>
  473. <script>
  474. import Editor from '@/components/Editor/wang';
  475. import { getConfigByKey,updateConfigByKey, clearCache } from "@/api/system/config";
  476. import Material from '@/components/Material'
  477. export default {
  478. name: "Config",
  479. components: {
  480. Material,
  481. Editor
  482. },
  483. watch: {
  484. photoArr: function(val) {
  485. this.form1.certs = val.join(',')
  486. },
  487. images: function(val) {
  488. this.form7.images = val.join(',')
  489. }
  490. },
  491. data() {
  492. return {
  493. uploadUrl:process.env.VUE_APP_BASE_API+"/common/uploadOSS",
  494. videoAccept:"video/*",
  495. sign:{
  496. title:"修改签到",
  497. open:false,
  498. },
  499. signform: {
  500. },
  501. photoArr:[],
  502. images:[],
  503. activeName:"store.config",
  504. configId:null,
  505. configKey:null,
  506. // 表单参数
  507. form1: {
  508. hotSearch:"",
  509. },
  510. // 表单校验
  511. rules1: {
  512. },
  513. form2: {
  514. },
  515. // 表单校验
  516. rules2: {
  517. },
  518. form3: {
  519. },
  520. // 表单校验
  521. rules3: {
  522. },
  523. form4: {
  524. sign:[],
  525. },
  526. // 表单校验
  527. rules4: {
  528. },
  529. form5: {
  530. },
  531. form6: {
  532. },
  533. form7: {
  534. },
  535. rules7: {
  536. },
  537. form18:{
  538. },
  539. form10:[],
  540. form19:{
  541. },
  542. // 表单校验
  543. rules5: {
  544. }
  545. };
  546. },
  547. created() {
  548. this.getConfigByKey(this.activeName);
  549. },
  550. methods: {
  551. handleSuccess(response, file) {
  552. // 上传成功后的回调函数
  553. this.myloading.close();
  554. this.form7.videoUrl = response.url;
  555. this.$refs.upload.clearFiles();
  556. },
  557. beforeUpload(file) {
  558. // 上传前的钩子函数,可以在这里对文件进行处理
  559. // 返回 false 则取消上传
  560. // 例如限制文件大小
  561. const isLt2M = file.size / 1024 / 1024 < 200;
  562. if (!isLt2M) {
  563. this.$message.error('上传视频文件大小不能超过 200MB!');
  564. return false;
  565. }
  566. this.myloading = this.$loading({
  567. lock: true,
  568. text: '上传中',
  569. spinner: 'el-icon-loading',
  570. background: 'rgba(0, 0, 0, 0.7)'
  571. });
  572. },
  573. handleSignEdit(item){
  574. this.signform=item;
  575. this.sign.open=true;
  576. },
  577. submitSignForm(){
  578. this.sign.open=false;
  579. },
  580. updateText1(text){
  581. this.form5.userAgreement=text
  582. },
  583. updateText2(text){
  584. this.form5.privacyPolicy=text
  585. },
  586. handleClick(tab, event){
  587. console.log(tab.name)
  588. this.getConfigByKey(tab.name);
  589. },
  590. getConfigByKey(key){
  591. getConfigByKey(key).then(response => {
  592. console.log(response)
  593. if(key=="store.config"){
  594. this.configId=response.data.configId;
  595. this.configKey=response.data.configKey;
  596. this.form1 =JSON.parse(response.data.configValue);
  597. if(this.form1.certs!=null){
  598. this.photoArr=this.form1.certs.split(",");
  599. }
  600. }
  601. else if(key=="store.concept"){
  602. this.configId=response.data.configId;
  603. this.configKey=response.data.configKey;
  604. this.form7 =JSON.parse(response.data.configValue);
  605. if(this.form7.images!=null){
  606. this.images=this.form7.images.split(",");
  607. }
  608. }
  609. else if(key=="store.integral"){
  610. this.configId=response.data.configId;
  611. this.configKey=response.data.configKey;
  612. console.log(response.data.configValue)
  613. this.form3 =JSON.parse(response.data.configValue);
  614. console.log(this.form3.sign)
  615. }
  616. else if(key=="store.sign"){
  617. this.configId=response.data.configId;
  618. this.configKey=response.data.configKey;
  619. this.form4.sign =JSON.parse(response.data.configValue);
  620. console.log(this.form4.sign)
  621. }
  622. else if(key=="store.agreement"){
  623. this.configId=response.data.configId;
  624. this.configKey=response.data.configKey;
  625. this.form5 =JSON.parse(response.data.configValue);
  626. this.$refs.myeditor1.setText(this.form5.userAgreement);
  627. this.$refs.myeditor2.setText(this.form5.privacyPolicy);
  628. }
  629. else if(key=="sys.oss.cloudStorage"){
  630. this.configId=response.data.configId;
  631. this.configKey=response.data.configKey;
  632. this.form2 =JSON.parse(response.data.configValue);
  633. }
  634. else if(key=="store.pay"){
  635. this.configId=response.data.configId;
  636. this.configKey=response.data.configKey;
  637. this.form6 =JSON.parse(response.data.configValue);
  638. }
  639. if(key=="course.config"){
  640. this.configId=response.data.configId;
  641. this.configKey=response.data.configKey;
  642. this.form18 =JSON.parse(response.data.configValue);
  643. }
  644. if(key=="redPacket.config"){
  645. this.configId=response.data.configId;
  646. this.configKey=response.data.configKey;
  647. this.form19 =JSON.parse(response.data.configValue);
  648. }
  649. if(key=="store.appShow"){
  650. this.configId=response.data.configId;
  651. this.configKey=response.data.configKey;
  652. this.form10 =JSON.parse(response.data.configValue);
  653. }
  654. });
  655. },
  656. /** 提交按钮 */
  657. submitForm1: function() {
  658. this.$refs["form1"].validate(valid => {
  659. if (valid) {
  660. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form1)}
  661. updateConfigByKey(param).then(response => {
  662. if (response.code === 200) {
  663. this.msgSuccess("修改成功");
  664. }
  665. });
  666. }
  667. });
  668. },
  669. submitForm2: function() {
  670. this.$refs["form2"].validate(valid => {
  671. if (valid) {
  672. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form2)}
  673. updateConfigByKey(param).then(response => {
  674. if (response.code === 200) {
  675. this.msgSuccess("修改成功");
  676. }
  677. });
  678. }
  679. });
  680. },
  681. submitForm3: function() {
  682. this.$refs["form3"].validate(valid => {
  683. if (valid) {
  684. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form3)}
  685. updateConfigByKey(param).then(response => {
  686. if (response.code === 200) {
  687. this.msgSuccess("修改成功");
  688. }
  689. });
  690. }
  691. });
  692. },
  693. submitForm4: function() {
  694. this.$refs["form4"].validate(valid => {
  695. if (valid) {
  696. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form4.sign)}
  697. updateConfigByKey(param).then(response => {
  698. if (response.code === 200) {
  699. this.msgSuccess("修改成功");
  700. }
  701. });
  702. }
  703. });
  704. },
  705. submitForm5: function() {
  706. this.$refs["form5"].validate(valid => {
  707. if (valid) {
  708. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form5)}
  709. updateConfigByKey(param).then(response => {
  710. if (response.code === 200) {
  711. this.msgSuccess("修改成功");
  712. }
  713. });
  714. }
  715. });
  716. },
  717. submitform6: function() {
  718. this.$refs["form6"].validate(valid => {
  719. if (valid) {
  720. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form6)}
  721. updateConfigByKey(param).then(response => {
  722. if (response.code === 200) {
  723. this.msgSuccess("修改成功");
  724. }
  725. });
  726. }
  727. });
  728. },
  729. submitForm7(){
  730. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form7)}
  731. updateConfigByKey(param).then(response => {
  732. if (response.code === 200) {
  733. this.msgSuccess("修改成功");
  734. }
  735. });
  736. },
  737. submitForm18(){
  738. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form18)}
  739. updateConfigByKey(param).then(response => {
  740. if (response.code === 200) {
  741. this.msgSuccess("修改成功");
  742. }
  743. });
  744. },
  745. submitForm19(){
  746. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form19)}
  747. updateConfigByKey(param).then(response => {
  748. if (response.code === 200) {
  749. this.msgSuccess("修改成功");
  750. }
  751. });
  752. },
  753. submitForm10(){
  754. var param={configId:this.configId,configKey:this.configKey,configValue:JSON.stringify(this.form10)}
  755. updateConfigByKey(param).then(response => {
  756. if (response.code === 200) {
  757. this.msgSuccess("修改成功");
  758. }
  759. });
  760. },
  761. /** 清理缓存按钮操作 */
  762. handleClearCache() {
  763. clearCache().then(response => {
  764. if (response.code === 200) {
  765. this.msgSuccess("清理成功");
  766. }
  767. });
  768. }
  769. }
  770. };
  771. </script>
  772. <style scoped>
  773. .footer{
  774. width: 100%;
  775. display: flex;
  776. align-items: flex-end;
  777. justify-content: flex-end;
  778. }
  779. </style>