init
- 框架初始化 - 安装插件 - 修复PHP8.4报错
This commit is contained in:
248
application/admin/view/shopro/goods/comment/add.html
Normal file
248
application/admin/view/shopro/goods/comment/add.html
Normal file
@@ -0,0 +1,248 @@
|
||||
{include file="/shopro/common/script" /}
|
||||
|
||||
<style>
|
||||
.comment-form .sa-template-wrap .item {
|
||||
border-bottom: none
|
||||
}
|
||||
|
||||
.comment-form .goods-image {
|
||||
margin-right: 8px;
|
||||
}
|
||||
|
||||
.comment-form .goods-price {
|
||||
color: var(--el-color-danger);
|
||||
}
|
||||
|
||||
.comment-form .top {
|
||||
background: var(--sa-table-header-bg);
|
||||
padding: 20px 24px 0;
|
||||
font-size: 12px;
|
||||
color: #8c8c8c;
|
||||
}
|
||||
|
||||
.comment-form .top .el-col {
|
||||
margin-bottom: 20px;
|
||||
}
|
||||
|
||||
.comment-form .top .title {
|
||||
font-size: 14px;
|
||||
line-height: 18px;
|
||||
font-weight: 500;
|
||||
color: var(--sa-title);
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
|
||||
.comment-form .top .goods-title {
|
||||
color: var(--el-color-primary);
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
|
||||
.comment-form .left {
|
||||
flex-shrink: 0;
|
||||
}
|
||||
|
||||
.comment-form .bottom {
|
||||
margin: 32px 20px 0;
|
||||
}
|
||||
|
||||
.comment-form .avatar {
|
||||
margin-right: 12px;
|
||||
}
|
||||
|
||||
.comment-form .list {
|
||||
padding: 20px 0;
|
||||
border-bottom: 1px solid var(--sa-space);
|
||||
}
|
||||
|
||||
.comment-form .nickname {
|
||||
font-weight: 500;
|
||||
font-size: 12px;
|
||||
color: var(--sa-subfont);
|
||||
margin-bottom: 4px;
|
||||
}
|
||||
|
||||
.comment-form .reply-time {
|
||||
font-weight: 400;
|
||||
font-size: 12px;
|
||||
color: var(--sa-subfont);
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
|
||||
.comment-form .reply-content {
|
||||
color: var(--sa-subtitle);
|
||||
font-weight: 500;
|
||||
font-size: 12px;
|
||||
margin-bottom: 8px;
|
||||
}
|
||||
|
||||
.comment-form .list-image {
|
||||
margin-right: 8px;
|
||||
}
|
||||
|
||||
.comment-form .list-image:last-of-type {
|
||||
margin-right: 0;
|
||||
}
|
||||
</style>
|
||||
|
||||
<div id="addEdit" class="comment-form" v-cloak>
|
||||
<el-container v-if="state.type=='add'" class="panel-block">
|
||||
<el-main>
|
||||
<el-scrollbar height="100%">
|
||||
<el-form :model="form.model" :rules="form.rules" ref="formRef" label-width="100px">
|
||||
<el-form-item label="评价内容" prop="content">
|
||||
<el-input class="sa-w-360" v-model="form.model.content" autosize type="textarea"
|
||||
placeholder="请输入评价内容">
|
||||
</el-input>
|
||||
</el-form-item>
|
||||
<el-form-item label="评价图片">
|
||||
<sa-uploader v-model="form.model.images" :multiple="true"></sa-uploader>
|
||||
</el-form-item>
|
||||
<el-form-item label="评价星级" prop="level">
|
||||
<el-rate v-model="form.model.level"></el-rate>
|
||||
</el-form-item>
|
||||
<el-form-item label="评价用户" prop="user_id">
|
||||
<el-button v-if="!form.model.user_id" type="primary" link @click="onSelectFakeUser">
|
||||
选择虚拟用户
|
||||
</el-button>
|
||||
<div v-if="form.model.user_id" class="sa-template-wrap">
|
||||
<div class="item">
|
||||
<div class="key id">{{ state.fakeUserData?.id }}</div>
|
||||
<div class="key">{{ state.fakeUserData?.nickname }}</div>
|
||||
<div class="oper">
|
||||
<el-button type="danger" link @click="onDeleteFakeUser">
|
||||
移除
|
||||
</el-button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</el-form-item>
|
||||
<el-form-item label="商品选择" prop="goods_id">
|
||||
<el-button v-if="!form.model.goods_id" type="primary" link @click="onSelectGoods">选择商品
|
||||
</el-button>
|
||||
<div v-if="form.model.goods_id" class="sa-template-wrap">
|
||||
<div class="item">
|
||||
<div class="key id">{{ form.model.goods_id }}</div>
|
||||
<div class="key">
|
||||
<sa-image class="goods-image" :url="state.goodsData?.image" size="40"></sa-image>
|
||||
<div class="right">
|
||||
<div class="goods-title sa-table-line-1">
|
||||
{{ state.goodsData?.title }}
|
||||
</div>
|
||||
<div class="goods-price">
|
||||
¥{{ state.goodsData?.price.join('~') || 0 }}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div class="oper">
|
||||
<el-button type="danger" link @click="onDeleteGoods">移除</el-button>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</el-form-item>
|
||||
<el-form-item label="状态" prop="status">
|
||||
<el-radio-group v-model="form.model.status">
|
||||
<el-radio label="normal">显示</el-radio>
|
||||
<el-radio label="hidden">隐藏</el-radio>
|
||||
</el-radio-group>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</el-scrollbar>
|
||||
</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>
|
||||
<el-container v-if="state.type=='edit'" class="panel-block">
|
||||
<el-main>
|
||||
<el-row class="top" :gutter="10">
|
||||
<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
|
||||
<div class="title">评价信息</div>
|
||||
<div class="item sa-flex">
|
||||
<div class="left">用户昵称:</div>
|
||||
<div class="right">{{form.model.user?.nickname || form.model.user_id}}</div>
|
||||
</div>
|
||||
<div class="item sa-flex">
|
||||
<div class="left">评价星级:</div>
|
||||
<div class="right">
|
||||
<el-rate v-model="form.model.level" disabled></el-rate>
|
||||
</div>
|
||||
</div>
|
||||
<div class="item sa-flex">
|
||||
<div class="left">显示状态:</div>
|
||||
<div class="right">
|
||||
<el-radio-group v-model="form.model.status" @change="onChangeStatus">
|
||||
<el-radio label="normal">正常</el-radio>
|
||||
<el-radio label="hidden">隐藏</el-radio>
|
||||
</el-radio-group>
|
||||
</div>
|
||||
</div>
|
||||
</el-col>
|
||||
<el-col :xs="24" :sm="12" :md="12" :lg="12" :xl="12">
|
||||
<div class="title">商品信息</div>
|
||||
<div v-if="form.model.order_item" class="sa-flex">
|
||||
<sa-image class="mr-2" :url="form.model.order_item.goods_image" size="64"></sa-image>
|
||||
<div class="right">
|
||||
<div class="goods-title sa-table-line-1">
|
||||
{{ form.model.order_item.goods_title }}
|
||||
</div>
|
||||
<div class="sa-flex mb-2">
|
||||
<div class="left">单价:</div>
|
||||
<div class="right goods-num">{{ form.model.order_item.goods_price }}×{{
|
||||
form.model.order_item.goods_num }}</div>
|
||||
</div>
|
||||
<div v-if="form.model.order_item.goods_sku_text" class="sa-flex">
|
||||
<div class="left">规格:</div>
|
||||
<div class="right goods-num">{{ form.model.order_item.goods_sku_text }},</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<div v-else-if="form.model.goods" class="sa-flex">
|
||||
<sa-image class="mr-2" :url="form.model.goods.image" size="64"></sa-image>
|
||||
<div class="right">
|
||||
<div class="goods-title sa-table-line-1">{{form.model.goods.title}}</div>
|
||||
<div class="item sa-flex">
|
||||
<div class="left">单价:</div>
|
||||
<div class="right goods-num">
|
||||
{{form.model.goods.price.join(',')}}
|
||||
</div>
|
||||
</div>
|
||||
<div v-if="form.model.goods.sku_text" class="item sa-flex">
|
||||
<div class="left">规格:</div>
|
||||
<div class="right goods-num">{{form.model.goods.sku_text }}</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</el-col>
|
||||
</el-row>
|
||||
<div class="bottom">
|
||||
<div class="title sa-flex sa-row-between">
|
||||
<div>评价记录</div>
|
||||
{if $auth->check('shopro/goods/comment/reply')}
|
||||
<el-button v-if="!form.model.reply_time" type="primary" link @click="onReply">点击回复</el-button>
|
||||
{/if}
|
||||
</div>
|
||||
<div v-if="form.model.admin" class="list sa-flex sa-col-top">
|
||||
<sa-image class="avatar" :url="form.model.admin.avatar" size="48"></sa-image>
|
||||
<div>
|
||||
<div class="nickname">{{ form.model.admin.nickname }}</div>
|
||||
<div class="reply-time">{{ form.model.reply_time }}</div>
|
||||
<div class="reply-content">{{ form.model.reply_content }}</div>
|
||||
</div>
|
||||
</div>
|
||||
<div v-if="form.model.user" class="list sa-flex sa-col-top">
|
||||
<sa-image class="avatar" :url="form.model.user.avatar" size="48"></sa-image>
|
||||
<div>
|
||||
<div class="nickname">{{ form.model.user.nickname }}</div>
|
||||
<div class="reply-time">{{ form.model.createtime }}</div>
|
||||
<div class="reply-content">{{ form.model.content }}</div>
|
||||
<div class="sa-flex">
|
||||
<template v-for="item in form.model.images">
|
||||
<sa-image class="list-image" :url="item" size="48"></sa-image>
|
||||
</template>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</el-main>
|
||||
</el-container>
|
||||
</div>
|
||||
178
application/admin/view/shopro/goods/comment/index.html
Normal file
178
application/admin/view/shopro/goods/comment/index.html
Normal file
@@ -0,0 +1,178 @@
|
||||
{include file="/shopro/common/script" /}
|
||||
|
||||
<style>
|
||||
.comment-index .image {
|
||||
margin-right: 4px;
|
||||
}
|
||||
|
||||
.comment-index .goods-item .goods-image {
|
||||
margin-right: 8px;
|
||||
}
|
||||
|
||||
.comment-index .goods-item .goods-title {
|
||||
color: var(--el-color-primary);
|
||||
cursor: pointer;
|
||||
}
|
||||
</style>
|
||||
|
||||
<div id="index" class="comment-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>
|
||||
{if $auth->check('shopro/goods/comment/add')}
|
||||
<el-button plain @click="onAdd">添加虚拟评价</el-button>
|
||||
{/if}
|
||||
{if $auth->check('shopro/goods/comment/recyclebin')}
|
||||
<el-button type="danger" icon="Delete" plain @click="onRecyclebin">回收站</el-button>
|
||||
{/if}
|
||||
</div>
|
||||
</div>
|
||||
</el-header>
|
||||
<el-main class="sa-main">
|
||||
<el-table height="100%" class="sa-table" :data="state.data" stripe @selection-change="onChangeSelection">
|
||||
<el-table-column type="selection" width="48"></el-table-column>
|
||||
<el-table-column label="商品信息" min-width="310">
|
||||
<template #default="scope">
|
||||
<div v-if="scope.row.order_item" class="goods-item sa-flex">
|
||||
<sa-image class="goods-image" :url="scope.row.order_item.goods_image" size="40"></sa-image>
|
||||
<div class="right">
|
||||
<span class="goods-title sa-table-line-1"
|
||||
@click="onOpenGoodsDetail(scope.row.order_item.goods_id)">
|
||||
{{ scope.row.order_item.goods_title || '-' }}
|
||||
</span>
|
||||
<span v-if="scope.row.order" class="sa-table-line-1">
|
||||
订单号:{{ scope.row.order.order_sn }}
|
||||
<el-icon class="copy-document" @click="onClipboard(scope.row.order.order_sn)">
|
||||
<copy-document />
|
||||
</el-icon>
|
||||
</span>
|
||||
<span v-else>订单号:-</span>
|
||||
</div>
|
||||
</div>
|
||||
<div v-else-if="scope.row.goods" class="goods-item sa-flex">
|
||||
<sa-image class="goods-image" :url="scope.row.goods.image" size="40"></sa-image>
|
||||
<div class="right">
|
||||
<span class=" goods-title sa-table-line-1"
|
||||
@click="onOpenGoodsDetail(scope.row.goods.id)">
|
||||
{{ scope.row.goods.title || '-' }}
|
||||
</span>
|
||||
<span>虚拟评价</span>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="用户信息" min-width="96" align="center">
|
||||
<template #default="scope">
|
||||
<sa-user-profile :user="scope.row.user" :id="scope.row.user_id" mode="col"
|
||||
:ishover="scope.row.user_type != 'fake_user'"></sa-user-profile>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="评价星级" min-width="146">
|
||||
<template #default="scope">
|
||||
<el-rate v-model="scope.row.level" disabled></el-rate>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="评价图片" width="200">
|
||||
<template #default="scope">
|
||||
<el-scrollbar>
|
||||
<div class="sa-flex">
|
||||
<template v-for="item in scope.row.images" :key="item">
|
||||
<sa-image class="image" :url="item" size="30"></sa-image>
|
||||
</template>
|
||||
</div>
|
||||
</el-scrollbar>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="评价内容" min-width="162">
|
||||
<template #default="scope">
|
||||
<div class="sa-table-line-1">
|
||||
{{ scope.row.content || '-' }}
|
||||
</div>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="评价时间" width="172">
|
||||
<template #default="scope">
|
||||
{{ scope.row.createtime || '-' }}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column label="显示状态" min-width="130">
|
||||
<template #default="scope">
|
||||
{if $auth->check('shopro/goods/comment/edit')}
|
||||
<el-dropdown @command="onCommand">
|
||||
<el-button link>
|
||||
<el-tag :type="scope.row.status == 'normal' ? 'success' : 'info'">
|
||||
{{ scope.row.status_text }}
|
||||
<el-icon>
|
||||
<arrow-down />
|
||||
</el-icon>
|
||||
</el-tag>
|
||||
</el-button>
|
||||
<template #dropdown>
|
||||
<el-dropdown-menu>
|
||||
<el-dropdown-item :command="{
|
||||
id: scope.row.id,
|
||||
type: 'normal',
|
||||
}">
|
||||
<span class="status-normal">正常</span>
|
||||
</el-dropdown-item>
|
||||
<el-dropdown-item :command="{
|
||||
id: scope.row.id,
|
||||
type: 'hidden',
|
||||
}">
|
||||
<span class="status-hidden">隐藏</span>
|
||||
</el-dropdown-item>
|
||||
</el-dropdown-menu>
|
||||
</template>
|
||||
</el-dropdown>
|
||||
{/if}
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column fixed="right" label="操作" min-width="120">
|
||||
<template #default="scope">
|
||||
{if $auth->check('shopro/goods/comment/edit')}
|
||||
<el-button type="primary" link @click="onEdit(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/goods/comment/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-between sa-flex-wrap">
|
||||
<div class="sa-batch sa-flex">
|
||||
<div class="tip">
|
||||
已选择 <span>{{batchHandle.data.length}}</span> 项</div>
|
||||
<div class="sa-flex">
|
||||
{if $auth->check('shopro/goods/comment/delete')}
|
||||
<el-button type="danger" :disabled="!batchHandle.data.length" @click="onBatchHandle('delete')">删除
|
||||
</el-button>
|
||||
{/if}
|
||||
{if $auth->check('shopro/goods/comment/edit')}
|
||||
<el-button type="success" :disabled="!batchHandle.data.length" @click="onBatchHandle('normal')">正常
|
||||
</el-button>
|
||||
{/if}
|
||||
{if $auth->check('shopro/goods/comment/edit')}
|
||||
<el-button type="info" :disabled="!batchHandle.data.length" @click="onBatchHandle('hidden')">隐藏
|
||||
</el-button>
|
||||
{/if}
|
||||
</div>
|
||||
</div>
|
||||
<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>
|
||||
54
application/admin/view/shopro/goods/comment/recyclebin.html
Normal file
54
application/admin/view/shopro/goods/comment/recyclebin.html
Normal file
@@ -0,0 +1,54 @@
|
||||
{include file="/shopro/common/script" /}
|
||||
|
||||
<div id="recyclebin" class="comment-recyclebin panel panel-default panel-intro" v-cloak>
|
||||
<el-container class="panel-block">
|
||||
<el-main>
|
||||
<el-table height="100%" class="sa-table" :data="state.data" stripe @selection-change="onChangeSelection"
|
||||
@sort-change="onChangeSort">
|
||||
<el-table-column type="selection" width="48" align="center"></el-table-column>
|
||||
<el-table-column prop="id" label="ID" width="90" sortable="custom"></el-table-column>
|
||||
<el-table-column label="名称" min-width="100">
|
||||
<template #default="scope">
|
||||
<div class="sa-table-line-1">{{ scope.row.content || '-' }}</div>
|
||||
</template>
|
||||
</el-table-column>
|
||||
<el-table-column prop="deletetime" label="删除时间" width="172" sortable="custom"></el-table-column>
|
||||
<el-table-column fixed="right" label="操作" min-width="120">
|
||||
<template #default="scope">
|
||||
{if $auth->check('shopro/goods/comment/restore')}
|
||||
<el-button type="primary" link @click="onRestore(scope.row.id)">还原</el-button>
|
||||
{/if}
|
||||
<el-popconfirm width="fit-content" confirm-button-text="确认" cancel-button-text="取消"
|
||||
title="确认销毁这条记录?" @confirm="onDestroy(scope.row.id)">
|
||||
<template #reference>
|
||||
{if $auth->check('shopro/goods/comment/destroy')}
|
||||
<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-between sa-flex-wrap">
|
||||
<div class="sa-batch sa-flex">
|
||||
<div class="tip">
|
||||
已选择 <span>{{batchHandle.data.length}}</span> 项</div>
|
||||
<div class="sa-flex">
|
||||
{if $auth->check('shopro/goods/comment/restore')}
|
||||
<el-button type="primary" :disabled="!batchHandle.data.length" @click="onBatchHandle('restore')">还原
|
||||
</el-button>
|
||||
{/if}
|
||||
{if $auth->check('shopro/goods/comment/destroy')}
|
||||
<el-button type="danger" :disabled="!batchHandle.data.length" @click="onBatchHandle('destroy')">销毁
|
||||
</el-button>
|
||||
{/if}
|
||||
{if $auth->check('shopro/goods/comment/destroy')}
|
||||
<el-button type="danger" @click="onBatchHandle('all')">清空回收站</el-button>
|
||||
{/if}
|
||||
</div>
|
||||
</div>
|
||||
<sa-pagination class="is-ellipsis" v-model="pagination" @pagination-change="getData"></sa-pagination>
|
||||
</el-footer>
|
||||
</el-container>
|
||||
</div>
|
||||
18
application/admin/view/shopro/goods/comment/reply.html
Normal file
18
application/admin/view/shopro/goods/comment/reply.html
Normal file
@@ -0,0 +1,18 @@
|
||||
{include file="/shopro/common/script" /}
|
||||
|
||||
<div id="reply" class="comment-reply" v-cloak>
|
||||
<el-container class="panel-block">
|
||||
<el-main>
|
||||
<el-scrollbar height="100%">
|
||||
<el-form :model="form.model" :rules="form.rules" ref="formRef" label-width="100px">
|
||||
<el-form-item label="回复内容" prop="content">
|
||||
<el-input class="sa-w-360" v-model="form.model.content" placeholder="请输入回复内容"></el-input>
|
||||
</el-form-item>
|
||||
</el-form>
|
||||
</el-scrollbar>
|
||||
</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>
|
||||
Reference in New Issue
Block a user