write.html 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. {{.Header}}
  2. <div id="app" style="width:100%">
  3. <template>
  4. <el-container v-loading.fullscreen.lock="fullscreenLoading">
  5. <el-aside>
  6. {{.Left}}
  7. </el-aside>
  8. <el-main class="mainMain">
  9. <el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="120px">
  10. <el-form-item label="smtp地址" prop="smtp">
  11. <el-input v-model="ruleForm.smtp" placeholder="SMTP服务器如smtp.sina.net:25包含端口号"></el-input>
  12. </el-form-item>
  13. <el-form-item label="主题" prop="subject">
  14. <el-input v-model="ruleForm.subject"></el-input>
  15. </el-form-item>
  16. <el-form-item label="收件人" prop="to">
  17. <el-input v-model="ruleForm.to"></el-input>
  18. </el-form-item>
  19. <el-form-item label="内容" prop="content">
  20. <el-input type="textarea" v-model="ruleForm.content"></el-input>
  21. </el-form-item>
  22. <el-form-item>
  23. <el-button type="primary" @click="submitForm('ruleForm')">立即发送</el-button>
  24. <el-button @click="resetForm('ruleForm')">取消</el-button>
  25. </el-form-item>
  26. </el-form>
  27. </el-main>
  28. </el-container>
  29. </template>
  30. </div>
  31. </body>
  32. <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
  33. <script>
  34. new Vue({
  35. el: '#app',
  36. delimiters:["<{","}>"],
  37. data: {
  38. fullscreenLoading:true,
  39. folders:[],
  40. fid:"",
  41. mailTotal:0,
  42. ruleForm: {
  43. smtp: '',
  44. to: '',
  45. subject: '',
  46. content: '',
  47. },
  48. rules: {
  49. smtp: [
  50. { required: true, message: 'SMTP服务器如"smtp.sina.net:25"包含端口号', trigger: 'blur' },
  51. ],
  52. to: [
  53. { required: true, message: '邮箱地址', trigger: 'blur' },
  54. ],
  55. subject: [
  56. { required: true, message: '主题', trigger: 'blur' },
  57. ],
  58. content: [
  59. { required: true, message: '内容', trigger: 'blur' },
  60. ],
  61. },
  62. },
  63. methods: {
  64. //获取邮件夹
  65. getFolders: function () {
  66. this.fullscreenLoading=true;
  67. let _this = this;
  68. $.get('/folder_dirs', function (rs) {
  69. _this.folders=rs.result.folders;
  70. _this.mailTotal=rs.result.total;
  71. _this.fid=rs.result.fid;
  72. _this.fullscreenLoading=false;
  73. }).then(()=>{
  74. _this.fullscreenLoading=false;
  75. });
  76. },
  77. //跳转
  78. openUrl(url){
  79. window.location.href=url;
  80. },
  81. //提交表单
  82. submitForm(formName){
  83. let _this=this;
  84. this.$refs[formName].validate((valid) => {
  85. console.log(valid,formName,this.$refs[formName]);
  86. if (valid) {
  87. let data=this.ruleForm;
  88. let to=[];
  89. to.push(this.ruleForm.to);
  90. data.to=to;
  91. axios.post('/send', data).then(function (response) {
  92. console.log(response);
  93. }).catch(function (error) {
  94. console.log(error);
  95. });
  96. } else {
  97. return false;
  98. }
  99. });
  100. },
  101. //重置表单
  102. resetForm(formName) {
  103. this.loading=false;
  104. this.$refs[formName].resetFields();
  105. },
  106. },
  107. created: function () {
  108. this.getFolders();
  109. }
  110. })
  111. </script>
  112. </html>