Index.vue 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499
  1. <template>
  2. <div class="index-wrap">
  3. <!-- <div class="home-text">首页</div> -->
  4. <div class="mask" v-show="drowMenuShow"></div>
  5. <div class="select" >
  6. <div class="drop-menu" :class="{active: drowMenuShow}">
  7. <div class="drop-menu-title tc fs-14" @click="drowMenuShow=!drowMenuShow">
  8. <span class="v-middle">{{selcommunityName}}</span>
  9. <van-icon name="arrow-down" />
  10. </div>
  11. <div class="drop-menu-area kitbox">
  12. <div class="drop-menu-area-left" v-if="townList&&townList.length">
  13. <van-sidebar v-model="activeKey">
  14. <van-sidebar-item v-for="(item, i) in townList" :key="i" :title="item.townName" />
  15. </van-sidebar>
  16. </div>
  17. <div class="drop-menu-area-right fs-14">
  18. <div v-for="(item, i) in communityList" :key="i" @click="onSelect(item)">{{item.hospitalName}}</div>
  19. </div>
  20. </div>
  21. </div>
  22. </div>
  23. <!-- 设备概况 -->
  24. <div class="panel mt10 sbzl">
  25. <div class="kitbox pt15 plr15 box-flex-c">
  26. <div class="box-flex-c c-333 fs-16 f-bold">设备概况</div>
  27. <div class="box-flex-c c-333 f-bold fs-12">在线率:{{ overview.onlineRate }}</div>
  28. </div>
  29. <div class="box-flex-c pt10 pb20 plr15">
  30. <div class="Online" @click="gotoDeviceList(1)">
  31. <div class="equipment-num">{{ overview.onlineTotal }}</div>
  32. <div class="equipment-text">在线设备</div>
  33. </div>
  34. <div class="total" @click="gotoDeviceList()">
  35. <div class="equipment-num">{{ overview.total }}</div>
  36. <div class="equipment-text">运营总台数</div>
  37. </div>
  38. <div class="offline" @click="gotoDeviceList(0)">
  39. <div class="equipment-num">{{ overview.noOnlineTotal }}</div>
  40. <div class="equipment-text">离线设备</div>
  41. </div>
  42. </div>
  43. </div>
  44. <!-- 运维数据 -->
  45. <div class="panel plr15 mt10 cygn">
  46. <div class="kitbox pt15 ">
  47. <div class="box-flex-1 c-333 fs-16 f-bold">运维数据</div>
  48. </div>
  49. <div class="pt10">
  50. <div class="pb20">
  51. <van-row>
  52. <van-col @click="gotoDevice()" class="col col-tl" span="12">
  53. <div class="operations-num">{{ maintain.addTotal }}</div>
  54. <div class="operations-text"><span><img class="img" src="../../assets/images/waiting-equipment.png" alt=""></span>待入库设备数</div>
  55. </van-col>
  56. <van-col @click="gotoDevice()" class="col" span="12">
  57. <div class="operations-num">{{ maintain.hcWaringTotalNum }}</div>
  58. <div class="operations-text"><span><img class="img" src="../../assets/images/thermometer.png" alt=""></span>温湿度预警数</div>
  59. </van-col>
  60. <van-col @click="gotoDeviceList(0)" class="col col-t col-bl" span="12">
  61. <div class="operations-num">{{ maintain.noOnlineTotal1WithUserId }}</div>
  62. <div class="operations-text"><span><img class="img" src="../../assets/images/waiting-equipment.png" alt=""></span>离线设备数</div>
  63. </van-col>
  64. <van-col @click="gotoUrl('/order/list')" class="col col-t" span="12">
  65. <div class="operations-num">{{ maintain.noGetDrugNum }}</div>
  66. <div class="operations-text"><span><img class="img" src="../../assets/images/offline-medicine.png" alt=""></span>待取药订单数</div>
  67. </van-col>
  68. </van-row>
  69. </div>
  70. </div>
  71. </div>
  72. <!-- 取药次数 -->
  73. <div v-if="medicineShow" class="panel plr15 mt10 medicine">
  74. <div class="kitbox pt15 box-flex-c">
  75. <div class="box-flex-c c-333 fs-16 f-bold">取药次数</div>
  76. <div class="box-flex-c c-333 fs-12 f-bold time">
  77. <ul class="ul">
  78. <li @click="medicineTime('1')" :class="medicineBag == '1' ? 'li-bag':''">今日</li>
  79. <li @click="medicineTime('7')" :class="medicineBag == '7' ? 'li-bag':''">7日</li>
  80. <li @click="medicineTime('30')" class="border-r" :class="medicineBag == '30' ? 'li-bag':''">30日</li>
  81. <li @click="medicineTime('90')" class="border-r" :class="medicineBag == '90' ? 'li-bag':''">90日</li>
  82. <li @click="medicineTime('全部')" :class="medicineBag == '' ? 'li-bag':''">全部</li>
  83. </ul>
  84. </div>
  85. </div>
  86. <div class="pt24 pb19">
  87. <div class="medicine-b-l">
  88. <div class="medicine-b-g-num">
  89. {{ shippingType.total }}
  90. <span>次</span>
  91. </div>
  92. </div>
  93. <div class="scan">扫码取药:{{ shippingType.saomaTotal }}次</div>
  94. <div class="care">医保卡取药:{{ shippingType.yibaoTotal }}次</div>
  95. </div>
  96. </div>
  97. <!-- 电子处方单 -->
  98. <div class="panel plr15 mt10 medicine">
  99. <div class="kitbox pt15 box-flex-c">
  100. <div class="box-flex-c c-333 fs-16 f-bold">电子处方单</div>
  101. <div class="box-flex-c c-333 fs-12 f-bold time">
  102. <ul class="ul">
  103. <li @click="prescriptionTime('1')" :class="prescriptionBag == '1' ? 'li-bag':''">今日</li>
  104. <li @click="prescriptionTime('7')" :class="prescriptionBag == '7' ? 'li-bag':''">7日</li>
  105. <li @click="prescriptionTime('30')" class="border-r" :class="prescriptionBag == '30' ? 'li-bag':''">30日</li>
  106. <li @click="prescriptionTime('90')" class="border-r" :class="prescriptionBag == '90' ? 'li-bag':''">90日</li>
  107. <li @click="prescriptionTime('全部')" :class="prescriptionBag == '' ? 'li-bag':''">全部</li>
  108. </ul>
  109. </div>
  110. </div>
  111. <div class="pt24 pb19">
  112. <div class="medicine-b-l prescription">
  113. <div class="medicine-b-g-num">
  114. {{ prescriptionStatics.total }}
  115. <span>次</span>
  116. </div>
  117. </div>
  118. <div class="prescription-num">药品数量:{{ prescriptionStatics.drugTotal }}件</div>
  119. </div>
  120. </div>
  121. <!-- 销售额 -->
  122. <div v-if="sales" class="panel plr15 mt10 medicine">
  123. <div class="kitbox pt15 box-flex-c">
  124. <div class="box-flex-c c-333 fs-16 f-bold">销售额</div>
  125. <div class="box-flex-c c-333 fs-12 f-bold time">
  126. <ul class="ul">
  127. <li @click="salesTime('1')" :class="salesBag == '1' ? 'li-bag':''">今日</li>
  128. <li @click="salesTime('7')" :class="salesBag == '7' ? 'li-bag':''">7日</li>
  129. <li @click="salesTime('30')" class="border-r" :class="salesBag == '30' ? 'li-bag':''">30日</li>
  130. <li @click="salesTime('90')" class="border-r" :class="salesBag == '90' ? 'li-bag':''">90日</li>
  131. <li @click="salesTime('全部')" :class="salesBag == '' ? 'li-bag':''">全部</li>
  132. </ul>
  133. </div>
  134. </div>
  135. <div class="pt20 pb20 sales-data">
  136. <div>¥{{ amount }}</div>
  137. <div style="display:none;">月同比:<span>0.40%</span></div>
  138. <div style="display:none;">日环比:<span>5.00%</span></div>
  139. </div>
  140. <div id="sales-chart" class="sales-chart"></div>
  141. </div>
  142. <div class="home-bottom"></div>
  143. </div>
  144. </template>
  145. <script>
  146. import { findOneUser} from "@/api/login";
  147. import * as echarts from 'echarts';
  148. import medicineAbinetApi from '@/api/api-medicineAbinet'
  149. export default {
  150. name: "index",
  151. components: {
  152. },
  153. watch: {
  154. drowMenuShow(n){
  155. var body = document.getElementsByTagName('body')[0]
  156. if(n){
  157. body.classList.add('over-hidden')
  158. } else {
  159. body.classList.remove('over-hidden')
  160. }
  161. },
  162. activeKey(n){
  163. this.loadChildren()
  164. }
  165. },
  166. computed:{
  167. selcommunityName(){
  168. if(this.selcommunity){
  169. if(this.selcommunity.hospital === ''){
  170. var item = this.townList[this.activeKey]
  171. return item.town === ''? "全部" : item.townName
  172. } else {
  173. return this.selcommunity.hospitalName
  174. }
  175. }
  176. return "全部"
  177. }
  178. },
  179. data() {
  180. return {
  181. medicineBag:'1',
  182. medicineData:false,
  183. medicineShow:true,
  184. sales:true,
  185. prescriptionBag:'1',
  186. salesBag:'1',
  187. count:[],
  188. date:[],
  189. amount:'- -',
  190. overview:{
  191. total:'- -', // 总台数
  192. noOnlineTotal:'- -', // 不在线数
  193. onlineRate:'- -', // 在线率
  194. onlineTotal:'- -', // 在线台数
  195. },
  196. maintain:{
  197. hcWaringTotalNum:'- -', // 温湿度异常警告
  198. noOnlineTotal1WithUserId:'- -', // 不在线数
  199. noGetDrugNum:'- -', // 待取药订单数
  200. addTotal:'- -', // 缺货设备数
  201. },
  202. shippingType:{
  203. saomaTotal:'- -',
  204. total:'- -',
  205. yibaoTotal:'- -'
  206. },
  207. prescriptionStatics:{
  208. total:'- -',
  209. drugTotal:'- -'
  210. },
  211. drowMenuShow: false,
  212. townList: [],
  213. communityList: [],
  214. selcommunity: '',
  215. activeKey: 0,
  216. defaultOption: [
  217. { townName: '全部', town: "", children: [{hospital: '', hospitalName: '全部'}] },
  218. ],
  219. }
  220. },
  221. created(){
  222. this.refreshData()
  223. this.getOrgList()
  224. console.log('this.$store.user.state',this.$store.state.user.curRoleCode)
  225. if(this.$store.state.user.curRoleCode =='replenisher'){
  226. this.medicineShow = false;
  227. this.sales = false;
  228. }
  229. },
  230. mounted(){
  231. this.echartsData();
  232. },
  233. methods: {
  234. // 设备概况 运营数据
  235. countall(){
  236. var p = this.getTownParams()
  237. medicineAbinetApi
  238. .countAllDevice(p)
  239. .then(res=>{
  240. // console.log('countall', res);
  241. this.overview = res.obj.overview;
  242. this.maintain = res.obj.maintain;
  243. })
  244. .catch(err=>{
  245. console.error(err)
  246. })
  247. },
  248. //跳转
  249. gotoDevice(){
  250. this.$router.push('/device/index')
  251. this.$store.commit('getDeviceActive' ,0);
  252. },
  253. // 取药次数
  254. medicine(){
  255. var p = this.getTownParams()
  256. p.day = this.medicineBag
  257. console.log('medicine', p)
  258. medicineAbinetApi
  259. .getmedicine(p)
  260. .then(res=>{
  261. console.log('medicine', res)
  262. this.medicineData = true;
  263. this.shippingType = res.obj;
  264. })
  265. .catch(err=>{
  266. console.error(err)
  267. this.medicineData = true;
  268. })
  269. },
  270. // 电子处方单
  271. prescriptions(){
  272. var p = this.getTownParams()
  273. p.day = this.prescriptionBag
  274. medicineAbinetApi
  275. .getprescriptions(p)
  276. .then(res=>{
  277. // console.log('prescriptions', res)
  278. this.prescriptionStatics = res.obj;
  279. })
  280. .catch(err=>{
  281. console.error(err)
  282. })
  283. },
  284. // 取药时间查询
  285. medicineTime(val){
  286. if(this.medicineData){
  287. if(val == '全部'){
  288. this.medicineBag = '';
  289. console.log('全部')
  290. }else{
  291. this.medicineBag = val;
  292. console.log('1,3,7,9')
  293. }
  294. this.medicineData = false;
  295. this.medicine();
  296. }
  297. },
  298. // 电子处方单查询
  299. prescriptionTime(val){
  300. if(val == '全部'){
  301. this.prescriptionBag = '';
  302. this.prescriptions();
  303. console.log('全部')
  304. }else{
  305. this.prescriptionBag = val;
  306. this.prescriptions();
  307. console.log('1,3,7,9')
  308. }
  309. },
  310. // 销售额查询
  311. salesTime(val){
  312. if(val == '全部'){
  313. this.salesBag = '';
  314. console.log('全部')
  315. }else{
  316. this.salesBag = val;
  317. console.log('1,3,7,9')
  318. }
  319. this.echartsData();
  320. },
  321. echartsData(){
  322. if(this.sales){
  323. var p = this.getTownParams()
  324. p.day = this.salesBag
  325. medicineAbinetApi
  326. .getechartsData(p)
  327. .then(res=>{
  328. // console.log('echartsData', res);
  329. this.amount = res.obj.amount;
  330. this.count = res.obj.amountdateList.map((item) =>{
  331. return item.count
  332. });
  333. this.date = res.obj.amountdateList.map((item) =>{
  334. return item.date
  335. });
  336. // 基于准备好的dom,初始化echarts实例
  337. var myChart;
  338. if (myChart != null && myChart != "" && myChart != undefined){
  339. // chartDom.clear();
  340. myChart.dispose();
  341. // document.getElementById('sales-chart').innerHTML = '';
  342. }
  343. var chartDom = document.getElementById('sales-chart');
  344. myChart = echarts.init(chartDom);
  345. var option;
  346. option = {
  347. grid:{
  348. left: '3%',
  349. right: '4%',
  350. bottom: '2%',
  351. top:'5%',
  352. containLabel: true
  353. },
  354. tooltip: {
  355. trigger: 'axis'
  356. },
  357. xAxis: {
  358. type: 'category',
  359. boundaryGap: false,
  360. data: this.date,
  361. axisTick:{
  362. show:false, // X轴刻度隐藏
  363. },
  364. axisLabel:{
  365. fontSize:'8', // X轴文字字体大小
  366. }
  367. },
  368. yAxis: {
  369. type: 'value'
  370. },
  371. series: [
  372. {
  373. data: this.count,
  374. type: 'line'
  375. }
  376. ]
  377. };
  378. // if (myChart != null && myChart != "" && myChart != undefined) {
  379. // myChart.dispose();
  380. // }
  381. option && myChart.setOption(option);
  382. })
  383. .catch(err=>{
  384. console.error(err)
  385. })
  386. }
  387. },
  388. refreshData(){
  389. this.countall();
  390. this.medicine();
  391. this.prescriptions();
  392. },
  393. getTownParams(){
  394. var p = {
  395. userId: this.user.id,
  396. }
  397. if(this.selcommunity){
  398. if(this.selcommunity.hospital===''){
  399. var item = this.townList[this.activeKey]
  400. if(item.town === ''){
  401. p.level = '';
  402. p.area = '';
  403. } else {
  404. p.level = 2;
  405. p.area = item.town;
  406. }
  407. } else {
  408. p.level = 3; //(name = "level", value = "1、市级、2、区级、3、社区", required = false)
  409. p.area = this.selcommunity.hospital
  410. }
  411. }
  412. return p
  413. },
  414. getOrgList(){
  415. findOneUser({
  416. id: this.user.id
  417. }).then(async res => {
  418. // "saasAdmin": "管理员"; regionAdmin" "区域管理员" ; communityAdmin "社区管理员" ; "replenisher": "补货员"
  419. var role = this.user.curRoleCode
  420. var userArea = res.obj.userArea
  421. var townList = [].concat(this.defaultOption)
  422. if(role=='communityAdmin' || role=="replenisher"){
  423. var g = _.groupBy(userArea, 'town')
  424. for(var k in g){
  425. var tmp = JSON.parse(JSON.stringify(g[k][0]))
  426. tmp.children = [{hospital: '', hospitalName: '全部'}].concat( g[k])
  427. townList.push(tmp)
  428. }
  429. this.townList = townList
  430. } else {
  431. if(role == 'regionAdmin'){
  432. userArea.forEach(v => {
  433. v.children = []
  434. });
  435. this.townList = townList.concat(userArea)
  436. } else if(role=='saasAdmin'){
  437. await medicineAbinetApi
  438. .baseTownList({ filters: "city=350200"})//写死厦门市
  439. .then(res => {
  440. console.log('baseTownList', res)
  441. if (res.status == 200) {
  442. var detailModelList = res.detailModelList;
  443. detailModelList.forEach((item) => {
  444. item.town = item.code
  445. item.townName = item.name
  446. item.children = [];
  447. });
  448. this.townList = townList.concat(detailModelList)
  449. }
  450. });
  451. }
  452. }
  453. this.loadChildren()
  454. });
  455. },
  456. async loadChildren(){
  457. var item = this.townList[this.activeKey]
  458. if(!item.children || !item.children.length){
  459. await medicineAbinetApi
  460. .findOrgList({ code: item.town, paeg: 1, pageSize: 999 })
  461. .then(res => {
  462. console.log('findOrgList', res)
  463. if (res.status == 200) {
  464. res.detailModelList.forEach(v=>{
  465. v.hospitalName = v.name
  466. v.hospital = v.code
  467. })
  468. item.children = [{hospital: '', hospitalName: '全部'}] .concat (res.detailModelList)
  469. }
  470. })
  471. .catch(err=>{
  472. item.children = []
  473. })
  474. }
  475. this.communityList = item.children
  476. },
  477. onSelect(item){
  478. this.selcommunity = item;
  479. this.drowMenuShow = false;
  480. this.refreshData()
  481. },
  482. gotoDeviceList(networkStatus){
  483. this.gotoUrl('/device/index', {networkStatus})
  484. }
  485. },
  486. }
  487. </script>
  488. <style lang="scss" scoped>
  489. @import "./scss/index.scss";
  490. </style>