comEdit.vue 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300
  1. <template>
  2. <view class="container">
  3. <u-navbar leftIconColor="#fff" titleStyle="color:#fff;fontSize:36rpx;" :autoBack="true" bgColor="#2C6FF3"
  4. :placeholder="true" title="商品编辑"></u-navbar>
  5. <swiper class="card-swiper round-dot" previous-margin="1rpx" :indicator-dots="false" :circular="true"
  6. :autoplay="true" interval="5000" duration="500" @change="cardSwiper" indicator-color="#ffffff"
  7. indicator-active-color="#ffffff" style="margin-top: 24rpx;">
  8. <swiper-item v-for="(item,index) in swiperList" :key="index" :class="cardCur == index ? 'cur':''">
  9. <view class="swiper-item shadow-shop" style="border-radius: 20rpx 20rpx 22rpx 22rpx;">
  10. <image :src="item" mode="aspectFill"></image>
  11. </view>
  12. </swiper-item>
  13. </swiper>
  14. <view class="content">
  15. <view class="xy-card">
  16. <view class="xy-list-item">
  17. <view>商品名称</view>
  18. <view>{{comDetail.goodsName}}</view>
  19. </view>
  20. <!-- <view class="xy-list-item">
  21. <view>可用机型</view>
  22. <view>{{comDetail.name}}</view>
  23. </view> -->
  24. <view class="xy-list-item">
  25. <view>商品条码</view>
  26. <view>{{comDetail.goodsBarcode}}</view>
  27. </view>
  28. <view class="xy-list-item">
  29. <view>商品尺寸</view>
  30. <view>{{comDetail.capacity}}</view>
  31. </view>
  32. <view class="xy-list-item">
  33. <view>所属分类</view>
  34. <view>{{comDetail.categoryCodeName||'其他'}}</view>
  35. </view>
  36. </view>
  37. <view class="xy-card">
  38. <u--form labelPosition="left" :model="form" :rules="rules" ref="form" errorType="toast">
  39. <u-form-item required labelWidth="90" label="进货价(元)" prop="priceCost" borderBottom ref="item1">
  40. <u--input type="digit" v-model="form.priceCost" border="none"></u--input>
  41. </u-form-item>
  42. <u-form-item required labelWidth="90" label="零售价(元)" prop="price" borderBottom ref="item1">
  43. <u--input type="digit" v-model="form.price" border="none"></u--input>
  44. </u-form-item>
  45. <!-- <u-form-item required labelWidth="90" label="单机容量" prop="capacity" borderBottom ref="item1">
  46. <u--input type="number" v-model="form.capacity" border="none"></u--input>
  47. </u-form-item> -->
  48. <u-form-item required labelWidth="90" label="库存预警" prop="warning" borderBottom ref="item1">
  49. <u--input type="number" v-model="form.warning" border="none"></u--input>
  50. </u-form-item>
  51. <u-form-item required labelWidth="90" label="上架状态" prop="warning" borderBottom ref="item1">
  52. <u-switch v-model="form.status"></u-switch>
  53. </u-form-item>
  54. </u--form>
  55. </view>
  56. </view>
  57. <view class="btn safe-bottom">
  58. <xbutton delay="1500" size="large" @click='submit'>保存</xbutton>
  59. </view>
  60. </view>
  61. </template>
  62. <script>
  63. import {
  64. searchObj,
  65. update
  66. } from "@/api/commodity/mercGoods.js"
  67. export default {
  68. data() {
  69. return {
  70. cardCur: 0,
  71. form: {
  72. price: undefined,
  73. warning: undefined,
  74. capacity: undefined,
  75. priceCost: undefined,
  76. status: true //上架状态
  77. },
  78. rules: {
  79. 'price': {
  80. type: 'number',
  81. required: true,
  82. message: '请输入商品价格~',
  83. trigger: ['blur', 'change']
  84. },
  85. 'warning': {
  86. type: 'number',
  87. required: true,
  88. message: '请输入预警值~',
  89. trigger: ['blur', 'change']
  90. },
  91. // 'capacity': {
  92. // type: 'number',
  93. // required: true,
  94. // message: '请输入容量~',
  95. // trigger: ['blur', 'change']
  96. // },
  97. 'priceCost': {
  98. type: 'number',
  99. required: true,
  100. message: '请输入商品进货价~',
  101. trigger: ['blur', 'change']
  102. },
  103. },
  104. show: false,
  105. actions: [{
  106. name: '全部',
  107. },
  108. {
  109. name: '饮料',
  110. },
  111. {
  112. name: '槟榔',
  113. },
  114. ],
  115. radio: '',
  116. switchVal: false,
  117. comDetail: null, //商品详情
  118. id: null,
  119. };
  120. },
  121. computed: {
  122. swiperList() {
  123. let imgArr = []
  124. if (this.comDetail) {
  125. imgArr = this.comDetail.imgUrls.split('|')
  126. }
  127. return imgArr
  128. }
  129. },
  130. onLoad(o) {
  131. this.id = o.id;
  132. this.getDetail(o.id)
  133. },
  134. methods: {
  135. getDetail(id) {
  136. searchObj({
  137. id: id
  138. }).then(res => {
  139. this.comDetail = res.data
  140. this.form = {
  141. "price": Number(res.data.price) / 100,
  142. "warning": res.data.warning,
  143. "capacity": res.data.capacity,
  144. "priceCost": Number(res.data.priceCost) / 100,
  145. "status": res.data.status == '1' ? true : false
  146. }
  147. })
  148. },
  149. cardSwiper(e) {
  150. this.cardCur = e.detail.current
  151. },
  152. // 下拉框点击事件
  153. showSelect(type) {
  154. if (type == 'class') {
  155. this.actions = [{
  156. name: '全部',
  157. },
  158. {
  159. name: '饮料',
  160. },
  161. {
  162. name: '槟榔',
  163. }
  164. ]
  165. } else {
  166. this.actions = [{
  167. name: '大瓶',
  168. },
  169. {
  170. name: '中瓶',
  171. },
  172. {
  173. name: '小瓶',
  174. }
  175. ]
  176. }
  177. this.show = true;
  178. },
  179. //表单提交
  180. submit() {
  181. this.$refs.form.validate().then(res => {
  182. this.form.id = this.id;
  183. let params = {
  184. id: this.id,
  185. price: this.form.price * 100,
  186. warning: this.form.warning,
  187. capacity: this.form.capacity,
  188. priceCost: this.form.priceCost * 100,
  189. status: this.form.status ? '1' : '0'
  190. }
  191. update(params).then(res => {
  192. this.$modal.msg('保存成功~')
  193. setTimeout(() => {
  194. this.$tab.navigateBack()
  195. }, 1000)
  196. })
  197. }).catch(errors => {})
  198. }
  199. },
  200. onReady() {
  201. setTimeout(() => {
  202. this.$refs.form.setRules(this.rules)
  203. }, 500)
  204. },
  205. };
  206. </script>
  207. <style scoped lang="scss">
  208. .container {
  209. .card-swiper {
  210. height: 350rpx !important;
  211. }
  212. .card-swiper swiper-item {
  213. width: 260upx !important;
  214. left: 245upx;
  215. box-sizing: border-box;
  216. padding: 0upx 15upx 50upx 15upx;
  217. overflow: initial;
  218. /* margin: 100rpx 0; */
  219. }
  220. .card-swiper swiper-item .swiper-item {
  221. width: 100%;
  222. display: block;
  223. height: 100%;
  224. border-radius: 6upx;
  225. transform: scale(0.7);
  226. transition: all 0.2s ease-in 0s;
  227. overflow: hidden;
  228. }
  229. .card-swiper swiper-item.cur .swiper-item {
  230. transform: none;
  231. transition: all 0.2s ease-in 0s;
  232. }
  233. .content {
  234. padding: 24rpx 24rpx 100rpx;
  235. .example-img {
  236. padding: 24rpx 24rpx 12rpx;
  237. display: flex;
  238. flex-flow: row nowrap;
  239. justify-content: space-between;
  240. >image {
  241. width: 100rpx;
  242. }
  243. }
  244. .img-upload {
  245. padding: 24rpx 24rpx 12rpx;
  246. }
  247. .xy-card {
  248. margin-bottom: 24rpx;
  249. }
  250. .xy-list-item {
  251. display: flex;
  252. flex-flow: row nowrap;
  253. justify-content: flex-start;
  254. border-bottom: 1upx solid #eee;
  255. line-height: 80rpx;
  256. >view:nth-child(1) {
  257. width: 180rpx;
  258. }
  259. >view:nth-child(2) {
  260. color: #666;
  261. font-size: 24rpx;
  262. }
  263. }
  264. }
  265. .btn {
  266. width: 100%;
  267. position: fixed;
  268. left: 0;
  269. bottom: 24rpx;
  270. padding: 0 24rpx;
  271. z-index: 999;
  272. }
  273. }
  274. </style>