From dadbc9b925b73c5b5765650ebaacd379e4fd2555 Mon Sep 17 00:00:00 2001 From: naoki Date: Thu, 7 Nov 2024 15:02:04 +0900 Subject: [PATCH] =?UTF-8?q?=E7=9F=AD=E7=B8=AEID=E3=82=92=E8=87=AA=E5=8B=95?= =?UTF-8?q?=E3=81=A7=E4=BB=98=E4=B8=8E?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- bin/configToMenuYAML.js | 54 +++++++++++++++++++++++++---------------- main.sh | 13 +++++----- 2 files changed, 40 insertions(+), 27 deletions(-) diff --git a/bin/configToMenuYAML.js b/bin/configToMenuYAML.js index 6b3f170..be7e12e 100644 --- a/bin/configToMenuYAML.js +++ b/bin/configToMenuYAML.js @@ -1,12 +1,23 @@ const fs = require('fs'); const yaml = require('js-yaml'); +// タイルレイヤー名から3桁の短縮IDを生成する関数 +const generateShortId = (tileLayerName) => { + const hash = Array.from(tileLayerName) + .reduce((acc, char) => acc + char.charCodeAt(0), 0); // Unicodeの合計を計算 + const alphabet = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'; + return ( + alphabet[hash % 26] + + alphabet[Math.floor((hash / 26) % 26)] + + alphabet[Math.floor((hash / 676) % 26)] + ); // 3文字のIDを生成 +}; + const configToMenuYAML = (config, outputFile) => { const app = { - // TODO: 別の設定ファイルから読み込むようにする name: 'スマートマップ', - zoom: 10, - center: [135.513, 34.6815], + zoom: 12, + center: [138.29255, 34.83344], minZoom: 9, maxZoom: 20, menus: { @@ -22,9 +33,9 @@ const configToMenuYAML = (config, outputFile) => { const menu = app.menus['都市情報一覧'].items; config.forEach(item => { - const { 大カテゴリー, 中カテゴリー, メニュータイトル, タイルレイヤー名, データ種別, 短縮レイヤーID, レイヤー色 } = item; + const { 大カテゴリー, 中カテゴリー, メニュータイトル, タイルレイヤー名, データ種別, レイヤー色, データ参照先 } = item; - const isFiware = データ種別 === 'fiware'; + const isCustomDataType = データ種別 === 'fiware' || データ種別 === 'raster'; if (!大カテゴリー && 中カテゴリー) { throw new Error('中カテゴリーを指定する場合は、大カテゴリーも指定してください'); @@ -37,7 +48,7 @@ const configToMenuYAML = (config, outputFile) => { // 中カテゴリーがない場合は追加 if (中カテゴリー && !menu[大カテゴリー].items[中カテゴリー]) { - menu[大カテゴリー].items[中カテゴリー] = { id: `${大カテゴリー}/${中カテゴリー}`,type: 'category', items: {} }; + menu[大カテゴリー].items[中カテゴリー] = { id: `${大カテゴリー}/${中カテゴリー}`, type: 'category', items: {} }; } if (メニュータイトル) { @@ -53,23 +64,23 @@ const configToMenuYAML = (config, outputFile) => { id: `${大カテゴリー}/${中カテゴリー}/${メニュータイトル}`, type: 'data', tileId: タイルレイヤー名, - shortId: 短縮レイヤーID }; - // レイヤー色が指定されている場合はメタデータに追加 if (レイヤー色) { data.metadata = { color: レイヤー色 }; } - if (isFiware) { - data.dataType = 'fiware'; + if (isCustomDataType) { + data.dataType = データ種別; + data.shortId = generateShortId(データ参照先) // Fiwareの場合はデータ参照先を使用 + } else { + data.shortId = generateShortId(タイルレイヤー名) } menu[大カテゴリー].items[中カテゴリー].items[メニュータイトル] = data; return; } - // 大カテゴリとメニュータイトルがある場合 if (大カテゴリー && メニュータイトル) { if (menu[大カテゴリー].items[メニュータイトル]) { @@ -80,23 +91,23 @@ const configToMenuYAML = (config, outputFile) => { id: `${大カテゴリー}/${メニュータイトル}`, type: 'data', tileId: タイルレイヤー名, - shortId: 短縮レイヤーID }; - // レイヤー色が指定されている場合はメタデータに追加 if (レイヤー色) { data.metadata = { color: レイヤー色 }; } - if (isFiware) { - data.dataType = 'fiware'; + if (isCustomDataType) { + data.dataType = データ種別; + data.shortId = generateShortId(データ参照先) // Fiwareの場合はデータ参照先を使用 + } else { + data.shortId = generateShortId(タイルレイヤー名) } menu[大カテゴリー].items[メニュータイトル] = data; return; } - // メニュータイトルのみの場合 if (メニュータイトル) { if (menu[メニュータイトル]) { @@ -107,18 +118,19 @@ const configToMenuYAML = (config, outputFile) => { id: メニュータイトル, type: 'data', tileId: タイルレイヤー名, - shortId: 短縮レイヤーID }; - // レイヤー色が指定されている場合はメタデータに追加 if (レイヤー色) { data.metadata = { color: レイヤー色 }; } - if (isFiware) { - data.dataType = 'fiware'; + if (isCustomDataType) { + data.dataType = データ種別; + data.shortId = generateShortId(データ参照先) // Fiwareの場合はデータ参照先を使用 + } else { + data.shortId = generateShortId(タイルレイヤー名) } - + menu[メニュータイトル] = data; return; diff --git a/main.sh b/main.sh index 73ed477..bb43318 100755 --- a/main.sh +++ b/main.sh @@ -40,7 +40,6 @@ jq -c '.[]' $json_file | while read item; do reference=$(echo $item | jq -r '.["データ参照先"]') tippecanoe_opts=$(echo $item | jq -r '.["Tippecanoeオプション"]') - # -------------------------------------------------- # 1. データ参照先で URL で指定されたファイルをダウンロード(GeoJSONとCSVに対応) # -------------------------------------------------- @@ -67,16 +66,18 @@ jq -c '.[]' $json_file | while read item; do # -------------------------------------------------- # Shape の場合 - if [ $dataType = "shape" ]; then + if [ "$dataType" = "shape" ]; then + extensions=("shp" "prj" "cpg" "dbf" "sbn" "fbn" "ain" "ixs" "mxs" "atx" "shp.xml" "shx" "sbx") - reference_file=$(basename $reference ".shp") + reference_file=$(basename "$reference" ".shp") for ext in "${extensions[@]}"; do + # -iname を使って拡張子の大文字小文字を無視して検索し、結果を小文字に変換 src=$(find "$input_directory" -iname "$reference_file.$ext" -print -quit) - dst="$input_directory/$tileLayer.$ext" + dst="$input_directory/$tileLayer.${ext,,}" # ${ext,,}で拡張子を小文字に変換 # 移動元と移動先が同じか確認 if [ -n "$src" ] && [ "$src" != "$dst" ]; then - echo "ファイル名を変更: $src to $dst" + echo "ファイル名を変更: $src to $dst" mv "$src" "$dst" else echo "移動元と移動先が同じファイルです。操作をスキップします。" @@ -157,7 +158,7 @@ jq -c '.[]' $json_file | while read item; do "--force" ) - if [ $dataType != "fiware" ]; then + if [[ "$dataType" != "fiware" && "$dataType" != "raster" ]]; then ndgeojsonfile="$input_directory/$tileLayer.ndgeojson" mbtilesfile="$input_directory/$tileLayer.mbtiles"