123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464 |
- <meta name="referrer" content="never">
- <link rel="stylesheet" href="__CDN__/assets/addons/shopro/libs/element/element.css">
- <style>
- #wechat-menu {
- height: 640px;
- background: #fff;
- border-radius: 6px;
- font-size: 14px;
- padding: 0 20px 20px;
- color: #444;
- }
- .menu-title {
- height: 50px;
- line-height: 50px;
- font-weight: 600;
- display: flex;
- align-items: center;
- justify-content: space-between;
- }
- .menu-body {
- height: 570px;
- background: #F2F2F6;
- border-radius: 6px;
- padding: 26px 20px;
- display: flex;
- }
- .body-left {
- width: 284px;
- height: 494px;
- background: #fff;
- border: 1px solid #E7E7EB;
- margin-right: 30px;
- padding-top: 444px;
- }
- .left-bottom {
- position: relative;
- height: 48px;
- display: flex;
- border-top: 1px solid #E7E7EB;
- }
- .left-tip {
- color: #999;
- height: 40px;
- line-height: 40px;
- text-align: center;
- }
- .menu-icon {
- width: 40px;
- border-right: 1px solid #E7E7EB;
- }
- .menu-item {
- flex: 1;
- display: flex;
- }
- .menu-item-add {
- flex: 1;
- }
- .menu-add-body {
- display: none;
- position: absolute;
- bottom: 60px;
- }
- .menu-item-add-2 {
- width: 82px;
- height: 44px;
- border: 1px solid #E7E7EB;
- border-bottom: none;
- line-height: 42px;
- text-align: center;
- color: #666;
- }
- .menu-item-add-2s {
- border-left: none;
- border-right: none;
- border-top: none;
- background: url('/assets/addons/shopro/img/wechat/add-btn.png');
- }
- .body-right {
- flex: 1;
- border-radius: 6px;
- }
- .body-right-content {
- background: #fff;
- height: 494px;
- }
- .right-title {
- height: 50px;
- line-height: 50px;
- border-bottom: #E7E7EB 1px solid;
- padding: 0 20px;
- display: flex;
- justify-content: space-between;
- }
- .frist-show {
- height: 100%;
- display: flex;
- justify-content: center;
- align-items: center;
- background: #fff;
- height: 494px;
- }
- .delete-btn {
- color: #E74C3C;
- }
- .select-body {
- padding: 20px 26px;
- }
- .display-flex {
- display: flex;
- justify-content: center;
- align-items: center;
- }
- .draggable-item {
- width: 82px;
- border-right: #E7E7EB 1px solid;
- }
- .menu-active {
- border: 1px solid #7438D5;
- color: #7438D5;
- }
- .menu-add-show {
- display: block;
- }
- i {
- font-size: 18px;
- }
- .el-form-item {
- margin-bottom: 20px;
- }
- .el-form-item__content {
- line-height: 34px;
- }
- .el-form-item__label {
- color: #444;
- padding-right: 30px;
- line-height: 34px;
- font-weight: 500;
- }
- .el-input__inner {
- height: 34px;
- line-height: 34px;
- flex: 1;
- }
- /* radio */
- .el-radio__inner:hover,
- .el-input__inner:hover,
- .el-radio__inner:focus,
- .el-input__inner:focus {
- border-color: #7438D5;
- }
- .el-radio__input.is-checked+.el-radio__label {
- color: #7438D5;
- }
- .el-radio__input.is-checked .el-radio__inner {
- border-color: #7438D5;
- background: #7438D5;
- }
- .cursor-pointer {
- cursor: pointer;
- }
- .save-item {
- display: flex;
- justify-content: flex-end;
- height: 50px;
- align-items: center;
- }
- .public-btn {
- width: 88px;
- height: 36px;
- line-height: 36px;
- text-align: center;
- color: #fff;
- background: #7438D5;
- border-radius: 18px;
- }
- .seve-btn {
- border: 1px solid #7438D5;
- margin-right: 30px;
- background: #F2F2F6;
- color: #7438D5;
- }
- .el-input {
- /* width: 400px; */
- flex: 1;
- }
- .select-tip {
- display: flex;
- align-items: center;
- }
- .tip {
- color: #999;
- font-size: 12px;
- }
- .select-url {
- width: 98px;
- height: 32px;
- line-height: 32px;
- text-align: center;
- background: #EAE4F5;
- border: 1px solid #B092E1;
- border-radius: 4px;
- margin-right: 30px;
- color: #7438D5;
- }
- .left-tip i {
- font-size: 8px !important;
- }
- .one-ellipsis {
- display: block;
- /* width: 130px; */
- overflow: hidden;
- text-overflow: ellipsis;
- white-space: nowrap;
- padding: 0 5px;
- }
- .el-select {
- width: 100%;
- }
- .el-select-dropdown__item.selected {
- color: #7438D5;
- }
- .ellipsis-item {
- overflow: hidden;
- text-overflow: ellipsis;
- white-space: nowrap;
- }
- [v-cloak] {
- display: none
- }
- </style>
- <script src="__CDN__/assets/addons/shopro/libs/vue.js"></script>
- <script src="__CDN__/assets/addons/shopro/libs/element/element.js"></script>
- <script src="__CDN__/assets/addons/shopro/libs/Sortable.min.js"></script>
- <script src="__CDN__/assets/addons/shopro/libs/vuedraggable.js"></script>
- <script src="__CDN__/assets/addons/shopro/libs/moment.js"></script>
- <div id="wechatMenu" v-cloak @click.stop="menuHide">
- <div class="menu-title">
- <div style="margin-right: 20px;">菜单名称</div>
- <el-input v-model="menuTitle" size="small" placeholder="请输入菜单名称"></el-input>
- </div>
- <div class="menu-body">
- <div class="body-left">
- <div class="left-bottom">
- <div class="menu-icon display-flex">
- <img src="/assets/addons/shopro/img/wechat/code.png">
- </div>
- <!-- 拖动组件 -->
- <draggable :list="menuData" v-bind="$attrs" class="menu-item" :options="{animation:100}">
- <div v-for="(item,index) in menuData" :key="index"
- class="draggable-item display-flex cursor-pointer" @click.stop="menuSelect(index,null)"
- :class="item.selected?'menu-active':''">
- <span v-if="item.sub_button.length>0" style="margin-right: 6px;">≡</span>{{item.name}}
- <div v-if="item.sub_button" class="menu-add-body" :class="item.show?'menu-add-show':''"
- :style="{'border-bottom':item.sub_button.length>=5?'1px solid #E7E7EB':'none'}">
- <div>
- <draggable :list="item.sub_button" v-bind="$attrs" :options="{animation:500}">
- <div class="menu-item-add-2 one-ellipsis" v-for="(it,idx) in item.sub_button"
- :key="idx" @click.stop="menuSelect(index,idx)"
- :class="it.selected?'menu-active':''">
- {{it.name}}
- </div>
- </draggable>
- <div class="menu-item-add-2 menu-item-add-2s cursor-pointer"
- v-if="item.sub_button.length<5" @click.stop="addMenu(index,2)">
- <i class="el-icon-plus"></i>
- </div>
- </div>
- </div>
- </div>
- <div class="menu-item-add display-flex cursor-pointer" v-if="menuData.length<3"
- @click.stop="addMenu(null,1)">
- <i class="el-icon-plus"></i>
- </div>
- </draggable>
- </div>
- <div class="left-tip">
- <i class="el-icon-rank margin-right-5" style="font-size: 8px;"></i>
- 可直接拖动菜单排序
- </div>
- </div>
- <div class="body-right">
- <div class="body-right-content" v-if="rightShow" @click.stop="menuShow">
- <div class="right-title">
- <div class="cursor-pointer">添加<span v-if="selectLevel==2">子</span>菜单</div>
- <div class="delete-btn cursor-pointer" @click.stop="delMenu()">
- 删除菜单
- </div>
- </div>
- <div class="select-body">
- <el-form ref="rightData" :model="rightData" label-width="106px">
- <el-form-item :label="selectLevel==2?'子菜单名称':'菜单名称'">
- <div class="select-tip">
- <el-input v-model="rightData.name" @keyup="limitLength()"></el-input>
- </div>
- </el-form-item>
- <el-form-item style="margin-top:-20px">
- <div class="select-tip">
- <div class="tip" v-if="selectLevel==1">菜单名称字数不多于4个汉字或8个字母</div>
- <div class="tip" v-if="selectLevel==2">菜单名称字数不多于8个汉字或16个字母</div>
- </div>
- </el-form-item>
- <div v-if="(selectLevel==1 && rightData.sub_button==0) || selectLevel==2">
- <el-form-item :label="selectLevel==2?'子页面内容':'页面内容'">
- <el-radio-group v-model="rightData.type" @change="changeRadio()">
- <el-radio label="view">跳转网页</el-radio>
- <el-radio label="miniprogram">跳转小程序</el-radio>
- <el-radio label="click">回复素材</el-radio>
- </el-radio-group>
- </el-form-item>
- <div v-if="rightData.type=='click'">
- <el-form-item label="消息类型">
- <el-radio-group v-model="rightData.media_type" @change="typeChange">
- <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="media_id" v-if="rightData.media_type">
- <div class="display-flex">
- <div style="flex: 1;">
- <el-select style="position: relative;" v-model="rightData.media_id"
- @change="selectChange">
- <el-option v-for="item in options" :key="item.media_id"
- :label="item.title" :value="item.media_id+''">
- <div class="display-flex">
- <img style="width: 30px;
- height: 30px;margin-right:20px"
- :src="Fast.api.cdnurl(item.thumb_url)"
- v-if="rightData.media_type!='voice' && rightData.media_type!='text' && rightData.media_type!='link'">
- <img style="width: 30px;
- height: 30px;margin-right:20px" :src="Fast.api.cdnurl(item.image)"
- v-if="rightData.media_type=='link'">
- <div class="ellipsis-item" style="width: 60px;"
- v-if="rightData.media_type=='text' || rightData.media_type=='link'">
- {{ item.media_id }}</div>
- <div class="ellipsis-item" style="width: 100px;">
- {{ item.title }}
- </div>
- <div class="ellipsis-item" style="flex: 1;"
- v-if="rightData.media_type!='text' && rightData.media_type!='link'">
- {{ item.media_id }}</div>
- <div class="ellipsis-item" style="flex: 1;"
- v-if="rightData.media_type=='text'">
- {{ item.thumb_url }}</div>
- </div>
- </el-option>
- <div class="text-center display-flex"
- style="position: sticky;background: #fff;height:32px;top:0;z-index:1;justify-content: center;">
- <el-pagination class="pagination" :page-sizes="[20]"
- :current-page="selectCurrentPage" :total="selectTotalPage"
- layout="total, prev, pager,next, jumper" pager-count="20"
- @size-change.stop="selectSizeChange"
- @current-change="selectCurrentChange" />
- </el-pagination>
- <div class="theme-color cursor-pointer" style="margin-left: 8px;"
- @click="getoptions">
- 跳转
- </div>
- </div>
- </el-select>
- </div>
- <div style="margin-left: 10px;cursor: pointer;color: #7438D5;"
- @click="createTemplate"
- v-if="rightData.media_type=='text' || rightData.media_type=='link'">创建</div>
- </div>
- </el-form-item>
- <el-form-item label=""
- v-if="rightData.media_type && rightData.media_type!='text' && rightData.media_type!='link'">
- <div style="color: #666;">如果没有数据,请去公众号添加</div>
- </el-form-item>
- </div>
- <el-form-item label="AppId" v-if="rightData.type=='miniprogram'">
- <el-input v-model="rightData.appid"></el-input>
- </el-form-item>
- <el-form-item label="小程序路径" v-if="rightData.type=='miniprogram'">
- <div class="select-tip">
- <el-input v-model="rightData.pagepath"></el-input>
- </div>
- </el-form-item>
- <el-form-item style="margin-top:-20px" v-if="rightData.type=='miniprogram'">
- <div class="select-tip">
- <div class="tip" v-if="rightData.type=='view'">点击该菜单会跳到页面链接</div>
- <div class="tip" v-if="rightData.type=='miniprogram'">小程序路径不可用时跳转页面链接</div>
- </div>
- </el-form-item>
- <el-form-item style="margin-top:-20px" v-if="rightData.type=='view'">
- <div class="select-tip">
- <div class="tip" v-if="rightData.type=='view'">点击该菜单会跳到页面链接</div>
- <div class="tip" v-if="rightData.type=='miniprogram'">小程序路径不可用时跳转页面链接</div>
- </div>
- </el-form-item>
- <el-form-item label="页面链接" v-if="rightData.type=='view' || rightData.type=='miniprogram'">
- <div class="select-tip">
- <el-input v-model="rightData.url"></el-input>
- </div>
- </el-form-item>
- <el-form-item v-if="rightData.type=='view' || rightData.type=='miniprogram'">
- <div class="select-tip">
- <div class="select-url cursor-pointer" @click.stop="choosePath">选择路径</div>
- <div>{{rightData.url_name}}</div>
- </div>
- </el-form-item>
- </div>
- </el-form>
- </div>
- </div>
- <div v-else class="frist-show">
- 点击左侧菜单进行编辑操作
- </div>
- <div class="save-item">
- <div class="public-btn seve-btn cursor-pointer" @click.stop="subData('save')">保存</div>
- <div class="public-btn cursor-pointer" @click.stop="subData('publish')">保存&发布</div>
- </div>
- </div>
- </div>
- </div>
|