package.vue 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. <template>
  2. <view>
  3. <z-text style="min-width: 300rpx;" arrow v-model="chooseContent" :placeholder="placeholder" @click="visible=true"></z-text>
  4. <z-slide-card title="选择套餐" :visible.sync="visible" @beforeClose="beforeClose" rightBtnText="确定" @rightClick="submit">
  5. <z-cell :label="item.packageName" v-for="(item,index) in list" :key="item.packageTypeCode" @click.native="changeChecked(item.packageTypeCode)">
  6. <view class="iconfont iconicon-test" v-if="item.checked"></view>
  7. </z-cell>
  8. </z-slide-card>
  9. </view>
  10. </template>
  11. <script>
  12. const app = getApp({
  13. allowDefault: true
  14. });
  15. export default {
  16. props: {
  17. value: String | Array,
  18. placeholder: String,
  19. //wedding就是婚庆
  20. type: {
  21. type: String,
  22. default: ''
  23. }
  24. },
  25. model: {
  26. prop: 'value',
  27. },
  28. data() {
  29. return {
  30. visible: false,
  31. list: [],
  32. checkedList: '',
  33. oldcheckedList: '',
  34. chooseContent: '',
  35. }
  36. },
  37. onBackPress() {
  38. if(this.visible) {
  39. this.visible = false;
  40. return true;
  41. }
  42. },
  43. watch: {
  44. value(newval, oldval) {
  45. this.oldcheckedList=newval;
  46. this.checkedList=newval;
  47. // var code = this.type == 'object' ? newval.dicCode : newval;
  48. var list = this.list.filter((item) => item.packageTypeCode == newval);
  49. //数据不存在时
  50. if (list.length == 0) {
  51. // this.$store.state.dicChange = true;
  52. if(this.type!='wedding')
  53. this.getData();
  54. else{
  55. this.getWedData();
  56. }
  57. }
  58. }
  59. },
  60. mounted() {
  61. if(this.type!='wedding')
  62. this.getData();
  63. else{
  64. this.getWedData();
  65. }
  66. },
  67. methods: {
  68. getData() {
  69. this.$axios.get("app/foodPackage/foodPackageListGeneralByStoreId/" + uni.getStorageSync('storeId')).then(res => {
  70. console.log('普通套餐类型', res)
  71. this.list = res.data.list;
  72. console.log(this.checkedList)
  73. var list = this.list.filter((item) => item.packageTypeCode == this.checkedList);
  74. if (list.length > 0) {
  75. this.changeChecked(list[0].packageTypeCode);
  76. this.chooseContent=list[0].packageName;
  77. }
  78. }).catch(err => {
  79. this.$message.error(err.msg);
  80. })
  81. },
  82. getWedData(){
  83. this.$axios.get("app/foodPackage/foodPackageListNoGeneralByStoreId/" + uni.getStorageSync('storeId')).then(res => {
  84. console.log('婚庆套餐类型', res)
  85. this.list = res.data.list;
  86. console.log(this.checkedList)
  87. var list = this.list.filter((item) => item.packageTypeCode == this.checkedList);
  88. if (list.length > 0) {
  89. this.changeChecked(list[0].packageTypeCode);
  90. this.chooseContent=list[0].packageName;
  91. }
  92. }).catch(err => {
  93. this.$message.error(err.msg);
  94. })
  95. },
  96. beforeClose() {
  97. console.log(this.oldcheckedList)
  98. this.checkedList=this.oldcheckedList;
  99. var checkedVal = '',checkedDetail='';
  100. this.chooseContent = '';
  101. for (var i = 0, len = this.list.length; i < len; i++) {
  102. this.list[i].checked = false;
  103. if (this.list[i].packageTypeCode==this.oldcheckedList) {
  104. this.chooseContent = this.list[i].packageName;
  105. checkedVal = this.list[i].packageTypeCode;
  106. checkedDetail=this.list[i];
  107. this.list[i].checked = true;
  108. }
  109. }
  110. this.$emit('change',checkedDetail);
  111. this.$emit('input', this.oldcheckedList);
  112. },
  113. changeChecked(id) {
  114. for (var i = 0, len = this.list.length; i < len; i++) {
  115. if (this.list[i].packageTypeCode == id) {
  116. this.list[i].checked = this.list[i].checked ? false : true;
  117. this.$set(this.list, i, this.list[i]);
  118. } else {
  119. this.list[i].checked = false;
  120. this.$set(this.list, i, this.list[i]);
  121. }
  122. }
  123. },
  124. submit(){
  125. var checkedVal = '',checkedDetail='';
  126. for (var i = 0, len = this.list.length; i < len; i++) {
  127. if (this.list[i].checked) {
  128. this.chooseContent = this.list[i].packageName;
  129. checkedVal = this.list[i].packageTypeCode;
  130. checkedDetail=this.list[i];
  131. break;
  132. } else {
  133. this.chooseContent = '';
  134. }
  135. }
  136. this.checkedList=checkedVal;
  137. this.$emit('input', checkedVal);
  138. this.$emit('change',checkedDetail);
  139. this.visible = false;
  140. }
  141. }
  142. }
  143. </script>
  144. <style lang="scss" scoped>
  145. .iconfont {
  146. color: #2481EE;
  147. }
  148. </style>