zq-checkTable #69

Merged
pengda merged 3 commits from zq-checkTable into master 4 months ago
  1. 7413
      package-lock.json
  2. 1
      package.json
  3. 1
      src/assets/site/form_close.svg
  4. 1
      src/assets/site/open_success.svg
  5. 1
      src/assets/site/open_success_menu.svg
  6. 5
      src/components/GuipRadio.vue
  7. 2
      src/components/GuipSwitch.vue
  8. 75
      src/components/paymentMethod.vue
  9. 13
      src/views/Register.vue
  10. 289
      src/views/agent/siteServiceAdd.vue
  11. 252
      src/views/agent/siteServiceList.vue

7413
package-lock.json

File diff suppressed because it is too large

1
package.json

@ -16,6 +16,7 @@
"vue": "^2.6.14", "vue": "^2.6.14",
"vue-clickaway": "^2.2.2", "vue-clickaway": "^2.2.2",
"vue-router": "^3.5.1", "vue-router": "^3.5.1",
"vuedraggable": "^2.24.3",
"vuex": "^3.6.2" "vuex": "^3.6.2"
}, },
"devDependencies": { "devDependencies": {

1
src/assets/site/form_close.svg

File diff suppressed because one or more lines are too long

After

Width:  |  Height:  |  Size: 5.9 KiB

1
src/assets/site/open_success.svg

@ -0,0 +1 @@
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="16" height="16" viewBox="0 0 16 16"><g><g><rect x="0" y="0" width="16" height="16" rx="8" fill="#00C261" fill-opacity="1"/></g><g><g><path d="M10.955277385177613,5.969208108535766L10.577137385177611,5.651911108535766C10.368257385177612,5.476809108535766,10.056967385177613,5.5040010085357665,9.881597385177614,5.712668108535767L7.219187385177612,8.883847108535766L6.016827385177613,7.848977108535767C5.8134663851776125,7.673937108535767,5.507526385177612,7.693407108535767,5.327981385177612,7.8928071085357665L4.996776385177612,8.260647108535768C4.994662385177612,8.262997108535767,4.9925723851776125,8.265367108535767,4.990504385177612,8.267747108535767C4.812006185177612,8.473817108535766,4.834351685177612,8.785557108535766,5.040414385177613,8.964057108535766L7.004127385177613,10.665087108535767C7.006667385177613,10.667287108535767,7.009227385177612,10.669467108535766,7.011817385177612,10.671617108535767C7.221487385177612,10.845867108535767,7.532717385177612,10.817157108535767,7.706957385177612,10.607487108535768L7.831547385177613,10.457577108535766L11.016017385177612,6.664557108535766L11.016207385177612,6.664537108535766C11.191447385177613,6.455699108535766,11.164207385177612,6.144346108535767,10.955277385177613,5.969208108535766Z" fill-rule="evenodd" fill="#FFFFFF" fill-opacity="1"/></g></g></g></svg>

After

Width:  |  Height:  |  Size: 1.4 KiB

1
src/assets/site/open_success_menu.svg

@ -0,0 +1 @@
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" fill="none" version="1.1" width="20" height="14" viewBox="0 0 20 14"><g><rect x="0" y="0" width="20" height="14" rx="7" fill="#00C261" fill-opacity="1"/><g><path d="M13.5388,5.123347472229004Q13.612210000000001,5.031587472229004,13.6511,4.920702472229004Q13.690000000000001,4.809817472229004,13.690000000000001,4.692307472229004Q13.690000000000001,4.6243483722290035,13.676739999999999,4.557695472229004Q13.66348,4.4910414722290035,13.63748,4.4282554722290035Q13.61147,4.365470472229004,13.57371,4.308964472229004Q13.53596,4.252458472229004,13.4879,4.204403472229004Q13.43985,4.156349472229004,13.38334,4.118593472229004Q13.32684,4.080837472229004,13.264050000000001,4.054830472229004Q13.201260000000001,4.0288234722290035,13.13461,4.015565472229004Q13.06796,4.002307472229004,13,4.002307472229004Q12.84279,4.002307472229004,12.7011,4.070408472229004Q12.55941,4.1385094722290034,12.4612,4.261268472229004L12.459399999999999,4.259826472229004L9.19957,8.334607472229004L7.432481,6.920937472229004L7.43104,6.922737472229004Q7.3392800000000005,6.849327472229004,7.228395,6.810437472229004Q7.11751,6.771537472229004,7,6.771537472229004Q6.9320409,6.771537472229004,6.865388,6.784797472229004Q6.798734,6.798057472229004,6.735948,6.824057472229004Q6.673163,6.850067472229004,6.616657,6.887827472229004Q6.560151,6.925577472229004,6.512096,6.973637472229004Q6.464042,7.021687472229004,6.426286,7.078197472229004Q6.38853,7.1346974722290035,6.362523,7.197487472229004Q6.336516,7.260277472229004,6.323258,7.326927472229004Q6.3100000000000005,7.393577472229004,6.3100000000000005,7.461537472229004Q6.3100000000000005,7.618747472229003,6.378101,7.760437472229004Q6.4462019999999995,7.9021274722290045,6.56896,8.000337472229004L6.567519,8.002137472229004L8.87521,9.848297472229003Q8.98274,9.934317472229004,9.11501,9.972647472229003Q9.24728,10.010977472229005,9.38414,9.995767472229005Q9.52101,9.980557472229004,9.64164,9.914127472229005Q9.762270000000001,9.847707472229004,9.84829,9.740177472229004L13.540600000000001,5.124788472229004L13.5388,5.123347472229004Z" fill-rule="evenodd" fill="#FFFFFF" fill-opacity="1"/></g></g></svg>

After

Width:  |  Height:  |  Size: 2.1 KiB

5
src/components/GuipRadio.vue

@ -12,10 +12,7 @@
:key="option.value" :key="option.value"
:label="option.value" :label="option.value"
:disabled="option.disabled" :disabled="option.disabled"
> >{{( selectedValue === option.value ) ? (option.selectedLabel ? option.selectedLabel : option.label) :option.label }}</el-radio>
<!-- 默认展示和选中显示 不同文案 -->
{{( selectedValue === option.value ) ? (option.selectedLabel ? option.selectedLabel : option.label) :option.label }}
</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
</template> </template>

2
src/components/GuipSwitch.vue

@ -77,7 +77,7 @@ export default {
this.loading = true; this.loading = true;
try { try {
// //
await new Promise((resolve) => setTimeout(resolve, 1000)); await new Promise((resolve) => setTimeout(resolve, 100));
this.internalValue = value; this.internalValue = value;
this.$emit('update:modelValue', value); this.$emit('update:modelValue', value);
this.$emit('change', value); this.$emit('change', value);

75
src/components/paymentMethod.vue

@ -1,47 +1,85 @@
<template> <template>
<div class="payment-wrap"> <div class="payment-wrap">
<draggable v-model="list" @start="drag=true" @end="onEnd" :move="checkMove" handle=".drag-handle" >
<div class="payment-item" v-for="item in paymentList" :key="item.name"> <div class="payment-item" v-for="item in list" :key="item.name">
<dl> <dl>
<dt> <dt class="drag-handle">
<img v-if="item.type == '1'" src="@/assets/register/weixin_pay.png" alt=""> <img v-if="item.pay_type == '1'" src="@/assets/register/jingdong_pay.png" alt="">
<img v-if="item.type == '2'" src="@/assets/register/zhifubao_pay.png" alt=""> <img v-if="item.pay_type == '2'" src="@/assets/register/weixin_pay.png" alt="">
<img v-if="item.type == '3'" src="@/assets/register/taobao_pay.png" alt=""> <img v-if="item.pay_type == '3'" src="@/assets/register/zhifubao_pay.png" alt="">
<img v-if="item.type == '4'" src="@/assets/register/jingdong_pay.png" alt=""> <img v-if="item.pay_type == '4'" src="@/assets/register/taobao_pay.png" alt="">
</dt> </dt>
<dd> <dd>
<p>{{ item.name }}</p> <p>{{ item.name }}</p>
<p>{{ item.num }}</p> <p>{{ item.account }}</p>
</dd> </dd>
</dl> </dl>
<GuipSwitch :modelValue="item.flag" activeText="开启" inactiveText="关闭" @change="onSwitchChange"> <el-form>
<GuipSwitch :modelValue="item.status" active-value="1" inactive-value="0" activeText="开启" inactiveText="关闭" @change="onSwitchChange(item)">
</GuipSwitch> </GuipSwitch>
</el-form>
</div> </div>
</draggable>
</div> </div>
</template> </template>
<script> <script>
import GuipSwitch from '@/components/GuipSwitch.vue'; import GuipSwitch from '@/components/GuipSwitch.vue';
import draggable from 'vuedraggable';
export default { export default {
name: '', name: '',
props:['paymentList'], props:['paymentList'],
components: { components: {
GuipSwitch GuipSwitch,
draggable
}, },
data(){ data(){
return { return {
payImg:{ payImg:{
'1':'weixin_pay.png', '1':'@/assets/register/weixin_pay.png',
'2':'zhifubao_pay.png', '2':'@/assets/register/zhifubao_pay.png',
'3':'taobao_pay.png', '3':'@/assets/register/taobao_pay.png',
'4':'jingdong_pay.png', '4':'@/assets/register/jingdong_pay.png',
} },
list:[],
drag: false,
} }
}, },
watch:{
paymentList: {
immediate: true,
handler(newVal) {
this.list = newVal;
},
},
},
methods:{ methods:{
onSwitchChange(data){ onSwitchChange(data){
console.log(data,'---'); data.status = data.status == "1" ? "0" : "1";
this.$emit('confirm', this.list)
},
onEnd() {
this.drag = false;
this.$emit('confirm', this.list)
},
checkMove(evt) {
//
const targetIndex = this.list.length - 1; // 1
//
// console.log(evt.relatedContext.index === evt.draggedContext.index,targetIndex === evt.draggedContext.index,'0000targetIndex00');
if ((evt.relatedContext.index === targetIndex) || (targetIndex === evt.draggedContext.index)) {
return false; //
} }
return true; //
}
// onStart(event) {
// console.log(event,'event====');
// //
// const index = this.list.findIndex(item => item.id === event.draggedContext.element.id);
// // event.cancel()
// if (index === this.list.length - 1) {
// event.cancel(); //
// }
// }
} }
} }
</script> </script>
@ -77,5 +115,8 @@ export default {
color: #1E2226; color: #1E2226;
} }
} }
.drag-handle {
cursor: move; /* 鼠标悬停时显示可拖拽光标 */
}
} }
</style> </style>

