init
This commit is contained in:
@@ -0,0 +1,223 @@
|
||||
"use strict";
|
||||
var common_vendor = require("../../../common/vendor.js");
|
||||
var pages_api_order = require("../../../pages/api/order.js");
|
||||
require("../../../utils/request.js");
|
||||
require("../../../utils/env.js");
|
||||
require("../../../pages/api/login.js");
|
||||
if (!Array) {
|
||||
const _easycom_uni_popup2 = common_vendor.resolveComponent("uni-popup");
|
||||
_easycom_uni_popup2();
|
||||
}
|
||||
const _easycom_uni_popup = () => "../../../uni_modules/uni-popup/components/uni-popup/uni-popup.js";
|
||||
if (!Math) {
|
||||
_easycom_uni_popup();
|
||||
}
|
||||
const _sfc_main = {
|
||||
__name: "selectArea",
|
||||
props: {
|
||||
provinceId: {
|
||||
type: String,
|
||||
default: ""
|
||||
},
|
||||
cityId: {
|
||||
type: String,
|
||||
default: ""
|
||||
},
|
||||
countyId: {
|
||||
type: String,
|
||||
default: ""
|
||||
}
|
||||
},
|
||||
emits: ["@getAreaData"],
|
||||
setup(__props, { expose, emit: emits }) {
|
||||
const props = __props;
|
||||
const popup = common_vendor.ref();
|
||||
let province = common_vendor.reactive({
|
||||
data: []
|
||||
});
|
||||
let selectedProvince = common_vendor.reactive({
|
||||
data: {
|
||||
name: "\u5317\u4EAC\u5E02",
|
||||
id: "1"
|
||||
}
|
||||
});
|
||||
const city = common_vendor.reactive({
|
||||
data: []
|
||||
});
|
||||
let selectedCity = common_vendor.reactive({
|
||||
data: {
|
||||
name: "\u76F4\u8F96\u5E02",
|
||||
id: "2"
|
||||
}
|
||||
});
|
||||
const area = common_vendor.reactive({
|
||||
data: []
|
||||
});
|
||||
let selectedArea = common_vendor.reactive({
|
||||
data: {
|
||||
name: "\u4E1C\u57CE\u533A",
|
||||
id: "3"
|
||||
}
|
||||
});
|
||||
let areaIndex = common_vendor.reactive({
|
||||
data: [0, 0, 0]
|
||||
});
|
||||
let hotCityIndex = common_vendor.ref("");
|
||||
const cityList = common_vendor.reactive([
|
||||
{
|
||||
label: "\u5317\u4EAC",
|
||||
provinceId: "1",
|
||||
cityId: "2",
|
||||
countyId: "3"
|
||||
},
|
||||
{
|
||||
label: "\u4E0A\u6D77",
|
||||
provinceId: "161792",
|
||||
cityId: "161793",
|
||||
countyId: "161794"
|
||||
},
|
||||
{
|
||||
label: "\u5E7F\u5DDE",
|
||||
provinceId: "483250",
|
||||
cityId: "483251",
|
||||
countyId: "483252"
|
||||
},
|
||||
{
|
||||
label: "\u6DF1\u5733",
|
||||
provinceId: "483250",
|
||||
cityId: "487721",
|
||||
countyId: "487722"
|
||||
}
|
||||
]);
|
||||
let placeIdItem = common_vendor.reactive({
|
||||
provinceId: "",
|
||||
cityId: "",
|
||||
countyId: ""
|
||||
});
|
||||
let chooseType = common_vendor.ref("select");
|
||||
common_vendor.watch(props, (newValue, oldValue) => {
|
||||
placeIdItem.provinceId = newValue.provinceId;
|
||||
placeIdItem.cityId = newValue.cityId;
|
||||
placeIdItem.countyId = newValue.countyId;
|
||||
});
|
||||
const handleHotCityClick = (item, index) => {
|
||||
placeIdItem.provinceId = item.provinceId;
|
||||
placeIdItem.cityId = item.cityId;
|
||||
placeIdItem.countyId = item.countyId;
|
||||
getAreaInfo("", province);
|
||||
getAreaInfo(placeIdItem.provinceId, city);
|
||||
getAreaInfo(placeIdItem.cityId, area);
|
||||
chooseType.value = "click";
|
||||
hotCityIndex.value = index;
|
||||
};
|
||||
const getList = () => {
|
||||
getAreaInfo("", province);
|
||||
getAreaInfo(placeIdItem.provinceId || 1, city);
|
||||
getAreaInfo(placeIdItem.cityId || 2, area);
|
||||
};
|
||||
const getAreaInfo = (parentId, type) => {
|
||||
pages_api_order.getArea({
|
||||
parentId
|
||||
}).then((res) => {
|
||||
type.data = res.data;
|
||||
if (type === province) {
|
||||
common_vendor.nextTick(() => {
|
||||
selectedProvince.data = res.data.filter((item) => item.id == placeIdItem.provinceId)[0] || res.data[0];
|
||||
areaIndex.data[0] = res.data.findIndex((item) => item.id == placeIdItem.provinceId);
|
||||
});
|
||||
} else if (type === city) {
|
||||
common_vendor.nextTick(() => {
|
||||
selectedCity.data = res.data.filter((item) => item.id == placeIdItem.cityId)[0] || res.data[0];
|
||||
areaIndex.data[1] = res.data.findIndex((item) => item.id == placeIdItem.cityId);
|
||||
});
|
||||
} else if (type === area) {
|
||||
common_vendor.nextTick(() => {
|
||||
selectedArea.data = res.data.filter((item) => item.id == placeIdItem.countyId)[0] || res.data[0];
|
||||
areaIndex.data[2] = res.data.findIndex((item) => item.id == placeIdItem.countyId);
|
||||
});
|
||||
}
|
||||
});
|
||||
};
|
||||
const handlePickStart = () => {
|
||||
chooseType.value = "select";
|
||||
};
|
||||
const bindChange = (event) => {
|
||||
if (chooseType.value === "click")
|
||||
return;
|
||||
if (areaIndex.data[0] !== event.detail.value[0]) {
|
||||
getAreaInfo(province.data[event.detail.value[0]].id, city);
|
||||
getAreaInfo(Number(province.data[event.detail.value[0]].id) + 1, area);
|
||||
selectedProvince.data = province.data[event.detail.value[0]];
|
||||
} else if (areaIndex.data[1] !== event.detail.value[1]) {
|
||||
getAreaInfo(city.data[event.detail.value[1]].id, area);
|
||||
selectedCity.data = city.data[event.detail.value[1]];
|
||||
} else {
|
||||
selectedArea.data = area.data[event.detail.value[2]];
|
||||
}
|
||||
areaIndex.data = event.detail.value;
|
||||
hotCityIndex.value = "";
|
||||
};
|
||||
const handleOpen = () => {
|
||||
popup.value.open("bottom");
|
||||
};
|
||||
const handleCancel = () => {
|
||||
popup.value.close("bottom");
|
||||
};
|
||||
const confirm = () => {
|
||||
handleCancel();
|
||||
emits("getAreaData", {
|
||||
province: selectedProvince.data,
|
||||
city: selectedCity.data,
|
||||
area: selectedArea.data
|
||||
});
|
||||
};
|
||||
expose({
|
||||
handleOpen,
|
||||
getList
|
||||
});
|
||||
return (_ctx, _cache) => {
|
||||
return {
|
||||
a: common_vendor.o(handleCancel),
|
||||
b: common_vendor.f(cityList, (item, index, i0) => {
|
||||
return {
|
||||
a: common_vendor.t(item.label),
|
||||
b: common_vendor.n(index === common_vendor.unref(hotCityIndex) ? "active" : ""),
|
||||
c: index,
|
||||
d: common_vendor.o(($event) => handleHotCityClick(item, index), index)
|
||||
};
|
||||
}),
|
||||
c: common_vendor.f(common_vendor.unref(province).data, (item, index, i0) => {
|
||||
return {
|
||||
a: common_vendor.t(item.name),
|
||||
b: index
|
||||
};
|
||||
}),
|
||||
d: common_vendor.f(city.data, (item, index, i0) => {
|
||||
return {
|
||||
a: common_vendor.t(item.name),
|
||||
b: index
|
||||
};
|
||||
}),
|
||||
e: common_vendor.f(area.data, (item, index, i0) => {
|
||||
return {
|
||||
a: common_vendor.t(item.name),
|
||||
b: index
|
||||
};
|
||||
}),
|
||||
f: common_vendor.unref(areaIndex).data,
|
||||
g: `height: 50px;`,
|
||||
h: common_vendor.o(bindChange),
|
||||
i: common_vendor.o(handlePickStart),
|
||||
j: common_vendor.o(confirm),
|
||||
k: common_vendor.sr(popup, "7dfaf907-0", {
|
||||
"k": "popup"
|
||||
}),
|
||||
l: common_vendor.p({
|
||||
type: "bottom"
|
||||
})
|
||||
};
|
||||
};
|
||||
}
|
||||
};
|
||||
var Component = /* @__PURE__ */ common_vendor._export_sfc(_sfc_main, [["__scopeId", "data-v-7dfaf907"], ["__file", "E:/project/project-wl-yonghuduan-uniapp-vue3/subPages/address-info/components/selectArea.vue"]]);
|
||||
wx.createComponent(Component);
|
@@ -0,0 +1,6 @@
|
||||
{
|
||||
"component": true,
|
||||
"usingComponents": {
|
||||
"uni-popup": "../../../uni_modules/uni-popup/components/uni-popup/uni-popup"
|
||||
}
|
||||
}
|
@@ -0,0 +1 @@
|
||||
<view class="selectArea data-v-7dfaf907"><uni-popup wx:if="{{l}}" class="r data-v-7dfaf907" u-s="{{['d']}}" u-r="popup" u-i="7dfaf907-0" bind:__l="__l" u-p="{{l}}"><view class="header data-v-7dfaf907"><view class="header-title data-v-7dfaf907">选择省市区</view><view class="close data-v-7dfaf907" bindtap="{{a}}"></view></view><view class="hot-city data-v-7dfaf907"><view class="title data-v-7dfaf907">热门城市</view><view class="city-box data-v-7dfaf907"><view wx:for="{{b}}" wx:for-item="item" wx:key="c" class="{{['city-item', 'data-v-7dfaf907', item.b]}}" bindtap="{{item.d}}">{{item.a}}</view></view></view><view class="province-city-area data-v-7dfaf907"><view class="label-box data-v-7dfaf907"><view class="label data-v-7dfaf907">省份</view><view class="label data-v-7dfaf907">城市</view><view class="label data-v-7dfaf907">区县</view></view><picker-view value="{{f}}" indicator-style="{{g}}" bindchange="{{h}}" bindpickstart="{{i}}" class="picker-view data-v-7dfaf907"><picker-view-column class="data-v-7dfaf907"><view wx:for="{{c}}" wx:for-item="item" wx:key="b" class="item data-v-7dfaf907">{{item.a}}</view></picker-view-column><picker-view-column class="data-v-7dfaf907"><view wx:for="{{d}}" wx:for-item="item" wx:key="b" class="item data-v-7dfaf907">{{item.a}}</view></picker-view-column><picker-view-column class="data-v-7dfaf907"><view wx:for="{{e}}" wx:for-item="item" wx:key="b" class="item data-v-7dfaf907">{{item.a}}</view></picker-view-column></picker-view></view><view class="footer data-v-7dfaf907"><view class="btn data-v-7dfaf907" bindtap="{{j}}">确定</view></view></uni-popup></view>
|
@@ -0,0 +1,123 @@
|
||||
/* 水平间距 */
|
||||
/* 水平间距 */
|
||||
.selectArea.data-v-7dfaf907 .uni-popup__wrapper {
|
||||
height: 1160rpx;
|
||||
background-color: white !important;
|
||||
border-radius: 24rpx 24rpx 0 0;
|
||||
}
|
||||
.selectArea .header.data-v-7dfaf907 {
|
||||
display: flex;
|
||||
height: 56rpx;
|
||||
padding: 30rpx 38rpx;
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
border-radius: 24rpx 24rpx 0 0;
|
||||
}
|
||||
.selectArea .header .header-title.data-v-7dfaf907 {
|
||||
font-size: 32rpx;
|
||||
color: #151515;
|
||||
font-weight: bold;
|
||||
}
|
||||
.selectArea .header .close.data-v-7dfaf907 {
|
||||
width: 24rpx;
|
||||
height: 24rpx;
|
||||
background-repeat: no-repeat;
|
||||
background-size: contain;
|
||||
background-image: url("");
|
||||
}
|
||||
.selectArea .seachBox.data-v-7dfaf907 .uni-searchbar {
|
||||
padding-left: 38rpx !important;
|
||||
}
|
||||
.selectArea .seachBox.data-v-7dfaf907 .uni-searchbar .uni-searchbar__box {
|
||||
border-radius: 34rpx !important;
|
||||
}
|
||||
.selectArea .seachBox .search-icon.data-v-7dfaf907 {
|
||||
width: 40rpx;
|
||||
height: 40rpx;
|
||||
background-repeat: no-repeat;
|
||||
background-size: contain;
|
||||
background-image: url("");
|
||||
}
|
||||
.selectArea .hot-city.data-v-7dfaf907 {
|
||||
margin-top: 31rpx;
|
||||
border-bottom: 2rpx solid #F4F4F4;
|
||||
padding-bottom: 40rpx;
|
||||
margin: 0 38rpx;
|
||||
}
|
||||
.selectArea .hot-city .title.data-v-7dfaf907 {
|
||||
font-size: 24rpx;
|
||||
color: #888;
|
||||
}
|
||||
.selectArea .hot-city .city-box.data-v-7dfaf907 {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
justify-content: space-between;
|
||||
}
|
||||
.selectArea .hot-city .city-box .city-item.data-v-7dfaf907 {
|
||||
font-size: 24rpx;
|
||||
height: 64rpx;
|
||||
background: #F4F4F4;
|
||||
border-radius: 34rpx;
|
||||
min-width: 148rpx;
|
||||
margin-top: 18rpx;
|
||||
text-align: center;
|
||||
line-height: 64rpx;
|
||||
}
|
||||
.selectArea .hot-city .city-box .city-item.active.data-v-7dfaf907 {
|
||||
border: 2rpx solid #E84134;
|
||||
color: #E84134;
|
||||
background-color: white;
|
||||
}
|
||||
.selectArea .province-city-area.data-v-7dfaf907 {
|
||||
margin-top: -10rpx;
|
||||
}
|
||||
.selectArea .province-city-area .picker-view.data-v-7dfaf907 {
|
||||
width: 750rpx;
|
||||
height: 600rpx;
|
||||
margin-top: 20rpx;
|
||||
}
|
||||
.selectArea .province-city-area .item.data-v-7dfaf907 {
|
||||
height: 50px;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
text-align: center;
|
||||
display: flex;
|
||||
}
|
||||
.selectArea .province-city-area.data-v-7dfaf907 .uni-picker-view-wrapper .uni-picker-view-mask {
|
||||
display: none;
|
||||
}
|
||||
.selectArea .province-city-area.data-v-7dfaf907 .uni-picker-view-wrapper .uni-picker-view-indicator {
|
||||
top: 46% !important;
|
||||
}
|
||||
.selectArea .province-city-area .label-box.data-v-7dfaf907 {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
padding: 40rpx 90rpx;
|
||||
}
|
||||
.selectArea .province-city-area .label-box .label.data-v-7dfaf907 {
|
||||
font-size: 30rpx;
|
||||
font-weight: bold;
|
||||
}
|
||||
.selectArea .footer.data-v-7dfaf907 {
|
||||
height: 168rpx;
|
||||
width: 100%;
|
||||
background-color: white;
|
||||
position: fixed;
|
||||
bottom: 0;
|
||||
left: 0;
|
||||
padding-top: 80rpx;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
.selectArea .footer .btn.data-v-7dfaf907 {
|
||||
width: 404rpx;
|
||||
height: 88rpx;
|
||||
background: #E84134;
|
||||
border-radius: 44rpx;
|
||||
color: white;
|
||||
text-align: center;
|
||||
line-height: 88rpx;
|
||||
font-size: 30rpx;
|
||||
margin: 0 auto;
|
||||
}
|
Reference in New Issue
Block a user