edit.vue 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352
  1. <template>
  2. <div class="system-edit-dic-container">
  3. <el-dialog :title="(ruleForm.sourceId !== 0 ? '修改' : '添加') + '数据源'" v-model="isShowDialog" width="769px">
  4. <el-form :model="ruleForm" ref="formRef" :rules="rules" size="default" label-width="110px">
  5. <el-form-item label="数据源标识" prop="key">
  6. <el-input v-model="ruleForm.key" placeholder="请输入数据源名称" />
  7. </el-form-item>
  8. <el-form-item label="数据源名称" prop="name">
  9. <el-input v-model="ruleForm.name" placeholder="请输入数据源名称" />
  10. </el-form-item>
  11. <el-form-item label="描述" prop="description">
  12. <el-input v-model="ruleForm.description" type="textarea" placeholder="请输入内容"></el-input>
  13. </el-form-item>
  14. <el-form-item label="数据来源" prop="from">
  15. <el-radio-group v-model="ruleForm.from">
  16. <el-radio :label="1">api导入</el-radio>
  17. <el-radio :label="2">数据库</el-radio>
  18. <el-radio :label="3">文件</el-radio>
  19. </el-radio-group>
  20. </el-form-item>
  21. <el-divider content-position="left">规则表达式</el-divider>
  22. <div v-for="(item, index) in rule" :key="index">
  23. <el-form-item label="表达式" prop="expression">
  24. <el-input v-model="item.expression" placeholder="请输入规则表达式" />
  25. </el-form-item>
  26. <el-form-item label="参数" prop="params">
  27. <el-input v-model="rule[index].params.name" placeholder="请输入键值" class="w-35" />
  28. <el-input v-model="rule[index].params.value" placeholder="请输入值" class="w-35" />
  29. <div class="conicon">
  30. <el-icon @click="delRule(index)" v-if="index > 0"><Delete /></el-icon>
  31. </div>
  32. </el-form-item>
  33. </div>
  34. <div style="padding: 10px">
  35. <el-button type="primary" class="addbutton" @click="addRule">增加</el-button>
  36. </div>
  37. <el-divider content-position="left">数据源配置</el-divider>
  38. <el-form-item label="请求方法" prop="method">
  39. <el-select v-model="config.method" placeholder="请选择请求方法">
  40. <el-option v-for="item in methodData" :key="item.value" :label="item.label" :value="item.value" />
  41. </el-select>
  42. </el-form-item>
  43. <el-form-item label="请求地址" prop="url">
  44. <el-input v-model="config.url" placeholder="请输入请求地址" />
  45. </el-form-item>
  46. <el-form-item label="更新时间" prop="interval">
  47. <el-input v-model="config.interval" placeholder="请输入更新时间" class="w-35" />
  48. <el-select v-model="config.intervalUnit" placeholder="请选择单位">
  49. <el-option v-for="item in unitData" :key="item.value" :label="item.label" :value="item.value" />
  50. </el-select>
  51. </el-form-item>
  52. <div class="box-content">
  53. <el-divider content-position="left">请求参数</el-divider>
  54. <div class="content-f" v-for="(item, index) in requestParams" :key="index">
  55. <el-select v-model="item.type" placeholder="参数类型" style="width: 320px">
  56. <el-option v-for="item in paramData" :key="item.value" :label="item.label" :value="item.value" />
  57. </el-select>
  58. <el-input v-model="item.name" placeholder="请输入参数标题" style="width: 320px" />
  59. <el-input v-model="item.key" placeholder="请输入参数名" style="width: 320px" />
  60. <el-input v-model="item.value" placeholder="请输入参数值" style="width: 320px" />
  61. <div class="conicon">
  62. <el-icon @click="delParams(index)" v-if="index > 0"><Delete /></el-icon>
  63. </div>
  64. </div>
  65. <el-button type="primary" class="addbutton" @click="addParams">增加</el-button>
  66. </div>
  67. </el-form>
  68. <template #footer>
  69. <span class="dialog-footer">
  70. <el-button @click="onCancel" size="default">取 消</el-button>
  71. <el-button type="primary" @click="onSubmit" size="default">{{ ruleForm.sourceId !== 0 ? '修 改' : '添 加' }}</el-button>
  72. </span>
  73. </template>
  74. </el-dialog>
  75. </div>
  76. </template>
  77. <script lang="ts">
  78. import { reactive, toRefs, defineComponent, ref, unref } from 'vue';
  79. import api from '/@/api/datahub';
  80. import { ElMessage } from 'element-plus';
  81. import { Delete, Minus, Right } from '@element-plus/icons-vue';
  82. interface RuleFormState {
  83. sourceId: number;
  84. name: string;
  85. from: number;
  86. key: string;
  87. userName: string;
  88. password: string;
  89. description: string;
  90. status: number;
  91. }
  92. interface DicState {
  93. isShowDialog: boolean;
  94. ruleForm: RuleFormState;
  95. rules: {};
  96. }
  97. export default defineComponent({
  98. name: 'Edit',
  99. components: { Delete, Minus, Right },
  100. setup(prop, { emit }) {
  101. const formRef = ref<HTMLElement | null>(null);
  102. const state = reactive<DicState>({
  103. isShowDialog: false,
  104. config: {},
  105. ruledata: [
  106. {
  107. expression: '',
  108. params: {},
  109. },
  110. ],
  111. rule: [
  112. {
  113. expression: '',
  114. params: {
  115. name: '',
  116. value: '',
  117. },
  118. },
  119. ],
  120. requestParams: [
  121. {
  122. type: '',
  123. key: '',
  124. name: '',
  125. value: '',
  126. },
  127. ],
  128. methodData: [
  129. {
  130. label: 'GET',
  131. value: 'get',
  132. },
  133. {
  134. label: 'POST',
  135. value: 'post',
  136. },
  137. {
  138. label: 'PUT',
  139. value: 'put',
  140. },
  141. ],
  142. unitData: [
  143. {
  144. label: '秒',
  145. value: 'second',
  146. },
  147. {
  148. label: '分',
  149. value: 'minute',
  150. },
  151. {
  152. label: '时',
  153. value: 'hour',
  154. },
  155. {
  156. label: '天',
  157. value: 'day',
  158. },
  159. ],
  160. paramData: [
  161. {
  162. lable: 'header',
  163. value: 'header',
  164. },
  165. {
  166. lable: 'body',
  167. value: 'body',
  168. },
  169. {
  170. lable: 'param',
  171. value: 'param',
  172. },
  173. ],
  174. ruleForm: {
  175. sourceId: 0,
  176. name: '',
  177. from: 1,
  178. key: '',
  179. rule: [],
  180. config: {
  181. method: '',
  182. url: '',
  183. interval: '',
  184. intervalUnit: '',
  185. requestParams: [],
  186. },
  187. description: '',
  188. },
  189. rules: {
  190. key: [{ required: true, message: '数据源标识不能为空', trigger: 'blur' }],
  191. name: [{ required: true, message: '数据源名称不能为空', trigger: 'blur' }],
  192. from: [{ required: true, message: '数据源类型不能为空', trigger: 'blur' }],
  193. host: [{ required: true, message: '地址不能为空', trigger: 'blur' }],
  194. port: [{ required: true, message: '端口不能为空', trigger: 'blur' }],
  195. userName: [{ required: true, message: '请输入用户名', trigger: 'blur' }],
  196. password: [{ required: true, message: '请输入密码', trigger: 'blur' }],
  197. },
  198. });
  199. const delParams = (index) => {
  200. state.requestParams.splice(index, 1);
  201. };
  202. const addParams = () => {
  203. state.requestParams.push({
  204. type: '',
  205. key: '',
  206. name: '',
  207. value: '',
  208. });
  209. };
  210. const delRule = (index) => {
  211. state.rule.splice(index, 1);
  212. };
  213. const addRule = () => {
  214. state.rule.push({
  215. expression: '',
  216. params: {
  217. name: '',
  218. value: '',
  219. },
  220. });
  221. };
  222. // 打开弹窗
  223. const openDialog = (row: RuleFormState | null) => {
  224. resetForm();
  225. if (row) {
  226. // api.dict.getType(row.id).then((res:any)=>{
  227. // state.ruleForm = res.data.dictType
  228. // })
  229. state.ruleForm = row;
  230. }
  231. state.isShowDialog = true;
  232. };
  233. const resetForm = () => {
  234. state.ruleForm = {
  235. sourceId: 0,
  236. name: '',
  237. from: 1,
  238. key: '',
  239. port: '',
  240. description: '',
  241. };
  242. };
  243. // 关闭弹窗
  244. const closeDialog = () => {
  245. state.isShowDialog = false;
  246. };
  247. // 取消
  248. const onCancel = () => {
  249. closeDialog();
  250. };
  251. // 新增
  252. const onSubmit = () => {
  253. const formWrap = unref(formRef) as any;
  254. if (!formWrap) return;
  255. formWrap.validate((valid: boolean) => {
  256. if (valid) {
  257. //修改rule数据
  258. state.rule.forEach((item, index) => {
  259. state.ruledata[index].expression = item.expression;
  260. state.ruledata[index].params[item.params.name] = item.params.value;
  261. });
  262. state.ruleForm.rule = state.ruledata;
  263. state.config.requestParams = state.requestParams;
  264. state.ruleForm.config = state.config;
  265. if (state.ruleForm.sourceId !== 0) {
  266. //修改
  267. api.common.edit(state.ruleForm).then(() => {
  268. ElMessage.success('数据源类型修改成功');
  269. closeDialog(); // 关闭弹窗
  270. emit('typeList');
  271. });
  272. } else {
  273. //添加
  274. api.common.add(state.ruleForm).then(() => {
  275. ElMessage.success('数据源类型添加成功');
  276. closeDialog(); // 关闭弹窗
  277. emit('typeList');
  278. });
  279. }
  280. }
  281. });
  282. };
  283. return {
  284. addRule,
  285. delRule,
  286. addParams,
  287. delParams,
  288. openDialog,
  289. closeDialog,
  290. onCancel,
  291. onSubmit,
  292. formRef,
  293. ...toRefs(state),
  294. };
  295. },
  296. });
  297. </script>
  298. <style>
  299. .el-input__wrapper {
  300. width: 98%;
  301. }
  302. .box-content {
  303. border: 1px solid #e8e8e8;
  304. margin: 10px;
  305. padding: 10px;
  306. }
  307. .content-f {
  308. display: flex;
  309. margin-bottom: 10px;
  310. }
  311. .content-f .el-input__wrapper {
  312. margin-right: 5px;
  313. }
  314. .addbutton {
  315. width: 100%;
  316. margin-top: 10px;
  317. }
  318. .conicon {
  319. width: 55px;
  320. height: 25px;
  321. font-size: 28px;
  322. line-height: 28px;
  323. cursor: pointer;
  324. }
  325. </style>