|
|
@ -657,6 +657,7 @@ async function roadSpotPrepare (ctx) { |
|
|
|
spotRoadIds.push(r.id) |
|
|
|
accumulationMileage += parseFloat(r.chainage_mileage) |
|
|
|
if (accumulationMileage >= targetMileage) { |
|
|
|
|
|
|
|
break; |
|
|
|
} |
|
|
|
} |
|
|
@ -684,13 +685,17 @@ async function roadSpotPrepare (ctx) { |
|
|
|
await filterRoad(otherWhere, true) |
|
|
|
} |
|
|
|
|
|
|
|
return spotRoadIds |
|
|
|
return [spotRoadIds, accumulationMileage] |
|
|
|
} |
|
|
|
let villageMil = 0, townMil = 0, countryMil = 0; |
|
|
|
|
|
|
|
// 抽县
|
|
|
|
const countryRoadTotalMileage = await getRoadTotalMileage('县') |
|
|
|
const countryRoadNeedMileage = countryRoadTotalMileage * countyPercentage / 100 |
|
|
|
let spotCountyRoadIds = await spotRoadId('县', lastCountyRoadIds, countryRoadNeedMileage, []) |
|
|
|
let spotCountyRoadIdsArr = await spotRoadId('县', lastCountyRoadIds, countryRoadNeedMileage, []) |
|
|
|
let spotCountyRoadIds = spotCountyRoadIdsArr[0] |
|
|
|
let countryMil_ = spotCountyRoadIdsArr[1] |
|
|
|
if (countryMil_) countryMil += countryMil_; |
|
|
|
|
|
|
|
// 抽乡
|
|
|
|
const allTownCodeRes = await sequelize.query(` |
|
|
@ -705,15 +710,18 @@ async function roadSpotPrepare (ctx) { |
|
|
|
let spotTownRoadIds = [] |
|
|
|
let spotVillageRoadIds = [] |
|
|
|
let spotVillageIds = [] |
|
|
|
|
|
|
|
for await (let t of allTownCodeRes) { |
|
|
|
// 遍历每个乡镇并抽取
|
|
|
|
let otherWhere = [`township_code='${t.township_code}'`] |
|
|
|
const townRoadTotalMileage = await getRoadTotalMileage('乡', otherWhere) |
|
|
|
const townRoadNeedMileage = townRoadTotalMileage * 25 / 100 |
|
|
|
|
|
|
|
let spotTownRoadIds_ = await spotRoadId('乡', lastTownRoadIds, townRoadNeedMileage, otherWhere) |
|
|
|
let spotTownRoadIdsArr = await spotRoadId('乡', lastTownRoadIds, townRoadNeedMileage, otherWhere) |
|
|
|
let spotTownRoadIds_ = spotTownRoadIdsArr[0] |
|
|
|
let townMil_ = spotTownRoadIdsArr[1] |
|
|
|
spotTownRoadIds = spotTownRoadIds.concat(spotTownRoadIds_) |
|
|
|
|
|
|
|
if (townMil_) townMil += townMil_ |
|
|
|
// 抽村
|
|
|
|
const villageRoadTotalMileage = await getRoadTotalMileage('村', otherWhere) |
|
|
|
const villageRoadNeedMileage = villageRoadTotalMileage * 10 / 100 |
|
|
@ -755,8 +763,11 @@ async function roadSpotPrepare (ctx) { |
|
|
|
villageCheckIdList.unshift(spotFirstVillageId) |
|
|
|
villageCheckIdList = [...(new Set(villageCheckIdList))] |
|
|
|
|
|
|
|
let spotVillageRoadIds_ = await spotRoadId('村', lastVillageRoadRoadIds, villageRoadNeedMileage, otherWhere, villageCheckIdList) |
|
|
|
let spotVillageRoadIdsArr = await spotRoadId('村', lastVillageRoadRoadIds, villageRoadNeedMileage, otherWhere, villageCheckIdList) |
|
|
|
let spotVillageRoadIds_ = spotVillageRoadIdsArr[0] |
|
|
|
let villageMil_ = spotVillageRoadIdsArr[1] |
|
|
|
spotVillageRoadIds = spotVillageRoadIds.concat(spotVillageRoadIds_) |
|
|
|
if (villageMil_) villageMil += villageMil_ |
|
|
|
} |
|
|
|
|
|
|
|
const previewRes = await models.RoadSpotCheckPreview.create({ |
|
|
@ -766,7 +777,10 @@ async function roadSpotPrepare (ctx) { |
|
|
|
townshipRoadId: spotTownRoadIds, |
|
|
|
villageRoadId: spotVillageRoadIds, |
|
|
|
villageId: spotVillageIds, |
|
|
|
checked: false |
|
|
|
checked: false, |
|
|
|
villageMil, |
|
|
|
townMil, |
|
|
|
countryMil |
|
|
|
}) |
|
|
|
|
|
|
|
ctx.status = 200; |
|
|
@ -775,6 +789,10 @@ async function roadSpotPrepare (ctx) { |
|
|
|
spotCountyRoadCount: spotCountyRoadIds.length, |
|
|
|
spotTownRoadCount: spotTownRoadIds.length, |
|
|
|
spotVillageRoadCount: spotVillageRoadIds.length, |
|
|
|
villageMil, |
|
|
|
townMil, |
|
|
|
countryMil |
|
|
|
|
|
|
|
} |
|
|
|
} catch (error) { |
|
|
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); |
|
|
|