add.js 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. module.exports = {
  2. addBlueDevice: addBlueDevice,
  3. addWifiDevice: addWifiDevice,
  4. updateDeviceList: updateDeviceList,
  5. }
  6. // {"applicationType":"[0, 1]","deviceId":"DB:45:DD:76:42:15","img":"https://music-play.oss-cn-shenzhen.aliyuncs.com/device/20220909100711728016597.png","offlineImg":"https://music-play.oss-cn-shenzhen.aliyuncs.com/device/20220909100714667384264.png","connectImg":null,"name":"猫王音响·小王子 OTR-X","bluetoothName":"猫王音响·小王子 OTR-X","bluetoothNames":["猫王音响·小王子 OTR-X"],"isChannelsPlatforms":0,"platform":-1,"typeList":[{"is5g":0,"type":1,"connectType":1,"functionList":[1,3,6],"deviceLinkResp":{"icon1":"https://music-play.oss-cn-shenzhen.aliyuncs.com/device/20220909100644913162836.png","icon2":"https://music-play.oss-cn-shenzhen.aliyuncs.com/device/20220909100648938942906.png","icon":null,"guideUrl":null}},{"is5g":0,"type":2,"connectType":3,"functionList":[1,3],"deviceLinkResp":{"icon1":"https://music-play.oss-cn-shenzhen.aliyuncs.com/device/20230313155903515728925.png","icon2":"https://music-play.oss-cn-shenzhen.aliyuncs.com/device/20230313155910706032704.png","icon":null,"guideUrl":null}}],"clientType":"MW-2AX(WIFI)","firstVersion":"0.0.1","filter":null,"guideUrl":null,"manufacturer":"ShanJing","deviceType":0,"mac":"9b45dd76e2150000",
  7. /// clientType 连接方式:bt-0,ble-1,upnp-2,mqtt-3
  8. // [{"deviceId":"BLUFI_7cdfa1fcbb24","name":"BLUFI_7cdfa1fcbb24","state":"online","ProdModel":"MW-2AX(WIFI-N)","devName":"猫王小王子OTR-X"}]
  9. ///新添加蓝牙设备
  10. function addBlueDevice(device) {
  11. // 同一个设备处理
  12. var deviceList = getCurrentPages()[0].getDeviceList();
  13. var tempList = deviceList.filter((v) => v.deviceId === device.deviceId);
  14. const strings = require('../strings');
  15. if (!strings.isEmpty(tempList)) {
  16. deviceList = deviceList.filter((v) => v.deviceId !== device.deviceId);
  17. }
  18. /// 添加到第一个
  19. deviceList.unshift({
  20. connectType: 1,
  21. devName: device.name,
  22. state: "online",
  23. name: device.name,
  24. deviceId: device.deviceId,
  25. mac: device.mac,
  26. ProdModel: device.ProdModel || device.clientType,
  27. clientType: device.clientType || device.ProdModel,
  28. image: device.image,
  29. });
  30. return deviceList;
  31. };
  32. // 新添加Wifi设备 猫王小王子OTR-X
  33. // [{"deviceId":"BLUFI_7cdfa1fcbb24","name":"BLUFI_7cdfa1fcbb24","state":"online"}]
  34. function addWifiDevice(device) {
  35. // 同一个设备处理
  36. var deviceList = getCurrentPages()[0].getDeviceList();
  37. var tempList = deviceList.filter((v) => v.deviceId === device.deviceId);
  38. const strings = require('../strings');
  39. if (!strings.isEmpty(tempList)) {
  40. deviceList = deviceList.filter((v) => v.deviceId !== device.deviceId);
  41. }
  42. /// 添加到第一个
  43. deviceList.unshift(device);
  44. return deviceList;
  45. };
  46. ///更新列表排序
  47. function updateDeviceList(list, isInit, closeAllBlue) {
  48. const strings = require('../strings');
  49. if (strings.isEmpty(list)) {
  50. return [];
  51. }
  52. const app = getApp();
  53. var finalList = [];
  54. if (isInit) {
  55. list[0].state = "offline";
  56. }
  57. /// 让所有蓝牙设备离线
  58. if (closeAllBlue) {
  59. list.forEach(element => {
  60. if (element.connectType != 3) {
  61. element.state = "offline";
  62. }
  63. });
  64. }
  65. ///挑选出第一个在线设备
  66. var isFirstOnline = false;
  67. if (list[0].state == "online") {
  68. isFirstOnline = true;
  69. finalList.push(list[0]);
  70. }
  71. ///区分在线和离线
  72. for (var i = isFirstOnline ? 1 : 0; i < list.length; i++) {
  73. if (isInit) {
  74. list[i].state = "offline";
  75. }
  76. }
  77. var onLineList = [];
  78. var onNoLineList = [];
  79. ///添加在线的
  80. for (var i = isFirstOnline ? 1 : 0; i < list.length; i++) {
  81. var device = list[i];
  82. if (device.state == "online") {
  83. onLineList.push(device)
  84. }
  85. }
  86. ///添加离线的
  87. for (var i = isFirstOnline ? 1 : 0; i < list.length; i++) {
  88. var device = list[i];
  89. if (device.state != "online") {
  90. onNoLineList.push(device)
  91. }
  92. }
  93. // 区分在线wifi和蓝牙 wifi在前 离线在后
  94. var onLineWifiList = [];
  95. var onLineBlueList = [];
  96. ///添加在线wifi
  97. onLineList.forEach(element => {
  98. if (element.connectType == 3) {
  99. onLineWifiList.push(element);
  100. }
  101. });
  102. ///添加在线蓝牙
  103. onLineList.forEach(element => {
  104. if (element.connectType != 3) {
  105. onLineBlueList.push(element)
  106. }
  107. });
  108. finalList = finalList.concat(onLineWifiList);
  109. finalList = finalList.concat(onLineBlueList);
  110. ///只需要蓝牙和wifi在线的
  111. var mDeviceList = []
  112. mDeviceList = mDeviceList.concat(onLineWifiList);
  113. mDeviceList = mDeviceList.concat(onLineBlueList);
  114. app.globalData.mDeviceList = mDeviceList;
  115. ///区分离线wifi和蓝牙 wifi在前 离线在后
  116. var onNoLineWifiList = [];
  117. var onNoLineBlueList = [];
  118. ///添加离线wifi
  119. onNoLineList.forEach(element => {
  120. if (element.connectType == 3) {
  121. onNoLineWifiList.push(element)
  122. }
  123. });
  124. ///添加离线蓝牙
  125. onNoLineList.forEach(element => {
  126. if (element.connectType != 3) {
  127. onNoLineBlueList.push(element)
  128. }
  129. });
  130. finalList = finalList.concat(onNoLineWifiList);
  131. finalList = finalList.concat(onNoLineBlueList);
  132. return finalList;
  133. };