13
src/views/Register.vue

@ -479,7 +479,7 @@
</div> </div>
</div> </div>
<!-- 设置域名弹出框 --> <!-- 设置域名弹出框 -->
<GuipDialog :dialogVisible="dialogVisible" :title="dialogTitle" :show-close-button="false" <GuipDialog :dialogVisible="true" :title="dialogTitle" :show-close-button="false"
:show-cancel-button="showCancelButton" @confirm="handleConfirm" @cancel="handleCancel" @close="handleClose" :show-cancel-button="showCancelButton" @confirm="handleConfirm" @cancel="handleCancel" @close="handleClose"
@dialogVisibleChange="dialogVisibleChange"> @dialogVisibleChange="dialogVisibleChange">
<PaymentMethod :paymentList="paymentList" /> <PaymentMethod :paymentList="paymentList" />
@ -535,7 +535,6 @@
</div> </div>
</el-dialog> </el-dialog>
<Footer></Footer>
<div class="register-btns"> <div class="register-btns">
<GuipButton type="system" :btnstyle="{ width: '144px', height: '46px' }" @click="jumpCurStep">跳过</GuipButton> <GuipButton type="system" :btnstyle="{ width: '144px', height: '46px' }" @click="jumpCurStep">跳过</GuipButton>
<GuipButton type="primary" :btnstyle="{ width: '144px', height: '46px' }" @click="finishCurStep">完成</GuipButton> <GuipButton type="primary" :btnstyle="{ width: '144px', height: '46px' }" @click="finishCurStep">完成</GuipButton>
@ -543,7 +542,6 @@
</div> </div>
</template> </template>
<script> <script>
import Footer from '@/components/Footer.vue';
import GuipButton from '@/components/GuipButton.vue'; import GuipButton from '@/components/GuipButton.vue';
import GuipFormItem from '@/components/GuipFormItem.vue'; import GuipFormItem from '@/components/GuipFormItem.vue';
import GuipInput from '@/components/GuipInput.vue'; import GuipInput from '@/components/GuipInput.vue';
@ -567,7 +565,6 @@ export default {
GuipRadio, GuipRadio,
GuipSelect, GuipSelect,
SvgIcon, SvgIcon,
Footer,
GuipSwitch, GuipSwitch,
GuipDialog, GuipDialog,
PaymentMethod, PaymentMethod,
@ -772,24 +769,28 @@ export default {
type: '1', type: '1',
name: '小知攻城狮', name: '小知攻城狮',
num: '1520574481 (wx1bda8b3d08d169cb)', num: '1520574481 (wx1bda8b3d08d169cb)',
flag: true flag: true,
img:require('@/assets/register/weixin_pay.png')
}, },
{ {
type: '2', type: '2',
name: '自收款', name: '自收款',
num: 'wangyong@kuailebanshou.com', num: 'wangyong@kuailebanshou.com',
img:require('@/assets/register/zhifubao_pay.png'),
flag: true flag: true
}, },
{ {
type: '3', type: '3',
name: '店铺收款', name: '店铺收款',
num: '轻歌曼舞82', num: '轻歌曼舞82',
img:require('@/assets/register/taobao_pay.png'),
flag: false flag: false
}, },
{ {
type: '4', type: '4',
name: '京东收款', name: '平台检测卡',
num: 'celunwen', num: 'celunwen',
img:require('@/assets/register/jingdong_pay.png'),
flag: false flag: false
}, },
], ],

