|
|
@@ -0,0 +1,490 @@
|
|
|
+<template>
|
|
|
+ <div class="ActivityQRCode">
|
|
|
+ <van-form ref="tabstoreVal" class="QRCodeActivity" @submit="openQRCode">
|
|
|
+ <div class="activityItem">
|
|
|
+ <span class="van-f-red">*</span>
|
|
|
+ <van-field
|
|
|
+ v-model="activityForm.name"
|
|
|
+ name="name"
|
|
|
+ label="活动名称"
|
|
|
+ placeholder="请输入活动名称"
|
|
|
+ :rules="[{ required: true, message: '请输入活动名称' }]" />
|
|
|
+ </div>
|
|
|
+ <div class="activityItem">
|
|
|
+ <span class="van-f-red">*</span>
|
|
|
+ <van-field
|
|
|
+ readonly
|
|
|
+ clickable
|
|
|
+ name="activityDate"
|
|
|
+ :value="activityForm.activityDate"
|
|
|
+ label="活动日期"
|
|
|
+ placeholder="请选择活动日期"
|
|
|
+ @click="activityShowCalendar = true"
|
|
|
+ :rules="[{ required: true, message: '请选择活动日期' }]" />
|
|
|
+ </div>
|
|
|
+ <div class="activityItem">
|
|
|
+ <span class="van-f-red">*</span>
|
|
|
+ <van-field
|
|
|
+ readonly
|
|
|
+ clickable
|
|
|
+ name="validDateStart"
|
|
|
+ :value="activityForm.validDateStart"
|
|
|
+ label="生效开始日期"
|
|
|
+ placeholder="请选择开始日期"
|
|
|
+ @click="clickValidDateShow('start')"
|
|
|
+ :rules="[{ required: true, message: '请选择开始日期' }]" />
|
|
|
+ </div>
|
|
|
+ <div class="activityItem">
|
|
|
+ <span class="van-f-red">*</span>
|
|
|
+ <van-field
|
|
|
+ readonly
|
|
|
+ clickable
|
|
|
+ name="validDateEnd"
|
|
|
+ :value="activityForm.validDateEnd"
|
|
|
+ label="生效结束日期"
|
|
|
+ placeholder="请选择结束日期"
|
|
|
+ @click="clickValidDateShow('end')"
|
|
|
+ :rules="[{ required: true, message: '请选择结束日期' }]" />
|
|
|
+ </div>
|
|
|
+ <div class="activityItem">
|
|
|
+ <div class="van-cell QRCodeBtnBox">
|
|
|
+ <van-button class="QRCodeBtn" color="#0057ba" native-type="openQRCode">
|
|
|
+ 打开签到二维码
|
|
|
+ </van-button>
|
|
|
+ <div class="tips">必须门店老板现场,使用企业微信扫码</div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="activityItem">
|
|
|
+ <div class="van-cell refreshBtnBox">
|
|
|
+ <div style="font-size: 16px; margin-right: 20px">已签到成功</div>
|
|
|
+ <div class="refresh">
|
|
|
+ <van-icon style="font-weight: 600" name="replay" size="20" color="#1989fa" />
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="activityItem">
|
|
|
+ <div class="van-cell chainListBox">
|
|
|
+ <div class="jxsContent">
|
|
|
+ <div class="item" v-for="(val, index) in QRChainList">
|
|
|
+ <el-popover
|
|
|
+ placement="bottom"
|
|
|
+ trigger="click"
|
|
|
+ :content="val.chainName + '(' + val.chainCode + ')'">
|
|
|
+ <template slot="reference">
|
|
|
+ <div class="selectItem">{{ val.chainName }} ({{ val.chainCode }})</div>
|
|
|
+ </template>
|
|
|
+ </el-popover>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </van-form>
|
|
|
+ <!-- 活动日期 -->
|
|
|
+ <van-calendar v-model="activityShowCalendar" @confirm="activityOnConfirm" />
|
|
|
+ <!-- 生效日期 -->
|
|
|
+ <van-popup v-model="validDateShow" capture position="bottom">
|
|
|
+ <van-datetime-picker
|
|
|
+ v-model="validDate"
|
|
|
+ :title="activate.title"
|
|
|
+ :min-date="activate.minDate"
|
|
|
+ :max-date="activate.maxDate"
|
|
|
+ type="datetime"
|
|
|
+ @cancel="validDateShow = false"
|
|
|
+ @confirm="onValidDateConfirm" />
|
|
|
+ </van-popup>
|
|
|
+ <!-- 二维码 -->
|
|
|
+ <div class="QRCodeBox" v-if="QRCodeBox">
|
|
|
+ <div class="centerBox">
|
|
|
+ <div class="title">{{ activityForm.name }}</div>
|
|
|
+ <div class="activityDate">{{ activityForm.activityDate }}</div>
|
|
|
+ <img class="QRCodeUrl" :src="require('@/assets/QRcode.png')" />
|
|
|
+ <div class="validTimeBox">
|
|
|
+ <div class="text">二维码有效期</div>
|
|
|
+ <div class="validTime">
|
|
|
+ {{ activityForm.validDateStart }}
|
|
|
+ ~
|
|
|
+ {{ activityForm.validDateEnd }}
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ <div class="close" @click="QRCodeBox = false">关闭</div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+ </div>
|
|
|
+</template>
|
|
|
+<script>
|
|
|
+export default {
|
|
|
+ data() {
|
|
|
+ return {
|
|
|
+ // 活动数据
|
|
|
+ activityForm: {
|
|
|
+ name: '',
|
|
|
+ activityDate: '',
|
|
|
+ validDateStart: '',
|
|
|
+ validDateEnd: '',
|
|
|
+ },
|
|
|
+ activityShowCalendar: false,
|
|
|
+ validDateShow: false,
|
|
|
+ QRCodeUrl: '',
|
|
|
+ QRCodeBox: false,
|
|
|
+ activate: {
|
|
|
+ type: '',
|
|
|
+ title: '',
|
|
|
+ minDate: new Date(2020, 0, 1),
|
|
|
+ maxDate: new Date(2025, 10, 1),
|
|
|
+ },
|
|
|
+ validDate: new Date(),
|
|
|
+ QRChainList: [
|
|
|
+ {
|
|
|
+ searchValue: null,
|
|
|
+ createBy: null,
|
|
|
+ createTime: null,
|
|
|
+ updateBy: null,
|
|
|
+ updateTime: null,
|
|
|
+ remark: null,
|
|
|
+ params: {},
|
|
|
+ pageSize: null,
|
|
|
+ pageNum: null,
|
|
|
+ chainId: null,
|
|
|
+ chainCode: '0110005930',
|
|
|
+ chainName: '洛阳市西工今典装饰行',
|
|
|
+ delFlag: null,
|
|
|
+ orgCode: null,
|
|
|
+ orgCodes: null,
|
|
|
+ orgIds: null,
|
|
|
+ orgName: '12城-洛阳销售部',
|
|
|
+ provinceName: null,
|
|
|
+ cityName: null,
|
|
|
+ cityLevel: null,
|
|
|
+ districtName: null,
|
|
|
+ freeze: null,
|
|
|
+ salesOrg: null,
|
|
|
+ productLineCode: null,
|
|
|
+ orgId: '1162',
|
|
|
+ close: null,
|
|
|
+ typeCode1: null,
|
|
|
+ typeName1: null,
|
|
|
+ typeCode2: null,
|
|
|
+ typeName2: null,
|
|
|
+ typeName2List: null,
|
|
|
+ typeCode2List: null,
|
|
|
+ typeCode3: null,
|
|
|
+ typeName3: null,
|
|
|
+ type: null,
|
|
|
+ customerTypeCode2: null,
|
|
|
+ customerTypeName2: null,
|
|
|
+ valid: null,
|
|
|
+ workCode: null,
|
|
|
+ nickName: null,
|
|
|
+ storeCategory: null,
|
|
|
+ categoryDescribe: null,
|
|
|
+ visitId: null,
|
|
|
+ lat: null,
|
|
|
+ lon: null,
|
|
|
+ startTime: null,
|
|
|
+ endTime: null,
|
|
|
+ stateString: null,
|
|
|
+ mainCustomerCode: null,
|
|
|
+ mainCustomerName: null,
|
|
|
+ openDate: null,
|
|
|
+ customerManager: null,
|
|
|
+ monthVisited: null,
|
|
|
+ chainsName: null,
|
|
|
+ hisTime: null,
|
|
|
+ myChainsVisit: null,
|
|
|
+ chainLabelTypes: null,
|
|
|
+ chainLabels: null,
|
|
|
+ skuNum: null,
|
|
|
+ fhCustomer: null,
|
|
|
+ shipped: null,
|
|
|
+ chainSonName: null,
|
|
|
+ beOverdueOne: null,
|
|
|
+ beOverdueTwo: null,
|
|
|
+ beOverdueThree: null,
|
|
|
+ limit: null,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ searchValue: null,
|
|
|
+ createBy: null,
|
|
|
+ createTime: null,
|
|
|
+ updateBy: null,
|
|
|
+ updateTime: null,
|
|
|
+ remark: null,
|
|
|
+ params: {},
|
|
|
+ pageSize: null,
|
|
|
+ pageNum: null,
|
|
|
+ chainId: null,
|
|
|
+ chainCode: '0110033307',
|
|
|
+ chainName: '洛阳豪沃德机械设备有限公司',
|
|
|
+ delFlag: null,
|
|
|
+ orgCode: null,
|
|
|
+ orgCodes: null,
|
|
|
+ orgIds: null,
|
|
|
+ orgName: '36城-豫西销售部',
|
|
|
+ provinceName: null,
|
|
|
+ cityName: null,
|
|
|
+ cityLevel: null,
|
|
|
+ districtName: null,
|
|
|
+ freeze: null,
|
|
|
+ salesOrg: null,
|
|
|
+ productLineCode: null,
|
|
|
+ orgId: '1111',
|
|
|
+ close: null,
|
|
|
+ typeCode1: null,
|
|
|
+ typeName1: null,
|
|
|
+ typeCode2: null,
|
|
|
+ typeName2: null,
|
|
|
+ typeName2List: null,
|
|
|
+ typeCode2List: null,
|
|
|
+ typeCode3: null,
|
|
|
+ typeName3: null,
|
|
|
+ type: null,
|
|
|
+ customerTypeCode2: null,
|
|
|
+ customerTypeName2: null,
|
|
|
+ valid: null,
|
|
|
+ workCode: null,
|
|
|
+ nickName: null,
|
|
|
+ storeCategory: null,
|
|
|
+ categoryDescribe: null,
|
|
|
+ visitId: null,
|
|
|
+ lat: null,
|
|
|
+ lon: null,
|
|
|
+ startTime: null,
|
|
|
+ endTime: null,
|
|
|
+ stateString: null,
|
|
|
+ mainCustomerCode: null,
|
|
|
+ mainCustomerName: null,
|
|
|
+ openDate: null,
|
|
|
+ customerManager: null,
|
|
|
+ monthVisited: null,
|
|
|
+ chainsName: null,
|
|
|
+ hisTime: null,
|
|
|
+ myChainsVisit: null,
|
|
|
+ chainLabelTypes: null,
|
|
|
+ chainLabels: null,
|
|
|
+ skuNum: null,
|
|
|
+ fhCustomer: null,
|
|
|
+ shipped: null,
|
|
|
+ chainSonName: null,
|
|
|
+ beOverdueOne: null,
|
|
|
+ beOverdueTwo: null,
|
|
|
+ beOverdueThree: null,
|
|
|
+ limit: null,
|
|
|
+ },
|
|
|
+ {
|
|
|
+ searchValue: null,
|
|
|
+ createBy: null,
|
|
|
+ createTime: null,
|
|
|
+ updateBy: null,
|
|
|
+ updateTime: null,
|
|
|
+ remark: null,
|
|
|
+ params: {},
|
|
|
+ pageSize: null,
|
|
|
+ pageNum: null,
|
|
|
+ chainId: null,
|
|
|
+ chainCode: '0110046938',
|
|
|
+ chainName: '洛阳融颜装饰工程有限公司',
|
|
|
+ delFlag: null,
|
|
|
+ orgCode: null,
|
|
|
+ orgCodes: null,
|
|
|
+ orgIds: null,
|
|
|
+ orgName: '12城-洛阳销售部',
|
|
|
+ provinceName: null,
|
|
|
+ cityName: null,
|
|
|
+ cityLevel: null,
|
|
|
+ districtName: null,
|
|
|
+ freeze: null,
|
|
|
+ salesOrg: null,
|
|
|
+ productLineCode: null,
|
|
|
+ orgId: '1162',
|
|
|
+ close: null,
|
|
|
+ typeCode1: null,
|
|
|
+ typeName1: null,
|
|
|
+ typeCode2: null,
|
|
|
+ typeName2: null,
|
|
|
+ typeName2List: null,
|
|
|
+ typeCode2List: null,
|
|
|
+ typeCode3: null,
|
|
|
+ typeName3: null,
|
|
|
+ type: null,
|
|
|
+ customerTypeCode2: null,
|
|
|
+ customerTypeName2: null,
|
|
|
+ valid: null,
|
|
|
+ workCode: null,
|
|
|
+ nickName: null,
|
|
|
+ storeCategory: null,
|
|
|
+ categoryDescribe: null,
|
|
|
+ visitId: null,
|
|
|
+ lat: null,
|
|
|
+ lon: null,
|
|
|
+ startTime: null,
|
|
|
+ endTime: null,
|
|
|
+ stateString: null,
|
|
|
+ mainCustomerCode: null,
|
|
|
+ mainCustomerName: null,
|
|
|
+ openDate: null,
|
|
|
+ customerManager: null,
|
|
|
+ monthVisited: null,
|
|
|
+ chainsName: null,
|
|
|
+ hisTime: null,
|
|
|
+ myChainsVisit: null,
|
|
|
+ chainLabelTypes: null,
|
|
|
+ chainLabels: null,
|
|
|
+ skuNum: null,
|
|
|
+ fhCustomer: null,
|
|
|
+ shipped: null,
|
|
|
+ chainSonName: null,
|
|
|
+ beOverdueOne: null,
|
|
|
+ beOverdueTwo: null,
|
|
|
+ beOverdueThree: null,
|
|
|
+ limit: null,
|
|
|
+ },
|
|
|
+ ],
|
|
|
+ };
|
|
|
+ },
|
|
|
+ methods: {
|
|
|
+ activityOnConfirm(date) {
|
|
|
+ this.activityForm.activityDate = this.formatDate(date);
|
|
|
+ this.activityShowCalendar = false;
|
|
|
+ },
|
|
|
+ // 打开二维码
|
|
|
+ openQRCode(values) {
|
|
|
+ this.$emit('onSubmit', values, () => {
|
|
|
+ this.QRCodeBox = true;
|
|
|
+ });
|
|
|
+ },
|
|
|
+ clickValidDateShow(type) {
|
|
|
+ if (type == 'start') {
|
|
|
+ this.activate = {
|
|
|
+ type: type,
|
|
|
+ title: '请选择开始日期',
|
|
|
+ minDate: new Date(2025, 9, 1),
|
|
|
+ maxDate: new Date(2026, 9, 1),
|
|
|
+ };
|
|
|
+ this.validDate = new Date(2025, 9, 1);
|
|
|
+ } else {
|
|
|
+ this.activate = {
|
|
|
+ type: type,
|
|
|
+ title: '请选择结束日期',
|
|
|
+ minDate: this.activityForm.validDateStart
|
|
|
+ ? new Date(this.activityForm.validDateStart)
|
|
|
+ : new Date(),
|
|
|
+ maxDate: new Date(2026, 9, 1),
|
|
|
+ };
|
|
|
+ this.validDate = this.activityForm.validDateEnd
|
|
|
+ ? new Date(this.activityForm.validDateEnd)
|
|
|
+ : new Date();
|
|
|
+ }
|
|
|
+ this.validDateShow = true;
|
|
|
+ },
|
|
|
+ onValidDateConfirm(date) {
|
|
|
+ let time = this.parseTime(new Date(date), '{y}-{m}-{d} {h}:{i}:{s}') + '';
|
|
|
+ if (this.activate.type == 'start') {
|
|
|
+ this.activityForm.validDateStart = time;
|
|
|
+ if (
|
|
|
+ new Date(this.activityForm.validDateStart).getTime() >
|
|
|
+ new Date(this.activityForm.validDateEnd).getTime()
|
|
|
+ ) {
|
|
|
+ this.activityForm.validDateEnd = null;
|
|
|
+ }
|
|
|
+ } else {
|
|
|
+ this.activityForm.validDateEnd = time;
|
|
|
+ }
|
|
|
+ this.validDateShow = false;
|
|
|
+ },
|
|
|
+ formatDate(date) {
|
|
|
+ var Month = date.getMonth() + 1;
|
|
|
+ var Day = date.getDate();
|
|
|
+ if (Month < 10) {
|
|
|
+ Month = '0' + Month;
|
|
|
+ }
|
|
|
+ if (Day < 10) {
|
|
|
+ Day = '0' + Day;
|
|
|
+ }
|
|
|
+ return `${date.getFullYear()}-${Month}-${Day}`;
|
|
|
+ },
|
|
|
+ },
|
|
|
+};
|
|
|
+</script>
|
|
|
+<style scoped lang="scss">
|
|
|
+.ActivityQRCode {
|
|
|
+ .QRCodeActivity {
|
|
|
+ background-color: white;
|
|
|
+ margin-bottom: 10px;
|
|
|
+ .activityItem {
|
|
|
+ display: flex;
|
|
|
+ .van-f-red {
|
|
|
+ position: relative;
|
|
|
+ left: 16px;
|
|
|
+ top: 10px;
|
|
|
+ z-index: 1;
|
|
|
+ }
|
|
|
+ .QRCodeBtnBox {
|
|
|
+ justify-content: space-between;
|
|
|
+ align-items: end;
|
|
|
+ .QRCodeBtn {
|
|
|
+ width: auto;
|
|
|
+ border-radius: 10px;
|
|
|
+ }
|
|
|
+ .tips {
|
|
|
+ font-size: 11px;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+ .QRCodeBox {
|
|
|
+ position: fixed;
|
|
|
+ width: 100%;
|
|
|
+ height: 100%;
|
|
|
+ z-index: 9999999999;
|
|
|
+ top: 0;
|
|
|
+ left: 0;
|
|
|
+ right: 0;
|
|
|
+ bottom: 0;
|
|
|
+ background: linear-gradient(135deg, #6a11cb 0%, #2575fc 100%);
|
|
|
+ display: flex;
|
|
|
+ align-items: center;
|
|
|
+ justify-content: center;
|
|
|
+ .centerBox {
|
|
|
+ width: 90%;
|
|
|
+ // height: 86%;
|
|
|
+ background: rgba(255, 255, 255, 0.1);
|
|
|
+ backdrop-filter: blur(10px);
|
|
|
+ border-radius: 20px;
|
|
|
+ padding: 10px 20px;
|
|
|
+ box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
|
|
|
+ text-align: center;
|
|
|
+ color: #fff;
|
|
|
+ font-size: 18px;
|
|
|
+ display: flex;
|
|
|
+ flex-direction: column;
|
|
|
+ align-items: center;
|
|
|
+ .title {
|
|
|
+ font-size: 24px;
|
|
|
+ font-weight: 600;
|
|
|
+ margin-bottom: 10px;
|
|
|
+ }
|
|
|
+ .activityDate {
|
|
|
+ // font-size: 20px;
|
|
|
+ margin: 10px 0;
|
|
|
+ }
|
|
|
+ .QRCodeUrl {
|
|
|
+ width: 100%;
|
|
|
+ margin: 10px 0;
|
|
|
+ }
|
|
|
+ .validTimeBox {
|
|
|
+ margin-top: 10px;
|
|
|
+ .validTime {
|
|
|
+ margin: 20px 0;
|
|
|
+ font-size: 14px;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ .close {
|
|
|
+ width: 40%;
|
|
|
+ padding: 10px 15px;
|
|
|
+ background: rgba(255, 255, 255, 0.2);
|
|
|
+ border-radius: 12px;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+}
|
|
|
+</style>
|