nc-pend-order.vue 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393
  1. <template>
  2. <view class="container">
  3. <view class="header">取单</view>
  4. <scroll-view scroll-y="true" @scrolltolower="getOrder" class="scroll-view-wrap">
  5. <view class="table-list" v-if="orderData.list.length">
  6. <block v-for="(item, index) in orderData.list" :key="index">
  7. <view class="table-item" v-show="item.order_id != orderId">
  8. <view class="table-header">
  9. <view class="table-header-info">
  10. <text>订单总价:</text>
  11. <text class="color">¥{{ item.order_money | moneyFormat }}</text>
  12. </view>
  13. <view class="table-header-time">
  14. <text>挂单时间:{{ item.create_time | timeFormat }}</text>
  15. <block v-if="item.member_id">
  16. <text class="line">|</text>
  17. <text>会员:{{ item.nickname }}</text>
  18. </block>
  19. </view>
  20. </view>
  21. <view class="table-content">
  22. <view class="table-content-item" v-for="(goods, gindex) in item.order_goods" :key="gindex">
  23. <view class="content-item-left">
  24. <view class="content-item-img">
  25. <image :src="$util.img('public/uniapp/default_img/goods.png')" v-if="goods.goods_class == 'money'"></image>
  26. <image
  27. :src="$util.img(goods.goods_image, { size: 'small' })"
  28. @error="goods.goods_image = $util.img('public/uniapp/default_img/goods.png')"
  29. v-else
  30. ></image>
  31. </view>
  32. <view class="content-item-info">
  33. <view class="content-item-name" v-if="goods.goods_class == 'money'">无码商品</view>
  34. <view class="content-item-name" v-else>{{ goods.goods_name }} {{ goods.spec_name }}</view>
  35. <view>¥{{ goods.price | moneyFormat }}</view>
  36. </view>
  37. </view>
  38. <view class="content-item-number">x {{ goods.num }}</view>
  39. <view class="content-item-price">¥{{ (goods.num * goods.price) | moneyFormat }}</view>
  40. </view>
  41. </view>
  42. <view class="remark-info" v-if="item.remark">备注:{{ item.remark }}</view>
  43. <view class="table-bottom">
  44. <button class="default-btn btn-left" @click="deleteOrder(item)">删除</button>
  45. <button class="default-btn btn-left" @click="remarkSeting(item, index)">备注</button>
  46. <button class="primary-btn btn-right" @click="takeorder(item, index)">取单</button>
  47. </view>
  48. </view>
  49. </block>
  50. </view>
  51. <view class="empty" v-if="!orderData.list.length || (orderData.list.length == 1 && orderId)">
  52. <image :src="$util.img('public/uniapp/cashier/goods_empty.png')" mode="widthFix"></image>
  53. <view class="tips">暂无挂单记录</view>
  54. </view>
  55. </scroll-view>
  56. <uni-popup ref="remarkPopup" type="center">
  57. <view class="remark-wrap">
  58. <view class="header">
  59. <text class="title">备注</text>
  60. <text class="iconfont iconguanbi1" @click="$refs.remarkPopup.close()"></text>
  61. </view>
  62. <view class="body"><textarea v-model="remark" placeholder="填写备注信息" placeholder-class="placeholder-class" /></view>
  63. <view class="footer"><button type="default" class="primary-btn" @click="remarkConfirm">确认</button></view>
  64. </view>
  65. </uni-popup>
  66. </view>
  67. </template>
  68. <script>
  69. export default {
  70. name: 'ncPendOrder',
  71. props: {},
  72. data() {
  73. return {
  74. orderData: {
  75. page: 0,
  76. total: 1,
  77. list: []
  78. },
  79. remark: '',
  80. index: -1,
  81. orderId: 0,
  82. isRepeat: false
  83. };
  84. },
  85. created() {
  86. this.getOrder();
  87. },
  88. methods: {
  89. getOrder() {
  90. if (this.orderData.page + 1 > this.orderData.total) return;
  91. this.orderData.page += 1;
  92. this.orderId = 0;
  93. this.$api.sendRequest({
  94. url: '/cashier/storeapi/pendorder/page',
  95. data: {
  96. page: this.orderData.page
  97. },
  98. success: res => {
  99. if (res.code == 0) {
  100. if (this.orderData.page == 1) this.orderData.list = [];
  101. this.$store.commit('setPendOrderNum', res.data.count);
  102. if (res.data.list.length) {
  103. this.orderData.total = res.data.page_count;
  104. this.orderData.list = this.orderData.list.concat(res.data.list);
  105. } else {
  106. this.orderData.total = 1;
  107. }
  108. }
  109. }
  110. });
  111. },
  112. deleteOrder(data) {
  113. this.$api.sendRequest({
  114. url: '/cashier/storeapi/pendorder/delete',
  115. data: {
  116. order_id: data.order_id
  117. },
  118. success: res => {
  119. if (res.code == 0) {
  120. this.orderData.page = 0;
  121. this.getOrder();
  122. }
  123. }
  124. });
  125. },
  126. remarkConfirm() {
  127. let data = this.orderData.list[this.index];
  128. this.$api.sendRequest({
  129. url: '/cashier/storeapi/pendorder/updateremark',
  130. data: {
  131. order_id: data.order_id,
  132. remark: this.remark
  133. },
  134. success: res => {
  135. if (res.code == 0) {
  136. this.orderData.list[this.index].remark = this.remark;
  137. this.$refs.remarkPopup.close();
  138. } else {
  139. this.$util.showToast({ title: '操作失败' });
  140. }
  141. }
  142. });
  143. },
  144. remarkSeting(data, index) {
  145. this.index = index;
  146. this.remark = data.remark;
  147. this.$refs.remarkPopup.open();
  148. },
  149. takeorder(data, index) {
  150. this.orderId = data.order_id;
  151. this.$emit('takeorder', data);
  152. },
  153. switchStoreAfter() {
  154. this.orderData = {
  155. page: 0,
  156. total: 1,
  157. list: []
  158. };
  159. this.getOrder();
  160. }
  161. }
  162. };
  163. </script>
  164. <style lang="scss">
  165. .container {
  166. height: 100%;
  167. display: flex;
  168. flex-direction: column;
  169. .scroll-view-wrap {
  170. box-sizing: border-box;
  171. padding: 0.15rem 0;
  172. height: 7.8rem;
  173. }
  174. }
  175. .header {
  176. height: 0.66rem;
  177. line-height: 0.66rem;
  178. text-align: left;
  179. border-bottom: 0.01rem solid #e6e6e6;
  180. color: #303133;
  181. font-size: 0.14rem;
  182. }
  183. .table-list {
  184. .table-item {
  185. border: 0.01rem solid #e6e6e6;
  186. padding: 0.15rem;
  187. position: relative;
  188. margin-bottom: 0.2rem;
  189. .table-header-info {
  190. text {
  191. font-size: 0.16rem;
  192. }
  193. .color {
  194. font-size: 0.18rem;
  195. color: #fe2278;
  196. }
  197. }
  198. .table-header-time {
  199. color: #909399;
  200. font-size: 0.14rem;
  201. margin-top: 0.1rem;
  202. .line {
  203. margin: 0 0.15rem;
  204. }
  205. }
  206. .table-header-btn {
  207. position: absolute;
  208. right: 0.3rem;
  209. top: 0.3rem;
  210. color: $primary-color;
  211. cursor: pointer;
  212. }
  213. .table-content {
  214. margin-top: 0.1rem;
  215. .table-content-item {
  216. display: flex;
  217. align-items: center;
  218. justify-content: space-between;
  219. border-bottom: 0.01rem solid #e6e6e6;
  220. padding: 0.1rem 0;
  221. .content-item-left {
  222. display: flex;
  223. align-items: center;
  224. flex: 1;
  225. width: 0;
  226. .content-item-info {
  227. padding-right: 0.15rem;
  228. flex: 1;
  229. width: 0;
  230. view {
  231. font-size: 0.14rem;
  232. }
  233. .content-item-name {
  234. margin-bottom: 0.05rem;
  235. overflow: hidden;
  236. text-overflow: ellipsis;
  237. display: -webkit-box;
  238. -webkit-line-clamp: 2;
  239. line-clamp: 2;
  240. -webkit-box-orient: vertical;
  241. white-space: normal;
  242. word-break: break-all;
  243. }
  244. }
  245. }
  246. .content-item-img {
  247. width: 0.5rem;
  248. height: 0.5rem;
  249. margin-right: 0.1rem;
  250. image {
  251. width: 100%;
  252. height: 100%;
  253. }
  254. }
  255. .content-item-number {
  256. font-size: 0.16rem;
  257. }
  258. .content-item-price {
  259. font-size: 0.14rem;
  260. width: 40%;
  261. text-align: right;
  262. }
  263. }
  264. }
  265. .remark-info {
  266. padding: 0.1rem;
  267. background-color: rgba($color: $primary-color, $alpha: 0.1);
  268. color: $primary-color;
  269. margin-top: 0.1rem;
  270. font-size: 0.12rem;
  271. }
  272. .table-bottom {
  273. margin-top: 0.2rem;
  274. display: flex;
  275. justify-content: end;
  276. button {
  277. width: 1rem;
  278. margin: 0;
  279. margin-right: 0.1rem;
  280. }
  281. }
  282. }
  283. }
  284. /deep/ .uni-scroll-view {
  285. &::-webkit-scrollbar {
  286. width: 0.06rem;
  287. height: 0.06rem;
  288. background-color: rgba($color: #000000, $alpha: 0);
  289. }
  290. &::-webkit-scrollbar-button {
  291. display: none;
  292. }
  293. &::-webkit-scrollbar-thumb {
  294. border-radius: 0.06rem;
  295. box-shadow: inset 0 0 0.06rem rgba(45, 43, 43, 0.45);
  296. background-color: #ddd;
  297. display: none;
  298. }
  299. &:hover::-webkit-scrollbar-thumb {
  300. display: block;
  301. }
  302. &::-webkit-scrollbar-track {
  303. background-color: transparent;
  304. }
  305. }
  306. .remark-wrap {
  307. width: 6rem;
  308. background-color: #fff;
  309. border-radius: 0.04rem;
  310. box-shadow: 0 0.01rem 0.12rem 0 rgba(0, 0, 0, 0.1);
  311. .header,
  312. .footer {
  313. height: 0.5rem;
  314. display: flex;
  315. align-items: center;
  316. justify-content: center;
  317. border-bottom: 0.01rem solid #e6e6e6;
  318. position: relative;
  319. .title {
  320. font-size: 0.16rem;
  321. font-weight: bold;
  322. }
  323. .iconfont {
  324. line-height: 1;
  325. position: absolute;
  326. right: 0.15rem;
  327. font-size: 0.2rem;
  328. cursor: pointer;
  329. }
  330. }
  331. .body {
  332. padding: 0.15rem;
  333. textarea {
  334. border: 0.01rem solid #e6e6e6;
  335. width: 100%;
  336. padding: 0.1rem;
  337. box-sizing: border-box;
  338. font-size: 0.14rem;
  339. }
  340. .placeholder-class {
  341. font-size: 0.14rem;
  342. }
  343. }
  344. .footer {
  345. border-top: 0.01rem solid #e6e6e6;
  346. border-bottom: unset;
  347. button {
  348. width: 1rem;
  349. }
  350. }
  351. }
  352. .empty {
  353. text-align: center;
  354. padding-top: 1.2rem;
  355. image {
  356. width: 2rem;
  357. }
  358. .tips {
  359. color: #999;
  360. margin-top: 0.15rem;
  361. }
  362. }
  363. </style>