config.vue 41 KB

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