289
src/views/agent/siteServiceAdd.vue

@ -1,28 +1,56 @@
<template> <template>
<div>
<div class="warning-text">
<img class="warning-icon" src="@/assets/site/info_filled.svg" alt="">
<span>操作提示设置价格并保存即添加服务</span>
</div>
<div class="main-content12"> <div class="main-content12">
<!-- page content --> <!-- page content -->
<div class="site-setting-wrap min-flex-right"> <div class="flex-common" v-for="(ver_row) in serviceAddList" :key="ver_row.name">
<div class="siteMessage flex-common" id="siteMessage1"> <h3>{{ver_row.name}}</h3>
<h3>站点信息</h3> <div class="service-setting-area" :class="row.status == 1 ? 'service-setting-open' : ''" v-for="(row) in ver_row.list" :key="row.type">
<el-form> <el-form class="el-row demo-ruleForm" ref="formRef">
<div class="flex-wrap"> <div class="service-flex service-title">
<div class="flex-left"> <div class="service-title-left">
<GuipInput ref="GuipInput" column="column" label="站点简称" :maxlength="10" <span class="service-title-name">{{row.type_name}}</span>
:showWordLimit="true" desc="一个站点对应一个销售渠道,定义好名字好区分" v-model="siteInfo.short_name" <span v-if="row.status == 1" class="service-title-status">已开启</span>
prop="short_name" placeholder="仅自己区分站点销售渠道,客户看不到" /> <span v-if="row.status == 1" class="service-title-close">关闭服务</span>
</div>
<GuipInput ref="GuipInput" column="column" label="公司电话" desc="在站点首页底部“关于我们”展示" <div class="service-title-right">
v-model="siteInfo.phone_num" prop="company_phone" placeholder="非必填" /> <el-checkbox v-model="row.has_base_price" @change="toggleSetBasePrice(row)">设置起售价格</el-checkbox>
</div>
</div>
<div class="service-flex">
<div class="service-info-item">
<span class="mr12">供货价格</span>
<span>{{row.supply_price}}</span>
</div>
<div class="service-info-item" v-if="row.freedom_set">
<GuipRadio label="计费方式" v-model="row.default_set" :options="methodOptions" @change="methodChange()"/>
</div>
<div class="service-info-item">
<GuipInput v-model="row.unit_price" label="售价管理" ref="GuipInput" width="180px" unit="元"></GuipInput>
<template v-if="row.default_set == 0">
<span class="mr12"></span>
<GuipInput v-model="row.unit_num" ref="GuipInput" width="180px" unit="字符"></GuipInput>
</template>
</div>
</div> </div>
<div class="flex-line"></div> <div class="service-flex" v-if="row.has_base_price">
<div class="flex-right"> <div class="service-info-item">
<GuipTextarea v-model="siteInfo.company_name" label="详细介绍" column="column" <GuipInput v-model="row.b_unit_num" label="起售价格" ref="GuipInput" width="240px" unit="字符内"></GuipInput>
prop="doctor_detail" width="100%" height="90px" placeholder="请输入描述内容" <span class="ml12 mr12">用户需支付</span>
desc="在站点首页底部“关于我们”展示" show-word-limit /> <GuipInput v-model="row.b_unit_price" ref="GuipInput" width="240px" unit="元"></GuipInput>
<span class="service-base-remark ml12">备注超过设定字符按照正常售价收取</span>
</div> </div>
</div> </div>
<div class="service-flex service-opt">
<GuipButton type="ignore" @click="reset">重置</GuipButton>
<GuipButton type="primary" @click="save(row)" size="medium">保存</GuipButton>
</div>
</el-form> </el-form>
<GroupFormBtns @cancel="cancleUpdateSiteInfo()" @confirm="updateSiteInfo()" /> </div>
</div> </div>
</div> </div>
</div> </div>
@ -30,167 +58,210 @@
<script> <script>
import store from '@/store'; import store from '@/store';
import { mapState } from 'vuex'; import { mapState } from 'vuex';
import GuipInput from '@/components/GuipInput.vue'; import GuipRadio from "@/components/GuipRadio.vue";
import GuipTextarea from '@/components/GuipTextarea.vue'; import GuipInput from "@/components/GuipInput.vue";
import GroupFormBtns from '@/components/GroupFormBtns.vue'; import GuipButton from "@/components/GuipButton.vue";
export default { export default {
name: 'siteServiceAdd', name: 'siteServiceAdd',
props: [''], props: [''],
components: { components: {
GuipButton,
GuipInput, GuipInput,
GuipTextarea, GuipRadio
GroupFormBtns
}, },
data() { data() {
return { return {
// AUTH // AUTH
token: 'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpYXQiOjE3NTAwNTM3MjQsIm5iZiI6MTc1MDA1MzcyNCwiZXhwIjoxNzUyNjQ1NzI0LCJ1c2VyIjoic3VidXNlciIsImxvZ2luX3R5cGUiOjAsImFpZCI6IjEifQ.xyIqBLelB-k6jCifgRevBJTyg_Qrm6m1e4OcHhOpepU', token: 'eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpYXQiOjE3NTAwNTM3MjQsIm5iZiI6MTc1MDA1MzcyNCwiZXhwIjoxNzUyNjQ1NzI0LCJ1c2VyIjoic3VidXNlciIsImxvZ2luX3R5cGUiOjAsImFpZCI6IjEifQ.xyIqBLelB-k6jCifgRevBJTyg_Qrm6m1e4OcHhOpepU',
uid:0,
serviceAddList:[],
methodOptions: [],
} }
}, },
computed: { computed: {
...mapState(['pageTitle']) // VuexshowSidebar ...mapState(['pageTitle']) // VuexshowSidebar
}, },
created() { created() {
if(!this.$route.query.uid) {
this.$message.error('非法请求');
this.$router.push('/agent/siteList')
}
this.uid = this.$route.query.uid;
store.commit('SET_CUSTOMIZE', true); store.commit('SET_CUSTOMIZE', true);
store.commit('SET_SLIDER_MENU', 'siteSettingData'); store.commit('SET_SLIDER_MENU', 'siteSettingData');
}, },
mounted() { mounted() {
store.commit('SET_PAGETITLE', '基本设置'); store.commit('SET_PAGETITLE', '站点信息');
this.getSiteInfo(); this.getServiceAdd();
}, },
methods: { methods: {
// //
getSiteInfo() { getServiceAdd() {
const that = this const that = this
that.siteInfo = [] that.siteInfo = []
this.$http('POST', '/agentnew/ajax_get_site_info', { this.$http('POST', '/agentnew/ajax_get_service_add', {
uid: this.$route.query.uid, uid: that.uid,
prodid: that.$route.query.prodid,
}, { }, {
headers: { headers: {
'Auth': this.token 'Auth': this.token
} }
}).then(response => { }).then(response => {
this.$nextTick(() => { this.$nextTick(() => {
that.siteInfo = response.data that.serviceAddList = response.data.service_add_list
store.commit('SET_BREADRIGHTTEXT', response.data.site_short_name);
that.methodOptions = Object.entries(response.data.freedom_set_method).map(([key, value]) => ({
label: value,
value: Number(key)
}));
}) })
}).catch(error => { }).catch(error => {
console.error(error, 'error') console.error(error, 'error')
}) })
}, },
toggleSetBasePrice(row){
row.has_base_price = row.has_base_price == true ? false : true;
},
methodChange(){
},
reset(){
},
save(row){
console.log(row)
const that = this
this.$http('POST', "/agentnew/ajax_set_service_price", {
uid: that.uid,
type: row.type,
unit_num: row.unit_num,
unit_price: row.unit_price,
// unit_piece: row.unit_piece,
b_unit_num: row.b_unit_num,
b_unit_price: row.b_unit_price,
// b_unit_piece: row.b_unit_piece,
},{
headers:{
'Auth': this.token
}
}).then(response => {
if(response.status){
that.$message.success('保存成功');
return true;
}
that.$message.success(response.info);
}).catch(error => {
console.error(error, 'error')
})
},
} }
} }
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.pageheader { .ml12{
display: flex; margin-left: 12px;
justify-content: space-between;
/* 关键属性 */
align-items: center;
margin: 16px 0px 16px 0px;
} }
.pagetitle { .mr12{
font-size: 18px; margin-right: 12px;
font-weight: bold;
line-height: normal;
letter-spacing: 0.08em;
color: #1E2226;
margin-top: 8px;
} }
.siteMessage { .warning-text{
margin: 0 12px;
display: flex;
align-items: center;
padding: 8px 13px;
align-self: stretch;
z-index: 1;
border-radius: 4px; border-radius: 4px;
transition: all .5s; background: #FEFCE8;
border: 1px solid transparent; border: 1px solid rgba(255, 140, 0, 0.3);
.warning-icon{
width: 16px;
height: 16px;;
margin-right: 8px;
} }
.combo-formItem { span{
::v-deep { color: #1E2226;
.form-item-bottom { letter-spacing: 0.08em;
position: relative; font-size: 14px;
} }
.select-trigger {
background: #F6F7FA;
border-color: transparent;
} }
.is-open .select-trigger { .service-setting-open{
border-color: #006AFF; background: #F2FBED!important;
} }
.el-input__inner { .service-setting-area{
border-radius: 2px 0 0 2px; padding: 24px;
} background: #F6F7FA;
margin-bottom: 12px;
letter-spacing: 0.08em;
.el-form-item{
margin: 0;
} }
.self-drop-wrap {
position: absolute; .el-checkbox{
z-index: 1; color: #1E2226;
width: 100%;
} }
.appendDrop {
height: 38px; .service-flex{
display: flex;
justify-content: space-between;
align-items: center; align-items: center;
border-radius: 0 2px 2px 0; margin-bottom: 24px;
border: 1px solid #DFE2E6;
border-left-color: transparent;
justify-content: center;
box-sizing: border-box;
padding: 0 30px 0 12px;
text-overflow: ellipsis;
white-space: nowrap;
overflow: hidden;
&:hover {
border: 1px solid #006AFF;
}
}
} }
.addStore {
margin-top: 12px;
// border-radius: 4px;
// opacity: 1;
// /* text/text_white_2 */
// border: 1px dashed #BABDC2;
// padding: 15px 20px;
// color: #626573;
// justify-content: center;
// img { .service-flex:last-child{
// margin-right: 12px; margin-bottom: 0;
// }
} }
.service-title{
.site-setting-wrap { .service-title-left .service-title-name{
width: 100%; color: #1E2226;
margin-right: 24px;
} }
#siteMessage2 { .service-title-left .service-title-status{
margin: 12px 0; border-radius: 4px;
border: 1px solid rgba(0, 194, 97, 0.6);
color: #0DAF49;
padding: 2px 10px 2px 32px;
background-image: url(@/assets/site/open_success.svg);
background-repeat: no-repeat;
background-position: 10px 50%;
background-size: 16px 16px;
margin-right: 12px;
}
.service-title-left .service-title-close{
color: #8A9099;
background-image: url(@/assets/site/form_close.svg);
background-repeat: no-repeat;
background-position: 0 50%;
background-size: 16px 16px;
padding: 2px 10px 2px 22px;
} }
.domain-wrap {
.domain-item {
margin-bottom: 10px;
} }
.service-info-item{
.domain-item p:last-child { display: flex;
padding-left: 23px; align-items: center;
color: #8A9099;
} }
p { .service-base-remark{
text-align: left; font-size: 12px;
line-height: 18px; color: #8A9099;
margin-bottom: 8px;
} }
.domain-box { .service-opt{
display: flex; justify-content: right;
flex-direction: column;
justify-content: flex-start;
} }
} }
</style> </style>

