ApplicationEquip.vue 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488
  1. <template>
  2. <div class="content-main common-scroll">
  3. <div class="content-body">
  4. <Row :gutter="8" style="width:100%;height:100%">
  5. <i-col span="6" style="height:100%">
  6. <div class="station-tree">
  7. <div class="station-tree-body">
  8. <div class="station-tree-top">
  9. <Input suffix="ios-search" placeholder="请输入地铁站台名" search v-model="currentStation" class="common-search" @on-search="iconChange"/>
  10. </div>
  11. <div class="station-tree-center">
  12. <div class="station-tree-left common-scroll" v-show="showTree">
  13. <tree-list :defaultData="stationData" :currentStaData="currentStaData" :clickAllNode="true" v-if="stationData.length>0" @treeChange="treeChange" ref="tree"></tree-list>
  14. </div>
  15. <div class="station-tree-left-notree" v-show="!showTree">
  16. 站点输入错误!
  17. </div>
  18. <div class="station-tree-right">
  19. </div>
  20. </div>
  21. </div>
  22. </div>
  23. </i-col>
  24. <i-col span="18" style="height:100%">
  25. <div class="right-main">
  26. <div class="manage-main-top">
  27. <Button icon="ios-add" class="common-add-btn" @click="addClick">新增关联</Button>
  28. </div>
  29. <div class="manage-main-center">
  30. <Table :columns="columns" :data="data1" class="common-table" :row-class-name="rowClassName"></Table>
  31. </div>
  32. <Page :total="tableTotal" :current="tableParams.pageNum" :page-size="tableParams.pageSize" @on-change="changePage" @on-page-size-change="sizeChange" show-elevator class="common-page"/>
  33. </div>
  34. </i-col>
  35. </Row>
  36. </div>
  37. <Modal
  38. v-model="showModal"
  39. :title="title"
  40. width="25"
  41. ref="modalGrag"
  42. draggable
  43. :mask-closable="false"
  44. class-name="common-modal">
  45. <!-- :rules="ruleValidate" -->
  46. <Form class="common-form" ref="formOption" :model="formOption" :label-width="120">
  47. <FormItem label="应用名称:" prop="lineName">
  48. <Select v-model="formOption.lineName" placeholder="应用名称">
  49. <Option v-for="item in typeList" :value="item.value" :key="item.value">{{ item.label }}</Option>
  50. </Select>
  51. </FormItem>
  52. <FormItem label="设备类型:" prop="stationName">
  53. <Select v-model="formOption.station" placeholder="设备类型">
  54. <Option v-for="item in typeList" :value="item.value" :key="item.value">{{ item.label }}</Option>
  55. </Select>
  56. </FormItem>
  57. </Form>
  58. <div slot="footer">
  59.     <Button @click="modalCancel">取消</Button>
  60.     <Button type="primary" @click="modalOk">确定</Button>
  61.   </div>
  62. </Modal>
  63. <Modal
  64. v-model="modalStatus"
  65. title="确认解绑"
  66. width="25"
  67. ref="modalGrag"
  68. draggable
  69. :mask-closable="false"
  70. class-name="common-modal">
  71. <Icon type="ios-information-circle" class="modal-icon" style="color:#E92E2E"></Icon>
  72. <span class="modal-text">删除的同时将解绑所有运营数据,且数据不可恢复。请慎重操作。</span>
  73. <div slot="footer">
  74.     <Button @click="commonCancel">取消</Button>
  75.     <Button type="primary" @click="commonOk">确定</Button>
  76.   </div>
  77. </Modal>
  78. </div>
  79. </template>
  80. <script>
  81. import _ from 'lodash'
  82. export default {
  83. name: "ApplicationEquip",
  84. components:{
  85. },
  86. data() {
  87. return {
  88. currentStation: '合肥轨道交通',
  89. currentStaData: [], // 当前搜索框搜索的站台数组对象,传给子组件,用来判断单选站台名当前选中状态
  90. treeName: ['合肥轨道交通'], // 当前选中的一级二级站台名
  91. preTreeName:['合肥轨道交通'],
  92. showTree: true,// 是否显示树形组件
  93. stationData: [{disabled: true,
  94. expand: true,
  95. children: [],
  96. id: 0,
  97. parent: null,
  98. selected: true,
  99. stationId: null,}],
  100. tableTotal: 100,
  101. tableParams: {
  102. pageNum: 1,
  103. pageSize: 20
  104. },
  105. data1: [
  106. {
  107. name: 'John Brown',
  108. age: 1,
  109. address: 'New York No.',
  110. date: '2016-10-03'
  111. },
  112. {
  113. name: 'Jim Green',
  114. age: 2,
  115. address: 'London No.',
  116. date: '2016-10-01'
  117. },
  118. {
  119. name: 'Joe Black',
  120. age: 3,
  121. address: 'Sydney No.',
  122. date: '2016-10-02'
  123. },
  124. {
  125. name: 'Jon Snow',
  126. age: 2,
  127. address: 'Ottawa No.',
  128. date: '2016-10-04'
  129. },
  130. {
  131. name: 'John Brown',
  132. age: 1,
  133. address: 'New York No.',
  134. date: '2016-10-03'
  135. },
  136. {
  137. name: 'Jim Green',
  138. age: 2,
  139. address: 'London No.',
  140. date: '2016-10-01'
  141. },
  142. {
  143. name: 'Joe Black',
  144. age: 3,
  145. address: 'Sydney No.',
  146. date: '2016-10-02'
  147. },
  148. {
  149. name: 'Jon Snow',
  150. age: 2,
  151. address: 'Ottawa No.',
  152. date: '2016-10-04'
  153. },
  154. {
  155. name: 'Joe Black',
  156. age: 3,
  157. address: 'Sydney No',
  158. date: '2016-10-02'
  159. },
  160. {
  161. name: 'Jon Snow',
  162. age: 2,
  163. address: '合肥城市轨道交通有限公司',
  164. date: '2016-10-04'
  165. },
  166. ],
  167. columns: [
  168. {
  169. title: '线路序号',
  170. width: 100,
  171. key: 'name',
  172. align: 'center'
  173. },
  174. {
  175. title: '线路名称',
  176. key: 'age',
  177. width: 100,
  178. align: 'center'
  179. },
  180. {
  181. title: '当前线路长度(km)',
  182. key: 'address',
  183. align: 'center'
  184. },
  185. {
  186. title: '站点数量',
  187. key: 'name',
  188. align: 'center'
  189. },
  190. {
  191. title: '运营机构',
  192. key: 'address',
  193. align: 'center',
  194. ellipsis: true,
  195. tooltip: true
  196. },
  197. {
  198. title: '线路类型',
  199. key: 'address',
  200. align: 'center'
  201. },
  202. { title: "操作", key: "action", align: 'center',
  203. render: (h, params) => {
  204. return h('div',[
  205. h('Tooltip', {
  206. props: { placement: 'top' },
  207. }, [
  208. h('span', { slot: 'content', style: { whiteSpace: 'normal', wordBreak: 'break-all' } },'解绑'),
  209. h('i',{style: { cursor:'pointer',color:'#B8B532',fontSize:'20px',marginRight:'6px'},
  210. on: {
  211. click: () => {
  212. this.modalStatus = true
  213. }
  214. },
  215. class: 'iconfont icon-xiangqingmingxi'})]),
  216. ])
  217. }
  218. },
  219. ],
  220. formOption: {lineName: '',stationName:''},
  221. typeList: [
  222. {
  223. value: 'New York',
  224. label: 'New York'
  225. },
  226. {
  227. value: 'London',
  228. label: 'London'
  229. },
  230. {
  231. value: 'Sydney',
  232. label: 'Sydney'
  233. },
  234. {
  235. value: 'Ottawa',
  236. label: 'Ottawa'
  237. },
  238. {
  239. value: 'Paris',
  240. label: 'Paris'
  241. },
  242. {
  243. value: 'Canberra',
  244. label: 'Canberra'
  245. }
  246. ],
  247. showModal: false,
  248. title: '新增关联',
  249. modalStatus: false,
  250. };
  251. },
  252. mounted() {
  253. this.$get('metroapi/equipment/energy/stationTree').then(res => {
  254. if (res.httpCode == 1) {
  255. this.stationData[0].children = this.getTree(res.data)
  256. this.currentStaData = [{disabled: true,
  257. expand: true,
  258. children: [],
  259. id: 0,
  260. parent: null,
  261. selected: true,
  262. stationId: null,
  263. title: "合肥轨道交通"}]
  264. } else {
  265. this.stationData = [{disabled: true,
  266. expand: true,
  267. children: [],
  268. id: 0,
  269. parent: true,
  270. selected: true,
  271. stationId: null,
  272. title: "合肥轨道交通"}]
  273. }
  274. })
  275. },
  276. methods: {
  277. getTree(arr) {
  278. return arr.map((v,index) => {
  279. v.disabled = false
  280. v.selected = false
  281. v.expand = false
  282. if (v.title == '1号线') {
  283. v.expand = true
  284. }
  285. if (v.children) v.children = this.getTree(v.children);
  286. return v;
  287. });
  288. },
  289. iconChange: _.throttle(function() {
  290. this.currentStaData = []
  291. this.treeName = []
  292. this.showTree = false
  293. if(this.currentStation != ''){
  294. document.querySelector(".tree-scroll").scrollTo(0, 0); // 滚动条回到顶部
  295. } else {
  296. document.querySelector(".tree-scroll").scrollTo(0, 0); // 滚动条回到顶部
  297. }
  298. this.getPamData (this.currentStation)
  299. this.stationData.forEach((item, index,itemArr) => {
  300. item.expand = false;
  301. item.disabled = false;
  302. item.selected = false;
  303. if (item.title == this.currentStation) {
  304. item.selected = true;
  305. item.disabled = true; // disabled 是否禁止选中
  306. item.expand = true;
  307. this.treeName.push(item.title)
  308. this.currentStaData.push(item)
  309. this.preTreeName = this.treeName
  310. this.showTree = true
  311. }
  312. item.children.forEach((val, i,valArr) => {
  313. val.expand = false; //expand 是否展开直子节点
  314. val.disabled = false; // disabled 是否禁止选中
  315. val.selected = false;
  316. if (val.title == this.currentStation) {
  317. val.selected = true;
  318. val.disabled = true; // disabled 是否禁止选中
  319. val.expand = true;
  320. item.expand = true;
  321. this.treeName.push(item.title)
  322. this.treeName.push(val.title)
  323. this.currentStaData.push(val)
  324. this.preTreeName = this.treeName
  325. this.showTree = true
  326. }
  327. val.children.forEach ((lastVal,lastIndex) => {
  328. lastVal.selected = false; //expand 是否展开直子节点
  329. lastVal.disabled = false;
  330. lastVal.expand = false;
  331. if (this.currentStation =='合肥轨道交通' || this.currentStation =='') {
  332. itemArr[index].selected = true
  333. itemArr[index].disabled = true
  334. itemArr[index].expand = true
  335. valArr[index].expand = true
  336. this.showTree = true
  337. this.currentStation = '合肥轨道交通'
  338. this.treeName = ['合肥轨道交通']
  339. }
  340. if (lastVal.title == this.currentStation) {
  341. lastVal.selected = true;
  342. lastVal.disabled = true; // disabled 是否禁止选中
  343. lastVal.expand = true;
  344. val.expand = true
  345. item.expand = true
  346. this.treeName.push(item.title)
  347. this.treeName.push(val.title)
  348. this.treeName.push(lastVal.title)
  349. this.currentStaData.push(lastVal)
  350. this.preTreeName = this.treeName
  351. this.showTree = true
  352. }
  353. })
  354. });
  355. });
  356. if (!this.showTree) {
  357. this.treeName = this.preTreeName
  358. }
  359. this.$nextTick(()=> {
  360. if (this.initActive == 'year') {
  361. this.$refs.longForecast.getTitle(this.pamData)
  362. } else {
  363. this.$refs.forecast.getTitle(this.pamData)
  364. }
  365. })
  366. }, 500),
  367. treeChange(val,arr) {
  368. this.currentStation = val
  369. this.treeName = arr
  370. this.preTreeName = arr
  371. },
  372. rowClassName(row, index) {
  373. if (index % 2 == 0) {
  374. return "ivu-table-stripe-even";
  375. } else {
  376. return "ivu-table-stripe-odd";
  377. }
  378. },
  379. // 分页
  380. changePage (val) {
  381. this.tableParams.pageNum = val
  382. // this.getTableData()
  383. },
  384. //跳转
  385. sizeChange (val) {
  386. this.tableParams.pageSize = val
  387. // this.getTableData()
  388. },
  389. addClick () {
  390. this.showModal = true
  391. this.$refs.modalGrag.dragData.x = null
  392. this.$refs.modalGrag.dragData.y = null
  393. },
  394. modalOk () {
  395. this.showModal = false
  396. },
  397. modalCancel () {
  398. this.showModal = false
  399. },
  400. commonOk () {
  401. this.modalStatus = false
  402. },
  403. commonCancel () {
  404. this.modalStatus = false
  405. },
  406. }
  407. };
  408. </script>
  409. <style scoped lang="stylus">
  410. .content-main {
  411. width: 100%;
  412. height: calc(100% - 50px);
  413. overflow: auto;
  414. }
  415. .common-search {
  416. width: 100%;
  417. }
  418. >>> .common-search .ivu-input {
  419. background-color: #06214D;
  420. border: 1px solid #2355A6;
  421. border-radius: 15px;
  422. color: #fff;
  423. height: 32px;
  424. }
  425. >>> .common-search .ivu-input:focus {
  426. border-color: #0185ea;
  427. }
  428. .content-body {
  429. width: 100%;
  430. height: 100%;
  431. background: #06214D;
  432. }
  433. .station-tree {
  434. height: 100%;
  435. padding: 10px;
  436. }
  437. .station-tree-body {
  438. border: 1px solid #204384;
  439. height: 100%;
  440. padding: 10px;
  441. }
  442. .station-tree-center {
  443. height: calc(100% - 32px);
  444. padding-top: 10px;
  445. // display: flex;
  446. }
  447. .station-tree-left {
  448. height: 100%;
  449. overflow: hidden;
  450. overflow-y: auto;
  451. }
  452. .station-tree-left-notree {
  453. height: 100%;
  454. display: flex;
  455. align-items: center;
  456. justify-content: center;
  457. color: #fff;
  458. fon-size: 14px;
  459. }
  460. .right-main {
  461. height: 100%;
  462. padding: 10px 0;
  463. // padding: 16px;
  464. }
  465. .manage-main-top {
  466. padding: 12px 0;
  467. display: flex;
  468. justify-content: flex-end;
  469. }
  470. .manage-main-center {
  471. width: 100%;
  472. height: calc(100% - 100px);
  473. }
  474. .common-table {
  475. max-height: 100%;
  476. }
  477. >>> .common-table .ivu-table th {
  478. height: 54px;
  479. }
  480. >>> .common-table .ivu-table td {
  481. height: 54px;
  482. }
  483. .common-page {
  484. margin-top: 15px;
  485. display: flex;
  486. justify-content: flex-end;
  487. }
  488. </style>