SelectShop.blade.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. <template id="selectShop">
  2. <div >
  3. <el-dialog center title="选择商品" :visible.sync="selectMemberVisible" width="50%" @close="close">
  4. <div style="display:flex;width: 95%;">
  5. <el-input placeholder="商品信息" v-model="search.keyword"></el-input>
  6. <el-button type="primary" style="margin-left:10px" @click="searchShop">搜索</el-button>
  7. </div>
  8. <el-table :data="tableData" style="width: 100%;height: 500px;overflow-y: auto;">
  9. <el-table-column align="center" prop="id" label="ID">
  10. </el-table-column>
  11. <el-table-column align="left" label="商品信息" width="700px">
  12. <template slot-scope="scope">
  13. <img :src="scope.row.thumb" alt="" style="width:50px;height:50px">
  14. <span>[[scope.row.title]]</span>
  15. </template>
  16. </el-table-column>
  17. <el-table-column align="center" label="操作">
  18. <template slot-scope="scope">
  19. <el-button plain @click="select(scope.row)">选择</el-button>
  20. </template>
  21. </el-table-column>
  22. </el-table>
  23. <el-pagination layout="prev, pager, next" :total="total" :page-size="pageSize" :current-page="page" @current-change="getShopList">
  24. </el-pagination>
  25. </el-dialog>
  26. </div>
  27. </template>
  28. <link rel="stylesheet" type="text/css" href="{{static_url('yunshop/goods/vue-goods1.css')}}" />
  29. <link rel="stylesheet" href="{{static_url('css/public-number.css')}}">
  30. <script>
  31. Vue.component('selectShop',{
  32. template: '#selectShop',
  33. delimiters: ['[[', ']]'],
  34. props:{
  35. selectMemberVisible: {
  36. type: Boolean,
  37. default: false
  38. },
  39. selectCouponType: {
  40. type: String,
  41. default: ""
  42. }
  43. },
  44. components: {
  45. },
  46. data() {
  47. return {
  48. search:{
  49. keyword:""
  50. },
  51. tableData: [],
  52. oneShow:false,
  53. total:1,
  54. pageSize:15,
  55. page:1
  56. };
  57. },
  58. computed: {
  59. },
  60. created(){
  61. },
  62. mounted(){
  63. },
  64. methods: {
  65. select(item){
  66. this.$emit('select-good',item)
  67. },
  68. close(){
  69. this.$emit('close')
  70. },
  71. searchShop(){
  72. this.$http.post('{!! yzWebFullUrl("plugin.material-center.admin.material.getSearchGoods") !!}',{keyword:this.search.keyword,page:this.page,pageSize:this.pageSize}).then(({data}) =>{
  73. if(data.result) {
  74. this.$message.success(data.msg);
  75. this.tableData = data.data.goods.data
  76. this.page = data.data.goods.current_page
  77. this.total =data.data.goods.total
  78. }else {
  79. this.$message.error(data.msg);
  80. }
  81. }, (response) => {
  82. console.log(response);
  83. });
  84. },
  85. getShopList(page){
  86. this.page = page
  87. this.searchShop()
  88. },
  89. }
  90. });
  91. </script>
  92. <style lang="scss" rel="stylesheet/scss" scoped>
  93. /deep/.vue-page {
  94. margin-top: 20px;
  95. }
  96. </style>