Skip to content

Commit

Permalink
feat: fill country (#654)
Browse files Browse the repository at this point in the history
* feat: add line color in China Geojson

* feat: fill countries that been there; only support Chinese user;

* feat: fill countries that been there; only support Chinese user;
  • Loading branch information
ben-29 authored Apr 15, 2024
1 parent 7901120 commit e7eec7c
Show file tree
Hide file tree
Showing 6 changed files with 70 additions and 7 deletions.
1 change: 1 addition & 0 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
"dependencies": {
"@mapbox/mapbox-gl-language": "^1.0.0",
"@mapbox/polyline": "^1.1.1",
"@surbowl/world-geo-json-zh": "^2.1.3",
"@svgr/plugin-svgo": "^8.1.0",
"@vercel/analytics": "^0.1.6",
"@vitejs/plugin-react": "^4.0.0",
Expand Down
7 changes: 7 additions & 0 deletions pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

18 changes: 15 additions & 3 deletions src/components/RunMap/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,9 @@ import {
MAP_LAYER_LIST,
IS_CHINESE,
ROAD_LABEL_DISPLAY,
MAIN_COLOR,
MAPBOX_TOKEN,
PROVINCE_FILL_COLOR,
COUNTRY_FILL_COLOR,
USE_DASH_LINE,
LINE_OPACITY,
MAP_HEIGHT,
Expand Down Expand Up @@ -42,7 +42,7 @@ const RunMap = ({
geoData,
thisYear,
}: IRunMapProps) => {
const { provinces } = useActivities();
const { countries, provinces } = useActivities();
const mapRef = useRef<MapRef>();
const [lights, setLights] = useState(PRIVACY_MODE ? false : LIGHTS_ON);
const keepWhenLightsOff = ['runs2']
Expand Down Expand Up @@ -84,8 +84,10 @@ const RunMap = ({
[mapRef, lights]
);
const filterProvinces = provinces.slice();
const filterCountries = countries.slice();
// for geojson format
filterProvinces.unshift('in', 'name');
filterCountries.unshift('in', 'name');

const initGeoDataLength = geoData.features.length;
const isBigMap = (viewState.zoom ?? 0) <= 3;
Expand Down Expand Up @@ -145,11 +147,21 @@ const RunMap = ({
}}
filter={filterProvinces}
/>
<Layer
id="countries"
type="fill"
paint={{
'fill-color': COUNTRY_FILL_COLOR,
// in China, fill a bit lighter while already filled provinces
'fill-opacity': ["case", ["==", ["get", "name"], '中国'], 0.1, 0.5],
}}
filter={filterCountries}
/>
<Layer
id="runs2"
type="line"
paint={{
'line-color': MAIN_COLOR,
'line-color': ['get', 'color'],
'line-width': isBigMap && lights ? 1 : 2,
'line-dasharray': dash,
'line-opacity': isSingleRun || isBigMap || !lights ? 1 : LINE_OPACITY,
Expand Down
35 changes: 35 additions & 0 deletions src/static/run_countries.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { FeatureCollection, LineString, Polygon, MultiPolygon } from 'geojson';
import { MAIN_COLOR } from '@/utils/const';

export type RPGeometry = LineString | Polygon | MultiPolygon;

Expand All @@ -13,6 +14,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '新疆维吾尔自治区',
cp: [84.9023, 42.148],
childNum: 18,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -181,6 +183,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '西藏自治区',
cp: [87.8695, 31.6846],
childNum: 7,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -345,6 +348,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '内蒙古自治区',
cp: [112.5977, 46.3408],
childNum: 12,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -587,6 +591,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '青海省',
cp: [95.2402, 35.4199],
childNum: 8,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -739,6 +744,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '四川省',
cp: [101.9199, 30.1904],
childNum: 21,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -884,6 +890,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '黑龙江省',
cp: [126.1445, 48.7156],
childNum: 13,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -1022,6 +1029,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '甘肃省',
cp: [99.7129, 38.166],
childNum: 14,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -1214,6 +1222,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '云南省',
cp: [101.0652, 25.1807],
childNum: 16,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -1357,6 +1366,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '广西壮族自治区',
cp: [107.7813, 23.6426],
childNum: 14,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -1459,6 +1469,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '湖南省',
cp: [111.5332, 27.3779],
childNum: 14,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -1551,6 +1562,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '陕西省',
cp: [109.5996, 35.7396],
childNum: 10,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -1652,6 +1664,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '广东省',
cp: [113.4668, 22.8076],
childNum: 21,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -1761,6 +1774,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '吉林省',
cp: [125.7746, 43.5938],
childNum: 9,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -1857,6 +1871,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '河北省',
cp: [115.4004, 39.4688],
childNum: 11,
color: MAIN_COLOR,
},
geometry: {
type: 'MultiPolygon',
Expand Down Expand Up @@ -1989,6 +2004,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '湖北省',
cp: [112.2363, 31.1572],
childNum: 17,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2083,6 +2099,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '贵州省',
cp: [106.6113, 26.9385],
childNum: 9,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2179,6 +2196,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '山东省',
cp: [118.7402, 36.4307],
childNum: 17,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2261,6 +2279,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '江西省',
cp: [116.0156, 27.29],
childNum: 11,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2340,6 +2359,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '河南省',
cp: [113.0668, 33.8818],
childNum: 17,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2420,6 +2440,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '辽宁省',
cp: [122.0438, 41.0889],
childNum: 14,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2490,6 +2511,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '山西省',
cp: [112.4121, 37.6611],
childNum: 11,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2559,6 +2581,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '安徽省',
cp: [117.2461, 32.0361],
childNum: 17,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2644,6 +2667,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '福建省',
cp: [118.3008, 25.9277],
childNum: 9,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2717,6 +2741,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '浙江省',
cp: [120.498, 29.0918],
childNum: 11,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2781,6 +2806,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '江苏省',
cp: [118.8586, 32.915],
childNum: 13,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2854,6 +2880,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '重庆市',
cp: [107.7539, 30.1904],
childNum: 40,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2937,6 +2964,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '宁夏回族自治区',
cp: [105.9961, 37.3096],
childNum: 5,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -2993,6 +3021,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '海南省',
cp: [109.9512, 19.2041],
childNum: 18,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -3029,6 +3058,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '台湾省',
cp: [120.0254, 23.5986],
childNum: 1,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -3062,6 +3092,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '北京市',
cp: [116.4551, 40.2539],
childNum: 19,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -3103,6 +3134,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '天津市',
cp: [117.4219, 39.4189],
childNum: 18,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -3143,6 +3175,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '上海市',
cp: [121.4648, 31.2891],
childNum: 19,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -3170,6 +3203,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '香港特别行政区',
cp: [114.1178, 22.3242],
childNum: 1,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down Expand Up @@ -3198,6 +3232,7 @@ export const chinaGeojson: FeatureCollection<RPGeometry> = {
name: '澳门特别行政区',
cp: [111.5547, 22.1484],
childNum: 1,
color: MAIN_COLOR,
},
geometry: {
type: 'Polygon',
Expand Down
2 changes: 2 additions & 0 deletions src/utils/const.ts
Original file line number Diff line number Diff line change
Expand Up @@ -98,9 +98,11 @@ export {
};

const nike = 'rgb(224,237,94)'; // if you want change the main color change here src/styles/variables.scss
const dark_vanilla = 'rgb(228,212,220)';

// If your map has an offset please change this line
// issues #92 and #198
export const NEED_FIX_MAP = false;
export const MAIN_COLOR = nike;
export const PROVINCE_FILL_COLOR = '#47b8e0';
export const COUNTRY_FILL_COLOR = dark_vanilla;
Loading

0 comments on commit e7eec7c

Please sign in to comment.