templateList.vue 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250
  1. <style lang="scss">
  2. .preview {
  3. .el-form-item {
  4. margin-bottom: 15px;
  5. }
  6. label,
  7. p {
  8. line-height: 25px !important;
  9. }
  10. }
  11. </style>
  12. <template>
  13. <section>
  14. <p><span>信息管理></span>问卷模板</p>
  15. <div class="content">
  16. <div class="filter">
  17. <el-form
  18. size="small"
  19. label-width="70px"
  20. :inline="true"
  21. label-position="left"
  22. >
  23. <el-form-item label="">
  24. <el-input
  25. clearable
  26. placeholder="请输入您要搜索的内容"
  27. v-model="form.name"
  28. @clear="search"
  29. @keyup.enter.native="search"
  30. ></el-input>
  31. </el-form-item>
  32. <el-form-item>
  33. <el-button type="primary" @click="search">搜索</el-button>
  34. </el-form-item>
  35. <el-form-item style="float: right">
  36. <el-button
  37. @click="(dialogVisible = true), (dialogTitle = '新增模板'),form1={}"
  38. type="primary"
  39. >新增模板</el-button
  40. >
  41. </el-form-item>
  42. </el-form>
  43. </div>
  44. <el-table
  45. class="table"
  46. :data="list"
  47. height="50vh"
  48. border
  49. v-loading="loading"
  50. default-expand-all
  51. row-key="id"
  52. style="width: 100%"
  53. >
  54. <el-table-column prop="name" label="模板名称"> </el-table-column>
  55. <el-table-column prop="cname" label="创建人"> </el-table-column>
  56. <el-table-column prop="ctime" label="创建时间"> </el-table-column>
  57. <el-table-column prop="zip" width="250" label="操作">
  58. <template slot-scope="scope">
  59. <el-button
  60. class="edit"
  61. type="text"
  62. @click="edit(scope.row)"
  63. v-if="scope.row.edit"
  64. >编辑</el-button
  65. >
  66. <el-tooltip
  67. v-else
  68. class="item"
  69. effect="dark"
  70. content="该模版使用的问卷正在被填报,无法修改,可新增模版-选择复用历史模版使用该模版或删除正在使用该模版的问卷!"
  71. placement="top-start"
  72. >
  73. <el-button
  74. class="edit"
  75. type="text"
  76. style="color: #ccc; cursor: not-allowed"
  77. >编辑</el-button
  78. >
  79. </el-tooltip>
  80. <el-button
  81. class="del"
  82. @click="del(scope.row.id)"
  83. type="text"
  84. >删除</el-button
  85. >
  86. </template>
  87. </el-table-column>
  88. </el-table>
  89. <Page
  90. ref="pageButton"
  91. :current="form.page"
  92. :page_size="form.page_size"
  93. :total="total"
  94. @pageChange="gopage"
  95. />
  96. </div>
  97. <el-dialog
  98. :title="dialogTitle"
  99. :close-on-click-modal="false"
  100. :visible.sync="dialogVisible"
  101. >
  102. <el-form
  103. ref="form1"
  104. size="small"
  105. class="preview"
  106. :inline="false"
  107. label-width="100px"
  108. :rules="rules"
  109. :model="form1"
  110. >
  111. <el-form-item label="复用历史模板" v-if="!form1.id">
  112. <el-select
  113. v-model="form1.copyid"
  114. filterable
  115. @change="changeTemplate"
  116. placeholder="请选择历史模板"
  117. >
  118. <el-option
  119. v-for="(item, index) in allTemplate"
  120. :key="index"
  121. :label="item.name"
  122. :value="item.id"
  123. ></el-option>
  124. </el-select>
  125. </el-form-item>
  126. <el-form-item label="模板名称" prop="name">
  127. <el-input
  128. v-model="form1.name"
  129. placeholder="请输入模板名称"
  130. maxlength="50"
  131. show-word-limit
  132. ></el-input>
  133. </el-form-item>
  134. </el-form>
  135. <span slot="footer" class="dialog-footer">
  136. <el-button size="small" type="primary" @click="addTtitle"
  137. >确 定</el-button
  138. >
  139. </span>
  140. </el-dialog>
  141. </section>
  142. </template>
  143. <script>
  144. import Page from "../../components/Page";
  145. export default {
  146. components: {
  147. Page,
  148. },
  149. data() {
  150. return {
  151. // edit:0,
  152. allTemplate: [],
  153. form: { name: "", page: 1, page_size: 20 },
  154. form1: {name:""},
  155. total: 1,
  156. list: [{ name: "2333" }],
  157. loading: false,
  158. input: "",
  159. dialogVisible: false,
  160. dialogTitle: "",
  161. defaultProps: {},
  162. data: [],
  163. rules: {
  164. name: [{ required: true, message: "请输入标题", trigger: "blur" }],
  165. },
  166. };
  167. },
  168. methods: {
  169. switchStatus(row) {
  170. this.$api.editTemplateStatus({id:row.id}).then((res)=>{
  171. row.status = res.data.data
  172. })
  173. },
  174. changeTemplate(val) {
  175. let selVal = this.allTemplate.filter(function (x) {
  176. return x.id == val;
  177. });
  178. this.form1.name = selVal[0].name;
  179. // this.form1.name = "111"
  180. },
  181. addTtitle() {
  182. this.$refs["form1"].validate((valid) => {
  183. if (valid) {
  184. let query = { title: this.form1.name, id: this.form1.id };
  185. if (this.form1.copyid) {
  186. query.id = this.form1.copyid;
  187. query.copyid = this.form1.copyid;
  188. }
  189. this.$router.push({
  190. path: "/message/template/add",
  191. query: query,
  192. });
  193. }
  194. });
  195. },
  196. search() {
  197. let parm = this.form;
  198. this.getData();
  199. },
  200. getData() {
  201. var parm = this.form;
  202. this.loading = true;
  203. this.$api.getTemplateList(parm).then((res) => {
  204. this.list = res.data.data.list;
  205. this.total = res.data.data.total;
  206. this.loading = false;
  207. });
  208. this.$api.getAllTemplateList().then((res) => {
  209. this.allTemplate = res.data.data;
  210. });
  211. },
  212. edit(row) {
  213. this.$api.getTemplate({ id: row.id }).then((res) => {
  214. // this.form1 = row;
  215. this.form1 = res.data.data;
  216. this.dialogVisible = true;
  217. });
  218. },
  219. del(id) {
  220. this.$confirm(
  221. "删除模板与模板相关联的消息会被一起删除,确定删除吗?",
  222. "提示",
  223. {
  224. type: "warning",
  225. }
  226. ).then(() => {
  227. this.$api.delTemplate({ id: id }).then((res) => {
  228. this.$message({
  229. message: "删除成功",
  230. type: "success",
  231. });
  232. this.getData();
  233. });
  234. });
  235. },
  236. gopage(size) {
  237. if (size) {
  238. this.form.page_size = size;
  239. }
  240. this.form.page = this.$refs.pageButton.page;
  241. this.getData();
  242. },
  243. },
  244. created() {
  245. this.getData();
  246. },
  247. };
  248. </script>