init
- 框架初始化 - 安装插件 - 修复PHP8.4报错
This commit is contained in:
56
application/admin/view/shopro/user/coupon/index.html
Normal file
56
application/admin/view/shopro/user/coupon/index.html
Normal file
@@ -0,0 +1,56 @@
|
||||
{include file="/shopro/common/script" /}
|
||||
|
||||
<div id="index" class="coupon-index panel panel-default panel-intro" v-cloak>
|
||||
<el-container class="panel-block">
|
||||
<el-header class="sa-header">
|
||||
<div class="sa-title sa-flex sa-row-between">
|
||||
<div class="sa-title-left">
|
||||
<div class="left-name">领取记录</div>
|
||||
<sa-filter-condition v-model="state.filter" @filter-delete="onChangeFilter">
|
||||
</sa-filter-condition>
|
||||
</div>
|
||||
<div class="sa-title-right">
|
||||
<el-button class="sa-button-refresh" icon="RefreshRight" @click="getData"></el-button>
|
||||
<el-button class="sa-button-refresh" icon="Search" @click="onOpenFilter"></el-button>
|
||||
</div>
|
||||
</div>
|
||||
</el-header>
|
||||
<el-main class="sa-main">
|
||||
<el-table height="100%" class="sa-table" :data="state.data" stripe @sort-change="onChangeSort">
|
||||
<el-table-column prop="id" label="ID" min-width="90" sortable="custom"> </el-table-column>
|
||||
<el-table-column label="用户信息" min-width="150">
|
||||
<template #default="scope">
|
||||
<sa-user-profile :user="scope.row.user" :id="scope.row.user_id"></sa-user-profile>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="status_text" label="使用状态" min-width="120">
|
||||
<template #default="scope">
|
||||
<div :class="`sa-color--${state.statusClass[scope.row.status]}`">
|
||||
{{ scope.row.status_text || '-' }}
|
||||
</div>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="有效期" min-width="320">
|
||||
<template #default="scope">
|
||||
{{scope.row.use_start_time}}~{{scope.row.use_end_time}}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="use_time" label="使用时间" min-width="172">
|
||||
<template #default="scope">
|
||||
{{scope.row.use_time || '-'}}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="order_sn" label="订单号" min-width="120">
|
||||
<template #default="scope">
|
||||
{{scope.row.order?.order_sn || '-'}}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="createtime" label="领取时间" min-width="172"></el-table-column>
|
||||
</el-table>
|
||||
</el-main>
|
||||
<el-footer class="sa-footer sa-flex sa-row-right">
|
||||
<sa-pagination v-model="pagination" @pagination-change="getData"></sa-pagination>
|
||||
</el-footer>
|
||||
</el-container>
|
||||
<sa-filter v-model="state.filter" @filter-change="onChangeFilter"></sa-filter>
|
||||
</div>
|
||||
377
application/admin/view/shopro/user/user/detail.html
Normal file
377
application/admin/view/shopro/user/user/detail.html
Normal file
@@ -0,0 +1,377 @@
|
||||
{include file="/shopro/common/script" /}
|
||||
|
||||
<style>
|
||||
.user-detail .title {
|
||||
height: 32px;
|
||||
line-height: 32px;
|
||||
font-size: 16px;
|
||||
color: var(--sa-subtitle);
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
|
||||
.user-detail .bottom {
|
||||
padding: 16px;
|
||||
background: var(--sa-table-header-bg);
|
||||
border-radius: 8px;
|
||||
margin-bottom: 20px;
|
||||
}
|
||||
|
||||
.user-detail .left {
|
||||
height: 12px;
|
||||
line-height: 12px;
|
||||
font-size: 12px;
|
||||
font-weight: 500;
|
||||
color: var(--sa-subfont);
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
|
||||
.user-detail .right {
|
||||
line-height: 32px;
|
||||
font-size: 14px;
|
||||
font-weight: 400;
|
||||
color: var(--sa-subtitle);
|
||||
}
|
||||
|
||||
.user-detail .info {
|
||||
padding: 16px 16px 0;
|
||||
background: var(--sa-background-assist);
|
||||
border-radius: 4px;
|
||||
}
|
||||
|
||||
.user-detail .info .el-col {
|
||||
margin-bottom: 16px;
|
||||
}
|
||||
|
||||
.user-detail .log .bottom {
|
||||
padding: 0;
|
||||
background: var(--sa-background-assist);
|
||||
}
|
||||
|
||||
.user-detail .el-tabs__nav-wrap::after {
|
||||
height: 0;
|
||||
}
|
||||
|
||||
.user-detail .third-oauth .provider-platform {
|
||||
flex-shrink: 0;
|
||||
width: 32px;
|
||||
height: 32px;
|
||||
}
|
||||
|
||||
.user-detail .third-oauth .provider-item {
|
||||
margin-bottom: 20px;
|
||||
}
|
||||
|
||||
.user-detail .third-oauth .provider-item:last-of-type {
|
||||
margin-bottom: 0;
|
||||
}
|
||||
</style>
|
||||
|
||||
<div id="detail" class="user-detail" v-cloak>
|
||||
<el-container class="panel-block">
|
||||
<el-main>
|
||||
<el-row :gutter="24">
|
||||
<el-col class="sa-col-24" :xs="24" :sm="24" :md="6" :lg="6" :xl="6">
|
||||
<div class="title">基本信息</div>
|
||||
<div class="bottom">
|
||||
<div class="sa-flex sa-row-between mb-3">
|
||||
<div class="sa-flex sa-flex-1">
|
||||
<sa-image :url="state.detail.avatar" size="64" radius="32"></sa-image>
|
||||
<div class="ml-4 sa-flex-1">
|
||||
<div class="nickname mb-1 sa-table-line-1">
|
||||
{{ state.detail.nickname }}
|
||||
</div>
|
||||
<div class="id">#{{ state.detail.id }}</div>
|
||||
</div>
|
||||
</div>
|
||||
{if $auth->check('shopro/user/user/edit')}
|
||||
<el-button type="primary" @click="onSelectAvatar">更换头像</el-button>
|
||||
{/if}
|
||||
</div>
|
||||
<div class="info">
|
||||
<el-row :gutter="24">
|
||||
<el-col :xs="24" :sm="12" :md="24" :lg="24" :xl="24">
|
||||
<div class="left">昵称</div>
|
||||
<div class="right">
|
||||
<el-input v-model="state.detail.nickname" />
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="24" :lg="24" :xl="24">
|
||||
<div class="left">性别</div>
|
||||
<div class="right">
|
||||
<el-radio-group v-model="state.detail.gender">
|
||||
<el-radio :label="0">女</el-radio>
|
||||
<el-radio :label="1">男</el-radio>
|
||||
</el-radio-group>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="24" :lg="24" :xl="24">
|
||||
<div class="left">用户名</div>
|
||||
<div class="right">
|
||||
<el-input v-model="state.detail.username" placeholder="首位需为字母且不少五位">
|
||||
<template #suffix>
|
||||
<span v-html="statusStyle('username')"></span>
|
||||
</template>
|
||||
</el-input>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="24" :lg="24" :xl="24">
|
||||
<div class="left">密码</div>
|
||||
<div class="right">
|
||||
<el-input v-model="state.detail.password" placeholder="不修改则留空">
|
||||
<template #suffix>
|
||||
<span v-html="statusStyle('password')"></span>
|
||||
</template>
|
||||
</el-input>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="24" :lg="24" :xl="24">
|
||||
<div class="left">手机号</div>
|
||||
<div class="right">
|
||||
<el-input v-model="state.detail.mobile" type="number">
|
||||
<template #suffix>
|
||||
<span v-html="statusStyle('mobile')"></span>
|
||||
</template>
|
||||
</el-input>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="24" :lg="24" :xl="24">
|
||||
<div class="left">电子邮箱</div>
|
||||
<div class="right">
|
||||
<el-input v-model="state.detail.email">
|
||||
<template #suffix>
|
||||
<span v-html="statusStyle('email')"></span>
|
||||
</template>
|
||||
</el-input>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="24" :lg="24" :xl="24">
|
||||
<div class="left">状态</div>
|
||||
<div class="right">
|
||||
<el-radio-group v-model="state.detail.status">
|
||||
<el-radio label="normal">正常</el-radio>
|
||||
<el-radio label="disabled">禁用</el-radio>
|
||||
</el-radio-group>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="24" :lg="24" :xl="24">
|
||||
<div class="label"></div>
|
||||
<div class="right sa-flex sa-row-right">
|
||||
<el-button @click="getDetail">重置</el-button>
|
||||
{if $auth->check('shopro/user/user/edit')}
|
||||
<el-button type="primary" @click="onSave">保存</el-button>
|
||||
{/if}
|
||||
</div>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</div>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col class="sa-col-24" :xs="24" :sm="24" :md="18" :lg="18" :xl="18">
|
||||
<el-row :gutter="24">
|
||||
<el-col class="sa-col-24" :xs="24" :sm="24" :md="12" :lg="12" :xl="12">
|
||||
<div class="title">账户信息</div>
|
||||
<div class="bottom">
|
||||
<div class="info">
|
||||
<el-row>
|
||||
<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
|
||||
<div class="left">推荐人</div>
|
||||
<div class="right sa-flex">
|
||||
<sa-user-profile type="agent" :user="state.detail.parent_user"
|
||||
:id="state.detail.parent_user_id"></sa-user-profile>
|
||||
{if $is_pro}
|
||||
<el-button class="ml-2" type="primary" link @click="onChangeParentUser">
|
||||
更换</el-button>
|
||||
{/if}
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
|
||||
<div class="left">佣金</div>
|
||||
<div class="right">{{ state.detail.commission }}</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
|
||||
<div class="left">余额</div>
|
||||
<div class="right sa-flex">
|
||||
{{ state.detail.money }}
|
||||
{if $auth->check('shopro/user/user/recharge')}
|
||||
<el-button class="ml-2" type="primary" link
|
||||
@click="onRecharge('money')">充值</el-button>
|
||||
{/if}
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
|
||||
<div class="left">上次登陆时间</div>
|
||||
<div class="right">{{ state.detail.logintime }}</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
|
||||
<div class="left">积分</div>
|
||||
<div class="right sa-flex">
|
||||
{{ state.detail.score }}
|
||||
{if $auth->check('shopro/user/user/recharge')}
|
||||
<el-button class="ml-2" type="primary" link
|
||||
@click="onRecharge('score')">充值</el-button>
|
||||
{/if}
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
|
||||
<div class="left">登录IP</div>
|
||||
<div class="right">{{ state.detail.loginip }}</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
|
||||
<div class="left">总计消费</div>
|
||||
<div class="right">
|
||||
{{ state.detail.total_consume }}
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
|
||||
<div class="left">注册时间</div>
|
||||
<div class="right">{{ state.detail.createtime }}</div>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</div>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col v-if="state.detail.third_oauth?.length>0" class="third-oauth sa-col-24" :xs="24"
|
||||
:sm="24" :md="12" :lg="12" :xl="12">
|
||||
<div class="title">第三方账号</div>
|
||||
<div class="bottom">
|
||||
<el-row class="info">
|
||||
<el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
|
||||
<div class="provider-item sa-flex sa-row-between"
|
||||
v-for="item in state.detail.third_oauth" :key="item.id">
|
||||
<div class="sa-flex">
|
||||
<img class="provider-platform"
|
||||
:src="`/assets/addons/shopro/img/user/${item.provider}/${item.platform}.png`" />
|
||||
<span class="ml-2">
|
||||
{{ platform[item.provider][item.platform] }}
|
||||
</span>
|
||||
</div>
|
||||
<el-popover popper-class="sa-popper" placement="top-start" trigger="hover">
|
||||
<div>
|
||||
<div class="item sa-flex">
|
||||
<div class="left">登录次数:</div>
|
||||
<div class="right">{{ item.login_num }}</div>
|
||||
</div>
|
||||
<div class="item sa-flex">
|
||||
<div class="left">Openid:</div>
|
||||
<div class="right">{{ item.openid }}</div>
|
||||
</div>
|
||||
<div v-if="item.unionid" class="item sa-flex">
|
||||
<div class="left">Unionid:</div>
|
||||
<div class="right">{{ item.unionid }}</div>
|
||||
</div>
|
||||
<div class="item sa-flex">
|
||||
<div class="left">更新时间:</div>
|
||||
<div class="right">{{ item.updatetime }}</div>
|
||||
</div>
|
||||
</div>
|
||||
<template #reference>
|
||||
<div class="sa-flex">
|
||||
<sa-image :url="item.avatar" size="32"></sa-image>
|
||||
<span class="name ml-2">
|
||||
{{ item.nickname }}
|
||||
</span>
|
||||
</div>
|
||||
</template>
|
||||
</el-popover>
|
||||
</div>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col class="log sa-col-24" :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
|
||||
<div class="title sa-flex"> 用户动态 </div>
|
||||
<div class="bottom">
|
||||
<el-tabs v-model="log.tabActive" @tab-change="onChangeTab">
|
||||
<el-tab-pane label="余额记录" name="money"></el-tab-pane>
|
||||
<el-tab-pane label="积分记录" name="score"></el-tab-pane>
|
||||
<el-tab-pane label="佣金记录" name="commission"></el-tab-pane>
|
||||
<el-tab-pane label="订单记录" name="order"></el-tab-pane>
|
||||
<el-tab-pane label="分享记录" name="share"></el-tab-pane>
|
||||
<el-tab-pane label="优惠券明细" name="coupon"></el-tab-pane>
|
||||
</el-tabs>
|
||||
<el-table
|
||||
v-if="log.tabActive=='money' || log.tabActive=='score' || log.tabActive=='commission'"
|
||||
height="520" class="sa-table" :data="log.data" stripe>
|
||||
<el-table-column prop="createtime" label="交易时间" width="172">
|
||||
</el-table-column>
|
||||
<el-table-column prop="amount" label="变动余额" min-width="120">
|
||||
</el-table-column>
|
||||
<el-table-column prop="before" label="变更前" min-width="120">
|
||||
</el-table-column>
|
||||
<el-table-column prop="after" label="剩余余额" min-width="120">
|
||||
</el-table-column>
|
||||
<el-table-column label="操作人" min-width="160">
|
||||
<template #default="scope">
|
||||
<sa-user-profile type="oper" :user="scope.row.oper" :id="scope.row.oper_id">
|
||||
</sa-user-profile>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="备注" min-width="160">
|
||||
<template #default="scope">
|
||||
{{ scope.row.event_text }}{{ scope.row.memo ? ':' + scope.row.memo : '' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
<el-table v-if="log.tabActive=='order'" height="520" class="sa-table" :data="log.data"
|
||||
stripe>
|
||||
<el-table-column prop="createtime" label="下单时间" min-width="172"></el-table-column>
|
||||
<el-table-column prop="order_sn" label="订单号" min-width="280"></el-table-column>
|
||||
<el-table-column prop="platform_text" label="订单来源" min-width="120">
|
||||
</el-table-column>
|
||||
<el-table-column prop="type_text" label="订单类型" min-width="100"></el-table-column>
|
||||
<el-table-column prop="order_amount" label="订单总金额" min-width="140">
|
||||
</el-table-column>
|
||||
<el-table-column prop="total_discount_fee" label="优惠减免" min-width="140">
|
||||
</el-table-column>
|
||||
<el-table-column prop="pay_fee" label="实付金额" min-width="140"></el-table-column>
|
||||
<el-table-column prop="status_text" label="订单状态" min-width="100"></el-table-column>
|
||||
</el-table>
|
||||
<el-table v-if="log.tabActive=='share'" height="520" class="sa-table" :data="log.data"
|
||||
stripe>
|
||||
<el-table-column prop="createtime" label="分享时间" width="172"></el-table-column>
|
||||
<el-table-column label="被分享用户" min-width="180">
|
||||
<template #default="scope">
|
||||
<sa-user-profile :user="scope.row.user" :id="scope.user_id">
|
||||
</sa-user-profile>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="from_text" label="分享类型" min-width="120"></el-table-column>
|
||||
<el-table-column label="分享信息" min-width="180" show-overflow-tooltip>
|
||||
<template #default="scope">
|
||||
<div v-if="scope.row.ext" class="sa-flex">
|
||||
<sa-image :url="scope.row.ext.image" size="32"></sa-image>
|
||||
<div class="sa-table-line-1 ml-2">{{ scope.row.ext.memo}}</div>
|
||||
</div>
|
||||
<div v-else>-</div>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="platform_text" label="平台" min-width="130"></el-table-column>
|
||||
</el-table>
|
||||
<el-table v-if="log.tabActive=='coupon'" height="520" class="sa-table" :data="log.data"
|
||||
stripe>
|
||||
<el-table-column label="优惠券名称" min-width="160">
|
||||
<template #default="scope">
|
||||
<div class="sa-line-1">{{ scope.row.coupon?.name || '-' }}</div>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="优惠券面额" min-width="120">
|
||||
<template #default="scope">
|
||||
<div class="sa-line-1">{{ scope.row.coupon?.amount || '-' }}</div>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="status_text" label="优惠券状态" min-width="120"></el-table-column>
|
||||
<el-table-column prop="createtime" label="领取时间" width="172"></el-table-column>
|
||||
<el-table-column prop="use_time" label="使用时间" width="172"></el-table-column>
|
||||
</el-table>
|
||||
<el-footer class="sa-flex sa-row-right">
|
||||
<sa-pagination v-model="pagination" @pagination-change="getLog">
|
||||
</sa-pagination>
|
||||
</el-footer>
|
||||
</div>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-col>
|
||||
</el-row>
|
||||
</el-main>
|
||||
</el-container>
|
||||
</div>
|
||||
56
application/admin/view/shopro/user/user/index.html
Normal file
56
application/admin/view/shopro/user/user/index.html
Normal file
@@ -0,0 +1,56 @@
|
||||
{include file="/shopro/common/script" /}
|
||||
|
||||
<div id="index" class="user-index panel panel-default panel-intro" v-cloak>
|
||||
<el-container class="panel-block">
|
||||
<el-header class="sa-header">
|
||||
<div class="sa-title sa-flex sa-row-between">
|
||||
<div class="sa-title-left">
|
||||
<div class="left-name">用户管理</div>
|
||||
<sa-filter-condition v-model="state.filter" @filter-delete="onChangeFilter">
|
||||
</sa-filter-condition>
|
||||
</div>
|
||||
<div class="sa-title-right">
|
||||
<el-button class="sa-button-refresh" icon="RefreshRight" @click="getData"></el-button>
|
||||
<el-button class="sa-button-refresh" icon="Search" @click="onOpenFilter"></el-button>
|
||||
</div>
|
||||
</div>
|
||||
</el-header>
|
||||
<el-main class="sa-main">
|
||||
<el-table height="100%" class="sa-table" :data="state.data" stripe @sort-change="onChangeSort">
|
||||
<el-table-column prop="id" label="ID" min-width="90" sortable="custom"> </el-table-column>
|
||||
<el-table-column label="用户信息" min-width="150">
|
||||
<template #default="scope">
|
||||
<sa-user-profile :user="scope.row" :id="scope.row.id"></sa-user-profile>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="username" label="用户名" min-width="120"></el-table-column>
|
||||
<el-table-column prop="mobile" label="手机号" min-width="120"></el-table-column>
|
||||
<el-table-column sortable="custom" prop="commission" label="佣金" min-width="110"></el-table-column>
|
||||
<el-table-column sortable="custom" prop="total_consume" label="总消费" min-width="110"></el-table-column>
|
||||
<el-table-column sortable="custom" prop="score" label="积分" min-width="110"></el-table-column>
|
||||
<el-table-column sortable="custom" prop="money" label="余额" min-width="110"></el-table-column>
|
||||
<el-table-column sortable="custom" prop="createtime" label="注册时间" min-width="172"></el-table-column>
|
||||
<el-table-column sortable="custom" prop="logintime" label="上次登录" min-width="172"></el-table-column>
|
||||
<el-table-column fixed="right" label="操作" min-width="120">
|
||||
<template #default="scope">
|
||||
{if $auth->check('shopro/user/user/detail')}
|
||||
<el-button type="primary" link @click="onDetail(scope.row.id)">查看</el-button>
|
||||
{/if}
|
||||
<el-popconfirm width="fit-content" confirm-button-text="确认" cancel-button-text="取消"
|
||||
title="确认删除这条记录?" @confirm="onDelete(scope.row.id)">
|
||||
<template #reference>
|
||||
{if $auth->check('shopro/user/user/delete')}
|
||||
<el-button type="danger" link>删除</el-button>
|
||||
{/if}
|
||||
</template>
|
||||
</el-popconfirm>
|
||||
</template>
|
||||
</el-table-column>
|
||||
</el-table>
|
||||
</el-main>
|
||||
<el-footer class="sa-footer sa-flex sa-row-right">
|
||||
<sa-pagination v-model="pagination" @pagination-change="getData"></sa-pagination>
|
||||
</el-footer>
|
||||
</el-container>
|
||||
<sa-filter v-model="state.filter" @filter-change="onChangeFilter"></sa-filter>
|
||||
</div>
|
||||
19
application/admin/view/shopro/user/user/recharge.html
Normal file
19
application/admin/view/shopro/user/user/recharge.html
Normal file
@@ -0,0 +1,19 @@
|
||||
{include file="/shopro/common/script" /}
|
||||
|
||||
<div id="recharge" class="user-recharge" v-cloak>
|
||||
<el-container class="panel-block">
|
||||
<el-main>
|
||||
<el-form ref="formRef" :model="form.model" :rules="form.rules" label-width="100px">
|
||||
<el-form-item :label="`充值${state.type == 'money' ? '金额' : '积分'}`" prop="amount">
|
||||
<el-input v-model="form.model.amount" type="number" placeholder="负数则为扣除" />
|
||||
</el-form-item>
|
||||
<el-form-item label="备注">
|
||||
<el-input v-model="form.model.memo"></el-input>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</el-main>
|
||||
<el-footer class="sa-footer--submit sa-flex sa-row-right">
|
||||
<el-button type="primary" @click="onConfirm">确定</el-button>
|
||||
</el-footer>
|
||||
</el-container>
|
||||
</div>
|
||||
53
application/admin/view/shopro/user/user/select.html
Normal file
53
application/admin/view/shopro/user/user/select.html
Normal file
@@ -0,0 +1,53 @@
|
||||
{include file="/shopro/common/script" /}
|
||||
|
||||
<style>
|
||||
.user-select .search {
|
||||
cursor: pointer;
|
||||
}
|
||||
</style>
|
||||
|
||||
<div id="select" class="user-select panel panel-default panel-intro" v-cloak>
|
||||
<el-container class="panel-block">
|
||||
<el-header class="sa-header pt-4 pb-0">
|
||||
<el-input v-model="state.filter.data.keyword" placeholder="请输入关键字" clearable>
|
||||
<template #append>
|
||||
<el-icon class="search" @click="onChangeFilter">
|
||||
<search></search>
|
||||
</el-icon>
|
||||
</template>
|
||||
</el-input>
|
||||
</el-header>
|
||||
<el-main>
|
||||
<el-table height="100%" class="sa-table" :data="state.data" stripe>
|
||||
<el-table-column width="48" align="center">
|
||||
<template #header="scope">
|
||||
<el-checkbox :model-value="state.isSelectAll" :indeterminate="state.isIndeterminate"
|
||||
@change="onSelectAll">
|
||||
</el-checkbox>
|
||||
</template>
|
||||
<template #default="scope">
|
||||
<el-checkbox :model-value="state.ids.includes(scope.row.id)"
|
||||
@change="onSelect($event, scope.row)">
|
||||
</el-checkbox>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="id" label="ID" min-width="90" sortable="custom"> </el-table-column>
|
||||
<el-table-column label="用户信息" min-width="150">
|
||||
<template #default="scope">
|
||||
<sa-user-profile :user="scope.row" :id="scope.row.id"></sa-user-profile>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="username" label="用户名" min-width="120"></el-table-column>
|
||||
<el-table-column prop="mobile" label="手机号" min-width="120"></el-table-column>
|
||||
<el-table-column sortable="custom" prop="commission" label="佣金" min-width="110"></el-table-column>
|
||||
<el-table-column sortable="custom" prop="total_consume" label="总消费" min-width="110"></el-table-column>
|
||||
<el-table-column sortable="custom" prop="score" label="积分" min-width="110"></el-table-column>
|
||||
<el-table-column sortable="custom" prop="money" label="余额" min-width="110"></el-table-column>
|
||||
</el-table>
|
||||
</el-main>
|
||||
<el-footer class="sa-footer--submit sa-flex sa-row-between sa-flex-wrap">
|
||||
<sa-pagination class="is-ellipsis" v-model="pagination" @pagination-change="getData"></sa-pagination>
|
||||
<el-button type="primary" :disabled="state.ids.length==0" @click="onConfirm">确定</el-button>
|
||||
</el-footer>
|
||||
</el-container>
|
||||
</div>
|
||||
Reference in New Issue
Block a user