Danger.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294
  1. <style lang="scss">
  2. .danger{
  3. display: flex;
  4. // justify-content: space-between;
  5. .companies{
  6. height: 75vh;
  7. overflow: auto;
  8. margin-right: 10px;
  9. overflow-x: hidden;
  10. }
  11. &>li{
  12. width: 45%;
  13. list-style: none;
  14. min-height: 70vh;
  15. background: #fff;
  16. border: 1px solid #d9d9d9;
  17. padding:20px 10px;
  18. margin-right: 20px;
  19. }
  20. .custom-tree-node{
  21. width: 100%;
  22. .el-tree-node__content{
  23. height: 32px;
  24. }
  25. .label_name{
  26. font-size: 14px;
  27. }
  28. .rsk{
  29. color: #DF5706;
  30. img{
  31. position: relative;
  32. top:2px;
  33. }
  34. }
  35. .edit{
  36. float: right;
  37. width: 80px;
  38. i{
  39. font-weight: bolder;
  40. font-size: 14px;
  41. }
  42. }
  43. }
  44. .form{
  45. .el-input,.el-textarea{
  46. width: 90%;
  47. }
  48. .el-select{
  49. width: 100%;
  50. }
  51. .req{
  52. color:red;
  53. font-weight: 600;
  54. margin-left: 5px;
  55. }
  56. }
  57. .company{
  58. h1{
  59. font-size: 18px;
  60. margin-bottom: 20px;
  61. button{
  62. float: right;
  63. }
  64. }
  65. p{
  66. color: #409EFF;
  67. padding: 10px 0;
  68. border-bottom: 1px solid #d9d9d9;
  69. font-size: 14px;
  70. width: 90%;
  71. margin: 0 auto;
  72. }
  73. }
  74. }
  75. </style>
  76. <template>
  77. <section>
  78. <p>任务管理 > 风险点管理</p>
  79. <div class="content">
  80. <ul class="danger">
  81. <li class="companies">
  82. <el-form size="small" >
  83. <el-form-item>
  84. <el-input suffix-icon="el-icon-search" v-model="filterText" placeholder="公司名称"></el-input>
  85. </el-form-item>
  86. </el-form>
  87. <el-tree
  88. :data="data" :props='props'
  89. node-key="id"
  90. :expand-on-click-node="false">
  91. <span class="custom-tree-node" slot-scope="{ node, data }" @click.stop="() => edit(data)" >
  92. <span v-if='data.type=="ent"' class="label_name"><i class="el-icon-office-building"></i> {{ node.label }}</span>
  93. <span v-if='data.type=="rsk"' class="label_name rsk"><img width="15" src="../../images/rsk2.png" alt=""> {{ node.label }}</span>
  94. <span v-if='!data.type' class="label_name rsk" style="color:#F49C0B;"><img width="15" src="../../images/rsk1.png" alt=""> {{ node.label }}</span>
  95. <span class="edit" v-if='utype!=2&&utype!=1'>
  96. <el-button
  97. type="text"
  98. size="mini"
  99. @click.stop="() => append(data)">
  100. <i class="el-icon-plus"></i>
  101. </el-button>
  102. <el-button v-if='data.type!="ent"'
  103. type="text"
  104. size="mini"
  105. @click.stop="() => edit(data)">
  106. <i class="el-icon-edit"></i>
  107. </el-button>
  108. <el-button v-if='data.type!="ent"'
  109. type="text"
  110. size="mini"
  111. @click.stop="() => remove(node,data)">
  112. <i class="el-icon-delete"></i>
  113. </el-button>
  114. </span>
  115. </span>
  116. </el-tree>
  117. </li>
  118. <li>
  119. <el-form class="form" label-width="90px" label-position='right' size="small">
  120. <el-form-item label="公司名称">
  121. <el-input v-model="form.enterprise_name" disabled></el-input>
  122. <span class="req">*</span>
  123. </el-form-item>
  124. <el-form-item label="风险点名称" >
  125. <el-input v-model="form.name"></el-input>
  126. <span class="req">*</span>
  127. </el-form-item>
  128. <el-form-item label="备注">
  129. <el-input :rows="4" type="textarea" v-model="form.remark"></el-input>
  130. </el-form-item>
  131. <el-form-item label="二维码">
  132. <img width="150" :src="form.qrcode" alt="">
  133. </el-form-item>
  134. <el-form-item v-if='utype!=2'>
  135. <el-button @click="save" type="primary">保存</el-button>
  136. <el-button @click="form={}" type="info">取消</el-button>
  137. </el-form-item>
  138. </el-form>
  139. </li>
  140. </ul>
  141. </div>
  142. </section>
  143. </template>
  144. <script>
  145. export default {
  146. data() {
  147. return {
  148. curNode:null,
  149. filterText:'',
  150. data:[],
  151. form:{},
  152. props:{
  153. label:'name'
  154. },
  155. };
  156. },
  157. watch: {
  158. filterText(val) {
  159. this.getData();
  160. }
  161. },
  162. methods: {
  163. addNode(data,curnode,target){
  164. let curid = curnode.id;
  165. let curname = curnode.name;
  166. data.forEach((item,i)=>{
  167. if(item.id==curid&&item.name==curname){
  168. const newChild = { id: target.id, name: target.name, children: [] };
  169. if (!item.children) {
  170. this.$set(item, 'children', []);
  171. }
  172. item.children.push(newChild)
  173. }else{
  174. this.addNode(item.children,curnode,target)
  175. }
  176. })
  177. },
  178. editNode(data,curnode,target){
  179. let curid = curnode.id;
  180. let curname = curnode.name;
  181. data.forEach((item,i)=>{
  182. if(item.id==curid&&item.name==curname){
  183. const newChild = { id: target.id, name: target.name, children: [] };
  184. // if (!item.children) {
  185. // this.$set(item, 'children', []);
  186. // }
  187. // item.children.push(newChild)
  188. this.$set(item,"name",target.name)
  189. }else{
  190. this.editNode(item.children,curnode,target)
  191. }
  192. })
  193. },
  194. getData(){
  195. this.$api.getRiskpointList({name:this.filterText}).then(res=>{
  196. this.data=res.data.data
  197. this.form.enterprise_name=res.data.data[0].name
  198. this.form.enterprise_id=res.data.data[0].id
  199. this.curNode = res.data.data[0];
  200. })
  201. },
  202. edit(data){
  203. console.log(data)
  204. this.curNode = data;
  205. this.$api.getRiskpoint({id:data.id}).then(res=>{
  206. let data=res.data.data;
  207. this.form=data
  208. })
  209. },
  210. append(data){
  211. // console.log(this.data,33333333333)
  212. this.curNode = data;
  213. // this.addNode(this.data,data,target)
  214. console.log(data)
  215. // this.show=1;
  216. if(data.type == 'ent'){
  217. this.form={
  218. enterprise_name:data.name,
  219. enterprise_id:data.id,
  220. name:''
  221. }
  222. }else{
  223. this.$api.getRiskpoint({id:data.id}).then(res=>{
  224. let data=res.data.data;
  225. this.form={
  226. parent_id:data.id,
  227. parent_name:data.name,
  228. enterprise_name:data.enterprise_name,
  229. enterprise_id:data.enterprise_id,
  230. name:''
  231. }
  232. })
  233. }
  234. },
  235. remove(node,data){
  236. this.$confirm('确定删除?', '提示', {
  237. type: 'warning'
  238. }).then(() => {
  239. this.$api.deleteRiskpoint({id:data.id}).then(res=>{
  240. this.$message({message: '删除成功!',type: 'success'});
  241. const parent = node.parent;
  242. const children = parent.data.children || parent.data;
  243. const index = children.findIndex(d => d.id === data.id);
  244. children.splice(index, 1);
  245. // this.getData()
  246. })
  247. })
  248. },
  249. save(){
  250. var parm=this.form;
  251. if(!parm.enterprise_name){
  252. this.$message.error('请选择公司名称');
  253. return;
  254. }
  255. if(!parm.name){
  256. this.$message.error('请输入风险点名称');
  257. return;
  258. }
  259. if(parm.id){
  260. this.$api.updateRiskpoint(parm).then(res=>{
  261. if(res.data.code==0){
  262. this.$message({message: '修改成功!',type: 'success'});
  263. let newNode = {id:res.data.data,name:this.form.name,children:[]}
  264. this.editNode(this.data,this.curNode,newNode)
  265. // this.getData()
  266. this.form={}
  267. }else{
  268. this.$message.error(res.data.message);
  269. }
  270. })
  271. }else{
  272. this.$api.saveRiskpoint(parm).then(res=>{
  273. if(res.data.code==0){
  274. this.$message({message: '添加成功!',type: 'success'});
  275. let newNode = {id:res.data.data,name:this.form.name,children:[]}
  276. this.addNode(this.data,this.curNode,newNode)
  277. // this.getData()
  278. this.form={}
  279. }else{
  280. this.$message.error(res.data.message);
  281. }
  282. })
  283. }
  284. },
  285. },
  286. created(){
  287. this.getData();
  288. this.utype=localStorage.getItem('utype')
  289. }
  290. };
  291. </script>