bmsbd02.vue 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. <template>
  2. <view class="container">
  3. <view class="tab-container">
  4. <view class="tab-row flex-row flex-around">
  5. <view :class="'tab-item ' + (selectedTabIndex == 1 ? 'tab-selected' : '')" @tap="bindSelectedTab" data-idx="1">{{$t('实时状态')}}</view>
  6. <view :class="'tab-item ' + (selectedTabIndex == 2 ? 'tab-selected' : '')" @tap="bindSelectedTab" data-idx="2">{{$t('保护统计')}}</view>
  7. <view :class="'tab-item ' + (selectedTabIndex == 3 ? 'tab-selected' : '')" @tap="bindSelectedTab" data-idx="3">{{$t('BMS控制')}}</view>
  8. </view>
  9. </view>
  10. <view class="man-body">
  11. <view v-if="selectedTabIndex == 1" class="box-body">
  12. <view class="section-head">
  13. <view class="fresh-area flex-row flex-between">
  14. <view>
  15. <text>{{$t('更新时间') + ':'}}</text>
  16. <text class="fresh-time">{{ tools.formatTime(bmsInfo.State.BMS_DateTime / 1000) }}</text>
  17. </view>
  18. <view @tap="loadBmsInfo">
  19. <image class="fresh-icon" src="/static/resource/images/fr-icon.png"></image>
  20. <text>{{$t('刷新')}}</text>
  21. </view>
  22. </view>
  23. <view class="battery-model">
  24. <!-- <image class="battery-model-icon" src="/resource/images/b3.png"></image> -->
  25. <com-ele-quantity :quantity="bmsInfo.State.RC"></com-ele-quantity>
  26. <text></text>
  27. </view>
  28. </view>
  29. <view class="section-body">
  30. <view class="param-item flex-row flex-between">
  31. <view class="param">
  32. {{$t('总电压') + ':'}}
  33. <text class="param-value">{{ bmsInfo.State.BetteryV_All }}</text>
  34. V
  35. </view>
  36. <view class="param">
  37. {{$t('温控数') + ':'}}
  38. <text class="param-value">{{ bmsInfo.State.TemperatureCount }}</text>
  39. </view>
  40. </view>
  41. <view class="param-item flex-row flex-between">
  42. <view class="param">
  43. {{$t('温控明细') + ':'}}
  44. <text class="param-value">
  45. [{{ bmsInfo.State.TC_B_1 }}°C][{{ bmsInfo.State.TC_B_2 }}°C][{{ bmsInfo.State.TC_B_3 }}°C][{{ bmsInfo.State.TC_B_4 }}°C]
  46. </text>
  47. </view>
  48. </view>
  49. <view class="param-item flex-row flex-between">
  50. <view class="param">
  51. {{$t('过压保护') + ':'}}
  52. <text class="param-value"></text>
  53. </view>
  54. <view class="param">
  55. {{$t('欠压保护') + ':'}}
  56. <text class="param-value"></text>
  57. </view>
  58. </view>
  59. <view class="param-item flex-row flex-between">
  60. <view class="param">
  61. {{$t('电流数据') + ':'}}
  62. <text class="param-value">{{ bmsInfo.State.BetteryA }}</text>
  63. A
  64. </view>
  65. <view class="param">
  66. {{$t('循环次数') + ':'}}
  67. <text class="param-value">{{ bmsInfo.State.BXHC }}</text>
  68. </view>
  69. </view>
  70. <view class="param-item flex-row flex-between">
  71. <view class="param">
  72. {{$t('剩余容量') + ':'}}
  73. <text class="param-value">{{ bmsInfo.State.RC }}%</text>
  74. </view>
  75. <view class="param">
  76. {{$t('剩余容量') + ':'}}
  77. <text class="param-value"></text>
  78. </view>
  79. </view>
  80. <view class="param-item flex-row flex-between">
  81. <view class="param">
  82. {{$t('均衡开闭') + ':'}}
  83. <text class="param-value">{{ bmsInfo.State.EM == 'Open' ? $t('开启') : $t('关闭') }}</text>
  84. </view>
  85. <view class="param">
  86. {{$t('标称容量') + ':'}}
  87. <text class="param-value">{{ bmsInfo.State.JZRL }}</text>
  88. AH
  89. </view>
  90. </view>
  91. <view class="param-item flex-row flex-between">
  92. <view class="param">
  93. {{$t('设备编码') + ':'}}
  94. <text class="param-value">{{ bmsInfo.State.SBBM }}</text>
  95. </view>
  96. <view class="param">
  97. {{$t('出厂日期') + ':'}}
  98. <text class="param-value">{{ bmsInfo.State.CCXX }}</text>
  99. </view>
  100. </view>
  101. </view>
  102. <view class="section-body">
  103. <view class="param-item flex-row flex-between">
  104. <view class="param">
  105. {{$t('电池数量') + ':'}}
  106. <text class="param-value">{{ bmsInfo.State.BetteryC }}</text>
  107. {{$t('串')}}
  108. </view>
  109. </view>
  110. <view class="param-item flex-row flex-between">
  111. <view class="param">
  112. {{$t('最低电压') + ':'}}
  113. <text class="param-value">{{ bmsInfo.State.min_v }}</text>
  114. V
  115. </view>
  116. <view class="param">
  117. {{$t('最高电压') + ':'}}
  118. <text class="param-value">{{ bmsInfo.State.max_v }}</text>
  119. V
  120. </view>
  121. </view>
  122. <view class="param-item flex-row flex-between">
  123. <view class="param">
  124. {{$t('相差电压') + ':'}}
  125. <text class="param-value">{{ bmsInfo.State.span_min_max }}</text>
  126. V
  127. </view>
  128. </view>
  129. <view class="param-item batterys-show">
  130. <view class="battery-row">
  131. <!-- <view class="battery-block" wx:for="{{bmsInfo.State.betList}}" wx:key="unique"> -->
  132. <view class="battery-block" v-for="(item, index) in batteryNumArr" :key="index">
  133. <view class="battery-bat">
  134. <view class="i-bat">
  135. <image class="i-bat-icon" src="/static/resource/images/b0.png"></image>
  136. <view class="i-bat-index">{{ index + 1 }}</view>
  137. </view>
  138. <view class="i-vol">{{ bmsInfo.State.betList[index] ? bmsInfo.State.betList[index] : 0 }}</view>
  139. </view>
  140. </view>
  141. </view>
  142. </view>
  143. </view>
  144. </view>
  145. <view v-else-if="selectedTabIndex == 2" class="box-body">
  146. <view class="section-head"></view>
  147. <view class="section-body">
  148. <view class="param-item flex-row flex-between">
  149. <view class="param">
  150. {{$t('刷新时间') + ':'}}
  151. <text class="fresh-time">{{ tools.formatTime(bmsInfo.State.BMS_DateTime / 1000) }}</text>
  152. </view>
  153. </view>
  154. <view class="param-item flex-row flex-between">
  155. <view class="param">
  156. 1.{{$t('短路保护次数') + ':'}}
  157. <text class="param-value">0</text>
  158. {{$t('次')}}
  159. </view>
  160. </view>
  161. <view class="param-item flex-row flex-between">
  162. <view class="param">
  163. 2.{{$t('充电过流次数') + ':'}}
  164. <text class="param-value">0</text>
  165. {{$t('次')}}
  166. </view>
  167. </view>
  168. <view class="param-item flex-row flex-between">
  169. <view class="param">
  170. 3.{{$t('放电过流次数') + ':'}}
  171. <text class="param-value">0</text>
  172. {{$t('次')}}
  173. </view>
  174. </view>
  175. <view class="param-item flex-row flex-between">
  176. <view class="param">
  177. 4.{{$t('单体过压次数') + ':'}}
  178. <text class="param-value">0</text>
  179. {{$t('次')}}
  180. </view>
  181. </view>
  182. <view class="param-item flex-row flex-between">
  183. <view class="param">
  184. 5.{{$t('单体欠压次数') + ':'}}
  185. <text class="param-value">0</text>
  186. {{$t('次')}}
  187. </view>
  188. </view>
  189. <view class="param-item flex-row flex-between">
  190. <view class="param">
  191. 6.{{$t('充电高温次数') + ':'}}
  192. <text class="param-value">0</text>
  193. {{$t('次')}}
  194. </view>
  195. </view>
  196. <view class="param-item flex-row flex-between">
  197. <view class="param">
  198. 7.{{$t('充电低温次数') + ':'}}
  199. <text class="param-value">0</text>
  200. {{$t('次')}}
  201. </view>
  202. </view>
  203. <view class="param-item flex-row flex-between">
  204. <view class="param">
  205. 8.{{$t('放电高温次数') + ':'}}
  206. <text class="param-value">0</text>
  207. {{$t('次')}}
  208. </view>
  209. </view>
  210. <view class="param-item flex-row flex-between">
  211. <view class="param">
  212. 9.{{$t('放电低温次数') + ':'}}
  213. <text class="param-value">0</text>
  214. {{$t('次')}}
  215. </view>
  216. </view>
  217. <view class="param-item flex-row flex-between">
  218. <view class="param">
  219. 10.{{$t('整体过压次数') + ':'}}
  220. <text class="param-value">0</text>
  221. {{$t('次')}}
  222. </view>
  223. </view>
  224. <view class="param-item flex-row flex-between">
  225. <view class="param">
  226. 11.{{$t('整体欠压次数') + ':'}}
  227. <text class="param-value">0</text>
  228. {{$t('次')}}
  229. </view>
  230. </view>
  231. </view>
  232. </view>
  233. <view v-else-if="selectedTabIndex == 3" class="box-body">
  234. <view class="section-head">
  235. <view class="fresh-area flex-row flex-between">
  236. <view>
  237. <text>{{$t('更新时间') + ':'}}</text>
  238. <text class="fresh-time">{{ tools.formatTime(bmsInfo.State.BMS_DateTime / 1000) }}</text>
  239. </view>
  240. <view @tap="loadBmsInfo">
  241. <image class="fresh-icon" src="/static/resource/images/fr-icon.png"></image>
  242. <text>{{$t('刷新')}}</text>
  243. </view>
  244. </view>
  245. </view>
  246. <view class="section-body">
  247. <view class="param-item flex-row flex-between">
  248. <view class="param">
  249. MOS{{$t('充电开关') + ':'}}
  250. <text class="param-value">{{ bmsInfo.Seting.EMST == 'Close' ? $t('关闭') : $t('开启') }}</text>
  251. </view>
  252. <view class="command-control">
  253. <text class="btn-def">{{$t('开启')}}</text>
  254. <text class="btn-def">{{$t('关闭')}}</text>
  255. </view>
  256. </view>
  257. <view class="param-item flex-row flex-between">
  258. <view class="param">
  259. MOS{{$t('放电开关') + ':'}}
  260. <text class="param-value">{{ bmsInfo.Seting.CHON == 'Close' ? $t('关闭') : $t('开启') }}</text>
  261. </view>
  262. <view class="command-control">
  263. <text class="btn-def">{{$t('开启')}}</text>
  264. <text class="btn-def">{{$t('关闭')}}</text>
  265. </view>
  266. </view>
  267. </view>
  268. </view>
  269. </view>
  270. </view>
  271. </template>
  272. <script module="tools" lang="wxs" src="@/pages/common/wxs/tools.wxs"></script>
  273. <script>
  274. import comEleQuantity from '@/component/comEleQuantity/comEleQuantity';
  275. // pages/bms/bms.js
  276. var config = require('../../../common/config.js');
  277. var http = require('../../../common/http.js');
  278. var common = require('../../../common/common.js');
  279. var storage = require('../../../common/storage.js');
  280. export default {
  281. components: {
  282. comEleQuantity
  283. },
  284. data() {
  285. return {
  286. selectedTabIndex: 1,
  287. battery_sn: '',
  288. bmsInfo: {
  289. State: {
  290. BMS_DateTime: 0,
  291. RC: '',
  292. BetteryV_All: '',
  293. TemperatureCount: '',
  294. TC_B_1: '',
  295. TC_B_2: '',
  296. TC_B_3: '',
  297. TC_B_4: '',
  298. BetteryA: '',
  299. BXHC: '',
  300. EM: '',
  301. JZRL: '',
  302. SBBM: '',
  303. CCXX: '',
  304. BetteryC: '',
  305. min_v: '',
  306. max_v: '',
  307. span_min_max: ''
  308. },
  309. Seting: {
  310. EMST: '',
  311. CHON: ''
  312. }
  313. },
  314. batteryNumArr: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31]
  315. };
  316. },
  317. /**
  318. * 生命周期函数--监听页面加载
  319. */
  320. onLoad: function (options) {
  321. uni.setNavigationBarTitle({
  322. title: this.$t('BMS信息')
  323. });
  324. const battery_sn = options.battery_sn || '015356934636';
  325. if (!battery_sn) {
  326. uni.navigateBack({
  327. delta: 1
  328. });
  329. }
  330. this.battery_sn = battery_sn;
  331. console.log(battery_sn);
  332. this.loadBmsInfo();
  333. },
  334. /**
  335. * 生命周期函数--监听页面显示
  336. */
  337. onShow: function () {},
  338. /**
  339. * 页面相关事件处理函数--监听用户下拉动作
  340. */
  341. onPullDownRefresh: function () {},
  342. /**
  343. * 页面上拉触底事件的处理函数
  344. */
  345. onReachBottom: function () {},
  346. methods: {
  347. bindSelectedTab: function (e) {
  348. const idx = e.currentTarget.dataset.idx;
  349. this.setData({
  350. selectedTabIndex: idx
  351. });
  352. },
  353. loadBmsInfo: function () {
  354. common.loading(this);
  355. const pData = {
  356. battery_sn: this.battery_sn
  357. };
  358. const that = this;
  359. http.postApi(config.API_BATTERY_BMS_INFO, pData, function (resp) {
  360. uni.hideLoading();
  361. if (resp.data.code === 200) {
  362. const bmsInfo = resp.data.data.bmsInfo;
  363. if (!bmsInfo) {
  364. common.simpleToast(that,that.$t('BMS数据暂无'));
  365. setTimeout(function () {
  366. uni.navigateBack({
  367. delta: 1
  368. });
  369. }, 1500);
  370. }
  371. that.setData({
  372. bmsInfo: resp.data.data.bmsInfo
  373. });
  374. } else {
  375. common.simpleToast(that,resp.data.msg);
  376. }
  377. });
  378. }
  379. }
  380. };
  381. </script>
  382. <style>
  383. @import './bmsbd02.css';
  384. </style>