index.html 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. {include file="/shopro/common/script" /}
  2. <style>
  3. .goods-index .goods-item .goods-title {
  4. height: 20px;
  5. line-height: 20px;
  6. font-size: 14px;
  7. font-weight: 500;
  8. color: var(--sa-font);
  9. }
  10. .goods-index .goods-item .goods-subtitle {
  11. height: 16px;
  12. line-height: 16px;
  13. font-size: 12px;
  14. font-weight: 400;
  15. color: var(--sa-subfont);
  16. margin-bottom: 6px;
  17. }
  18. .goods-index .goods-item .goods-sku {
  19. width: fit-content;
  20. height: 18px;
  21. line-height: 18px;
  22. background: var(--el-color-primary);
  23. border-radius: 10px;
  24. padding: 0 8px;
  25. font-size: 12px;
  26. color: var(--sa-background-assist);
  27. }
  28. </style>
  29. <div id="index" class="goods-index panel panel-default panel-intro" v-cloak>
  30. <el-container class="panel-block">
  31. <el-header class="sa-header">
  32. <div class="sa-title sa-flex sa-row-between">
  33. <div class="sa-title-left">
  34. <div class="left-name">分销商品</div>
  35. <sa-filter-condition v-model="state.filter" @filter-delete="onChangeFilter">
  36. </sa-filter-condition>
  37. </div>
  38. <div class="sa-title-right">
  39. <el-button class="sa-button-refresh" icon="RefreshRight" @click="getData"></el-button>
  40. <el-button class="sa-button-refresh" icon="Search" @click="onOpenFilter"></el-button>
  41. </div>
  42. </div>
  43. </el-header>
  44. <el-main class="sa-main">
  45. <el-table height="100%" class="sa-table" :data="state.data" stripe @selection-change="onChangeSelection">
  46. <el-table-column type="selection" width="48"></el-table-column>
  47. <el-table-column prop="id" label="ID" min-width="90"></el-table-column>
  48. <el-table-column label="商品信息" min-width="300">
  49. <template #default="scope">
  50. <div class="goods-item sa-flex sa-col-top">
  51. <sa-image class="mr-2" :url="scope.row.image" size="64"></sa-image>
  52. <div>
  53. <div class="goods-title sa-table-line-1">{{scope.row.title}}</div>
  54. <div class="goods-subtitle sa-table-line-1">{{scope.row.subtitle}}</div>
  55. <div v-if="scope.row.is_sku==1" class="goods-sku">多规格</div>
  56. </div>
  57. </div>
  58. </template>
  59. </el-table-column>
  60. <el-table-column label="价格" min-width="150">
  61. <template #default="scope">
  62. <div>{{ scope.row.price?.join('~') || 0 }}</div>
  63. </template>
  64. </el-table-column>
  65. <el-table-column label="分销规则" width="100">
  66. <template #default="scope">
  67. <template v-if="scope.row.commission_goods && scope.row.commission_goods.status == 1">
  68. <template v-if="scope.row.commission_goods.self_rules == 0">默认规则</template>
  69. <template v-if="scope.row.commission_goods.self_rules == 1">独立规则</template>
  70. <template v-if="scope.row.commission_goods.self_rules == 2">批量规则</template>
  71. </template>
  72. <template v-else>-</template>
  73. </template>
  74. </el-table-column>
  75. <el-table-column label="商品状态" width="100">
  76. <template #default="scope">
  77. <span :class="`sa-color--${state.statusStyle[scope.row.status]}`">
  78. {{ scope.row.status_text }}
  79. </span>
  80. </template>
  81. </el-table-column>
  82. <el-table-column label="操作" min-width="140" fixed="right">
  83. <template #default="scope">
  84. <div class="sa-flex">
  85. <span class="mr-2"
  86. :class="`sa-color--${state.goodsStatusStyle[scope.row.commission_goods?.status] || 'info'}`">
  87. {{ scope.row.commission_goods?.status_text || '未参与' }}
  88. </span>
  89. {if $auth->check('shopro/commission/goods/edit')}
  90. <el-button type="primary" link @click="onEdit(scope.row.id)">设置佣金</el-button>
  91. {/if}
  92. </div>
  93. </template>
  94. </el-table-column>
  95. </el-table>
  96. </el-main>
  97. <el-footer class="sa-footer sa-flex sa-row-between sa-flex-wrap">
  98. <div class="sa-batch sa-flex">
  99. <div class="tip">
  100. 已选择 <span>{{batchHandle.data.length}}</span> 项</div>
  101. <div class="sa-flex">
  102. {if $auth->check('shopro/commission/goods/edit')}
  103. <el-button type="primary" :disabled="!batchHandle.data.length" @click="onBatchHandle('edit')">设置佣金
  104. </el-button>
  105. {/if}
  106. </div>
  107. </div>
  108. <sa-pagination v-model="pagination" @pagination-change="getData"></sa-pagination>
  109. </el-footer>
  110. </el-container>
  111. <sa-filter v-model="state.filter" @filter-change="onChangeFilter"></sa-filter>
  112. </div>