RuleSettings.vue 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. <template>
  2. <el-table :data="data" :show-header="true">
  3. <el-table-column prop="id" label="id" />
  4. <el-table-column prop="name" :label="lang.rule_name" />
  5. <el-table-column prop="action" :label="lang.rule_do">
  6. <template #default="scope">
  7. {{ ActionName[scope.row.action] }}
  8. </template>
  9. </el-table-column>
  10. <el-table-column prop="params" :label="lang.rule_params" />
  11. <el-table-column prop="sort" :label="lang.rule_priority" />
  12. <el-table-column>
  13. <template #default="scope">
  14. <div style="display: flex; align-items: center">
  15. <el-button size="small" type="primary" :icon="Edit" circle @click="editRule(scope.row)" />
  16. <el-popconfirm confirm-button-text="Yes" cancel-button-text="No, Thanks" :icon="InfoFilled"
  17. @confirm="delRule(scope.row.id)" icon-color="#626AEF" :title="lang.del_rule_confirm">
  18. <template #reference>
  19. <el-button size="small" type="danger" :icon="Delete" circle />
  20. </template>
  21. </el-popconfirm>
  22. </div>
  23. </template>
  24. </el-table-column>
  25. </el-table>
  26. <div>
  27. <el-button @click="dialogVisible = true">{{ lang.new_rule }}</el-button>
  28. </div>
  29. <el-dialog v-model="dialogVisible" :title="lang.new_rule" width="60%">
  30. <div style="text-align: left; padding-left: 20px;">
  31. <el-form v-model="addRuleForm" :inline="true" label-position="top">
  32. <el-form-item style="width: 400px;" :label="lang.rule_name">
  33. <el-input v-model="addRuleForm.name" />
  34. </el-form-item>
  35. <el-form-item :label="lang.rule_priority">
  36. <el-input v-model="addRuleForm.sort" type="number" oninput="value=value.replace(/[^\-\d]/g, '')" />
  37. </el-form-item>
  38. <el-divider />
  39. <div style="width: 100%;">{{ lang.rule_desc }}</div>
  40. <div style="width: 100%;">
  41. <div v-for="(rule, index) in addRuleForm.rules">
  42. <el-select v-model="rule.field" placeholder="Select">
  43. <el-option key="From" :label="lang.from" value="From" />
  44. <el-option key="Subject" :label="lang.subject" value="Subject" />
  45. <el-option key="To" :label="lang.to" value="To" />
  46. <el-option key="Cc" :label="lang.cc" value="Cc" />
  47. <el-option key="Content" :label="lang.content" value="Content" />
  48. </el-select>
  49. <el-select v-model="rule.type" placeholder="Select">
  50. <el-option key="equal" :label="lang.equal" value="equal" />
  51. <el-option key="contains" :label="lang.contains" value="contains" />
  52. <el-option key="regex" :label="lang.regex" value="regex" />
  53. </el-select>
  54. <el-input v-model="rule.rule" style="width: 350px;" />
  55. <el-button size="small" type="danger" :icon="Delete" @click="removeRuleLine(index)" circle />
  56. </div>
  57. </div>
  58. <div style="padding-top: 7px;">
  59. <el-button size="small" type="primary" :icon="Plus" circle @click="addRule()" />
  60. </div>
  61. <el-divider />
  62. <div style="width: 100%;">{{ lang.rule_do }}</div>
  63. <el-form-item>
  64. <el-select v-model="addRuleForm.action" placeholder="Select" @change="ruleTypeChange()">
  65. <el-option key="mark_read" :label="lang.mark_read" :value="READ" />
  66. <el-option key="move" :label="lang.move" :value="MOVE" />
  67. <el-option key="delete" :label="lang.delete" :value="DELETE" />
  68. <el-option key="forward" :label="lang.forward" :value="FORWARD" />
  69. </el-select>
  70. <el-select v-if="addRuleForm.action == 4" v-model="addRuleForm.params" @click="reflushGroupInfos">
  71. <el-option v-for="gp in groupData.list" :key="gp.id" :label="gp.name" :value="gp.id" />
  72. </el-select>
  73. <el-input v-if="addRuleForm.action == 2" v-model="addRuleForm.params" style="width: 250px;"
  74. placeholder="Forward Email Address" />
  75. </el-form-item>
  76. </el-form>
  77. </div>
  78. <template #footer>
  79. <span class="dialog-footer">
  80. <el-button type="primary" @click="submitRule()">
  81. {{ lang.submit }}
  82. </el-button>
  83. </span>
  84. </template>
  85. </el-dialog>
  86. </template>
  87. <script setup>
  88. import { ref, reactive } from 'vue';
  89. import $http from "../http/http";
  90. import lang from '../i18n/i18n';
  91. import {
  92. Plus,
  93. Delete,
  94. Edit,
  95. InfoFilled
  96. } from '@element-plus/icons-vue'
  97. const data = ref([])
  98. const dialogVisible = ref(false)
  99. const READ = 1
  100. const FORWARD = 2
  101. const DELETE = 3
  102. const MOVE = 4
  103. const ActionName = {
  104. 1: lang.mark_read,
  105. 2: lang.forward,
  106. 3: lang.delete,
  107. 4: lang.move
  108. }
  109. const init = function () {
  110. $http.post("/api/rule/get").then((res) => {
  111. data.value = res.data
  112. })
  113. }
  114. init()
  115. const groupData = reactive({
  116. list: []
  117. })
  118. const reflushGroupInfos = function () {
  119. $http.get('/api/group/list').then(res => {
  120. groupData.list = res.data
  121. for (let i = 0; i < groupData.list.length; i++) {
  122. groupData.list[i].id += ""
  123. }
  124. })
  125. }
  126. reflushGroupInfos()
  127. const addRuleForm = reactive({
  128. "id": 0,
  129. "name": "",
  130. "sort": 0,
  131. "rules": [
  132. {
  133. "field": "",
  134. "type": "",
  135. "rule": ""
  136. }
  137. ],
  138. "action": "",
  139. "params": ""
  140. })
  141. const delRule = function (id) {
  142. $http.post("/api/rule/del", { "id": id }).then((res) => {
  143. ElNotification({
  144. title: res.errorNo == 0 ? lang.succ : lang.fail,
  145. message: res.data,
  146. type: res.errorNo == 0 ? 'success' : 'error',
  147. })
  148. init()
  149. })
  150. }
  151. const editRule = function (ruleInfo) {
  152. addRuleForm.id = ruleInfo.id
  153. addRuleForm.name = ruleInfo.name
  154. addRuleForm.rules = ruleInfo.rules
  155. addRuleForm.action = ruleInfo.action
  156. addRuleForm.params = ruleInfo.params
  157. addRuleForm.sort = ruleInfo.sort
  158. dialogVisible.value = true
  159. }
  160. const removeRuleLine = function (index) {
  161. addRuleForm.rules.splice(index, 1);
  162. }
  163. const addRule = function () {
  164. addRuleForm.rules.push(
  165. {
  166. "field": "",
  167. "type": "",
  168. "rule": ""
  169. }
  170. )
  171. }
  172. const submitRule = function () {
  173. let api = "/api/rule/add"
  174. if (addRuleForm.id > 0) {
  175. api = "/api/rule/update"
  176. }
  177. addRuleForm.sort = parseInt(addRuleForm.sort)
  178. $http.post(api, addRuleForm).then((res) => {
  179. if (res.errorNo != 0) {
  180. ElNotification({
  181. title: lang.fail,
  182. message: res.data,
  183. type: 'error',
  184. })
  185. } else {
  186. init()
  187. dialogVisible.value = false
  188. addRuleForm.id = 0
  189. addRuleForm.name = ""
  190. addRuleForm.sort = 0
  191. addRuleForm.rules = [
  192. {
  193. "field": "",
  194. "type": "",
  195. "rule": ""
  196. }
  197. ]
  198. addRuleForm.action = ""
  199. addRuleForm.params = ""
  200. }
  201. })
  202. }
  203. const ruleTypeChange = function () {
  204. addRuleForm.params = ''
  205. }
  206. </script>