You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

133 lines
5.3 KiB

5 years ago
  1. <template>
  2. <el-dialog
  3. title="云存储配置"
  4. :close-on-click-modal="false"
  5. :visible.sync="visible">
  6. <el-form :model="dataForm" :rules="dataRule" ref="dataForm" @keyup.enter.native="dataFormSubmit()" label-width="120px">
  7. <el-form-item size="mini" label="存储类型">
  8. <el-radio-group v-model="dataForm.type">
  9. <el-radio :label="1">七牛</el-radio>
  10. <el-radio :label="2">阿里云</el-radio>
  11. <el-radio :label="3">腾讯云</el-radio>
  12. </el-radio-group>
  13. </el-form-item>
  14. <template v-if="dataForm.type === 1">
  15. <el-form-item size="mini">
  16. <a href="http://www.gaotao.io/open/qiniu.html" target="_blank">免费申请(七牛)10GB储存空间</a>
  17. </el-form-item>
  18. <el-form-item label="域名">
  19. <el-input v-model="dataForm.qiniuDomain" placeholder="七牛绑定的域名"></el-input>
  20. </el-form-item>
  21. <el-form-item label="路径前缀">
  22. <el-input v-model="dataForm.qiniuPrefix" placeholder="不设置默认为空"></el-input>
  23. </el-form-item>
  24. <el-form-item label="AccessKey">
  25. <el-input v-model="dataForm.qiniuAccessKey" placeholder="七牛AccessKey"></el-input>
  26. </el-form-item>
  27. <el-form-item label="SecretKey">
  28. <el-input v-model="dataForm.qiniuSecretKey" placeholder="七牛SecretKey"></el-input>
  29. </el-form-item>
  30. <el-form-item label="空间名">
  31. <el-input v-model="dataForm.qiniuBucketName" placeholder="七牛存储空间名"></el-input>
  32. </el-form-item>
  33. </template>
  34. <template v-else-if="dataForm.type === 2">
  35. <el-form-item label="域名">
  36. <el-input v-model="dataForm.aliyunDomain" placeholder="阿里云绑定的域名"></el-input>
  37. </el-form-item>
  38. <el-form-item label="路径前缀">
  39. <el-input v-model="dataForm.aliyunPrefix" placeholder="不设置默认为空"></el-input>
  40. </el-form-item>
  41. <el-form-item label="EndPoint">
  42. <el-input v-model="dataForm.aliyunEndPoint" placeholder="阿里云EndPoint"></el-input>
  43. </el-form-item>
  44. <el-form-item label="AccessKeyId">
  45. <el-input v-model="dataForm.aliyunAccessKeyId" placeholder="阿里云AccessKeyId"></el-input>
  46. </el-form-item>
  47. <el-form-item label="AccessKeySecret">
  48. <el-input v-model="dataForm.aliyunAccessKeySecret" placeholder="阿里云AccessKeySecret"></el-input>
  49. </el-form-item>
  50. <el-form-item label="BucketName">
  51. <el-input v-model="dataForm.aliyunBucketName" placeholder="阿里云BucketName"></el-input>
  52. </el-form-item>
  53. </template>
  54. <template v-else-if="dataForm.type === 3">
  55. <el-form-item label="域名">
  56. <el-input v-model="dataForm.qcloudDomain" placeholder="腾讯云绑定的域名"></el-input>
  57. </el-form-item>
  58. <el-form-item label="路径前缀">
  59. <el-input v-model="dataForm.qcloudPrefix" placeholder="不设置默认为空"></el-input>
  60. </el-form-item>
  61. <el-form-item label="AppId">
  62. <el-input v-model="dataForm.qcloudAppId" placeholder="腾讯云AppId"></el-input>
  63. </el-form-item>
  64. <el-form-item label="SecretId">
  65. <el-input v-model="dataForm.qcloudSecretId" placeholder="腾讯云SecretId"></el-input>
  66. </el-form-item>
  67. <el-form-item label="SecretKey">
  68. <el-input v-model="dataForm.qcloudSecretKey" placeholder="腾讯云SecretKey"></el-input>
  69. </el-form-item>
  70. <el-form-item label="BucketName">
  71. <el-input v-model="dataForm.qcloudBucketName" placeholder="腾讯云BucketName"></el-input>
  72. </el-form-item>
  73. <el-form-item label="Bucket所属地区">
  74. <el-input v-model="dataForm.qcloudRegion" placeholder="如:sh(可选值 ,华南:gz 华北:tj 华东:sh)"></el-input>
  75. </el-form-item>
  76. </template>
  77. </el-form>
  78. <span slot="footer" class="dialog-footer">
  79. <el-button @click="visible = false">取消</el-button>
  80. <el-button type="primary" @click="dataFormSubmit()">确定</el-button>
  81. </span>
  82. </el-dialog>
  83. </template>
  84. <script>
  85. export default {
  86. data () {
  87. return {
  88. visible: false,
  89. dataForm: {},
  90. dataRule: {}
  91. }
  92. },
  93. methods: {
  94. init (id) {
  95. this.visible = true
  96. this.$http({
  97. url: this.$http.adornUrl('/sys/oss/config'),
  98. method: 'get',
  99. params: this.$http.adornParams()
  100. }).then(({data}) => {
  101. this.dataForm = data && data.code === 0 ? data.config : []
  102. })
  103. },
  104. // 表单提交
  105. dataFormSubmit () {
  106. this.$refs['dataForm'].validate((valid) => {
  107. if (valid) {
  108. this.$http({
  109. url: this.$http.adornUrl('/sys/oss/saveConfig'),
  110. method: 'post',
  111. data: this.$http.adornData(this.dataForm)
  112. }).then(({data}) => {
  113. if (data && data.code === 0) {
  114. this.$message({
  115. message: '操作成功',
  116. type: 'success',
  117. duration: 1500,
  118. onClose: () => {
  119. this.visible = false
  120. }
  121. })
  122. } else {
  123. this.$message.error(data.msg)
  124. }
  125. })
  126. }
  127. })
  128. }
  129. }
  130. }
  131. </script>