import { areaData } from '../config/index'; const addressParse = (provinceName, cityName, countryName) => { console.log('[地址解析工具] 开始解析地址'); console.log('[地址解析工具] 输入参数:', { provinceName, cityName, countryName }); console.log('[地址解析工具] 地区数据总数:', areaData ? areaData.length : 0); return new Promise((resolve, reject) => { try { console.log('[地址解析工具] 开始查找省份:', provinceName); const province = areaData.find((v) => v.label === provinceName); if (!province) { console.error('[地址解析工具] 未找到省份:', provinceName); console.log('[地址解析工具] 可用省份列表:', areaData.map(p => p.label)); reject('未找到省份: ' + provinceName); return; } console.log('[地址解析工具] 找到省份:', { label: province.label, value: province.value }); const { value: provinceCode } = province; console.log('[地址解析工具] 开始查找城市:', cityName); console.log('[地址解析工具] 省份下城市数量:', province.children ? province.children.length : 0); const city = province.children.find((v) => v.label === cityName); if (!city) { console.error('[地址解析工具] 未找到城市:', cityName); console.log('[地址解析工具] 省份下可用城市列表:', province.children.map(c => c.label)); reject('未找到城市: ' + cityName); return; } console.log('[地址解析工具] 找到城市:', { label: city.label, value: city.value }); const { value: cityCode } = city; console.log('[地址解析工具] 开始查找区县:', countryName); console.log('[地址解析工具] 城市下区县数量:', city.children ? city.children.length : 0); const country = city.children.find((v) => v.label === countryName); if (!country) { console.error('[地址解析工具] 未找到区县:', countryName); console.log('[地址解析工具] 城市下可用区县列表:', city.children.map(d => d.label)); reject('未找到区县: ' + countryName); return; } console.log('[地址解析工具] 找到区县:', { label: country.label, value: country.value }); const { value: districtCode } = country; const result = { provinceCode, cityCode, districtCode, }; console.log('[地址解析工具] 地址解析成功:', result); resolve(result); } catch (error) { console.error('[地址解析工具] 地址解析异常:', error); console.error('[地址解析工具] 异常堆栈:', error.stack); reject('地址解析失败: ' + (error.message || error)); } }); }; module.exports = { addressParse, };