Browse Source

Merge pull request '注册也样式修改' (#37) from zq-ui into master

Reviewed-on: zhangqi/kuailelunwen_new_houtai#37
master
zhangqi 5 months ago
parent
commit
57bd9212b6
  1. 198
      src/views/Register.vue

198
src/views/Register.vue

@ -329,17 +329,16 @@
<div class="step3-top flex-common"> <div class="step3-top flex-common">
<h3>服务列表</h3> <h3>服务列表</h3>
<div class="btngroup"> <div class="btngroup">
<GuipButton type="normal" size="mmedium" @click="showDomainModal">添加查重服务</GuipButton> <GuipButton type="ignore" :btnstyle="{ width: '97px', height: '33px' }" @click="showDomainModal">添加查重服务
<GuipButton type="normal" size="mmedium">添加写作辅助</GuipButton> </GuipButton>
<GuipButton type="normal" size="mmedium">添加AIGC</GuipButton> <GuipButton type="ignore" :btnstyle="{ width: '97px', height: '33px' }">添加写作辅助</GuipButton>
<GuipButton type="ignore" :btnstyle="{ width: '97px', height: '33px' }">添加AIGC</GuipButton>
</div> </div>
</div> </div>
<div> <div>
<div class="flex-common table-wrap"> <div class="flex-common table-wrap">
<el-form> <el-form>
<el-table :data="tableData1.slice((currentPage - 1) * pageSize, currentPage * pageSize)" style="width: 100%" <GuipTable :tableData="tableData1" :loading="tableLoading">
:key="random()">
<!-- 其他列 -->
<el-table-column prop="name" label="检测服务" width="210"> <el-table-column prop="name" label="检测服务" width="210">
<template slot-scope="scope"> <template slot-scope="scope">
<div class="flex"> <div class="flex">
@ -349,21 +348,17 @@
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="stock" label="今日供货价"> <el-table-column prop="stock" label="今日供货价" width="198">
<template slot-scope="scope"> <template slot-scope="scope">
<div class="flex cell_render"> <div class="flex cell_render">
<span>¥{{ scope.row.stock }}/</span> <span>¥{{ scope.row.stock }}/</span>
<img class="edit_icon" src="@/assets/register/tableEdit.svg" alt="">
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="price" label="售价" width="200">
<!-- 价格列 --> <template #default="{ row,$index }">
<el-table-column label="售价"> <el-popover :ref="`pricePopover-${row.id}`" popper-class="single-popover" placement="top" :append-to-body="true" trigger="manual"
<template v-slot="{ row, $index }"> v-model="row.pricePopoverVisible" @show="closeOtherPopovers(row, 'price')">
<el-popover v-model="row.price_popover" placement="top" trigger="manual" :ref="`popover-${$index}`"
@show="popshow">
<!-- 弹框内容 -->
<div style="text-align: center"> <div style="text-align: center">
<GuipInput ref="GuipInput" v-if="!row.word" width="252px" v-model="row.edit_price" label="售价" <GuipInput ref="GuipInput" v-if="!row.word" width="252px" v-model="row.edit_price" label="售价"
placeholder="请输入售价" unit="元"> placeholder="请输入售价" unit="元">
@ -376,68 +371,86 @@
<GuipInput ref="GuipInput" width="133px" v-model="row.edit_word" placeholder="请输入字符" unit="字符"> <GuipInput ref="GuipInput" width="133px" v-model="row.edit_word" placeholder="请输入字符" unit="字符">
</GuipInput> </GuipInput>
</div> </div>
<!-- <el-input v-model="row.edit_price" size="small" placeholder="请输入价格" /> -->
<div class="flex" style="text-align: right; margin-top: 32px;justify-content: flex-end;"> <div class="flex" style="text-align: right; margin-top: 32px;justify-content: flex-end;">
<GuipButton size="medium" @click="cancelEdit(row, 'price')">取消</GuipButton> <GuipButton size="medium" @click="cancelEdit(row, 'price')">取消</GuipButton>
<GuipButton type="primary" @click="savePrice(row, 'price')" size="medium">确定</GuipButton> <GuipButton type="primary" @click="savePrice(row, 'price')" size="medium">确定</GuipButton>
</div> </div>
</div> </div>
<!-- 触发弹框的按钮 --> <template #reference>
<span slot="reference" @click="handlePriceClick(row, $index, 'price')"> <div class="flex cell_render" @click="handlePriceClick(row,$index,'price')">
<div class="flex cell_render">
<span v-if="row.word" :key="random()">¥{{ row.price }}/{{ row.word }}</span> <span v-if="row.word" :key="random()">¥{{ row.price }}/{{ row.word }}</span>
<span v-else :key="random()">¥{{ row.price }}/</span> <span v-else :key="random()">¥{{ row.price }}/</span>
<img class="edit_icon" src="@/assets/register/tableEdit.svg" alt=""> <svg-icon :size="16" :path="require('@/assets/register/tableEdit.svg')" :color="'#8A9099'"
:hoverColor="'#006AFF'" />
</div> </div>
</span> </template>
</el-popover> </el-popover>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="stock" label="排序">
<template v-slot="{ row, $index }"> <el-table-column prop="num" label="排序" width="126">
<el-popover v-model="row.num_popover" placement="top" trigger="manual" :ref="`popover-${$index}`" <template #default="{ row,$index }">
@show="popshow"> <!-- <el-tooltip :manual="true" v-model="row.numPopoverVisible" placement="top" effect="light">
<!-- 弹框内容 --> <template #content>
<div style="text-align: center">
<GuipInput ref="GuipInput" width="252px" v-model="row.edit_num" label="排序" placeholder="请输入数字">
</GuipInput>
<p
style="width: 252px;margin-left: 40px;text-align: right;color: #8A9099;letter-spacing: 0.08em;">
输入0的数越小排序越前重复则新者优先0则默认排序</p>
<div class="flex" style="text-align: right; margin-top: 32px;justify-content: flex-end;">
<GuipButton size="medium" @click="cancelEdit(row, 'num')">取消</GuipButton>
<GuipButton type="primary" @click="savePrice(row, 'num')" size="medium">确定</GuipButton>
</div>
</div>
</template>
<div class="flex cell_render" @click="row.numPopoverVisible = true">
<span>{{ row.num }}</span>
<svg-icon :size="16" :path="require('@/assets/register/tableEdit.svg')" :color="'#8A9099'"
:hoverColor="'#006AFF'" />
</div>
</el-tooltip> -->
<el-popover v-model="row.numPopoverVisible" placement="top" trigger="manual" append-to-body :ref="`popover-${row.id}`">
<div style="text-align: center"> <div style="text-align: center">
<GuipInput ref="GuipInput" width="252px" v-model="row.edit_num" label="排序" placeholder="请输入数字"> <GuipInput ref="GuipInput" width="252px" v-model="row.edit_num" label="排序" placeholder="请输入数字">
</GuipInput> </GuipInput>
<p style=" width: 252px; <p
margin-left: 40px; style="width: 252px;margin-left: 40px;text-align: right;color: #8A9099;letter-spacing: 0.08em;">
text-align: right;color: #8A9099;letter-spacing: 0.08em;">输入0的数越小排序越前重复则新者优先0则默认排序</p> 输入0的数越小排序越前重复则新者优先0则默认排序</p>
<!-- <el-input v-model="row.edit_price" size="small" placeholder="请输入价格" /> -->
<div class="flex" style="text-align: right; margin-top: 32px;justify-content: flex-end;"> <div class="flex" style="text-align: right; margin-top: 32px;justify-content: flex-end;">
<GuipButton size="medium" @click="cancelEdit(row, 'num')">取消</GuipButton> <GuipButton size="medium" @click="cancelEdit(row, 'num')">取消</GuipButton>
<GuipButton type="primary" @click="savePrice(row, 'num')" size="medium">确定</GuipButton> <GuipButton type="primary" @click="savePrice(row, 'num')" size="medium">确定</GuipButton>
</div> </div>
</div> </div>
<!-- 触发弹框的按钮 --> <span slot="reference" @click="handlePriceClick(row,$index,'num')">
<span slot="reference" @click="handlePriceClick(row, $index, 'num')">
<div class="flex cell_render"> <div class="flex cell_render">
<span>{{ row.num }}</span> <span>{{ row.num }}</span>
<img class="edit_icon" src="@/assets/register/tableEdit.svg" alt=""> <svg-icon :size="16" :path="require('@/assets/register/tableEdit.svg')" :color="'#8A9099'"
:hoverColor="'#006AFF'" />
</div> </div>
</span> </span>
</el-popover> </el-popover>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="stock" label="收款方式" width="195"> <el-table-column prop="stock" label="收款方式" width="198">
<template slot-scope="scope"> <template slot-scope="scope">
<div class="flex cell_render" @click="popPayMentModal(scope.row)"> <div class="flex cell_render">
<span :class="(scope.row.payment == '0' ? 'normal_payment' : 'self_payment')">{{ scope.row.payment <span :class="(scope.row.payment == '0' ? 'normal_payment' : 'self_payment')">{{ scope.row.payment
== ==
'0' ? '默认站点支付' : '自定义支付' }}</span> '0' ? '默认站点支付' : '自定义支付' }}</span>
<img class="edit_icon" src="@/assets/register/tableEdit.svg" alt=""> <svg-icon :size="16" :path="require('@/assets/register/tableEdit.svg')"
@click="popPayMentModal(scope.row)" :color="'#8A9099'" :hoverColor="'#006AFF'" />
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column prop="stock" label="上首页"> <el-table-column prop="stock" label="上首页" width="110">
<template slot-scope="scope"> <template slot-scope="scope">
<GuipSwitch :modelValue="scope.row.homeFlag" @change="onSwitchChange(scope.row)"> <GuipSwitch :modelValue="scope.row.homeFlag" @change="onSwitchChange(scope.row)">
</GuipSwitch> </GuipSwitch>
</template> </template>
</el-table-column> </el-table-column>
<el-table-column fixed="right" label="操作" width="112"> <!-- :fixed="popoverFlag ? 'false' : 'right'" -->
<el-table-column label="操作" width="150">
<template slot-scope="scope"> <template slot-scope="scope">
<div class="flex"> <div class="flex">
<el-button type="text">编辑</el-button> <el-button type="text">编辑</el-button>
@ -445,7 +458,8 @@
</div> </div>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </GuipTable>
<el-pagination background @size-change='handleSizeChange' @current-change='handleCurrentChange' <el-pagination background @size-change='handleSizeChange' @current-change='handleCurrentChange'
:current-page="currentPage" :page-size=pageSize layout="prev, pager, next,jumper" :current-page="currentPage" :page-size=pageSize layout="prev, pager, next,jumper"
:total="tableData1.length"> :total="tableData1.length">
@ -514,8 +528,8 @@
<Footer></Footer> <Footer></Footer>
<div class="register-btns"> <div class="register-btns">
<GuipButton type="mild" @click="jumpCurStep">跳过</GuipButton> <GuipButton type="system" :btnstyle="{ width: '144px', height: '46px' }" @click="jumpCurStep">跳过</GuipButton>
<GuipButton type="primary" @click="finishCurStep">完成</GuipButton> <GuipButton type="primary" :btnstyle="{ width: '144px', height: '46px' }" @click="finishCurStep">完成</GuipButton>
</div> </div>
</div> </div>
</template> </template>
@ -531,8 +545,9 @@ import GuipDialog from '@/components/GuipDialog.vue';
import PaymentMethod from '@/components/paymentMethod.vue'; import PaymentMethod from '@/components/paymentMethod.vue';
import DomainModal from '@/components/domainModal.vue'; import DomainModal from '@/components/domainModal.vue';
import CustomDropdown from '@/components/CustomDropdown.vue'; import CustomDropdown from '@/components/CustomDropdown.vue';
// import GuipTable from '@/components/GuipTable.vue'; import SvgIcon from '@/components/SvgIcon.vue';
import store from '../store'; import store from '../store';
import GuipTable from '@/components/GuipTable.vue';
export default { export default {
components: { components: {
@ -541,16 +556,28 @@ export default {
GuipInput, GuipInput,
GuipRadio, GuipRadio,
GuipSelect, GuipSelect,
SvgIcon,
Footer, Footer,
GuipSwitch, GuipSwitch,
GuipDialog, GuipDialog,
PaymentMethod, PaymentMethod,
DomainModal, DomainModal,
CustomDropdown CustomDropdown,
// GuipTable GuipTable
}, },
data() { data() {
return { return {
popoverFlag:false,
tableData2: [
{
id: 1,
date: '2023-01-01',
name: '张三',
namePopoverVisible: false,
agePopoverVisible: false
},
// ...
],
btnstyleObj1: { btnstyleObj1: {
width: '137px', width: '137px',
height: '38px', height: '38px',
@ -756,12 +783,12 @@ export default {
}, },
], ],
currentPage: 1, // currentPage: 1, //
pageSize: 1, // pageSize: 2, //
total: 0, // total: 0, //
dialogVisible: false,// dialogVisible: false,//
showCancelButton: true, // showCancelButton: true, //
showCloseButton: true, // showCloseButton: true, //
activeStep: 2,// activeStep: 3,//
has_store: '1',// 0 has_store: '1',// 0
distribution_channel: '0',// 0 >0 distribution_channel: '0',// 0 >0
payment_method_list: [// payment_method_list: [//
@ -794,22 +821,23 @@ export default {
'3': '想卖哪些东西?来选选吧', '3': '想卖哪些东西?来选选吧',
}, },
tableData1: [ tableData1: [
{ id: 1, name: '万方大学生版', stock: 100, price: 50, price_popover: false, edit_price: '', type: 'a', num: '1', edit_num: '', num_popover: false, homeFlag: true, payment: '0' }, { id: 1, name: '万方大学生版', stock: 100, price: 50, pricePopoverVisible: false, edit_price: '', type: 'a', num: '1', edit_num: '', num_popover: false, homeFlag: true, payment: '0' },
{ id: 2, name: '维普检测版', stock: 200, price: 80, word: 1000, price_popover: false, edit_price: '', editWord: '', type: 'a', num: '2', edit_num: '', num_popover: false, homeFlag: true, payment: '1' }, { id: 2, name: '维普检测版', stock: 200, price: 80, word: 1000, pricePopoverVisible: false, edit_price: '', editWord: '', type: 'a', num: '2', edit_num: '', num_popover: false, homeFlag: true, payment: '1' },
{ id: 3, name: '商品C1', stock: 150, price: 120, price_popover: false, edit_price: '', type: 'b', num: '2', edit_num: '', num_popover: false, homeFlag: false, payment: '0' }, { id: 3, name: '商品C1', stock: 150, price: 120, pricePopoverVisible: false, edit_price: '', type: 'b', num: '2', edit_num: '', num_popover: false, homeFlag: false, payment: '0' },
{ id: 1, name: '商品A2', stock: 100, price: 50, price_popover: false, edit_price: '', type: 'a', num: '3', edit_num: '', num_popover: false, homeFlag: false, payment: '0' }, { id: 11, name: '商品A2', stock: 100, price: 50, pricePopoverVisible: false, edit_price: '', type: 'a', num: '3', edit_num: '', num_popover: false, homeFlag: false, payment: '0' },
{ id: 2, name: '商品B2', stock: 200, price: 80, word: 1000, price_popover: false, edit_price: '', editWord: '', type: 'a', num: '0', edit_num: '', num_popover: false, homeFlag: true }, { id: 21, name: '商品B2', stock: 200, price: 80, word: 1000, pricePopoverVisible: false, edit_price: '', editWord: '', type: 'a', num: '0', edit_num: '', num_popover: false, homeFlag: true },
{ id: 3, name: '商品C2', stock: 150, price: 120, price_popover: false, edit_price: '', type: 'b', num: '1', edit_num: '' }, { id: 31, name: '商品C2', stock: 150, price: 120, pricePopoverVisible: false, edit_price: '', type: 'b', num: '1', edit_num: '' },
{ id: 1, name: '商品A3', stock: 100, price: 50, price_popover: false, edit_price: '', type: 'a' }, { id: 12, name: '商品A3', stock: 100, price: 50, pricePopoverVisible: false, edit_price: '', type: 'a' },
{ id: 2, name: '商品B3', stock: 200, price: 80, word: 1000, price_popover: false, edit_price: '', editWord: '', type: 'a' }, { id: 22, name: '商品B3', stock: 200, price: 80, word: 1000, pricePopoverVisible: false, edit_price: '', editWord: '', type: 'a' },
{ id: 3, name: '商品C3', stock: 150, price: 120, price_popover: false, edit_price: '', type: 'b' }, { id: 32, name: '商品C3', stock: 150, price: 120, pricePopoverVisible: false, edit_price: '', type: 'b' },
{ id: 1, name: '商品A4', stock: 100, price: 50, price_popover: false, edit_price: '', type: 'a' }, { id: 13, name: '商品A4', stock: 100, price: 50, pricePopoverVisible: false, edit_price: '', type: 'a' },
{ id: 2, name: '商品B4', stock: 200, price: 80, word: 1000, price_popover: false, edit_price: '', editWord: '', type: 'a' }, { id: 23, name: '商品B4', stock: 200, price: 80, word: 1000, pricePopoverVisible: false, edit_price: '', editWord: '', type: 'a' },
{ id: 3, name: '商品C4', stock: 150, price: 120, price_popover: false, edit_price: '', type: 'b' }, { id: 33, name: '商品C4', stock: 150, price: 120, pricePopoverVisible: false, edit_price: '', type: 'b' },
{ id: 1, name: '商品A5', stock: 100, price: 50, price_popover: false, edit_price: '', type: 'a' }, { id: 14, name: '商品A5', stock: 100, price: 50, pricePopoverVisible: false, edit_price: '', type: 'a' },
{ id: 2, name: '商品B5', stock: 200, price: 80, word: 1000, price_popover: false, edit_price: '', editWord: '', type: 'a' }, { id: 24, name: '商品B5', stock: 200, price: 80, word: 1000, pricePopoverVisible: false, edit_price: '', editWord: '', type: 'a' },
{ id: 3, name: '商品C5', stock: 150, price: 120, price_popover: false, edit_price: '', type: 'b' }, { id: 34, name: '商品C5', stock: 150, price: 120, pricePopoverVisible: false, edit_price: '', type: 'b' },
], ],
tableLoading: false,
typelistobj: { typelistobj: {
a: '' a: ''
}, },
@ -884,6 +912,19 @@ export default {
}, },
}, },
methods: { methods: {
closeOtherPopovers(currentRow, type) {
this.tableData1.forEach(row => {
if (row !== currentRow) {
row[`${type}PopoverVisible`] = false;
}
//
Object.keys(row)
.filter(key => key.endsWith('PopoverVisible') && key !== `${type}PopoverVisible`)
.forEach(key => {
row[key] = false;
});
});
},
nextGoSettingPrice() { nextGoSettingPrice() {
this.$router.push('/configureServicePrices') this.$router.push('/configureServicePrices')
}, },
@ -949,13 +990,14 @@ export default {
// //
handlePriceClick(row, index, type) { handlePriceClick(row, index, type) {
// //
this.popoverFlag = true;
this.tableData.forEach((item, i) => { this.tableData.forEach((item, i) => {
if (i !== index) { if (i !== index) {
item[type + '_popover'] = false; item[type + 'PopoverVisible'] = false;
} }
}); });
// //
row[type + '_popover'] = true; row[type + 'PopoverVisible'] = true;
row['edit_' + type] = row[type] row['edit_' + type] = row[type]
// row.edit_price = row.price; // // row.edit_price = row.price; //
}, },
@ -973,7 +1015,7 @@ export default {
row.word = row.edit_word row.word = row.edit_word
} }
row[type] = row['edit_' + type]; // row[type] = row['edit_' + type]; //
row[type + '_popover'] = false; // row[type + 'PopoverVisible'] = false; //
this.$message.success('保存成功'); this.$message.success('保存成功');
this.$set(this.tableData1, row) this.$set(this.tableData1, row)
console.log('保存价格:', this.tableData1, row.price); console.log('保存价格:', this.tableData1, row.price);
@ -981,8 +1023,10 @@ export default {
}, },
// //
cancelEdit(row, type) { cancelEdit(row, type) {
row[type + '_popover'] = false; // row[type + 'PopoverVisible'] = false;
this.$message.info('已取消编辑'); this.popoverFlag = false
// row[type + '_popover'] = false; //
this.$Message.info('已取消编辑');
}, },
random() { random() {
var randomNumber = Math.random(); var randomNumber = Math.random();
@ -1125,6 +1169,16 @@ export default {
}; };
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.single-popover {
transform: translateX(-50%); /* 根据需要调整 */
left: 50% !important; /* 根据需要调整 */
}
/* 隐藏固定列中的弹出框 */
.el-table__fixed .el-popover,
.el-table__fixed-right .el-popover {
display: none !important;
}
.width-box { .width-box {
width: 1220px; width: 1220px;
} }
@ -1258,11 +1312,16 @@ export default {
display: flex; display: flex;
justify-content: space-between; justify-content: space-between;
padding-bottom: 0; padding-bottom: 0;
h3{
margin: 0;
}
.btngroup { .btngroup {
display: flex; display: flex;
height: 33px;
button { button {
font-size: 12px;
margin-left: 12px; margin-left: 12px;
} }
} }
@ -1337,6 +1396,7 @@ export default {
.register-btns { .register-btns {
// height: 78px; // height: 78px;
/* 自动布局 */ /* 自动布局 */
// width: 344px;
display: flex; display: flex;
flex-direction: row; flex-direction: row;
justify-content: center; justify-content: center;
@ -1344,6 +1404,10 @@ export default {
padding: 16px 0px; padding: 16px 0px;
/* 蓝色阴影_常规 */ /* 蓝色阴影_常规 */
box-shadow: 0px 4px 16px 0px rgba(17, 55, 143, 0.12); box-shadow: 0px 4px 16px 0px rgba(17, 55, 143, 0.12);
button:nth-child(1) {
margin-right: 56px;
}
} }
.tem-home { .tem-home {

Loading…
Cancel
Save