index.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395
  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:5,
  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. // 按照iscollect排序,true的排在前面
  173. storeList.sort((a, b) => {
  174. return (b.iscollect === true) - (a.iscollect === true);
  175. });
  176. if (storeList.length < this.data.pageSize) {
  177. this.setData({
  178. noMoreItems: true
  179. });
  180. } else {
  181. this.setData({
  182. noMoreItems: false
  183. });
  184. }
  185. this.setData({
  186. storeList: this.data.storeList.concat(storeList),
  187. loadedItems: this.data.loadedItems + storeList.length,
  188. });
  189. console.log(this.data.storeList);
  190. },
  191. //收藏功能
  192. async iscollect(object) {
  193. const currentUser = Parse.User.current();
  194. let Collect = new Parse.Query('DramaShopCollect');
  195. Collect.equalTo('company', company);
  196. Collect.equalTo('user', currentUser.id);
  197. Collect.equalTo('homestayStore', object);
  198. Collect.equalTo('isCollect', 'true');
  199. Collect.notEqualTo('isDeleted', "true");
  200. let collect = await Collect.first();
  201. if (collect) {
  202. return true
  203. } else {
  204. return false
  205. }
  206. },
  207. //点击收藏
  208. async submit(e) {
  209. const object = e.currentTarget.dataset.id
  210. console.log(object);
  211. const currentUser = Parse.User.current();
  212. let Collect = new Parse.Query('DramaShopCollect');
  213. Collect.equalTo('company', company);
  214. Collect.equalTo('user', currentUser.id);
  215. Collect.equalTo('homestayStore', object);
  216. Collect.notEqualTo('isDeleted', "true");
  217. let collect = await Collect.first();
  218. await this.changeiscollect(object)
  219. if (collect) {
  220. collect.set('isCollect', true)
  221. try {
  222. let saveDate = await collect.save();
  223. console.log(saveDate);
  224. console.log("收藏成功1");
  225. } catch (error) {
  226. console.error("保存数据时出现错误:", error);
  227. }
  228. } else {
  229. //user
  230. const currentUser = Parse.User.current();
  231. let userquery2 = new Parse.Query('_User');
  232. userquery2.equalTo('company', company);
  233. userquery2.equalTo('objectId', currentUser.id);
  234. userquery2.notEqualTo('isDeleted', true)
  235. let user2 = await userquery2.first();
  236. //店铺
  237. let Collect3 = new Parse.Query('ShopStore');
  238. Collect3.equalTo('company', company);
  239. Collect3.equalTo('objectId', object);
  240. Collect3.notEqualTo('isDeleted', "true");
  241. let collect3 = await Collect3.first();
  242. let companyPointer = Parse.Object.extend('Company').createWithoutData(company);
  243. let Comment = new Parse.Object('DramaShopCollect');
  244. Comment.set('company', companyPointer);
  245. Comment.set('homestayStore', collect3.toPointer());
  246. Comment.set('user', user2.toPointer());
  247. Comment.set('isCollect', true);
  248. try {
  249. let saveDate2 = await Comment.save();
  250. console.log(saveDate2);
  251. console.log("收藏成功");
  252. } catch (error) {
  253. console.error("保存数据时出现错误:", error);
  254. }
  255. }
  256. },
  257. // 点击收藏后把storeList中对应的isCollect变成true
  258. changeiscollect(objectId) {
  259. // 创建一个新的 storeList 数组,以确保视图更新
  260. const updatedStoreList = this.data.storeList.map(item => {
  261. if (item.objectId === objectId) {
  262. return {
  263. ...item,
  264. iscollect: !item.iscollect // 切换 iscollect 的值
  265. };
  266. }
  267. return item; // 返回未修改的项
  268. });
  269. // 更新 storeList
  270. this.setData({
  271. storeList: updatedStoreList
  272. });
  273. console.log('修改成功', objectId);
  274. },
  275. //点击取消
  276. async cancle(e) {
  277. const object = e.currentTarget.dataset.id
  278. const currentUser = Parse.User.current();
  279. let Collect = new Parse.Query('DramaShopCollect');
  280. Collect.equalTo('company', company);
  281. Collect.equalTo('user', currentUser.id);
  282. Collect.equalTo('isCollect', true);
  283. Collect.equalTo('homestayStore', object);
  284. Collect.notEqualTo('isDeleted', "true");
  285. let collect = await Collect.first();
  286. await this.changeiscollect(object)
  287. if (collect) {
  288. collect.set('isCollect', false)
  289. try {
  290. let saveDate = await collect.save();
  291. console.log(saveDate);
  292. console.log("取消成功");
  293. } catch (error) {
  294. console.error("保存数据时出现错误:", error);
  295. }
  296. }
  297. },
  298. //搜索功能
  299. search(e) {
  300. const value = e.detail.value;
  301. console.log(value);
  302. this.getRooms(value)
  303. },
  304. //清零后
  305. change(e) {
  306. const value = e.detail.value;
  307. if (!value) {
  308. console.log('运行');
  309. this.clear()
  310. }
  311. },
  312. clear(){
  313. this.setData({
  314. loadedItems:0,
  315. noMoreItems:false,
  316. storeList:[]
  317. })
  318. this.gethomestar()
  319. },
  320. // 搜索函数
  321. async getRooms(value) {
  322. // 确保 value 不为空
  323. if (!value) {
  324. console.log('搜索值为空');
  325. return; // 如果没有输入值,直接返回
  326. }
  327. let queryParams = {
  328. where: {
  329. $or: [{
  330. storeName: {
  331. $regex: `.*${value}.*` // 使用 value 进行正则匹配
  332. }
  333. }, {
  334. storeAddress: {
  335. $regex: `.*${value}.*` // 使用 value 进行正则匹配
  336. }
  337. }]
  338. }
  339. };
  340. let ShopStore = Parse.Query.fromJSON('ShopStore', queryParams);
  341. ShopStore.equalTo('company', company);
  342. ShopStore.equalTo('type', "stay");
  343. ShopStore.notEqualTo('isDeleted', "true");
  344. try {
  345. let store = await ShopStore.find();
  346. let storeListPromises = store.map(async item => {
  347. let storeItem = item.toJSON();
  348. // 为每一项添加价格属性
  349. storeItem.price = storeItem.perCapita * this.data.daysBetween;
  350. storeItem.iscollect = await this.iscollect(storeItem.objectId); // 等待 iscollect 的结果
  351. return storeItem;
  352. });
  353. let storeList = await Promise.all(storeListPromises); // 等待所有的 Promise 完成
  354. this.setData({
  355. storeList // 更新 storeList
  356. });
  357. } catch (error) {
  358. console.error("查询商店时出现错误:", error);
  359. }
  360. },
  361. //触底加载
  362. async loadMoreData(){
  363. if(!this.data.noMoreItems){
  364. await this.gethomestar()
  365. }
  366. },
  367. }
  368. });