252
src/views/agent/siteServiceList.vue

@ -10,24 +10,25 @@
<!-- page header --> <!-- page header -->
<div class="pageheader"> <div class="pageheader">
<div class="pageheader-left"> <div class="pageheader-left">
<el-checkbox @change="toggleAllSelection">全选</el-checkbox> <el-checkbox @change="toggleAllSelection" :indeterminate="isIndeterminate" v-model="selectAll">全选</el-checkbox>
<span class="checked-text">共80条已选0条</span> <span class="checked-text">{{ serviceList.length }}已选{{ selectedCount }}</span>
<GuipButton type="ignore" :btnstyle="btnInfostyleObj">批量删除</GuipButton>
<GuipButton type="ignore" :btnstyle="btnInfostyleObj" @click="handleBatchDelClick">批量删除</GuipButton>
</div> </div>
<div class="pageheader-right"> <div class="pageheader-right">
<GuipButton type="primary" :btnstyle="btnstyleObj" @click="jumpAdd(1)">添加查重服务</GuipButton> <GuipButton type="primary" :btnstyle="btnstyleObj" @click="jumpAdd(1)">添加查重服务</GuipButton>
<GuipButton type="primary" :btnstyle="btnstyleObj" @click="jumpAdd(2)">添加写作辅助</GuipButton> <GuipButton type="primary" :btnstyle="btnstyleObj" @click="jumpAdd(3)">添加写作辅助</GuipButton>
<GuipButton type="primary" :btnstyle="btnstyleObj" @click="jumpAdd(3)">添加AIGC</GuipButton> <GuipButton type="primary" :btnstyle="btnstyleObj" @click="jumpAdd(2)">添加AIGC</GuipButton>
</div> </div>
</div> </div>
<!-- page content --> <!-- page content -->
<el-form> <el-form>
<GuipTable :tableData="serviceList" ref="multipleTable" autoColumn="true" :loading="tableLoading"> <GuipTable :tableData="serviceList" ref="multipleTable" autoColumn="true" :loading="tableLoading"
@selection-change="handleSelectionChange" @select="handleSelect">
<el-table-column label="选择" width="70" header-align="center" align="center"> <el-table-column type="selection" width="100">
<template slot-scope="scope"> <template slot="header">
<el-checkbox @change="toggleSelection(scope.row)"></el-checkbox> <span class="selection-header-text">选择</span>
</template> </template>
</el-table-column> </el-table-column>
@ -125,16 +126,19 @@
</GuipTable> </GuipTable>
<GuipDialog :dialogVisible="dialogVisible" :title="dialogTitle" :show-close-button="false" <GuipDialog :dialogVisible="dialogVisible" :title="dialogTitle" :show-close-button="false" @confirm="handleConfirm"
:show-cancel-button="showCancelButton" @confirm="handleConfirm" @cancel="handleCancel" @close="handleClose" @cancel="handleCancel">
@dialogVisibleChange="dialogVisibleChange"> <PaymentMethod :paymentList="payList" @confirm="confirmPayment"/>
<PaymentMethod :paymentList="payList" />
</GuipDialog> </GuipDialog>
<GuipDialog :dialogVisible="dialogDelConfim" title="提示" :show-close-button="false" @confirm="handleDelConfirm" <GuipDialog :dialogVisible="dialogDelConfim" title="提示" :show-close-button="false" @confirm="handleDelConfirm"
@cancel="handleDelCancel"> @cancel="handleDelCancel">
确定要移除服务吗? 确定要移除服务吗?
</GuipDialog> </GuipDialog>
<GuipDialog :dialogVisible="dialogBatchDelConfim" title="提示" :show-close-button="false" @confirm="handleBatchDelConfirm"
@cancel="handleBatchDelCancel">
确定要移除选中的服务吗?
</GuipDialog>
</el-form> </el-form>
</div> </div>
</div> </div>
@ -189,17 +193,23 @@ export default {
serviceList: [], serviceList: [],
// //
payList: [], payList: [],
selectedRows:[],//
selectAll: false,//
isIndeterminate: false,///
// //
popoverFlag:false, popoverFlag:false,
// //
dialogVisible: false, // dialogVisible: false, //
dialogTitle: "", // dialogTitle: "", //
showCancelButton: true, // editRow:{},
showCloseButton: true, //
// //
dialogDelConfim: false, dialogDelConfim: false,
delRow:{}, delRow:{},
dialogBatchDelConfim: false,
delRows:[],
// url // url
serviceAddUrl: '/agent/siteServiceAdd', serviceAddUrl: '/agent/siteServiceAdd',
@ -219,16 +229,18 @@ export default {
mounted() { mounted() {
this.getSiteServiceList(); this.getSiteServiceList();
}, },
computed: {
selectedCount() {
return this.selectedRows.length;
},
},
methods: { methods: {
jumpAdd(type){ jumpAdd(prodid){
this.$router.push(this.serviceAddUrl + '?type=' + type + '&uid=' + this.uid) this.$router.push(this.serviceAddUrl + '?uid=' + this.uid + '&prodid=' + prodid)
}, },
toggleAllSelection() { toggleAllSelection() {
this.$refs.multipleTable.$refs.guiptable.toggleAllSelection(); this.$refs.multipleTable.$refs.guiptable.toggleAllSelection();
}, },
toggleSelection(row){
console.log(row)
},
// //
getSiteServiceList() { getSiteServiceList() {
this.tableLoading = true this.tableLoading = true
@ -250,14 +262,87 @@ export default {
console.error(error, 'error') console.error(error, 'error')
}) })
}, },
onSwitchChange(row){ handleSelect(selection, row) {
row.is_display = row.is_display == 1 ? 0 : 1 console.log('操作的行:', row);
console.log('当前所有选中行:', selection);
},
//
handleSelectionChange(rows) {
this.selectedRows = rows;
//
const allSelected = rows.length === this.serviceList.length;
const noneSelected = rows.length === 0;
let obj = {} this.selectAll = allSelected;
obj.uid = this.uid this.isIndeterminate = !noneSelected && !allSelected;
obj.type = row.type },
obj.is_display = row.is_display //
this.saveRequest('/agentnew/ajax_set_service_display_index', obj, row) handleBatchDelClick() {
this.dialogBatchDelConfim = true
},
handleBatchDelCancel(){
this.dialogBatchDelConfim = false
},
handleBatchDelConfirm(){
let delTypes = [];
this.selectedRows.forEach((row) => {
delTypes.push(row.type)
});
const that = this
this.dialogBatchDelConfim = false
this.$http('POST', '/agentnew/ajax_del_services', {
uid: that.uid,
types: JSON.stringify(delTypes)
},{
headers:{
'Auth': this.token
}
}).then(response => {
if(response.status){
that.$message.success('删除成功');
that.selectedRows = [];
that.$nextTick(() => {
this.serviceList = this.serviceList.filter(row => !delTypes.includes(row.type));
})
return true;
}
that.$message.success(response.info);
}).catch(error => {
console.error(error, 'error')
})
},
//
handleDelClick(row, index) {
this.dialogDelConfim = true
this.delRow.index = index
this.delRow.type = row.type
},
handleDelCancel(){
this.dialogDelConfim = false
},
handleDelConfirm(){
const that = this
this.dialogDelConfim = false
this.$http('POST', '/agentnew/ajax_del_service', {
uid: that.uid,
type: that.delRow.type
},{
headers:{
'Auth': this.token
}
}).then(response => {
if(response.status){
that.$message.success('删除成功');
this.$nextTick(() => {
that.serviceList.splice(that.delRow.index, 1);
})
return true;
}
that.$message.success(response.info);
}).catch(error => {
console.error(error, 'error')
})
}, },
// //
handleEditClick(row, index, type) { handleEditClick(row, index, type) {
@ -325,6 +410,15 @@ export default {
obj.sort_num = row.sort_id obj.sort_num = row.sort_id
this.saveRequest('/agentnew/ajax_set_service_sort', obj, row) this.saveRequest('/agentnew/ajax_set_service_sort', obj, row)
}, },
onSwitchChange(row){
row.is_display = row.is_display == "1" ? "0" : "1"
let obj = {}
obj.uid = this.uid
obj.type = row.type
obj.is_display = row.is_display
this.saveRequest('/agentnew/ajax_set_service_display_index', obj, row)
},
saveRequest(url, obj, row){ saveRequest(url, obj, row){
const that = this const that = this
this.$http('POST', url, obj,{ this.$http('POST', url, obj,{
@ -347,6 +441,7 @@ export default {
popPayMentModal(row){ popPayMentModal(row){
this.dialogVisible = true; this.dialogVisible = true;
this.dialogTitle = row.type_desc + '-收款方式' this.dialogTitle = row.type_desc + '-收款方式'
this.editRow = row
this.getPayList(row.type) this.getPayList(row.type)
}, },
// //
@ -368,61 +463,76 @@ export default {
console.error(error, 'error') console.error(error, 'error')
}) })
}, },
confirmPayment(payList){
this.payList = payList
},
// //
handleConfirm() { handleConfirm() {
this.$message.success('点击了确认按钮');
this.dialogVisible = false; this.dialogVisible = false;
let obj = {}
obj.uid = this.uid
obj.type = this.editRow.type
obj.info = ""
let hasClose = false
this.payList.forEach((row) => {
if(row.status == 1) {
let value = row.pay_type
if(row.id) value += ',' + row.id
obj.info = obj.info + ';' + value;
}else{
hasClose = true
}
});
obj.info = obj.info.substr(1, obj.info.length-1);
if(hasClose) this.editRow.payment_method_desc = '自定义支付';
this.saveRequest('/agentnew/ajax_payment_switch', obj, this.editRow)
}, },
// //
handleCancel() { handleCancel() {
this.$message.warning('点击了取消按钮');
this.dialogVisible = false;
},
//
handleClose() {
this.$message.info('弹框已关闭');
this.dialogVisible = false; this.dialogVisible = false;
}, },
dialogVisibleChange(data) {
console.log(data, 'data098908090');
}, },
}
</script>
<style lang="scss" scoped>
::v-deep .custom-popover {
position: fixed !important;
// max-height: 290px;
// overflow-y: auto;
margin-top: 0 !important;
margin-left: 0 !important;
transform: none !important;
}
// ::v-deep .el-table__header-wrapper .el-checkbox {
handleDelClick(row, index) { display: none;
this.dialogDelConfim = true
this.delRow.index = index
this.delRow.type = row.type
},
handleDelConfirm(){
const that = this
that.dialogDelConfim = false
this.$http('POST', '/agentnew/ajax_del_service', {
uid: that.uid,
type: that.delRow.type
},{
headers:{
'Auth': this.token
} }
}).then(response => {
if(response.status){ /* 隐藏表头的复选框 */
that.$message.success('删除成功'); ::v-deep .el-table__header-wrapper .el-checkbox {
this.$nextTick(() => { display: none !important;
that.serviceList.splice(that.delRow.index, 1);
})
return true;
} }
that.$message.success(response.info);
}).catch(error => { /* 确保选择文字可见 */
console.error(error, 'error') ::v-deep .selection-header-text {
}) display: inline-block;
}, margin-left: 8px;
handleDelCancel(){ /* 调整位置 */
this.dialogDelConfim = false font-size: 14px;
}, color: #606266;
}, font-weight: bold;
}
/* 调整表头单元格的padding */
::v-deep .el-table .el-table__header th {
padding: 8px 0;
/* 根据需要调整 */
} }
</script>
<style lang="scss" scoped>
.flex-service-title{ .flex-service-title{
margin-bottom: 12px; margin-bottom: 12px;
} }

Loading…
Cancel
Save