comp.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320
  1. <template>
  2. <section>
  3. <!--工具条-->
  4. <el-col :span="24" class="toolbar" style="padding-bottom: 0px;">
  5. <el-form :inline="true" :model="filters">
  6. <el-form-item>
  7. <el-input v-model="filters.keyName" placeholder="请输入资产方名称进行搜索" clearable></el-input>
  8. </el-form-item>
  9. <el-form-item>
  10. <el-button type="primary" @click.native="getComp">查询</el-button>
  11. </el-form-item>
  12. <el-form-item style="float:right;">
  13. <el-button type="primary" @click.native="handleAdd">新增</el-button>
  14. </el-form-item>
  15. </el-form>
  16. </el-col>
  17. <!--列表-->
  18. <el-table :data="list" highlight-current-row :height="tableHeight" v-loading="listLoading" style="width: 100%;">
  19. <el-table-column type="index" width="60"></el-table-column>
  20. <el-table-column prop="companyName" label="资产方名称" width="300" sortable></el-table-column>
  21. <!-- <el-table-column prop="companyType" label="资产方类型" width="200" sortable>
  22. <template slot-scope="scope">
  23. {{ scope.row.companyType == 0?"资产方":"生产方" }}
  24. </template>
  25. </el-table-column> -->
  26. <el-table-column prop="companyAddress" label="资产方地址" sortable></el-table-column>
  27. <el-table-column label="操作" width="150">
  28. <template slot-scope="scope">
  29. <el-button size="small" @click.native="handleEdit(scope.$index, scope.row)">编辑</el-button>
  30. <el-button type="danger" size="small" @click.native.native="handleDel(scope.$index, scope.row)">删除</el-button>
  31. </template>
  32. </el-table-column>
  33. </el-table>
  34. <!--工具条-->
  35. <el-col :span="24" class="toolbar">
  36. <el-pagination
  37. @size-change="handleSizeChange"
  38. @current-change="handleCurrentChange"
  39. :page-sizes="[20 , 50 , 80 , 100]"
  40. :page-size="20"
  41. layout="total, sizes, prev, pager, next"
  42. :total="total"
  43. style="float:right;">
  44. </el-pagination>
  45. </el-col>
  46. <!--新增界面-->
  47. <el-dialog title="新增资产方" v-if="addFormVisible" :visible.sync="addFormVisible" :close-on-click-modal="false" customClass='customWidth'>
  48. <el-form :model="addForm" label-width="100px" :rules="formRules" ref="addForm">
  49. <el-form-item label="资产方名称" prop="companyName">
  50. <el-input v-model="addForm.companyName" autocomplete="off" placeholder="请输入资产方地址"></el-input>
  51. </el-form-item>
  52. <!-- <el-form-item label="公司类型" prop="companyType">
  53. <el-select v-model="addForm.companyType" clearable filterable placeholder="请选择公司类型" style="width:533px">
  54. <el-option v-for="item in team" :key="item.value" :label="item.label" :value="item.value">
  55. </el-option>
  56. </el-select>
  57. </el-form-item> -->
  58. <el-form-item label="资产方地址" prop="companyAddress">
  59. <el-input v-model="addForm.companyAddress" autocomplete="off" placeholder="请输入资产方地址"></el-input>
  60. </el-form-item>
  61. </el-form>
  62. <div slot="footer" class="dialog-footer">
  63. <el-button @click.native="addFormVisible = false">取消</el-button>
  64. <el-button type="primary" @click.native="addSubmit" :loading="addLoading">提交</el-button>
  65. </div>
  66. </el-dialog>
  67. <!--编辑界面-->
  68. <el-dialog title="编辑资产方" v-if="editFormVisible" :visible.sync="editFormVisible" :close-on-click-modal="false" customClass='customWidth'>
  69. <el-form :model="editForm" label-width="100px" :rules="formRules" ref="editForm">
  70. <el-form-item label="资产方名称" prop="companyName">
  71. <el-input v-model="editForm.companyName" autocomplete="off" placeholder="请输入资产方地址"></el-input>
  72. </el-form-item>
  73. <!-- <el-form-item label="公司名称" prop="companyType">
  74. <el-select v-model="editForm.companyType" clearable filterable placeholder="请选择公司类型" style="width:533px">
  75. <el-option v-for="item in team" :key="item.value" :label="item.label" :value="item.value">
  76. </el-option>
  77. </el-select>
  78. </el-form-item> -->
  79. <el-form-item label="资产方地址" prop="companyAddress">
  80. <el-input v-model="editForm.companyAddress" autocomplete="off" placeholder="请输入资产方地址"></el-input>
  81. </el-form-item>
  82. </el-form>
  83. <div slot="footer" class="dialog-footer">
  84. <el-button @click.native="editFormVisible = false">取消</el-button>
  85. <el-button type="primary" @click.native="editSubmit" :loading="editLoading">提交</el-button>
  86. </div>
  87. </el-dialog>
  88. </section>
  89. </template>
  90. <script>
  91. import util from '../../common/js/util'
  92. export default {
  93. data() {
  94. return {
  95. filters: {
  96. keyName: ''
  97. },
  98. list: [],
  99. total: 0,
  100. page: 1,
  101. size: 20,
  102. listLoading: false,
  103. tableHeight: 0,
  104. formRules: {
  105. companyName: [
  106. { required: true, message: '请输入资产方名称', trigger: 'blur' }
  107. ],
  108. companyType: [
  109. { required: true, message:'请选择资产方类型', trigger: ['blur', 'change'] }
  110. ],
  111. companyAddress: [
  112. { required: true, message: '请输入资产方地址', trigger: 'blur' }
  113. ]
  114. },
  115. team: [{label:'资产方',value:0},{label:'生产方',value:1}],
  116. // 新增界面
  117. addFormVisible: false,
  118. addLoading: false,
  119. addForm: {
  120. companyName: '',
  121. companyType: 0,
  122. companyAddress: '',
  123. flag: 0
  124. },
  125. // 编辑界面
  126. editFormVisible: false,
  127. editLoading: false,
  128. editForm: {
  129. id: 0,
  130. companyName: '',
  131. companyType: 0,
  132. companyAddress: '',
  133. flag: 1
  134. }
  135. }
  136. },
  137. methods: {
  138. // 分页
  139. handleCurrentChange(val) {
  140. this.page = val;
  141. this.getComp();
  142. },
  143. handleSizeChange(val) {
  144. this.size = val;
  145. this.getComp();
  146. },
  147. //获取用户列表
  148. getComp() {
  149. this.listLoading = true;
  150. this.http.post(this.port.base.companyList, {
  151. keyName: this.filters.keyName,
  152. pageNum: this.page,
  153. pageSize: this.size,
  154. companyType: 0
  155. }, res => {
  156. this.listLoading = false;
  157. if (res.code == "ok") {
  158. this.list = res.data.list;
  159. this.total = res.data.total;
  160. } else {
  161. this.$message({
  162. message: res.msg,
  163. type: 'error'
  164. });
  165. }
  166. }, error => {
  167. this.listLoading = false;
  168. this.$message({
  169. message: error,
  170. type: 'error'
  171. });
  172. })
  173. },
  174. //显示新增界面
  175. handleAdd() {
  176. this.addFormVisible = true;
  177. this.addForm = {
  178. companyName: '',
  179. companyType: 0,
  180. companyAddress: '',
  181. flag: 0
  182. };
  183. },
  184. //新增
  185. addSubmit() {
  186. this.$refs.addForm.validate((valid) => {
  187. if (valid) {
  188. this.addLoading = true;
  189. this.http.post(this.port.base.addCompany, this.addForm , res => {
  190. this.addLoading = false;
  191. if (res.code == "ok") {
  192. this.addFormVisible = false;
  193. this.$message({
  194. message: '创建成功',
  195. type: 'success'
  196. });
  197. this.getComp();
  198. } else {
  199. this.$message({
  200. message: res.msg,
  201. type: 'error'
  202. });
  203. }
  204. }, error => {
  205. this.addLoading = false;
  206. this.addFormVisible = false;
  207. this.$message({
  208. message: error,
  209. type: 'error'
  210. });
  211. })
  212. }
  213. });
  214. },
  215. //删除
  216. handleDel(index, row) {
  217. this.$confirm('确认删除该资产方吗?', '提示', {
  218. type: 'warning'
  219. }).then(() => {
  220. this.http.post(this.port.base.delCompany, {
  221. id: row.id
  222. }, res => {
  223. if (res.code == "ok") {
  224. this.$message({
  225. message: '删除成功',
  226. type: 'success'
  227. });
  228. this.getComp();
  229. } else {
  230. this.$message({
  231. message: res.msg,
  232. type: 'error'
  233. });
  234. }
  235. }, error => {
  236. this.$message({
  237. message: error,
  238. type: 'error'
  239. });
  240. })
  241. });
  242. },
  243. //显示编辑界面
  244. handleEdit(index, row) {
  245. this.editFormVisible = true;
  246. this.editForm = {
  247. id: row.id,
  248. companyName: row.companyName,
  249. companyType: 0,
  250. companyAddress: row.companyAddress,
  251. flag: 1
  252. };
  253. },
  254. //编辑
  255. editSubmit() {
  256. this.$refs.editForm.validate((valid) => {
  257. if (valid) {
  258. this.editLoading = true;
  259. this.http.post(this.port.base.addCompany, this.editForm , res => {
  260. this.editLoading = false;
  261. if (res.code == "ok") {
  262. this.editFormVisible = false;
  263. this.$message({
  264. message: '修改成功',
  265. type: 'success'
  266. });
  267. this.getComp();
  268. } else {
  269. this.$message({
  270. message: res.msg,
  271. type: 'error'
  272. });
  273. }
  274. }, error => {
  275. this.editLoading = false;
  276. this.editFormVisible = false;
  277. this.$message({
  278. message: error,
  279. type: 'error'
  280. });
  281. })
  282. }
  283. });
  284. }
  285. },
  286. created() {
  287. let height = window.innerHeight;
  288. this.tableHeight = height - 210;
  289. const that = this;
  290. window.onresize = function temp() {
  291. that.tableHeight = window.innerHeight - 210;
  292. };
  293. },
  294. mounted() {
  295. this.getComp();
  296. }
  297. }
  298. </script>
  299. <style scoped>
  300. </style>