index.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400
  1. let Parse = getApp().Parse;
  2. const company = getApp().globalData.company
  3. Component({
  4. /**
  5. * 组件的属性列表
  6. */
  7. properties: {},
  8. /**
  9. * 组件的初始数据
  10. */
  11. data: {
  12. statusBarHeight: 0,
  13. screenHeight: 0,
  14. customHeight: 0,
  15. bottomNavHeight: 0,
  16. contentHeight: 0,
  17. date_start: '',
  18. date_end: '',
  19. date_start1: '',
  20. date_end1: '',
  21. istoday: true,
  22. daysBetween: 1,
  23. show: false,
  24. //店铺数据
  25. storeList: [],
  26. //价格
  27. price: 211,
  28. //搜索
  29. value: '',
  30. start: '',
  31. end: '',
  32. //触底加载
  33. loadedItems: 0,
  34. pageSize: 3,
  35. noMoreItems: false,
  36. },
  37. lifetimes: {
  38. detached: function () {},
  39. attached: async function () {
  40. const systemInfo = wx.getSystemInfoSync();
  41. const statusBarHeight = systemInfo.statusBarHeight || 0;
  42. const screenHeight = systemInfo.screenHeight || 0;
  43. const custom = wx.getMenuButtonBoundingClientRect();
  44. const customHeight = custom.height + 10 + 2 || 0;
  45. const bottomNavHeight = systemInfo.screenHeight - systemInfo.safeArea.bottom || 0;
  46. const contentHeight = (screenHeight - bottomNavHeight - 50 - statusBarHeight - customHeight) * 750 / systemInfo.windowWidth;
  47. this.setData({
  48. statusBarHeight,
  49. screenHeight,
  50. customHeight,
  51. bottomNavHeight,
  52. contentHeight
  53. });
  54. this.getcurrentdate();
  55. this.gethomestar()
  56. },
  57. },
  58. /**
  59. * 组件的方法列表
  60. */
  61. methods: {
  62. //获取今日明日日期
  63. getcurrentdate() {
  64. const today = new Date();
  65. const tomorrow = new Date();
  66. tomorrow.setDate(today.getDate() + 1);
  67. this.setData({
  68. date_start: this.formatDate(today),
  69. date_end: this.formatDate(tomorrow),
  70. date_start1: this.formatDate(today),
  71. date_end1: this.formatDate(tomorrow),
  72. start: today,
  73. end: tomorrow
  74. });
  75. console.log(this.data.start, this.data.end);
  76. },
  77. // 计算两个日期之间的天数
  78. calculateDaysBetween(startDate, endDate) {
  79. const start = new Date(startDate);
  80. const end = new Date(endDate);
  81. const timeDifference = end - start; // 计算时间差(毫秒)
  82. const daysDifference = timeDifference / (1000 * 3600 * 24); // 转换为天数
  83. return daysDifference; // 返回天数差
  84. },
  85. //开日历
  86. onDisplay() {
  87. this.setData({
  88. show: true
  89. });
  90. },
  91. //关日历
  92. onClose() {
  93. this.setData({
  94. show: false
  95. });
  96. },
  97. //转换日期
  98. formatDate(date) {
  99. date = new Date(date);
  100. return `${date.getMonth() + 1}月${date.getDate()}日`;
  101. },
  102. //选好日期点击完成后
  103. async onConfirm(event) {
  104. const [start, end] = event.detail;
  105. const daysBetween = this.calculateDaysBetween(start, end); // 计算天数差
  106. this.setData({
  107. show: false,
  108. start,
  109. end,
  110. date_start: `${this.formatDate(start)} `,
  111. date_end: `${this.formatDate(end)}`,
  112. daysBetween
  113. });
  114. if (this.data.date_start.trim() == this.data.date_start1.trim() && this.data.date_end.trim() == this.data.date_end1.trim()) {
  115. this.setData({
  116. istoday: true
  117. })
  118. console.log(this.data.istoday);
  119. } else {
  120. this.setData({
  121. istoday: false
  122. })
  123. console.log(this.data.istoday);
  124. }
  125. this.setData({
  126. loadedItems: 0,
  127. noMoreItems: false,
  128. storeList: []
  129. })
  130. await this.gethomestar()
  131. console.log(`入住日期: ${this.data.date_start}, 离店日期: ${this.data.date_end}, 天数差: ${daysBetween}天`);
  132. },
  133. gourl(e) {
  134. const url = e.currentTarget.dataset.url;
  135. const id = e.currentTarget.dataset.id;
  136. // 构造要传递的信息
  137. const info = {
  138. objectId: id,
  139. date_start: this.data.date_start,
  140. date_end: this.data.date_end,
  141. daysBetween: this.data.daysBetween,
  142. istoday: this.data.istoday,
  143. start: this.data.start,
  144. end: this.data.end
  145. };
  146. // 将信息转为查询字符串
  147. const queryString = Object.keys(info)
  148. .map(key => `${encodeURIComponent(key)}=${encodeURIComponent(info[key])}`)
  149. .join('&');
  150. // 使用查询字符串跳转
  151. wx.navigateTo({
  152. url: `${url}?${queryString}`,
  153. });
  154. },
  155. //获取店铺消息
  156. async gethomestar() {
  157. let ShopStore = new Parse.Query('ShopStore');
  158. ShopStore.equalTo('company', company);
  159. ShopStore.equalTo('type', "stay");
  160. ShopStore.notEqualTo('isDeleted', "true");
  161. ShopStore.limit(this.data.pageSize);
  162. ShopStore.skip(this.data.loadedItems);
  163. let store = await ShopStore.find();
  164. let storeListPromises = store.map(async item => {
  165. let storeItem = item.toJSON();
  166. // 为每一项添加价格属性
  167. storeItem.price = storeItem.perCapita * this.data.daysBetween;
  168. storeItem.iscollect = await this.iscollect(storeItem.objectId); // 等待iscollect的结果
  169. return storeItem;
  170. });
  171. let storeList = await Promise.all(storeListPromises); // 等待所有的Promise完成
  172. // 收藏提前-----------------------
  173. // 合并新加载的商店和已存在的商店列表
  174. let updatedStoreList = this.data.storeList.concat(storeList);
  175. // 按照iscollect排序,true的排在前面
  176. updatedStoreList.sort((a, b) => {
  177. return (b.iscollect === true) - (a.iscollect === true);
  178. });
  179. // 收藏提前-----------------------
  180. if (storeList.length < this.data.pageSize) {
  181. this.setData({
  182. noMoreItems: true
  183. });
  184. } else {
  185. this.setData({
  186. noMoreItems: false
  187. });
  188. }
  189. this.setData({
  190. storeList: updatedStoreList,//storeList: this.data.storeList.concat(storeList),
  191. loadedItems: this.data.loadedItems + storeList.length,//loadedItems: this.data.loadedItems + storeList.length,
  192. });
  193. console.log(this.data.storeList);
  194. },
  195. //收藏功能
  196. async iscollect(object) {
  197. const currentUser = Parse.User.current();
  198. let Collect = new Parse.Query('DramaShopCollect');
  199. Collect.equalTo('company', company);
  200. Collect.equalTo('user', currentUser.id);
  201. Collect.equalTo('homestayStore', object);
  202. Collect.equalTo('isCollect', 'true');
  203. Collect.notEqualTo('isDeleted', "true");
  204. let collect = await Collect.first();
  205. if (collect) {
  206. return true
  207. } else {
  208. return false
  209. }
  210. },
  211. //点击收藏
  212. async submit(e) {
  213. const object = e.currentTarget.dataset.id
  214. console.log(object);
  215. const currentUser = Parse.User.current();
  216. let Collect = new Parse.Query('DramaShopCollect');
  217. Collect.equalTo('company', company);
  218. Collect.equalTo('user', currentUser.id);
  219. Collect.equalTo('homestayStore', object);
  220. Collect.notEqualTo('isDeleted', "true");
  221. let collect = await Collect.first();
  222. await this.changeiscollect(object)
  223. if (collect) {
  224. collect.set('isCollect', true)
  225. try {
  226. let saveDate = await collect.save();
  227. console.log(saveDate);
  228. console.log("收藏成功1");
  229. } catch (error) {
  230. console.error("保存数据时出现错误:", error);
  231. }
  232. } else {
  233. //user
  234. const currentUser = Parse.User.current();
  235. let userquery2 = new Parse.Query('_User');
  236. userquery2.equalTo('company', company);
  237. userquery2.equalTo('objectId', currentUser.id);
  238. userquery2.notEqualTo('isDeleted', true)
  239. let user2 = await userquery2.first();
  240. //店铺
  241. let Collect3 = new Parse.Query('ShopStore');
  242. Collect3.equalTo('company', company);
  243. Collect3.equalTo('objectId', object);
  244. Collect3.notEqualTo('isDeleted', "true");
  245. let collect3 = await Collect3.first();
  246. let companyPointer = Parse.Object.extend('Company').createWithoutData(company);
  247. let Comment = new Parse.Object('DramaShopCollect');
  248. Comment.set('company', companyPointer);
  249. Comment.set('homestayStore', collect3.toPointer());
  250. Comment.set('user', user2.toPointer());
  251. Comment.set('isCollect', true);
  252. try {
  253. let saveDate2 = await Comment.save();
  254. console.log(saveDate2);
  255. console.log("收藏成功");
  256. } catch (error) {
  257. console.error("保存数据时出现错误:", error);
  258. }
  259. }
  260. },
  261. // 点击收藏后把storeList中对应的isCollect变成true
  262. changeiscollect(objectId) {
  263. // 创建一个新的 storeList 数组,以确保视图更新
  264. const updatedStoreList = this.data.storeList.map(item => {
  265. if (item.objectId === objectId) {
  266. return {
  267. ...item,
  268. iscollect: !item.iscollect // 切换 iscollect 的值
  269. };
  270. }
  271. return item; // 返回未修改的项
  272. });
  273. // 更新 storeList
  274. this.setData({
  275. storeList: updatedStoreList
  276. });
  277. console.log('修改成功', objectId);
  278. },
  279. //点击取消
  280. async cancle(e) {
  281. const object = e.currentTarget.dataset.id
  282. const currentUser = Parse.User.current();
  283. let Collect = new Parse.Query('DramaShopCollect');
  284. Collect.equalTo('company', company);
  285. Collect.equalTo('user', currentUser.id);
  286. Collect.equalTo('isCollect', true);
  287. Collect.equalTo('homestayStore', object);
  288. Collect.notEqualTo('isDeleted', "true");
  289. let collect = await Collect.first();
  290. await this.changeiscollect(object)
  291. if (collect) {
  292. collect.set('isCollect', false)
  293. try {
  294. let saveDate = await collect.save();
  295. console.log(saveDate);
  296. console.log("取消成功");
  297. } catch (error) {
  298. console.error("保存数据时出现错误:", error);
  299. }
  300. }
  301. },
  302. //搜索功能
  303. search(e) {
  304. const value = e.detail.value;
  305. console.log(value);
  306. this.getRooms(value)
  307. },
  308. //清零后
  309. change(e) {
  310. const value = e.detail.value;
  311. if (!value) {
  312. console.log('运行');
  313. this.clear()
  314. }
  315. },
  316. clear() {
  317. this.setData({
  318. loadedItems: 0,
  319. noMoreItems: false,
  320. storeList: []
  321. })
  322. this.gethomestar()
  323. },
  324. // 搜索函数
  325. async getRooms(value) {
  326. // 确保 value 不为空
  327. if (!value) {
  328. console.log('搜索值为空');
  329. return; // 如果没有输入值,直接返回
  330. }
  331. let queryParams = {
  332. where: {
  333. $or: [{
  334. storeName: {
  335. $regex: `.*${value}.*` // 使用 value 进行正则匹配
  336. }
  337. }, {
  338. storeAddress: {
  339. $regex: `.*${value}.*` // 使用 value 进行正则匹配
  340. }
  341. }]
  342. }
  343. };
  344. let ShopStore = Parse.Query.fromJSON('ShopStore', queryParams);
  345. ShopStore.equalTo('company', company);
  346. ShopStore.equalTo('type', "stay");
  347. ShopStore.notEqualTo('isDeleted', "true");
  348. try {
  349. let store = await ShopStore.find();
  350. let storeListPromises = store.map(async item => {
  351. let storeItem = item.toJSON();
  352. // 为每一项添加价格属性
  353. storeItem.price = storeItem.perCapita * this.data.daysBetween;
  354. storeItem.iscollect = await this.iscollect(storeItem.objectId); // 等待 iscollect 的结果
  355. return storeItem;
  356. });
  357. let storeList = await Promise.all(storeListPromises); // 等待所有的 Promise 完成
  358. this.setData({
  359. storeList // 更新 storeList
  360. });
  361. } catch (error) {
  362. console.error("查询商店时出现错误:", error);
  363. }
  364. },
  365. //触底加载
  366. async loadMoreData() {
  367. if (!this.data.noMoreItems) {
  368. await this.gethomestar()
  369. }
  370. },
  371. }
  372. });