convertProdDet.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458
  1. // pages/prod/prod.js
  2. const app = getApp()
  3. var http = require('../../../utils/http.js');
  4. var config = require('../../../utils/config.js');
  5. var util = require('../../../utils/util.js');
  6. Page({
  7. /**
  8. * 页面的初始数据
  9. */
  10. data: {
  11. shopId: 1,
  12. shopName: '',
  13. picDomain: config.picDomain,
  14. indicatorDots: true,
  15. indicatorColor: '#f2f2f2',
  16. indicatorActiveColor: '#eb2444',
  17. isAuthInfo: true,
  18. autoplay: true,
  19. interval: 3000,
  20. duration: 1000,
  21. prodNum: 1,
  22. totalCartNum: 0,
  23. groupActivityId: 0,
  24. pic: "",
  25. imgs: '',
  26. prodName: '',
  27. price: 0,
  28. actPrice: 0,
  29. content: '',
  30. prodId: 0,
  31. brief: '',
  32. skuId: 0,
  33. popupShow: false,
  34. skuShow: false,
  35. skuGroupShow: false,
  36. commentShow: false,
  37. skuList: [],
  38. skuGroup: {},
  39. findSku: true,
  40. defaultSku: undefined,
  41. detaultGroupSku: undefined,
  42. selectedProp: [],
  43. selectedPropObj: {},
  44. selectedProperties: "",
  45. propKeys: [],
  46. allProperties: [],
  47. isCollection: false,
  48. skuShowType: 0, // sku的显示类型 0普通sku 1拼团sku
  49. totalStocks: 0, // 活动剩余库存
  50. hasMaxNum: false, // 是否限购
  51. maxNum: 0, // 限购数量
  52. totalStocks: 0, //库存量
  53. },
  54. /**
  55. * 生命周期函数--监听页面加载
  56. */
  57. onLoad: function(options) {
  58. this.setData({
  59. prodId: options.prodId,
  60. });
  61. // 加载商品信息
  62. this.getProdInfo();
  63. },
  64. /**
  65. * 获取是否关注信息
  66. */
  67. getCollection() {
  68. wx.showLoading();
  69. var params = {
  70. url: "/p/user/collection/isCollection",
  71. method: "GET",
  72. data: {
  73. prodId: this.data.prodId
  74. },
  75. callBack: (res) => {
  76. this.setData({
  77. isCollection: res
  78. })
  79. wx.hideLoading();
  80. }
  81. };
  82. http.request(params);
  83. },
  84. // 获取商品信息
  85. getProdInfo() {
  86. wx.showLoading();
  87. var params = {
  88. url: "/score/prod/prodInfo",
  89. method: "GET",
  90. data: {
  91. prodId: this.data.prodId,
  92. // userType: 0
  93. },
  94. callBack: (res) => {
  95. var imgStrs = res.imgs;
  96. var imgs = imgStrs.split(",");
  97. var content = util.formatHtml(res.content);
  98. this.setData({
  99. imgs: imgs,
  100. content: content,
  101. price: res.price,
  102. prodName: res.prodName,
  103. groupActivityId: res.groupActivityId,
  104. prodId: res.prodId,
  105. brief: res.brief,
  106. totalStocks: res.totalStocks,
  107. // skuId: res.skuId
  108. skuList: res.skuList,
  109. totalStocks: res.totalStocks, //库存量
  110. pic: res.pic,
  111. shopId: res.shopId,
  112. scorePrice: res.scorePrice, //积分价格
  113. });
  114. // 团购活动
  115. if (res.groupActivityId) {
  116. this.getJoinGroupList();
  117. }
  118. // 组装sku
  119. this.groupSkuProp(res.skuList);
  120. // this.getShopInfo();
  121. wx.hideLoading();
  122. }
  123. };
  124. http.request(params);
  125. },
  126. //根据sku的属性 分组
  127. groupSkuProp: function(skuList) {
  128. // var skuList = this.data.skuList;
  129. if (skuList.length == 1 && skuList[0].properties == "") {
  130. this.setData({
  131. defaultSku: skuList[0]
  132. });
  133. // this.setDefaultGroupSku();
  134. return;
  135. }
  136. var skuGroup = {};
  137. var allProperties = [];
  138. var propKeys = [];
  139. this.setData({
  140. selectedPropObj: {}
  141. });
  142. for (var i = 0; i < skuList.length; i++) {
  143. var defaultSku = this.data.defaultSku;
  144. var isDefault = false;
  145. if (!defaultSku && skuList[i].price == this.data.price) { //找到和商品价格一样的那个SKU,作为默认选中的SKU
  146. defaultSku = skuList[i];
  147. isDefault = true;
  148. this.setData({
  149. defaultSku: defaultSku
  150. });
  151. }
  152. var properties = skuList[i].properties; //版本:公开版;颜色:金色;内存:64GB
  153. allProperties.push(properties);
  154. var propList = properties.split(";"); // ["版本:公开版","颜色:金色","内存:64GB"]
  155. var selectedPropObj = this.data.selectedPropObj;
  156. for (var j = 0; j < propList.length; j++) {
  157. var propval = propList[j].split(":"); //["版本","公开版"]
  158. var props = skuGroup[propval[0]]; //先取出 版本对应的值数组
  159. //如果当前是默认选中的sku,把对应的属性值 组装到selectedProp
  160. if (isDefault) {
  161. propKeys.push(propval[0]);
  162. selectedPropObj[propval[0]] = propval[1];
  163. }
  164. if (props == undefined) {
  165. props = []; //假设还没有版本,新建个新的空数组
  166. props.push(propval[1]); //把 "公开版" 放进空数组
  167. } else {
  168. if (!this.array_contain(props, propval[1])) { //如果数组里面没有"公开版"
  169. props.push(propval[1]); //把 "公开版" 放进数组
  170. }
  171. }
  172. skuGroup[propval[0]] = props; //最后把数据 放回版本对应的值
  173. }
  174. this.setData({
  175. selectedPropObj: selectedPropObj,
  176. propKeys: propKeys
  177. });
  178. }
  179. this.parseSelectedObjToVals();
  180. this.setData({
  181. skuGroup: skuGroup,
  182. allProperties: allProperties
  183. });
  184. // this.setDefaultGroupSku();
  185. },
  186. //将已选的 {key:val,key2:val2}转换成 [val,val2]
  187. parseSelectedObjToVals: function() {
  188. var selectedPropObj = this.data.selectedPropObj;
  189. var selectedProperties = "";
  190. var selectedProp = [];
  191. for (var key in selectedPropObj) {
  192. selectedProp.push(selectedPropObj[key]);
  193. selectedProperties += key + ":" + selectedPropObj[key] + ";";
  194. }
  195. selectedProperties = selectedProperties.substring(0, selectedProperties.length - 1);
  196. // console.log(selectedProperties);
  197. this.setData({
  198. selectedProp: selectedProp,
  199. selectedProperties: selectedProperties
  200. });
  201. var findSku = false;
  202. for (var i = 0; i < this.data.skuList.length; i++) {
  203. if (this.data.skuList[i].properties == selectedProperties) {
  204. findSku = true;
  205. this.setData({
  206. defaultSku: this.data.skuList[i]
  207. });
  208. break;
  209. }
  210. }
  211. this.setData({
  212. findSku: findSku
  213. });
  214. // this.setDefaultGroupSku();
  215. },
  216. //点击选择规格
  217. toChooseItem: function(e) {
  218. var ok = e.currentTarget.dataset.ok;
  219. if (ok == 0) {
  220. return;
  221. }
  222. var val = e.currentTarget.dataset.val;
  223. var key = e.currentTarget.dataset.key;
  224. var selectedPropObj = this.data.selectedPropObj;
  225. selectedPropObj[key] = val;
  226. this.setData({
  227. selectedPropObj: selectedPropObj
  228. });
  229. this.parseSelectedObjToVals();
  230. },
  231. //判断数组是否包含某对象
  232. array_contain: function(array, obj) {
  233. for (var i = 0; i < array.length; i++) {
  234. if (array[i] == obj) //如果要求数据类型也一致,这里可使用恒等号===
  235. return true;
  236. }
  237. return false;
  238. },
  239. /**
  240. * 立即兑换
  241. */
  242. redeemNow: function() {
  243. if (!this.data.findSku) {
  244. return;
  245. }
  246. if (!this.data.skuShow) {
  247. this.setData({
  248. skuShow: true
  249. })
  250. return
  251. }
  252. wx.showLoading({
  253. mask: true
  254. });
  255. if (this.data.totalStocks < 0) {
  256. wx.showToast({
  257. title: '商品库存不足!',
  258. icon: none,
  259. duration: 2000,
  260. })
  261. return
  262. }
  263. // 查看是否授权
  264. util.checkAuthInfo(this._redeemNow)
  265. },
  266. _redeemNow() {
  267. wx.setStorageSync("orderItem", JSON.stringify({
  268. prodId: this.data.prodId,
  269. skuId: this.data.defaultSku.skuId,
  270. prodCount: this.data.prodNum,
  271. shopId: this.data.shopId,
  272. distributionCardNo: this.data.distributionCardNo
  273. }));
  274. wx.navigateTo({
  275. url: '/packageMemberIntegral/pages/integralSubmitOrder/integralSubmitOrder?orderEntry=1',
  276. })
  277. },
  278. /**
  279. * 页面隐藏触发
  280. */
  281. onHide(){
  282. this.setData({
  283. skuShow: false
  284. })
  285. },
  286. /**
  287. * 生命周期函数--监听页面初次渲染完成
  288. */
  289. onReady: function() {
  290. },
  291. /**
  292. * 生命周期函数--监听页面显示
  293. */
  294. onShow: function() {
  295. this.setData({
  296. totalCartNum: app.globalData.totalCartCount,
  297. });
  298. // 查看用户是否关注
  299. this.getCollection();
  300. },
  301. /**
  302. * 页面相关事件处理函数--监听用户下拉动作
  303. */
  304. onPullDownRefresh: function() {
  305. },
  306. /**
  307. * 页面上拉触底事件的处理函数
  308. */
  309. onReachBottom: function() {
  310. },
  311. /**
  312. * 跳转到首页
  313. */
  314. toHomePage: function() {
  315. wx.switchTab({
  316. url: '/pages/index/index',
  317. })
  318. },
  319. /**
  320. * 减数量
  321. */
  322. onCountMinus: function() {
  323. var prodNum = this.data.prodNum;
  324. if (prodNum > 1) {
  325. this.setData({
  326. prodNum: prodNum - 1
  327. });
  328. }
  329. },
  330. /**
  331. * 加数量
  332. */
  333. onCountPlus: function() {
  334. var prodNum = this.data.prodNum;
  335. // 判断是否限购
  336. if (this.data.hasMaxNum) {
  337. if (prodNum < this.data.totalStocks && prodNum < this.data.maxNum) {
  338. this.setData({
  339. prodNum: prodNum + 1
  340. });
  341. } else {
  342. wx.showToast({
  343. title: '限购' + this.data.maxNum + '件',
  344. icon: 'none',
  345. })
  346. }
  347. } else {
  348. if (prodNum < this.data.totalStocks) {
  349. this.setData({
  350. prodNum: prodNum + 1
  351. });
  352. }
  353. }
  354. },
  355. // sku弹框
  356. showSku: function(e) {
  357. if (e.currentTarget.dataset.alonebuy == 1) {
  358. this.setData({
  359. skuShow: true,
  360. skuShowType: 0
  361. });
  362. } else {
  363. if (this.data.groupActivityId) {
  364. this.setData({
  365. skuShow: true,
  366. skuShowType: 1
  367. });
  368. } else {
  369. this.setData({
  370. skuShow: true,
  371. skuShowType: 0
  372. });
  373. }
  374. }
  375. },
  376. // 关闭规格弹窗
  377. closePopup: function() {
  378. this.setData({
  379. popupShow: false,
  380. skuShow: false,
  381. commentShow: false
  382. });
  383. },
  384. /**
  385. * 获取用户信息
  386. */
  387. onGotUserInfo: function(e) {
  388. if (e.detail.errMsg != "getUserInfo:fail auth deny") {
  389. this.setData({
  390. isAuthInfo: true
  391. });
  392. http.updateUserInfo();
  393. }
  394. },
  395. groupConfirmOrder: function(e) {
  396. if (!this.data.findSku) {
  397. return;
  398. }
  399. var ths = this;
  400. wx.showLoading({
  401. mask: true
  402. });
  403. // 查看是否授权
  404. util.checkAuthInfo(ths._groupConfirmData)
  405. },
  406. _groupConfirmData() {
  407. wx.setStorageSync("groupOrderItem", JSON.stringify({
  408. groupSkuId: ths.data.detaultGroupSku.groupSkuId, // this.data.groupSkuId,
  409. prodCount: ths.data.prodNum, // this.data.prodNum,
  410. groupTeamId: e.currentTarget.dataset.teamid // this.data.groupTeamId
  411. }));
  412. wx.navigateTo({
  413. url: '/pages/groupConfirmOrder/groupConfirmOrder',
  414. })
  415. }
  416. })