RuleSettings.vue 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  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 lang from '../i18n/i18n';
  90. import {
  91. Plus,
  92. Delete,
  93. Edit,
  94. InfoFilled
  95. } from '@element-plus/icons-vue'
  96. import { getCurrentInstance } from 'vue'
  97. const app = getCurrentInstance()
  98. const $http = app.appContext.config.globalProperties.$http
  99. const data = ref([])
  100. const dialogVisible = ref(false)
  101. const READ = 1
  102. const FORWARD = 2
  103. const DELETE = 3
  104. const MOVE = 4
  105. const ActionName = {
  106. 1: lang.mark_read,
  107. 2: lang.forward,
  108. 3: lang.delete,
  109. 4: lang.move
  110. }
  111. const init = function () {
  112. $http.post("/api/rule/get").then((res) => {
  113. data.value = res.data
  114. })
  115. }
  116. init()
  117. const groupData = reactive({
  118. list: []
  119. })
  120. const reflushGroupInfos = function () {
  121. $http.get('/api/group/list').then(res => {
  122. if (res.data != null) {
  123. groupData.list = res.data
  124. for (let i = 0; i < groupData.list.length; i++) {
  125. groupData.list[i].id += ""
  126. }
  127. }
  128. })
  129. }
  130. reflushGroupInfos()
  131. const addRuleForm = reactive({
  132. "id": 0,
  133. "name": "",
  134. "sort": 0,
  135. "rules": [
  136. {
  137. "field": "",
  138. "type": "",
  139. "rule": ""
  140. }
  141. ],
  142. "action": "",
  143. "params": ""
  144. })
  145. const delRule = function (id) {
  146. $http.post("/api/rule/del", { "id": id }).then((res) => {
  147. ElNotification({
  148. title: res.errorNo == 0 ? lang.succ : lang.fail,
  149. message: res.data,
  150. type: res.errorNo == 0 ? 'success' : 'error',
  151. })
  152. init()
  153. })
  154. }
  155. const editRule = function (ruleInfo) {
  156. addRuleForm.id = ruleInfo.id
  157. addRuleForm.name = ruleInfo.name
  158. addRuleForm.rules = ruleInfo.rules
  159. addRuleForm.action = ruleInfo.action
  160. addRuleForm.params = ruleInfo.params
  161. addRuleForm.sort = ruleInfo.sort
  162. dialogVisible.value = true
  163. }
  164. const removeRuleLine = function (index) {
  165. addRuleForm.rules.splice(index, 1);
  166. }
  167. const addRule = function () {
  168. addRuleForm.rules.push(
  169. {
  170. "field": "",
  171. "type": "",
  172. "rule": ""
  173. }
  174. )
  175. }
  176. const submitRule = function () {
  177. let api = "/api/rule/add"
  178. if (addRuleForm.id > 0) {
  179. api = "/api/rule/update"
  180. }
  181. addRuleForm.sort = parseInt(addRuleForm.sort)
  182. $http.post(api, addRuleForm).then((res) => {
  183. if (res.errorNo != 0) {
  184. ElNotification({
  185. title: lang.fail,
  186. message: res.data,
  187. type: 'error',
  188. })
  189. } else {
  190. init()
  191. dialogVisible.value = false
  192. addRuleForm.id = 0
  193. addRuleForm.name = ""
  194. addRuleForm.sort = 0
  195. addRuleForm.rules = [
  196. {
  197. "field": "",
  198. "type": "",
  199. "rule": ""
  200. }
  201. ]
  202. addRuleForm.action = ""
  203. addRuleForm.params = ""
  204. }
  205. })
  206. }
  207. const ruleTypeChange = function () {
  208. addRuleForm.params = ''
  209. }
  210. </script>