index.js 12 KB

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