index.vue 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. <template>
  2. <div id="index">
  3. <el-row>
  4. <el-col :span="24" class="main">
  5. <breadcrumb :breadcrumbTitle="this.$route.meta.title"></breadcrumb>
  6. <el-col :span="24" class="container info">
  7. <el-col :span="24" class="top">
  8. <el-button type="primary" size="mini" @click="dialog = true">添加</el-button>
  9. </el-col>
  10. <el-col :span="24" class="list">
  11. <data-table :fields="fields" :opera="opera" :data="list" :total="total" @edit="toEdit" @delete="toDelete" @query="search"></data-table>
  12. </el-col>
  13. </el-col>
  14. </el-col>
  15. </el-row>
  16. <el-dialog :visible.sync="dialog" title="增加企业信息" @close="toClose" :destroy-on-close="true" width="50%">
  17. <data-form :data="form" :fields="formFields" :rules="rules" @save="turnSave">
  18. <!-- 单选 -->
  19. <!-- <template #radios="{item}">
  20. <template v-if="item.model === 'type'">
  21. <el-radio label="0">技术</el-radio>
  22. <el-radio label="1">产品</el-radio>
  23. <el-radio label="1">服务</el-radio>
  24. </template>
  25. </template> -->
  26. <!-- 下拉单选 -->
  27. <!-- <template #options="{item}">
  28. <template v-if="item.model == 'type'">
  29. <template v-for="(i, index) in typeList">
  30. <el-option :key="index" :label="`${i.name}`" :value="i.id"></el-option>
  31. </template>
  32. </template>
  33. </template>
  34. <template #custom="{item,form}">
  35. <template v-if="item.model === 'file'">
  36. <upload
  37. :limit="1"
  38. :data="form.file"
  39. type="file"
  40. :isBtn="true"
  41. :url="`/files/file/upload`"
  42. @upload="uploadSuccess"
  43. @onedelete="uploadDeletefile"
  44. ></upload>
  45. </template>
  46. <template v-else-if="item.model === 'video'">
  47. <upload
  48. :limit="1"
  49. :data="form.video"
  50. type="video"
  51. :uploadBtn="true"
  52. listType=""
  53. :url="`/files/video/upload`"
  54. @upload="uploadSuccess"
  55. @onedelete="uploadDeletevideo"
  56. ></upload>
  57. </template>
  58. <template v-else-if="item.model === 'image'">
  59. <upload
  60. :limit="2"
  61. :data="form.image"
  62. type="image"
  63. :isBtn="true"
  64. fileType="2"
  65. :url="`/files/image/upload`"
  66. @upload="uploadSuccess"
  67. @delete="uploadDelete"
  68. ></upload>
  69. </template>
  70. </template> -->
  71. </data-form>
  72. </el-dialog>
  73. </div>
  74. </template>
  75. <script>
  76. import breadcrumb from '@c/common/breadcrumb.vue';
  77. import dataTable from '@/components/frame/filter-page-table.vue';
  78. import dataForm from '@/components/frame/form.vue';
  79. import upload from '@/components/frame/uploadone.vue';
  80. import { mapState, createNamespacedHelpers } from 'vuex';
  81. const { mapActions: testmess } = createNamespacedHelpers('testmess');
  82. export default {
  83. metaInfo() {
  84. return { title: this.$route.meta.title };
  85. },
  86. name: 'index',
  87. props: {},
  88. components: {
  89. breadcrumb,
  90. dataTable,
  91. dataForm,
  92. // upload,
  93. },
  94. data: function() {
  95. return {
  96. opera: [
  97. {
  98. label: '修改',
  99. icon: 'el-icon-edit',
  100. method: 'edit',
  101. },
  102. {
  103. label: '删除',
  104. icon: 'el-icon-delete',
  105. method: 'delete',
  106. },
  107. ],
  108. fields: [
  109. { label: '标题', prop: 'title' },
  110. { label: '发布时间', prop: 'publish_time' },
  111. { label: '来源', prop: 'origin' },
  112. { label: '内容', prop: 'content' },
  113. ],
  114. list: [],
  115. total: 0,
  116. // 增加菜单
  117. dialog: false,
  118. formFields: [
  119. { label: '标题', required: true, model: 'title' },
  120. { label: '发布时间', required: true, model: 'publish_time', type: 'date' },
  121. { label: '来源', required: true, model: 'origin' },
  122. { label: '内容', required: true, model: 'content' },
  123. ],
  124. form: {},
  125. rules: {},
  126. // 类型
  127. typeList: [
  128. {
  129. id: '0',
  130. name: '技术',
  131. },
  132. {
  133. id: '1',
  134. name: '产品',
  135. },
  136. {
  137. id: '2',
  138. name: '服务',
  139. },
  140. ],
  141. };
  142. },
  143. created() {
  144. this.search();
  145. },
  146. methods: {
  147. ...testmess(['query', 'fetch', 'create', 'update', 'delete']),
  148. // 查询列表
  149. async search({ skip = 0, limit = 10, ...info } = {}) {
  150. let res = await this.query({ skip, limit, ...info });
  151. if (this.$checkRes(res)) {
  152. this.$set(this, `list`, res.data);
  153. this.$set(this, `total`, res.total);
  154. }
  155. },
  156. // 修改
  157. async toEdit({ data }) {
  158. this.dialog = true;
  159. let res = await this.fetch(data.id);
  160. if (this.$checkRes(res)) {
  161. this.$set(this, `form`, res.data);
  162. }
  163. },
  164. // 删除
  165. async toDelete() {
  166. let res = await this.delete(data);
  167. if (this.$checkRes(res)) {
  168. this.$message({
  169. message: '删除成功',
  170. type: 'success',
  171. });
  172. this.search();
  173. }
  174. },
  175. // 增加菜单
  176. // 保存
  177. async turnSave({ data }) {
  178. if (data.id) {
  179. let res = await this.update(data);
  180. if (this.$checkRes(res)) {
  181. this.$message({
  182. message: '修改成功',
  183. type: 'success',
  184. });
  185. this.toClose();
  186. } else {
  187. this.$message({
  188. message: res.errmsg,
  189. type: 'error',
  190. });
  191. }
  192. } else {
  193. let res = await this.create(data);
  194. if (this.$checkRes(res)) {
  195. this.$message({
  196. message: '创建成功',
  197. type: 'success',
  198. });
  199. this.toClose();
  200. } else {
  201. this.$message({
  202. message: res.errmsg,
  203. type: 'error',
  204. });
  205. }
  206. }
  207. },
  208. // 取消增加
  209. toClose() {
  210. this.form = {};
  211. this.dialog = false;
  212. this.search();
  213. },
  214. uploadSuccess({ type, data }) {
  215. if (type == 'image') {
  216. let arr = _.get(this.form, type);
  217. if (_.isArray(arr)) {
  218. let datas = { name: data.name, url: data.uri };
  219. this.form[type].push({ name: data.name, url: data.uri });
  220. } else {
  221. let newArr = [{ name: data.name, url: data.uri }];
  222. this.$set(this.form, `${type}`, newArr);
  223. }
  224. } else {
  225. this.$set(this.form, `${type}`, data.uri);
  226. }
  227. },
  228. // 删除图片
  229. uploadDelete(index) {
  230. this.form.image.splice(index, 1);
  231. },
  232. uploadDeletefile(data) {
  233. this.form.file = null;
  234. },
  235. uploadDeletevideo(data) {
  236. this.form.video = null;
  237. },
  238. },
  239. computed: {
  240. ...mapState(['user']),
  241. },
  242. };
  243. </script>
  244. <style lang="less" scoped>
  245. .main {
  246. .info {
  247. .top {
  248. text-align: right;
  249. margin: 10px 0;
  250. }
  251. }
  252. }
  253. </style>