- 框架初始化
 - 安装插件
 - 修复PHP8.4报错
This commit is contained in:
2025-04-19 17:21:20 +08:00
commit c6a4e1f5f6
5306 changed files with 967782 additions and 0 deletions

View File

@@ -0,0 +1,91 @@
{include file="/shopro/common/script" /}
<style>
.reply-form .keywords {
border: none;
border-radius: 12px;
margin-right: 12px;
margin-top: 12px;
}
.reply-form .keywords:last-of-type {
margin-right: 0;
}
.material-select .title {
width: 100px;
flex-shrink: 0;
}
.material-select .media_id {
flex: 1;
}
</style>
<div id="addEdit" class="reply-form" 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 v-if="form.model.group == 'keywords'" label="关键字" prop="keywords">
<div>
<el-input class="sa-w-360" v-model="keywords" placeholder="请输入关键字、空格确认"
@keyup.space="onAddKeywords(keywords)">
</el-input>
<el-scrollbar>
<div class="sa-flex">
<el-tag class="keywords" v-for="(tag,index) in form.model.keywords" :key="tag"
closable :disable-transitions="false" @close="onDeleteKeywords(index)">{{ tag }}
</el-tag>
</div>
</el-scrollbar>
</div>
</el-form-item>
<el-form-item label="类型" required>
<el-radio-group v-model="form.model.type" @change="onChangeType">
<el-radio label="news">图文消息</el-radio>
<el-radio label="image">图片</el-radio>
<el-radio label="video">视频</el-radio>
<el-radio label="voice">语音</el-radio>
<el-radio label="text">文本</el-radio>
<el-radio label="link">链接</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="回复内容" prop="content">
<el-select popper-class="material-select" v-model="form.model.content">
<el-option v-for="item in material.select" :key="item.media_id" :label="item.title"
:value="item.media_id + ''">
<div class="sa-flex">
<sa-image v-if="
item.type == 'news' ||
item.type == 'image' ||
item.type == 'video' ||
item.type == 'link'
" :url="item.thumb_url" size="30"></sa-image>
<div class="title ml-2 sa-table-line-1">
{{ item.title }}
</div>
<div class="media_id ml-2 sa-table-line-1">
{{ item.media_id }}
</div>
</div>
</el-option>
<sa-pagination class="is-ellipsis" v-model="material.pagination"
@pagination-change="getMaterialSelect">
</sa-pagination>
</el-select>
</el-form-item>
<el-form-item label="状态" required>
<el-radio-group v-model="form.model.status">
<el-radio label="enable">启用</el-radio>
<el-radio label="disabled">禁用</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>
</div>

View File

@@ -0,0 +1,106 @@
{include file="/shopro/common/script" /}
<style>
.reply-index .reply-main {
--el-main-padding: 0 20px;
}
.reply-index .card-wrap {
padding: 12px;
line-height: 1;
box-shadow: 0 1px 6px #5959591f;
border-radius: 8px;
border: 1px solid var(--sa-space);
margin-bottom: 24px;
}
.reply-index .card-wrap:hover {
box-shadow: 0 3px 12px #59595933;
transform: translateY(-4px);
}
.reply-index .card-wrap .item-type-text {
font-size: 12px;
color: var(--sa-subfont);
margin-bottom: 12px;
}
.reply-index .card-wrap .item-content {
height: 40px;
line-height: 20px;
word-break: break-all;
font-size: 12px;
color: var(--sa-subfont);
margin-bottom: 12px;
}
.reply-index .card-wrap .item-keywords {
border: none;
border-radius: 12px;
margin-right: 4px;
margin-bottom: 12px;
}
.reply-index .card-wrap .item-keywords:last-of-type {
margin-right: 0;
}
</style>
<div id="index" class="reply-index panel panel-default panel-intro" v-cloak>
<el-container class="panel-block">
<el-header class="sa-header">
<el-tabs class="sa-tabs" v-model="state.group" @tab-change="getData">
<el-tab-pane label="关键字回复" name="keywords"></el-tab-pane>
<el-tab-pane label="关注回复" name="subscribe"></el-tab-pane>
<el-tab-pane label="默认回复" name="default"></el-tab-pane>
</el-tabs>
<div class="sa-title sa-flex sa-row-between">
<div class="sa-title-left">
<div class="left-name">自动回复</div>
</div>
<div class="sa-title-right">
<el-button class="sa-button-refresh" icon="RefreshRight" @click="getData"></el-button>
{if $auth->check('shopro/wechat/reply/add')}
<el-button icon="Plus" type="primary" @click="onAdd">添加</el-button>
{/if}
</div>
</div>
</el-header>
<el-main class="reply-main">
<el-row :gutter="16">
<el-col v-for="item in state.data" :key="item" :xs="12" :sm="8" :md="6" :lg="4" :xl="4">
<div class="card-wrap">
<div class="item-type-text">{{ item.type_text }}</div>
<div class="item-content sa-line-2">{{ item.content }}</div>
<el-scrollbar v-if="state.group=='keywords'">
<div class="sa-flex">
<el-tag class="item-keywords" v-for="keyword in item.keywords">{{keyword}}</el-tag>
</div>
</el-scrollbar>
<div class="sa-flex sa-row-between">
<el-tooltip effect="dark" :content="item.status_text" placement="top-start">
{if $auth->check('shopro/wechat/reply/edit')}
<el-switch v-model="item.status" active-value="enable" inactive-value="disabled"
@change="onChangeStatus(item)"></el-switch>
{/if}
</el-tooltip>
<div class="sa-flex">
{if $auth->check('shopro/wechat/reply/edit')}
<el-button type="primary" link @click="onEdit(item.id)">编辑</el-button>
{/if}
<el-popconfirm width="fit-content" confirm-button-text="确认" cancel-button-text="取消"
title="确认删除这条记录?" @confirm="onDelete(item.id)">
<template #reference>
{if $auth->check('shopro/wechat/reply/delete')}
<el-button type="danger" link>删除</el-button>
{/if}
</template>
</el-popconfirm>
</div>
</div>
</div>
</el-col>
</el-row>
</el-main>
</el-container>
</div>