Compare commits
	
		
			22 Commits
		
	
	
		
			0.1a-rc3
			...
			6aef6dabb2
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 6aef6dabb2 | ||
|  | 91574f4060 | ||
|  | 8b2b694a00 | ||
|  | fbeefa0276 | ||
|  | cd999c2a6e | ||
|  | 728994a8f3 | ||
|  | 6123048426 | ||
|  | ddef61a0cf | ||
|  | 59a72e0544 | ||
|  | a3f81c95a0 | ||
|  | d041df9805 | ||
|  | 01dab6aa30 | ||
|  | bafd3cea14 | ||
|  | ec52574ae3 | ||
|  | 923404ebc5 | ||
|  | 32ba5e0b07 | ||
|  | 72b2148e4b | ||
|  | 513660b3a4 | ||
|  | 443d62b6df | ||
|  | a360c7496b | ||
|  | 3fe83cff2e | ||
|  | 71acf04f20 | 
							
								
								
									
										16
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						| @@ -48,17 +48,17 @@ jobs: | ||||
|           cache: 'gradle' | ||||
|  | ||||
|       - name: Build APK | ||||
|         run: ./gradlew assemble | ||||
|  | ||||
|       # - name: Upload APK | ||||
|       #   uses: actions/upload-artifact@v4 | ||||
|       #   with: | ||||
|       #     name: app.apk | ||||
|       #     path: app/build/outputs/apk/release/app-release.apk | ||||
|         run: ./gradlew assembleSignedRelease | ||||
|  | ||||
|       - name: Release | ||||
|         uses: softprops/action-gh-release@v2 | ||||
|         if: startsWith(github.ref, 'refs/tags/') | ||||
|         with: | ||||
|           files: | | ||||
|             app/build/outputs/apk/release/app-release.apk    | ||||
|             app/build/outputs/apk/signedRelease/app-signedRelease.apk | ||||
|           prerelease: | | ||||
|             if [[ ${{ github.ref }} =~ ^refs/tags/[0-9]+\.[0-9]+[a-z]+$ ]]; then | ||||
|               echo "false" | ||||
|             else | ||||
|               echo "true" | ||||
|             fi | ||||
| @@ -5,9 +5,6 @@ plugins { | ||||
|     id 'com.mikepenz.aboutlibraries.plugin' version '11.1.1' | ||||
| } | ||||
|  | ||||
| def keystorePropertiesFile = rootProject.file("app/keystore.properties") | ||||
| def keystoreProperties = new Properties() | ||||
| keystoreProperties.load(new FileInputStream(keystorePropertiesFile)) | ||||
|  | ||||
| android { | ||||
|     namespace 'net.helcel.beans' | ||||
| @@ -20,22 +17,37 @@ android { | ||||
|         versionCode 1 | ||||
|         versionName "0.1a" | ||||
|     } | ||||
|  | ||||
|     signingConfigs { | ||||
|         create("release") { | ||||
|             try { | ||||
|                 def keystorePropertiesFile = rootProject.file("app/keystore.properties") | ||||
|                 def keystoreProperties = new Properties() | ||||
|                 keystoreProperties.load(new FileInputStream(keystorePropertiesFile)) | ||||
|  | ||||
|                 keyAlias keystoreProperties['keyAlias'] | ||||
|                 keyPassword keystoreProperties['keyPassword'] | ||||
|                 storeFile file(keystoreProperties['storeFile']) | ||||
|                 storePassword keystoreProperties['storePassword'] | ||||
|             } catch (FileNotFoundException e) { | ||||
|                 println("File not found: ${e.message}") | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|  | ||||
|     buildTypes { | ||||
|         debug { | ||||
|             debuggable true | ||||
|         } | ||||
|         release { | ||||
|             minifyEnabled true | ||||
|             shrinkResources false | ||||
|             proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' | ||||
|         } | ||||
|         signedRelease { | ||||
|             minifyEnabled true | ||||
|             shrinkResources false | ||||
|             proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' | ||||
|             signingConfig = signingConfigs.getByName("release") | ||||
|         } | ||||
|     } | ||||
| @@ -75,6 +87,5 @@ dependencies { | ||||
|  | ||||
|     implementation 'com.caverock:androidsvg-aar:1.4' | ||||
|     implementation 'com.github.chrisbanes:PhotoView:2.3.0' | ||||
|     implementation "com.github.AppDevNext:AndroidChart:3.1.0.21" | ||||
|     implementation 'com.mikepenz:aboutlibraries:11.1.1' | ||||
| } | ||||
							
								
								
									
										4893
									
								
								app/src/main/assets/aeqd01.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.4 MiB | 
							
								
								
									
										4893
									
								
								app/src/main/assets/eqdc01.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.4 MiB | 
							
								
								
									
										4893
									
								
								app/src/main/assets/eqearth01.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.4 MiB | 
| @@ -32,7 +32,8 @@ AFG_TK|AFG|Takhar|12361 | ||||
| AFG_OZ|AFG|Uruzgan|12900 | ||||
| AFG_VR|AFG|Wardak|8945 | ||||
| AFG_ZB|AFG|Zabul|17375 | ||||
| XAD_NA|XAD|Dhekelia|125 | ||||
| XAD_Akrotiri|XAD|Akrotiri|109 | ||||
| XAD_Dhekelia|XAD|Dhekelia|125 | ||||
| ALA_AR|ALA|Archipelago|448 | ||||
| ALA_CO|ALA|Countryside|1022 | ||||
| ALA_MH|ALA|Mariehamn|13 | ||||
| @@ -49,8 +50,8 @@ ALB_SD|ALB|Shkodër|3507 | ||||
| ALB_TI|ALB|Tiranë|1638 | ||||
| ALB_VR|ALB|Vlorë|2648 | ||||
| DZA_AR|DZA|Adrar|433285 | ||||
| DZA_AD|DZA|AïnDefla|4557 | ||||
| DZA_AT|DZA|AïnTémouchent|2405 | ||||
| DZA_AD|DZA|Aïn Defla|4557 | ||||
| DZA_AT|DZA|Aïn Témouchent|2405 | ||||
| DZA_AL|DZA|Alger|769 | ||||
| DZA_AN|DZA|Annaba|1413 | ||||
| DZA_BT|DZA|Batna|12167 | ||||
| @@ -106,7 +107,7 @@ AND_EN|AND|Encamp|68 | ||||
| AND_EE|AND|Escaldes-Engordany|47 | ||||
| AND_MA|AND|La Massana|68 | ||||
| AND_OR|AND|Ordino|79 | ||||
| AND_JL|AND|Sant Juliàde Lòria|65 | ||||
| AND_JL|AND|Sant Julià de Lòria|65 | ||||
| AGO_BO|AGO|Bengo|34586 | ||||
| AGO_BG|AGO|Benguela|39748 | ||||
| AGO_BI|AGO|Bié|72491 | ||||
| @@ -126,14 +127,17 @@ AGO_NA|AGO|Namibe|58240 | ||||
| AGO_UI|AGO|Uíge|62425 | ||||
| AGO_ZA|AGO|Zaire|36821 | ||||
| AIA_BP|AIA|Blowing Point|5 | ||||
| AIA_NA|AIA|Sombrero Island|0 | ||||
| AIA_DogIsland|AIA|Dog Island|2 | ||||
| AIA_EE|AIA|East End|5 | ||||
| AIA_GH|AIA|George Hill|7 | ||||
| AIA_IH|AIA|Island Harbour|6 | ||||
| AIA_NH|AIA|North Hill|1 | ||||
| AIA_NS|AIA|North Side|9 | ||||
| AIA_PriclyPearCays|AIA|Pricly Pear Cays|0 | ||||
| AIA_SG|AIA|Sandy Ground|1 | ||||
| AIA_SH|AIA|Sandy Hill|7 | ||||
| AIA_ScrubIsland|AIA|Scrub Island|4 | ||||
| AIA_SombreroIsland|AIA|Sombrero Island|0 | ||||
| AIA_SO|AIA|South Hill|7 | ||||
| AIA_ST|AIA|Stoney Ground|7 | ||||
| AIA_TF|AIA|The Farrington|5 | ||||
| @@ -152,7 +156,7 @@ ARG_BA|ARG|Buenos Aires|307606 | ||||
| ARG_CT|ARG|Catamarca|101718 | ||||
| ARG_CC|ARG|Chaco|100177 | ||||
| ARG_CH|ARG|Chubut|224436 | ||||
| ARG_DF|ARG|Ciudadde Buenos Aires|212 | ||||
| ARG_DF|ARG|Ciudad de Buenos Aires|212 | ||||
| ARG_CB|ARG|Córdoba|165143 | ||||
| ARG_CN|ARG|Corrientes|89281 | ||||
| ARG_ER|ARG|Entre Ríos|78238 | ||||
| @@ -163,14 +167,14 @@ ARG_LR|ARG|La Rioja|91415 | ||||
| ARG_MZ|ARG|Mendoza|149125 | ||||
| ARG_MN|ARG|Misiones|30098 | ||||
| ARG_NQ|ARG|Neuquén|94649 | ||||
| ARG_RN|ARG|RíoNegro|202737 | ||||
| ARG_RN|ARG|Río Negro|202737 | ||||
| ARG_SA|ARG|Salta|155883 | ||||
| ARG_SJ|ARG|San Juan|89103 | ||||
| ARG_SL|ARG|San Luis|76041 | ||||
| ARG_SC|ARG|Santa Cruz|242689 | ||||
| ARG_SF|ARG|Santa Fe|133534 | ||||
| ARG_SE|ARG|Santiagodel Estero|137431 | ||||
| ARG_TF|ARG|Tierradel Fuego|20841 | ||||
| ARG_SE|ARG|Santiago del Estero|137431 | ||||
| ARG_TF|ARG|Tierra del Fuego|20841 | ||||
| ARG_TM|ARG|Tucumán|22628 | ||||
| ARM_AG|ARM|Aragatsotn|2884 | ||||
| ARM_AR|ARM|Ararat|2227 | ||||
| @@ -183,7 +187,7 @@ ARM_SH|ARM|Shirak|2987 | ||||
| ARM_SU|ARM|Syunik|4504 | ||||
| ARM_TV|ARM|Tavush|2521 | ||||
| ARM_VD|ARM|Vayots Dzor|2316 | ||||
| AUS_AS|AUS|Ashmoreand Cartier Islands|18 | ||||
| AUS_AS|AUS|Ashmore and Cartier Islands|18 | ||||
| AUS_AC|AUS|Australian Capital Territory|2364 | ||||
| AUS_CR|AUS|Coral Sea Islands Territory|7 | ||||
| AUS_JB|AUS|Jervis Bay Territory|68 | ||||
| @@ -203,8 +207,16 @@ AUT_ST|AUT|Steiermark|16408 | ||||
| AUT_TR|AUT|Tirol|12646 | ||||
| AUT_VO|AUT|Vorarlberg|2602 | ||||
| AUT_WI|AUT|Wien|415 | ||||
| AZE_NA|AZE|Yukhari-Karabakh|7407 | ||||
| AZE_Absheron|AZE|Absheron|6147 | ||||
| AZE_Aran|AZE|Aran|21914 | ||||
| AZE_Daglig-Shirvan|AZE|Daglig-Shirvan|5989 | ||||
| AZE_Ganja-Qazakh|AZE|Ganja-Qazakh|12044 | ||||
| AZE_Kalbajar-Lachin|AZE|Kalbajar-Lachin|5770 | ||||
| AZE_LA|AZE|Lankaran|5592 | ||||
| AZE_Nakhchivan|AZE|Nakhchivan|5400 | ||||
| AZE_Quba-Khachmaz|AZE|Quba-Khachmaz|7339 | ||||
| AZE_Shaki-Zaqatala|AZE|Shaki-Zaqatala|8729 | ||||
| AZE_Yukhari-Karabakh|AZE|Yukhari-Karabakh|7407 | ||||
| BHS_AK|BHS|Acklins|496 | ||||
| BHS_BR|BHS|Berry Islands|61 | ||||
| BHS_BI|BHS|Biminis|34 | ||||
| @@ -213,7 +225,7 @@ BHS_CI|BHS|Cat Island|371 | ||||
| BHS_CB|BHS|Central Abaco|712 | ||||
| BHS_CN|BHS|Central Andros|1216 | ||||
| BHS_CE|BHS|Central Eleuthera|70 | ||||
| BHS_FP|BHS|Cityof Freeport|25 | ||||
| BHS_FP|BHS|City of Freeport|25 | ||||
| BHS_CK|BHS|Crooked Island|334 | ||||
| BHS_EB|BHS|East Grand Bahama|580 | ||||
| BHS_EM|BHS|Exuma|348 | ||||
| @@ -224,7 +236,7 @@ BHS_IN|BHS|Inagua|1688 | ||||
| BHS_LI|BHS|Long Island|481 | ||||
| BHS_MC|BHS|Mangrove Cay|489 | ||||
| BHS_MG|BHS|Mayaguana|290 | ||||
| BHS_MI|BHS|Moore'sIsland|21 | ||||
| BHS_MI|BHS|Moore's Island|21 | ||||
| BHS_NW|BHS|New Providence|231 | ||||
| BHS_NB|BHS|North Abaco|219 | ||||
| BHS_NN|BHS|North Andros|2876 | ||||
| @@ -266,7 +278,9 @@ BLR_HR|BLR|Grodno|24952 | ||||
| BLR_MI|BLR|Minsk|2255 | ||||
| BLR_MA|BLR|Mogilev|28984 | ||||
| BLR_VI|BLR|Vitebsk|40056 | ||||
| BEL_NA|BEL|Wallonie|16827 | ||||
| BEL_Bruxelles|BEL|Bruxelles|156 | ||||
| BEL_Vlaanderen|BEL|Vlaanderen|13685 | ||||
| BEL_Wallonie|BEL|Wallonie|16827 | ||||
| BLZ_BZ|BLZ|Belize|3372 | ||||
| BLZ_CY|BLZ|Cayo|5322 | ||||
| BLZ_CZ|BLZ|Corozal|2012 | ||||
| @@ -291,7 +305,7 @@ BMU_HC|BMU|Hamilton Municipality|1 | ||||
| BMU_PA|BMU|Paget|6 | ||||
| BMU_PE|BMU|Pembroke|7 | ||||
| BMU_SC|BMU|Saint George's|10 | ||||
| BMU_SG|BMU|Saint Georgemunicipality|2 | ||||
| BMU_SG|BMU|Saint George municipality|2 | ||||
| BMU_SA|BMU|Sandys|9 | ||||
| BMU_SM|BMU|Smiths|5 | ||||
| BMU_SO|BMU|Southampton|6 | ||||
| @@ -365,18 +379,22 @@ BRA_PB|BRA|Paraíba|56838 | ||||
| BRA_PR|BRA|Paraná|200198 | ||||
| BRA_PE|BRA|Pernambuco|98705 | ||||
| BRA_PI|BRA|Piauí|253394 | ||||
| BRA_RJ|BRA|Riode Janeiro|43962 | ||||
| BRA_RN|BRA|Rio Grandedo Norte|53165 | ||||
| BRA_RS|BRA|Rio Grandedo Sul|282688 | ||||
| BRA_RJ|BRA|Rio de Janeiro|43962 | ||||
| BRA_RN|BRA|Rio Grande do Norte|53165 | ||||
| BRA_RS|BRA|Rio Grande do Sul|282688 | ||||
| BRA_RO|BRA|Rondônia|238929 | ||||
| BRA_RR|BRA|Roraima|225857 | ||||
| BRA_SC|BRA|Santa Catarina|96032 | ||||
| BRA_SP|BRA|SãoPaulo|249417 | ||||
| BRA_SP|BRA|São Paulo|249417 | ||||
| BRA_SE|BRA|Sergipe|22079 | ||||
| BRA_TO|BRA|Tocantins|279170 | ||||
| VGB_NA|VGB|Virgin Gorda|28 | ||||
| VGB_Anegada|VGB|Anegada|40 | ||||
| VGB_JostVanDyke|VGB|Jost Van Dyke|11 | ||||
| VGB_OtherIslands|VGB|Other Islands|14 | ||||
| VGB_Tortola|VGB|Tortola|76 | ||||
| VGB_VirginGorda|VGB|Virgin Gorda|28 | ||||
| BRN_BE|BRN|Belait|2863 | ||||
| BRN_BM|BRN|Bruneiand Muara|533 | ||||
| BRN_BM|BRN|Brunei and Muara|533 | ||||
| BRN_TE|BRN|Temburong|1283 | ||||
| BRN_TU|BRN|Tutong|1136 | ||||
| BGR_BL|BGR|Blagoevgrad|6611 | ||||
| @@ -445,11 +463,11 @@ KHM_KS|KHM|Kâmpóng Spœ|7014 | ||||
| KHM_KT|KHM|Kâmpóng Thum|12907 | ||||
| KHM_KP|KHM|Kâmpôt|4752 | ||||
| KHM_KN|KHM|Kândal|3274 | ||||
| KHM_KK|KHM|KaôhKong|11076 | ||||
| KHM_KK|KHM|Kaôh Kong|11076 | ||||
| KHM_KH|KHM|Krâchéh|12057 | ||||
| KHM_PL|KHM|Krong Pailin|1082 | ||||
| KHM_KA|KHM|Krong Preah Sihanouk|2651 | ||||
| KHM_MK|KHM|MôndólKiri|13747 | ||||
| KHM_MK|KHM|Môndól Kiri|13747 | ||||
| KHM_OC|KHM|Otdar Mean Chey|6672 | ||||
| KHM_PP|KHM|Phnom Penh|689 | ||||
| KHM_PO|KHM|Pouthisat|12588 | ||||
| @@ -493,18 +511,18 @@ CPV_PN|CPV|Porto Novo|581 | ||||
| CPV_PC|CPV|Praia|103 | ||||
| CPV_RB|CPV|Ribeira Brava|237 | ||||
| CPV_RG|CPV|Ribeira Grande|168 | ||||
| CPV_RS|CPV|Ribeira Grandede Santiago|142 | ||||
| CPV_RS|CPV|Ribeira Grande de Santiago|142 | ||||
| CPV_SL|CPV|Sal|225 | ||||
| CPV_CT|CPV|Santa Catarinado Fogo|55 | ||||
| CPV_CZ|CPV|Santa Cruz|116 | ||||
| CPV_SD|CPV|SãoDomingos|159 | ||||
| CPV_FP|CPV|SãoFilipe|340 | ||||
| CPV_LO|CPV|SãoLourençodosÓrgãos|36 | ||||
| CPV_SM|CPV|SãoMiguel|81 | ||||
| CPV_SS|CPV|SãoSalvadordo Mundo|31 | ||||
| CPV_SV|CPV|SãoVicente|271 | ||||
| CPV_SD|CPV|São Domingos|159 | ||||
| CPV_FP|CPV|São Filipe|340 | ||||
| CPV_LO|CPV|São Lourenço dos Órgãos|36 | ||||
| CPV_SM|CPV|São Miguel|81 | ||||
| CPV_SS|CPV|São Salvadordo Mundo|31 | ||||
| CPV_SV|CPV|São Vicente|271 | ||||
| CPV_TF|CPV|Tarrafal|120 | ||||
| CPV_TS|CPV|Tarrafalde SãoNicolau|115 | ||||
| CPV_TS|CPV|Tarrafal de São Nicolau|115 | ||||
| CYM_BT|CYM|Bodden Town|8 | ||||
| CYM_EE|CYM|East End|56 | ||||
| CYM_GT|CYM|George Town|29 | ||||
| @@ -549,13 +567,13 @@ TCD_SA|TCD|Salamat|68389 | ||||
| TCD_SI|TCD|Sila|35924 | ||||
| TCD_TA|TCD|Tandjilé|17645 | ||||
| TCD_TI|TCD|Tibesti|126795 | ||||
| TCD_NJ|TCD|Villede N'Djamena|399 | ||||
| TCD_NJ|TCD|Ville de N'Djamena|399 | ||||
| TCD_BI|TCD|Wadi Fira|54434 | ||||
| CHL_AN|CHL|Antofagasta|126678 | ||||
| CHL_AR|CHL|Araucanía|31844 | ||||
| CHL_AP|CHL|Aricay Parinacota|16931 | ||||
| CHL_AT|CHL|Atacama|75995 | ||||
| CHL_AI|CHL|Ayséndel General Ibañezdel Cam|106476 | ||||
| CHL_AI|CHL|Aysén del General Ibañez del Cam|106476 | ||||
| CHL_BI|CHL|Bío-Bío|24032 | ||||
| CHL_CO|CHL|Coquimbo|40711 | ||||
| CHL_LI|CHL|Libertador General Bernardo O'Hi|16389 | ||||
| @@ -604,7 +622,7 @@ COL_AM|COL|Amazonas|109901 | ||||
| COL_AN|COL|Antioquia|63337 | ||||
| COL_AR|COL|Arauca|23888 | ||||
| COL_AT|COL|Atlántico|3336 | ||||
| COL_DC|COL|BogotáD.C.|1646 | ||||
| COL_DC|COL|Bogotá D.C.|1646 | ||||
| COL_BL|COL|Bolívar|26790 | ||||
| COL_BY|COL|Boyacá|23235 | ||||
| COL_CL|COL|Caldas|7454 | ||||
| @@ -622,21 +640,31 @@ COL_LG|COL|La Guajira|20580 | ||||
| COL_MA|COL|Magdalena|22912 | ||||
| COL_ME|COL|Meta|85947 | ||||
| COL_NA|COL|Nariño|31546 | ||||
| COL_NS|COL|Nortede Santander|22077 | ||||
| COL_NS|COL|Norte de Santander|22077 | ||||
| COL_PU|COL|Putumayo|26063 | ||||
| COL_QD|COL|Quindío|1947 | ||||
| COL_RI|COL|Risaralda|3562 | ||||
| COL_SA|COL|San Andrésy Providencia|52 | ||||
| COL_SA|COL|San Andrés y Providencia|52 | ||||
| COL_ST|COL|Santander|30788 | ||||
| COL_SU|COL|Sucre|10787 | ||||
| COL_TO|COL|Tolima|24131 | ||||
| COL_VC|COL|Valledel Cauca|21034 | ||||
| COL_VC|COL|Valle del Cauca|21034 | ||||
| COL_VP|COL|Vaupés|53546 | ||||
| COL_VD|COL|Vichada|100014 | ||||
| COM_MO|COM|Mwali|220 | ||||
| COM_GC|COM|Njazídja|1028 | ||||
| COM_AN|COM|Nzwani|436 | ||||
| COK_NA|COK|Rarotonga|70 | ||||
| COK_Aitutaki|COK|Aitutaki|28 | ||||
| COK_Atiu|COK|Atiu|31 | ||||
| COK_Mangaia|COK|Mangaia|49 | ||||
| COK_Manihiki|COK|Manihiki|8 | ||||
| COK_Mauke|COK|Mauke|20 | ||||
| COK_Mitiaro|COK|Mitiaro|25 | ||||
| COK_Palmerston|COK|Palmerston|24 | ||||
| COK_Penhryn|COK|Penhryn|17 | ||||
| COK_Pukapuka|COK|Pukapuka|6 | ||||
| COK_Rakahanga|COK|Rakahanga|5 | ||||
| COK_Rarotonga|COK|Rarotonga|70 | ||||
| CRI_AL|CRI|Alajuela|9834 | ||||
| CRI_CA|CRI|Cartago|3113 | ||||
| CRI_GU|CRI|Guanacaste|10250 | ||||
| @@ -682,18 +710,18 @@ HRV_ZG|HRV|Zagrebačka|2395 | ||||
| CUB_CM|CUB|Camagüey|15816 | ||||
| CUB_CA|CUB|CiegodeÁvila|7393 | ||||
| CUB_CF|CUB|Cienfuegos|4019 | ||||
| CUB_CH|CUB|Ciudaddela Habana|822 | ||||
| CUB_CH|CUB|Ciudad de la Habana|822 | ||||
| CUB_GR|CUB|Granma|8700 | ||||
| CUB_GU|CUB|Guantánamo|6187 | ||||
| CUB_HO|CUB|Holguín|8738 | ||||
| CUB_IJ|CUB|Isladela Juventud|2519 | ||||
| CUB_IJ|CUB|Isla de la Juventud|2519 | ||||
| CUB_LH|CUB|La Habana|1964 | ||||
| CUB_LT|CUB|Las Tunas|6583 | ||||
| CUB_MA|CUB|Matanzas|11741 | ||||
| CUB_MQ|CUB|Mayabeque|3692 | ||||
| CUB_PR|CUB|Pinardel Río|11079 | ||||
| CUB_SS|CUB|Sancti Spíritus|6401 | ||||
| CUB_SC|CUB|Santiagode Cuba|6441 | ||||
| CUB_SC|CUB|Santiago de Cuba|6441 | ||||
| CUB_VC|CUB|Villa Clara|9161 | ||||
| CYP_FA|CYP|Famagusta|204 | ||||
| CYP_LA|CYP|Larnaca|915 | ||||
| @@ -774,7 +802,7 @@ DOM_AL|DOM|La Altagracia|3119 | ||||
| DOM_EP|DOM|La Estrelleta|1432 | ||||
| DOM_RO|DOM|La Romana|561 | ||||
| DOM_VE|DOM|La Vega|2257 | ||||
| DOM_MT|DOM|MaríaTrinidad Sánchez|1238 | ||||
| DOM_MT|DOM|María Trinidad Sánchez|1238 | ||||
| DOM_MN|DOM|Monseñor Nouel|977 | ||||
| DOM_MC|DOM|Monte Cristi|1956 | ||||
| DOM_MP|DOM|Monte Plata|2604 | ||||
| @@ -784,9 +812,9 @@ DOM_PP|DOM|Puerto Plata|1900 | ||||
| DOM_SC|DOM|Salcedo|426 | ||||
| DOM_SM|DOM|Samaná|864 | ||||
| DOM_CR|DOM|San Cristóbal|1217 | ||||
| DOM_JO|DOM|San Joséde Ocoa|853 | ||||
| DOM_JO|DOM|San José de Ocoa|853 | ||||
| DOM_JU|DOM|San Juan|3347 | ||||
| DOM_PM|DOM|San Pedrode Macorís|1270 | ||||
| DOM_PM|DOM|San Pedro de Macorís|1270 | ||||
| DOM_SZ|DOM|Sánchez Ramírez|1183 | ||||
| DOM_ST|DOM|Santiago|2786 | ||||
| DOM_SR|DOM|Santiago Rodríguez|1150 | ||||
| @@ -812,7 +840,7 @@ ECU_OR|ECU|Orellana|21738 | ||||
| ECU_PA|ECU|Pastaza|29671 | ||||
| ECU_PI|ECU|Pichincha|9512 | ||||
| ECU_SE|ECU|Santa Elena|3720 | ||||
| ECU_SD|ECU|Santo Domingodelos Tsachilas|3803 | ||||
| ECU_SD|ECU|Santo Domingo de los Tsachilas|3803 | ||||
| ECU_SU|ECU|Sucumbios|18069 | ||||
| ECU_TU|ECU|Tungurahua|3405 | ||||
| ECU_ZC|ECU|Zamora Chinchipe|10605 | ||||
| @@ -878,7 +906,7 @@ EST_JN|EST|Jõgeva|2597 | ||||
| EST_LN|EST|Lääne|2420 | ||||
| EST_LV|EST|Lääne-Viru|3478 | ||||
| EST_PR|EST|Pärnu|4796 | ||||
| EST_NA|EST|Peipsi|1758 | ||||
| EST_Peipsi|EST|Peipsi|1758 | ||||
| EST_PL|EST|Põlva|2161 | ||||
| EST_RA|EST|Rapla|2971 | ||||
| EST_SA|EST|Saare|2932 | ||||
| @@ -916,7 +944,7 @@ FIN_LS|FIN|Western Finland|89423 | ||||
| FRA_AR|FRA|Auvergne-Rhône-Alpes|71204 | ||||
| FRA_BF|FRA|Bourgogne-Franche-Comté|48033 | ||||
| FRA_BT|FRA|Bretagne|27609 | ||||
| FRA_CN|FRA|Centre-Valde Loire|39509 | ||||
| FRA_CN|FRA|Centre-Val de Loire|39509 | ||||
| FRA_CE|FRA|Corse|8750 | ||||
| FRA_AO|FRA|Grand Est|57666 | ||||
| FRA_NC|FRA|Hauts-de-France|31945 | ||||
| @@ -924,17 +952,17 @@ FRA_IF|FRA|Île-de-France|12058 | ||||
| FRA_ND|FRA|Normandie|30143 | ||||
| FRA_AC|FRA|Nouvelle-Aquitaine|84800 | ||||
| FRA_LP|FRA|Occitanie|73302 | ||||
| FRA_PL|FRA|Paysdela Loire|32365 | ||||
| FRA_PR|FRA|Provence-Alpes-Côted'Azur|31952 | ||||
| FRA_PL|FRA|Pays de la Loire|32365 | ||||
| FRA_PR|FRA|Provence-Alpes-Côte d'Azur|31952 | ||||
| GUF_CY|GUF|Cayenne|42886 | ||||
| GUF_SL|GUF|Saint-Laurent-du-Maroni|40970 | ||||
| PYF_TI|PYF|Îles Australes|373 | ||||
| PYF_WI|PYF|Îlesdu Vent|1216 | ||||
| PYF_WI|PYF|Îles du Vent|1216 | ||||
| PYF_MI|PYF|Îles Marquises|996 | ||||
| PYF_LI|PYF|Îles Sous-le-Vent|429 | ||||
| PYF_TG|PYF|Îles Tuamotu-Gambier|1039 | ||||
| ATF_CR|ATF|Îles Crozet|372 | ||||
| ATF_NA|ATF|ÎlesÉparses|44 | ||||
| ATF_ÎlesÉparses|ATF|Îles Éparses|44 | ||||
| ATF_AS|ATF|Îles Saint Paulet Amsterdam|64 | ||||
| ATF_KG|ATF|Kerguelen|7372 | ||||
| GAB_ES|GAB|Estuaire|20024 | ||||
| @@ -1001,7 +1029,7 @@ GRC_MA|GRC|Athos|338 | ||||
| GRC_AT|GRC|Attica|3853 | ||||
| GRC_CR|GRC|Crete|8391 | ||||
| GRC_EM|GRC|Epirusand Western Macedonia|18771 | ||||
| GRC_MH|GRC|Macedoniaand Thrace|33122 | ||||
| GRC_MH|GRC|Macedonia and Thrace|33122 | ||||
| GRC_PW|GRC|Peloponnese, Western Greeceand|29194 | ||||
| GRC_TC|GRC|Thessalyand Central Greece|29744 | ||||
| GRL_KU|GRL|Kujalleq|45647 | ||||
| @@ -1071,9 +1099,14 @@ GGY_SV|GGY|Saint Saviour|6 | ||||
| GGY_SK|GGY|Sark|7 | ||||
| GGY_TV|GGY|Torteval|3 | ||||
| GGY_VA|GGY|Vale|10 | ||||
| GIN_NA|GIN|Nzérékoré|36751 | ||||
| GIN_Boké|GIN|Boké|34287 | ||||
| GIN_C|GIN|Conakry|423 | ||||
| GIN_Faranah|GIN|Faranah|35989 | ||||
| GIN_K|GIN|Kankan|72197 | ||||
| GIN_Kindia|GIN|Kindia|25816 | ||||
| GIN_Labé|GIN|Labé|22959 | ||||
| GIN_Mamou|GIN|Mamou|17935 | ||||
| GIN_Nzérékoré|GIN|Nzérékoré|36751 | ||||
| GNB_BA|GNB|Bafatá|5881 | ||||
| GNB_BM|GNB|Biombo|761 | ||||
| GNB_BS|GNB|Bissau|83 | ||||
| @@ -1113,7 +1146,7 @@ HND_EP|HND|El Paraíso|7417 | ||||
| HND_FM|HND|Francisco Morazán|8606 | ||||
| HND_GD|HND|Graciasa Dios|16439 | ||||
| HND_IN|HND|Intibucá|3167 | ||||
| HND_IB|HND|Islasdela Bahía|233 | ||||
| HND_IB|HND|Islas de la Bahía|233 | ||||
| HND_LP|HND|La Paz|2463 | ||||
| HND_LE|HND|Lempira|4277 | ||||
| HND_OC|HND|Ocotepeque|1704 | ||||
| @@ -1155,7 +1188,7 @@ IND_AS|IND|Assam|78810 | ||||
| IND_BR|IND|Bihar|94631 | ||||
| IND_CH|IND|Chandigarh|118 | ||||
| IND_CT|IND|Chhattisgarh|136109 | ||||
| IND_DN|IND|Dadraand Nagar Haveli|494 | ||||
| IND_DN|IND|Dadra and Nagar Haveli|494 | ||||
| IND_DD|IND|Damanand Diu|84 | ||||
| IND_GA|IND|Goa|3717 | ||||
| IND_GJ|IND|Gujarat|186600 | ||||
| @@ -1171,7 +1204,7 @@ IND_MN|IND|Manipur|22420 | ||||
| IND_ML|IND|Meghalaya|22612 | ||||
| IND_MZ|IND|Mizoram|21350 | ||||
| IND_NL|IND|Nagaland|16668 | ||||
| IND_DL|IND|NC Tof Delhi|1508 | ||||
| IND_DL|IND|NCT of Delhi|1508 | ||||
| IND_OR|IND|Odisha|156427 | ||||
| IND_PY|IND|Puducherry|550 | ||||
| IND_PB|IND|Punjab|50386 | ||||
| @@ -1298,7 +1331,7 @@ IMN_MC|IMN|Michael|34 | ||||
| IMN_MD|IMN|Santon|16 | ||||
| IMN_GR|IMN|Garff|72 | ||||
| IMN_GB|IMN|Peel|2 | ||||
| ISR_NA|ISR|Golan|1238 | ||||
| ISR_Golan|ISR|Golan|1238 | ||||
| ISR_HD|ISR|Ha Darom|14557 | ||||
| ISR_HA|ISR|Haifa|887 | ||||
| ISR_HM|ISR|Ha Merkaz|1243 | ||||
| @@ -1471,10 +1504,13 @@ KEN_UG|KEN|Uasin Gishu|3453 | ||||
| KEN_VI|KEN|Vihiga|562 | ||||
| KEN_WJ|KEN|Wajir|57017 | ||||
| KEN_WP|KEN|West Pokot|9574 | ||||
| XKO_NA|XKO|Uroševac|1056 | ||||
| XKO_Đakovica|XKO|Đakovica|1109 | ||||
| XKO_Gnjilane|XKO|Gnjilane|1360 | ||||
| XKO_KM|XKO|Kosovska Mitrovica|2070 | ||||
| XKO_PE|XKO|Pećki|1357 | ||||
| XKO_Pristina|XKO|Pristina|2175 | ||||
| XKO_PZ|XKO|Prizren|1715 | ||||
| XKO_Uroševac|XKO|Uroševac|1056 | ||||
| KWT_AH|KWT|Al Ahmadi|4659 | ||||
| KWT_FA|KWT|Al Farwaniyah|219 | ||||
| KWT_JA|KWT|Al Jahrah|12438 | ||||
| @@ -1512,15 +1548,22 @@ LVA_L|LVA|Latgale|14678 | ||||
| LVA_R|LVA|Riga|10324 | ||||
| LVA_V|LVA|Vidzeme|15240 | ||||
| LVA_Z|LVA|Zemgale|10775 | ||||
| LBN_NA|LBN|South|919 | ||||
| LBN_Akkar|LBN|Akkar|793 | ||||
| LBN_Baalbak-Hermel|LBN|Baalbak-Hermel|2854 | ||||
| LBN_Beirut|LBN|Beirut|21 | ||||
| LBN_Bekaa|LBN|Bekaa|1408 | ||||
| LBN_MountLebanon|LBN|Mount Lebanon|1990 | ||||
| LBN_Nabatiyeh|LBN|Nabatiyeh|1099 | ||||
| LBN_North|LBN|North|1181 | ||||
| LBN_South|LBN|South|919 | ||||
| LSO_BE|LSO|Berea|1999 | ||||
| LSO_BB|LSO|Butha-Buthe|1796 | ||||
| LSO_LE|LSO|Leribe|2829 | ||||
| LSO_MF|LSO|Mafeteng|2659 | ||||
| LSO_MS|LSO|Maseru|3781 | ||||
| LSO_MH|LSO|Mohale'sHoek|3451 | ||||
| LSO_MH|LSO|Mohale's Hoek|3451 | ||||
| LSO_MK|LSO|Mokhotlong|4184 | ||||
| LSO_QN|LSO|Qacha'sNek|2131 | ||||
| LSO_QN|LSO|Qacha's Nek|2131 | ||||
| LSO_QT|LSO|Quthing|2974 | ||||
| LSO_TT|LSO|Thaba-Tseka|4849 | ||||
| LBR_BM|LBR|Bomi|2122 | ||||
| @@ -1607,7 +1650,7 @@ MKD_DK|MKD|Demir Kapija|314 | ||||
| MKD_DE|MKD|Dolneni|410 | ||||
| MKD_GB|MKD|Gazi Baba|102 | ||||
| MKD_GV|MKD|Gevgelija|438 | ||||
| MKD_GP|MKD|GjorčePetrov|70 | ||||
| MKD_GP|MKD|Gjorče Petrov|70 | ||||
| MKD_GT|MKD|Gostivar|524 | ||||
| MKD_GR|MKD|Gradsko|282 | ||||
| MKD_IL|MKD|Ilinden|95 | ||||
| @@ -1624,7 +1667,7 @@ MKD_KZ|MKD|Kriva Palanka|508 | ||||
| MKD_KG|MKD|Krivogaštani|95 | ||||
| MKD_KS|MKD|Kruševo|183 | ||||
| MKD_UM|MKD|Kumanovo|503 | ||||
| MKD_NA|MKD|Staro Nagoričane|438 | ||||
| MKD_LakeOhrid|MKD|Lake Ohrid|247 | ||||
| MKD_LI|MKD|Lipkovo|265 | ||||
| MKD_LO|MKD|Lozovo|161 | ||||
| MKD_MK|MKD|Makedonska Kamenica|198 | ||||
| @@ -1647,6 +1690,7 @@ MKD_RM|MKD|Rosoman|133 | ||||
| MKD_AJ|MKD|Saraj|234 | ||||
| MKD_SS|MKD|Sopište|214 | ||||
| MKD_SD|MKD|Star Dojran|150 | ||||
| MKD_NA|MKD|Staro Nagoričane|438 | ||||
| MKD_ST|MKD|Štip|565 | ||||
| MKD_UG|MKD|Struga|475 | ||||
| MKD_RU|MKD|Strumitsa|320 | ||||
| @@ -1669,7 +1713,7 @@ MDG_D|MDG|Antsiranana|44120 | ||||
| MDG_F|MDG|Fianarantsoa|101276 | ||||
| MDG_M|MDG|Mahajanga|152526 | ||||
| MDG_A|MDG|Toamasina|71636 | ||||
| MDG_NA|MDG|Toliary|164809 | ||||
| MDG_Toliary|MDG|Toliary|164809 | ||||
| MWI_BA|MWI|Balaka|2143 | ||||
| MWI_BL|MWI|Blantyre|2038 | ||||
| MWI_CK|MWI|Chikwawa|4908 | ||||
| @@ -1728,9 +1772,29 @@ MLT_GO|MLT|Għawdex|71 | ||||
| MLT_SO|MLT|Nofsinhar|78 | ||||
| MLT_NO|MLT|Tramuntana|116 | ||||
| MLT_SE|MLT|Xlokk|36 | ||||
| MHL_NA|MHL|NA|26 | ||||
| MHL_Ailinglaplap|MHL|Ailinglaplap|18 | ||||
| MHL_Ailuk|MHL|Ailuk|11 | ||||
| MHL_Arno|MHL|Arno|28 | ||||
| MHL_Aur|MHL|Aur|6 | ||||
| MHL_Ebon|MHL|Ebon|8 | ||||
| MHL_Enewetok|MHL|Enewetok|16 | ||||
| MHL_Jabat|MHL|Jabat|1 | ||||
| MHL_Jaluit|MHL|Jaluit|13 | ||||
| MHL_KWA|MHL|Kwajalein|27 | ||||
| MHL_Lae|MHL|Lae|3 | ||||
| MHL_Lib|MHL|Lib|1 | ||||
| MHL_Likiep|MHL|Likiep|13 | ||||
| MHL_MAJ|MHL|Majuro|22 | ||||
| MHL_Maloelap|MHL|Maloelap|12 | ||||
| MHL_Mejit|MHL|Mejit|4 | ||||
| MHL_Mili|MHL|Mili|27 | ||||
| MHL_Namorik|MHL|Namorik|5 | ||||
| MHL_Namu|MHL|Namu|7 | ||||
| MHL_Ujae|MHL|Ujae|3 | ||||
| MHL_Utirik|MHL|Utirik|14 | ||||
| MHL_Wotho|MHL|Wotho|6 | ||||
| MHL_Wotje|MHL|Wotje|15 | ||||
| MHL_19_1|MHL|NA|26 | ||||
| MTQ_FF|MTQ|Fort-de-France|189 | ||||
| MTQ_MA|MTQ|Le Marin|393 | ||||
| MTQ_TR|MTQ|Le Trinité|353 | ||||
| @@ -1896,7 +1960,7 @@ MAR_FB|MAR|Fès-Boulemane|19366 | ||||
| MAR_GB|MAR|Gharb-Chrarda-Béni Hssen|8782 | ||||
| MAR_GC|MAR|Grand Casablanca|879 | ||||
| MAR_GE|MAR|Guelmim-Es-Semara|64701 | ||||
| MAR_LB|MAR|Laâyoune-Boujdour-Sakia El H|5763 | ||||
| MAR_LB|MAR|Laâyoune-Boujdour-Sakia El Hamra|5763 | ||||
| MAR_MK|MAR|Marrakech-Tensift-Al Haouz|32483 | ||||
| MAR_MT|MAR|Meknès-Tafilalet|60303 | ||||
| MAR_OR|MAR|Oriental|59914 | ||||
| @@ -1968,22 +2032,24 @@ NLD_FL|NLD|Flevoland|1466 | ||||
| NLD_FR|NLD|Fryslân|3573 | ||||
| NLD_GE|NLD|Gelderland|5102 | ||||
| NLD_GR|NLD|Groningen|2370 | ||||
| NLD_SH|NLD|Zuid-Holland|3143 | ||||
| NLD_IJsselmeer|NLD|IJsselmeer|1995 | ||||
| NLD_LI|NLD|Limburg|2159 | ||||
| NLD_NB|NLD|Noord-Brabant|5082 | ||||
| NLD_NH|NLD|Noord-Holland|2872 | ||||
| NLD_OV|NLD|Overijssel|3369 | ||||
| NLD_UT|NLD|Utrecht|1555 | ||||
| NLD_ZE|NLD|Zeeland|1804 | ||||
| NLD_Zeeuwsemeren|NLD|Zeeuwsemeren|477 | ||||
| NLD_14_1|NLD|NA|3143 | ||||
| NCL_IL|NCL|Îles Loyauté|1988 | ||||
| NCL_NO|NCL|Nord|9520 | ||||
| NCL_SU|NCL|Sud|7408 | ||||
| NZL_AU|NZL|Auckland|4958 | ||||
| NZL_BP|NZL|Bayof Plenty|12293 | ||||
| NZL_BP|NZL|Bay of Plenty|12293 | ||||
| NZL_CA|NZL|Canterbury|48152 | ||||
| NZL_CI|NZL|Chatham Islands|798 | ||||
| NZL_GI|NZL|Gisborne|8369 | ||||
| NZL_HB|NZL|Hawke'sBay|12790 | ||||
| NZL_HB|NZL|Hawke's Bay|12790 | ||||
| NZL_MW|NZL|Manawatu-Wanganui|21998 | ||||
| NZL_MA|NZL|Marlborough|10491 | ||||
| NZL_NE|NZL|Nelson|425 | ||||
| @@ -2013,7 +2079,7 @@ NIC_MN|NIC|Managua|4628 | ||||
| NIC_MS|NIC|Masaya|607 | ||||
| NIC_MT|NIC|Matagalpa|8856 | ||||
| NIC_NS|NIC|Nueva Segovia|3142 | ||||
| NIC_SJ|NIC|RíoSan Juan|7345 | ||||
| NIC_SJ|NIC|Río San Juan|7345 | ||||
| NIC_RI|NIC|Rivas|1909 | ||||
| NER_AG|NER|Agadez|626771 | ||||
| NER_DF|NER|Diffa|147076 | ||||
| @@ -2067,13 +2133,18 @@ PRK_WB|PRK|Hwanghae-bukto|8248 | ||||
| PRK_WN|PRK|Hwanghae-namdo|8563 | ||||
| PRK_KS|PRK|Kaesŏng|1182 | ||||
| PRK_KW|PRK|Kangwŏn-do|10286 | ||||
| PRK_NA|PRK|Sinŭiju|109 | ||||
| PRK_Kumgangsan|PRK|Kumgangsan|987 | ||||
| PRK_PB|PRK|P'yŏngan-bukto|12424 | ||||
| PRK_PN|PRK|P'yŏngan-namdo|12479 | ||||
| PRK_PY|PRK|P'yŏngyang|2718 | ||||
| PRK_NJ|PRK|Rasŏn|856 | ||||
| PRK_YG|PRK|Ryanggang|13935 | ||||
| ZNC_NA|ZNC|Nicosia|522 | ||||
| PRK_Sinŭiju|PRK|Sinŭiju|109 | ||||
| ZNC_Gazimağusa|ZNC|Gazimağusa|927 | ||||
| ZNC_Girne|ZNC|Girne|677 | ||||
| ZNC_Güzelyurt|ZNC|Güzelyurt|346 | ||||
| ZNC_Iskele|ZNC|Iskele|849 | ||||
| ZNC_Nicosia|ZNC|Nicosia|522 | ||||
| MNP_NI|MNP|Northern Islands|181 | ||||
| MNP_RO|MNP|Rota|90 | ||||
| MNP_SA|MNP|Saipan|123 | ||||
| @@ -2131,7 +2202,7 @@ PLW_NW|PLW|Ngiwal|18 | ||||
| PLW_SO|PLW|Sonsorol|3 | ||||
| PSE_GZ|PSE|Gaza|344 | ||||
| PSE_WE|PSE|West Bank|5895 | ||||
| PAN_BC|PAN|Bocasdel Toro|4718 | ||||
| PAN_BC|PAN|Bocas del Toro|4718 | ||||
| PAN_CH|PAN|Chiriquí|6676 | ||||
| PAN_CC|PAN|Coclé|4939 | ||||
| PAN_CL|PAN|Colón|4711 | ||||
| @@ -2142,7 +2213,7 @@ PAN_SB|PAN|Kuna Yala|2554 | ||||
| PAN_LS|PAN|Los Santos|3819 | ||||
| PAN_NB|PAN|Ngöbe Buglé|6649 | ||||
| PAN_PN|PAN|Panamá|8843 | ||||
| PAN_PO|PAN|PanamáOeste|3066 | ||||
| PAN_PO|PAN|Panamá Oeste|3066 | ||||
| PAN_VR|PAN|Veraguas|10980 | ||||
| PNG_NS|PNG|Bougainville|9470 | ||||
| PNG_CE|PNG|Central|29630 | ||||
| @@ -2201,7 +2272,7 @@ PER_LB|PER|Lambayeque|14380 | ||||
| PER_LR|PER|Lima|32537 | ||||
| PER_LP|PER|Lima Province|2722 | ||||
| PER_LO|PER|Loreto|377948 | ||||
| PER_MD|PER|Madrede Dios|84858 | ||||
| PER_MD|PER|Madre de Dios|84858 | ||||
| PER_MQ|PER|Moquegua|15844 | ||||
| PER_PA|PER|Pasco|24123 | ||||
| PER_PI|PER|Piura|36095 | ||||
| @@ -2211,8 +2282,8 @@ PER_TA|PER|Tacna|16085 | ||||
| PER_TU|PER|Tumbes|4673 | ||||
| PER_UC|PER|Ucayali|105741 | ||||
| PHL_AB|PHL|Abra|3992 | ||||
| PHL_AN|PHL|Agusandel Norte|3013 | ||||
| PHL_AS|PHL|Agusandel Sur|8641 | ||||
| PHL_AN|PHL|Agusan del Norte|3013 | ||||
| PHL_AS|PHL|Agusan del Sur|8641 | ||||
| PHL_AK|PHL|Aklan|1673 | ||||
| PHL_AL|PHL|Albay|2529 | ||||
| PHL_AQ|PHL|Antique|2753 | ||||
| @@ -2236,8 +2307,8 @@ PHL_CT|PHL|Catanduanes|1482 | ||||
| PHL_CV|PHL|Cavite|1251 | ||||
| PHL_CB|PHL|Cebu|4912 | ||||
| PHL_CL|PHL|Compostela Valley|4277 | ||||
| PHL_DV|PHL|Davaodel Norte|3511 | ||||
| PHL_DS|PHL|Davaodel Sur|6091 | ||||
| PHL_DV|PHL|Davao del Norte|3511 | ||||
| PHL_DS|PHL|Davao del Sur|6091 | ||||
| PHL_DO|PHL|Davao Oriental|5158 | ||||
| PHL_DI|PHL|Dinagat Islands|813 | ||||
| PHL_ES|PHL|Eastern Samar|4304 | ||||
| @@ -2250,8 +2321,8 @@ PHL_IB|PHL|Isabela|10340 | ||||
| PHL_KA|PHL|Kalinga|2914 | ||||
| PHL_LU|PHL|La Union|1470 | ||||
| PHL_LG|PHL|Laguna|2713 | ||||
| PHL_LN|PHL|Lanaodel Norte|2859 | ||||
| PHL_LS|PHL|Lanaodel Sur|3904 | ||||
| PHL_LN|PHL|Lanao del Norte|2859 | ||||
| PHL_LS|PHL|Lanao del Sur|3904 | ||||
| PHL_LE|PHL|Leyte|5595 | ||||
| PHL_MG|PHL|Maguindanao|4817 | ||||
| PHL_MQ|PHL|Marinduque|934 | ||||
| @@ -2283,12 +2354,12 @@ PHL_SC|PHL|South Cotabato|4375 | ||||
| PHL_SL|PHL|Southern Leyte|1694 | ||||
| PHL_SK|PHL|Sultan Kudarat|4478 | ||||
| PHL_SU|PHL|Sulu|1562 | ||||
| PHL_SN|PHL|Surigaodel Norte|2110 | ||||
| PHL_SS|PHL|Surigaodel Sur|4335 | ||||
| PHL_SN|PHL|Surigao del Norte|2110 | ||||
| PHL_SS|PHL|Surigao del Sur|4335 | ||||
| PHL_TR|PHL|Tarlac|3032 | ||||
| PHL_TT|PHL|Tawi-Tawi|1183 | ||||
| PHL_ZN|PHL|Zamboangadel Norte|6433 | ||||
| PHL_ZS|PHL|Zamboangadel Sur|5329 | ||||
| PHL_ZN|PHL|Zamboanga del Norte|6433 | ||||
| PHL_ZS|PHL|Zamboanga del Sur|5329 | ||||
| PHL_ZY|PHL|Zamboanga Sibugay|2733 | ||||
| POL_02|POL|Dolnośląskie|19878 | ||||
| POL_04|POL|Kujawsko-Pomorskie|17940 | ||||
| @@ -2318,7 +2389,7 @@ PRT_FA|PRT|Faro|4975 | ||||
| PRT_GU|PRT|Guarda|5541 | ||||
| PRT_LE|PRT|Leiria|3501 | ||||
| PRT_LI|PRT|Lisboa|2765 | ||||
| PRT_NA|PRT|Madeira|801 | ||||
| PRT_Madeira|PRT|Madeira|801 | ||||
| PRT_PA|PRT|Portalegre|6091 | ||||
| PRT_PO|PRT|Porto|2332 | ||||
| PRT_SA|PRT|Santarém|6725 | ||||
| @@ -2386,7 +2457,7 @@ PRI_PN|PRI|Peñuelas|118 | ||||
| PRI_PO|PRI|Ponce|307 | ||||
| PRI_QB|PRI|Quebradillas|60 | ||||
| PRI_RC|PRI|Rincón|37 | ||||
| PRI_RG|PRI|RíoGrande|158 | ||||
| PRI_RG|PRI|Río Grande|158 | ||||
| PRI_SB|PRI|Sabana Grande|94 | ||||
| PRI_SA|PRI|Salinas|185 | ||||
| PRI_SG|PRI|San Germán|140 | ||||
| @@ -2482,7 +2553,7 @@ RUS_CN|RUS|Chechnya|15154 | ||||
| RUS_CL|RUS|Chelyabinsk|88739 | ||||
| RUS_CK|RUS|Chukot|716435 | ||||
| RUS_CV|RUS|Chuvash|18377 | ||||
| RUS_SP|RUS|Cityof St.Petersburg|2039 | ||||
| RUS_SP|RUS|City of St.Petersburg|2039 | ||||
| RUS_DA|RUS|Dagestan|49446 | ||||
| RUS_GA|RUS|Gorno-Altay|92910 | ||||
| RUS_IN|RUS|Ingush|3228 | ||||
| @@ -2511,7 +2582,7 @@ RUS_LP|RUS|Lipetsk|24425 | ||||
| RUS_MG|RUS|Magadan|459480 | ||||
| RUS_ME|RUS|Mariy-El|23468 | ||||
| RUS_MR|RUS|Mordovia|26161 | ||||
| RUS_NA|RUS|Moscow City|1095 | ||||
| RUS_MoscowCity|RUS|Moscow City|1095 | ||||
| RUS_MS|RUS|Moskva|46592 | ||||
| RUS_MM|RUS|Murmansk|142851 | ||||
| RUS_NN|RUS|Nenets|175502 | ||||
| @@ -2557,7 +2628,8 @@ RWA_SU|RWA|Amajyepfo|5997 | ||||
| RWA_ES|RWA|Iburasirazuba|9530 | ||||
| RWA_OU|RWA|Iburengerazuba|5910 | ||||
| RWA_KV|RWA|Umujyiwa Kigali|733 | ||||
| BLM_NA|BLM|Sousle Vent|8 | ||||
| BLM_AuVent|BLM|Au Vent|13 | ||||
| BLM_SousleVent|BLM|Sous le Vent|8 | ||||
| SHN_AC|SHN|Ascension|100 | ||||
| SHN_SH|SHN|Saint Helena|124 | ||||
| SHN_TA|SHN|Tristanda Cunha|189 | ||||
| @@ -2614,7 +2686,7 @@ SMR_MG|SMR|Montegiardino|3 | ||||
| SMR_SM|SMR|San Marino|7 | ||||
| SMR_SE|SMR|Serravalle|10 | ||||
| STP_PR|STP|Príncipe|145 | ||||
| STP_ST|STP|SãoTomé|864 | ||||
| STP_ST|STP|São Tomé|864 | ||||
| SAU_AS|SAU|'Asir|77398 | ||||
| SAU_BA|SAU|Al Bahah|10566 | ||||
| SAU_HS|SAU|Al Hududash Shamaliyah|104147 | ||||
| @@ -2697,7 +2769,11 @@ SLE_EA|SLE|Eastern|15846 | ||||
| SLE_NO|SLE|Northern|36238 | ||||
| SLE_SO|SLE|Southern|20261 | ||||
| SLE_WE|SLE|Western|722 | ||||
| SGP_NA|SGP|West|230 | ||||
| SGP_Central|SGP|Central|133 | ||||
| SGP_East|SGP|East|103 | ||||
| SGP_North|SGP|North|131 | ||||
| SGP_North-East|SGP|North-East|103 | ||||
| SGP_West|SGP|West|230 | ||||
| SVK_BC|SVK|Banskobystrický|9565 | ||||
| SVK_BL|SVK|Bratislavský|2015 | ||||
| SVK_KI|SVK|Košický|6768 | ||||
| @@ -2708,7 +2784,7 @@ SVK_TA|SVK|Trnavský|4125 | ||||
| SVK_ZI|SVK|Žilinský|6828 | ||||
| SVN_GO|SVN|Gorenjska|2117 | ||||
| SVN_SP|SVN|Goriška|2277 | ||||
| SVN_NA|SVN|Jugovzhodna Slovenija|2635 | ||||
| SVN_JugovzhodnaSlovenija|SVN|Jugovzhodna Slovenija|2635 | ||||
| SVN_KO|SVN|Koroška|1032 | ||||
| SVN_NO|SVN|Notranjsko-kraška|1452 | ||||
| SVN_JP|SVN|Obalno-kraška|945 | ||||
| @@ -2789,17 +2865,17 @@ ESP_CM|ESP|Castilla-La Mancha|79561 | ||||
| ESP_CL|ESP|Castillay León|94291 | ||||
| ESP_CT|ESP|Cataluña|32133 | ||||
| ESP_ML|ESP|Ceutay Melilla|29 | ||||
| ESP_MD|ESP|Comunidadde Madrid|8036 | ||||
| ESP_NA|ESP|Comunidad Foralde Navarra|10362 | ||||
| ESP_MD|ESP|Comunidad de Madrid|8036 | ||||
| ESP_NA|ESP|Comunidad Foral de Navarra|10362 | ||||
| ESP_VC|ESP|Comunidad Valenciana|23290 | ||||
| ESP_EX|ESP|Extremadura|41695 | ||||
| ESP_GA|ESP|Galicia|29622 | ||||
| ESP_PM|ESP|Islas Baleares|5036 | ||||
| ESP_CN|ESP|Islas Canarias|7540 | ||||
| ESP_LO|ESP|La Rioja|5053 | ||||
| ESP_PV|ESP|PaísVasco|7237 | ||||
| ESP_AS|ESP|Principadode Asturias|10607 | ||||
| ESP_MU|ESP|Regiónde Murcia|11337 | ||||
| ESP_PV|ESP|País Vasco|7237 | ||||
| ESP_AS|ESP|Principado de Asturias|10607 | ||||
| ESP_MU|ESP|Región de Murcia|11337 | ||||
| LKA_AP|LKA|Ampara|4513 | ||||
| LKA_AD|LKA|Anuradhapura|7253 | ||||
| LKA_BD|LKA|Badulla|2887 | ||||
| @@ -2926,7 +3002,7 @@ TWN_TG|TWN|Taichung|2254 | ||||
| TWN_TN|TWN|Tainan|2236 | ||||
| TWN_TP|TWN|Taipei|279 | ||||
| TWN_TA|TWN|Taiwan|26568 | ||||
| TJK_RR|TJK|Districtsof Republican Subordin|28383 | ||||
| TJK_RR|TJK|Districts of Republican Subordin|28383 | ||||
| TJK_DU|TJK|Dushanbe|169 | ||||
| TJK_BK|TJK|Gorno-Badakhshan|63429 | ||||
| TJK_KL|TJK|Khatlon|23925 | ||||
| @@ -3072,7 +3148,7 @@ TTO_DM|TTO|Diego Martin|142 | ||||
| TTO_MR|TTO|Mayaro/Rio Claro|792 | ||||
| TTO_PD|TTO|Penal-Debe|246 | ||||
| TTO_PF|TTO|Point Fortin|29 | ||||
| TTO_PS|TTO|Portof Spain|14 | ||||
| TTO_PS|TTO|Port of Spain|14 | ||||
| TTO_PT|TTO|Princes Town|619 | ||||
| TTO_SF|TTO|San Fernando|20 | ||||
| TTO_SL|TTO|San Juan-Laventille|216 | ||||
| @@ -3191,7 +3267,12 @@ TKM_BA|TKM|Balkan|136605 | ||||
| TKM_DA|TKM|Daşoguz|76751 | ||||
| TKM_LE|TKM|Lebap|96478 | ||||
| TKM_MA|TKM|Mary|86353 | ||||
| TCA_NA|TCA|South Caicosand East Caicos|247 | ||||
| TCA_GrandTurk|TCA|Grand Turk|20 | ||||
| TCA_MiddleCaicos|TCA|Middle Caicos|306 | ||||
| TCA_NorthCaicos|TCA|North Caicos|259 | ||||
| TCA_ProvidencialesandWestCaicos|TCA|Providenciales and West Caicos|152 | ||||
| TCA_SaltCay|TCA|Salt Cay|11 | ||||
| TCA_SouthCaicosandEastCaicos|TCA|South Caicos and East Caicos|247 | ||||
| TUV_FN|TUV|Funafuti|7 | ||||
| TUV_NG|TUV|Nanumanga|3 | ||||
| TUV_NA|TUV|Nanumea|4 | ||||
| @@ -3231,7 +3312,8 @@ UGA_TG|UGA|Kitgum|9621 | ||||
| UGA_KF|UGA|Kotido|13366 | ||||
| UGA_KU|UGA|Kumi|2867 | ||||
| UGA_KJ|UGA|Kyenjojo|4125 | ||||
| UGA_NA|UGA|Nakasongola|3536 | ||||
| UGA_LakeAlbert|UGA|Lake Albert|3212 | ||||
| UGA_LakeVictoria|UGA|Lake Victoria|28585 | ||||
| UGA_LA|UGA|Lira|7285 | ||||
| UGA_LW|UGA|Luwero|5734 | ||||
| UGA_MA|UGA|Masaka|3643 | ||||
| @@ -3245,6 +3327,7 @@ UGA_MI|UGA|Mpigi|3321 | ||||
| UGA_MD|UGA|Mubende|6242 | ||||
| UGA_MN|UGA|Mukono|3434 | ||||
| UGA_NP|UGA|Nakapiripirit|5859 | ||||
| UGA_NA|UGA|Nakasongola|3536 | ||||
| UGA_NE|UGA|Nebbi|2910 | ||||
| UGA_NT|UGA|Ntungamo|2068 | ||||
| UGA_PD|UGA|Pader|6905 | ||||
| @@ -3295,7 +3378,7 @@ ARE_UQ|ARE|Ummal-Qaywayn|746 | ||||
| GBR_NIR|GBR|Northern Ireland|14134 | ||||
| GBR_SCT|GBR|Scotland|78704 | ||||
| GBR_WLS|GBR|Wales|20818 | ||||
| GBR_NA|GBR|NA|130659 | ||||
| GBR_1_1|GBR|England|130659 | ||||
| USA_AL|USA|Alabama|133995 | ||||
| USA_AK|USA|Alaska|1501231 | ||||
| USA_AZ|USA|Arizona|296082 | ||||
| @@ -3304,7 +3387,7 @@ USA_CA|USA|California|410314 | ||||
| USA_CO|USA|Colorado|270116 | ||||
| USA_CT|USA|Connecticut|12902 | ||||
| USA_DE|USA|Delaware|5304 | ||||
| USA_DC|USA|Districtof Columbia|166 | ||||
| USA_DC|USA|District of Columbia|166 | ||||
| USA_FL|USA|Florida|147978 | ||||
| USA_GA|USA|Georgia|152863 | ||||
| USA_HI|USA|Hawaii|16809 | ||||
| @@ -3347,7 +3430,15 @@ USA_WA|USA|Washington|174789 | ||||
| USA_WV|USA|West Virginia|62782 | ||||
| USA_WI|USA|Wisconsin|169315 | ||||
| USA_WY|USA|Wyoming|253420 | ||||
| UMI_NA|UMI|Wake|9 | ||||
| UMI_Baker|UMI|Baker|2 | ||||
| UMI_Howland|UMI|Howland|2 | ||||
| UMI_Jarvisisland|UMI|Jarvis island|5 | ||||
| UMI_Johnston|UMI|Johnston|5 | ||||
| UMI_KingmanReef|UMI|Kingman Reef|3 | ||||
| UMI_Midway|UMI|Midway|12 | ||||
| UMI_Navassa|UMI|Navassa|5 | ||||
| UMI_Palmyra|UMI|Palmyra|4 | ||||
| UMI_Wake|UMI|Wake|9 | ||||
| URY_AR|URY|Artigas|12058 | ||||
| URY_CA|URY|Canelones|4536 | ||||
| URY_CL|URY|Cerro Largo|13843 | ||||
| @@ -3359,7 +3450,7 @@ URY_LA|URY|Lavalleja|10055 | ||||
| URY_MA|URY|Maldonado|4819 | ||||
| URY_MO|URY|Montevideo|533 | ||||
| URY_PA|URY|Paysandú|14141 | ||||
| URY_RN|URY|RíoNegro|9727 | ||||
| URY_RN|URY|Río Negro|9727 | ||||
| URY_RV|URY|Rivera|9358 | ||||
| URY_RO|URY|Rocha|10965 | ||||
| URY_SA|URY|Salto|14226 | ||||
| @@ -3388,87 +3479,93 @@ VUT_SE|VUT|Shefa|1522 | ||||
| VUT_TF|VUT|Tafea|1666 | ||||
| VUT_TR|VUT|Torba|889 | ||||
| VEN_Z|VEN|Amazonas|184052 | ||||
| VEN_NA|VEN|Vargas|1002 | ||||
| VEN_Anzoátegui|VEN|Anzoátegui|48025 | ||||
| VEN_C|VEN|Apure|74003 | ||||
| VEN_D|VEN|Aragua|6977 | ||||
| VEN_E|VEN|Barinas|36436 | ||||
| VEN_Bolívar|VEN|Bolívar|241518 | ||||
| VEN_G|VEN|Carabobo|4812 | ||||
| VEN_H|VEN|Cojedes|14572 | ||||
| VEN_Y|VEN|Delta Amacuro|40278 | ||||
| VEN_DP|VEN|Dependencias Federales|343 | ||||
| VEN_A|VEN|Distrito Capital|329 | ||||
| VEN_Falcón|VEN|Falcón|27275 | ||||
| VEN_Guárico|VEN|Guárico|67685 | ||||
| VEN_K|VEN|Lara|19166 | ||||
| VEN_Mérida|VEN|Mérida|12914 | ||||
| VEN_M|VEN|Miranda|8623 | ||||
| VEN_N|VEN|Monagas|29251 | ||||
| VEN_O|VEN|Nueva Esparta|1039 | ||||
| VEN_P|VEN|Portuguesa|19622 | ||||
| VEN_R|VEN|Sucre|10950 | ||||
| VEN_Táchira|VEN|Táchira|10851 | ||||
| VEN_T|VEN|Trujillo|8129 | ||||
| VEN_Vargas|VEN|Vargas|1002 | ||||
| VEN_U|VEN|Yaracuy|6259 | ||||
| VEN_V|VEN|Zulia|44191 | ||||
| VNM_AG|VNM|An Giang|3547 | ||||
| VNM_BV|VNM|BàRịa-Vũng Tàu|1918 | ||||
| VNM_BG|VNM|BắcGiang|3913 | ||||
| VNM_BK|VNM|BắcKạn|4885 | ||||
| VNM_BL|VNM|BạcLiêu|2495 | ||||
| VNM_BN|VNM|BắcNinh|825 | ||||
| VNM_BR|VNM|BếnTre|2354 | ||||
| VNM_BD|VNM|BìnhĐịnh|6102 | ||||
| VNM_BV|VNM|Bà Rịa-Vũng Tàu|1918 | ||||
| VNM_BG|VNM|Bắc Giang|3913 | ||||
| VNM_BK|VNM|Bắc Kạn|4885 | ||||
| VNM_BL|VNM|Bạc Liêu|2495 | ||||
| VNM_BN|VNM|Bắc Ninh|825 | ||||
| VNM_BR|VNM|Bến Tre|2354 | ||||
| VNM_BD|VNM|Bình Định|6102 | ||||
| VNM_BI|VNM|Bình Dương|2709 | ||||
| VNM_BP|VNM|Bình Phước|6909 | ||||
| VNM_BU|VNM|Bình Thuận|7994 | ||||
| VNM_CM|VNM|CàMau|5201 | ||||
| VNM_CN|VNM|CầnThơ|1448 | ||||
| VNM_CM|VNM|Cà Mau|5201 | ||||
| VNM_CN|VNM|Cần Thơ|1448 | ||||
| VNM_CB|VNM|Cao Bằng|6729 | ||||
| VNM_DA|VNM|ĐàNẵng|988 | ||||
| VNM_DC|VNM|ĐắkLắk|13105 | ||||
| VNM_DO|VNM|ĐắkNông|6550 | ||||
| VNM_DB|VNM|ĐiệnBiên|9549 | ||||
| VNM_DA|VNM|Đà Nẵng|988 | ||||
| VNM_DC|VNM|Đắk Lắk|13105 | ||||
| VNM_DO|VNM|Đắk Nông|6550 | ||||
| VNM_DB|VNM|Điện Biên|9549 | ||||
| VNM_DN|VNM|Đồng Nai|5899 | ||||
| VNM_DT|VNM|Đồng Tháp|3410 | ||||
| VNM_GL|VNM|Gia Lai|15610 | ||||
| VNM_HG|VNM|HàGiang|7958 | ||||
| VNM_HM|VNM|HàNam|867 | ||||
| VNM_HI|VNM|HàNội|3374 | ||||
| VNM_HT|VNM|HàTĩnh|6016 | ||||
| VNM_HD|VNM|HảiDương|1679 | ||||
| VNM_HP|VNM|HảiPhòng|1407 | ||||
| VNM_HU|VNM|HậuGiang|1633 | ||||
| VNM_HC|VNM|HồChíMinh|2122 | ||||
| VNM_HO|VNM|HoàBình|4602 | ||||
| VNM_HG|VNM|Hà Giang|7958 | ||||
| VNM_HM|VNM|Hà Nam|867 | ||||
| VNM_HI|VNM|Hà Nội|3374 | ||||
| VNM_HT|VNM|Hà Tĩnh|6016 | ||||
| VNM_HD|VNM|Hải Dương|1679 | ||||
| VNM_HP|VNM|Hải Phòng|1407 | ||||
| VNM_HU|VNM|Hậu Giang|1633 | ||||
| VNM_HC|VNM|Hồ Chí Minh|2122 | ||||
| VNM_HO|VNM|Hoà Bình|4602 | ||||
| VNM_HY|VNM|Hưng Yên|931 | ||||
| VNM_KH|VNM|Khánh Hòa|4870 | ||||
| VNM_KG|VNM|KiênGiang|6327 | ||||
| VNM_KG|VNM|Kiên Giang|6327 | ||||
| VNM_KT|VNM|Kon Tum|9706 | ||||
| VNM_LI|VNM|Lai Châu|9106 | ||||
| VNM_LD|VNM|LâmĐồng|9846 | ||||
| VNM_LD|VNM|Lâm Đồng|9846 | ||||
| VNM_LS|VNM|Lạng Sơn|8344 | ||||
| VNM_LO|VNM|LàoCai|6390 | ||||
| VNM_LO|VNM|Lào Cai|6390 | ||||
| VNM_LA|VNM|Long An|4518 | ||||
| VNM_ND|VNM|NamĐịnh|1595 | ||||
| VNM_NA|VNM|NghệAn|16562 | ||||
| VNM_ND|VNM|Nam Định|1595 | ||||
| VNM_NA|VNM|Nghệ An|16562 | ||||
| VNM_NB|VNM|Ninh Bình|1351 | ||||
| VNM_NT|VNM|Ninh Thuận|3382 | ||||
| VNM_PT|VNM|PhúThọ|3555 | ||||
| VNM_PY|VNM|PhúYên|5061 | ||||
| VNM_PT|VNM|Phú Thọ|3555 | ||||
| VNM_PY|VNM|Phú Yên|5061 | ||||
| VNM_QB|VNM|Quảng Bình|8023 | ||||
| VNM_QM|VNM|Quảng Nam|10634 | ||||
| VNM_QG|VNM|Quảng Ngãi|5194 | ||||
| VNM_QN|VNM|Quảng Ninh|6017 | ||||
| VNM_QT|VNM|Quảng Trị|4639 | ||||
| VNM_ST|VNM|SócTrăng|3303 | ||||
| VNM_SL|VNM|SơnLa|14185 | ||||
| VNM_TN|VNM|TâyNinh|4060 | ||||
| VNM_TB|VNM|TháiBình|1620 | ||||
| VNM_TY|VNM|TháiNguyên|3540 | ||||
| VNM_ST|VNM|Sóc Trăng|3303 | ||||
| VNM_SL|VNM|Sơn La|14185 | ||||
| VNM_TN|VNM|Tây Ninh|4060 | ||||
| VNM_TB|VNM|Thái Bình|1620 | ||||
| VNM_TY|VNM|Thái Nguyên|3540 | ||||
| VNM_TH|VNM|Thanh Hóa|11163 | ||||
| VNM_TT|VNM|ThừaThiênHuế|5053 | ||||
| VNM_TG|VNM|TiềnGiang|2421 | ||||
| VNM_TV|VNM|TràVinh|2339 | ||||
| VNM_TQ|VNM|TuyênQuang|5895 | ||||
| VNM_TT|VNM|Thừa Thiên Huế|5053 | ||||
| VNM_TG|VNM|Tiền Giang|2421 | ||||
| VNM_TV|VNM|Trà Vinh|2339 | ||||
| VNM_TQ|VNM|Tuyên Quang|5895 | ||||
| VNM_VL|VNM|Vĩnh Long|1534 | ||||
| VNM_VC|VNM|Vĩnh Phúc|1237 | ||||
| VNM_YB|VNM|YênBái|6921 | ||||
| VNM_YB|VNM|Yên Bái|6921 | ||||
| VIR_SC|VIR|Saint Croix|222 | ||||
| VIR_SJ|VIR|Saint John|53 | ||||
| VIR_ST|VIR|Saint Thomas|89 | ||||
| @@ -3478,7 +3575,7 @@ WLF_UV|WLF|Uvéa|82 | ||||
| ESH_BO|ESH|Boujdour|43588 | ||||
| ESH_ES|ESH|Es Semara|67211 | ||||
| ESH_LA|ESH|Laayoune|30514 | ||||
| ESH_OD|ESH|Ouedel Dahab|127186 | ||||
| ESH_OD|ESH|Oued el Dahab|127186 | ||||
| YEM_AD|YEM|`Adan|730 | ||||
| YEM_AB|YEM|Abyan|16406 | ||||
| YEM_BA|YEM|Al Bayda'|9338 | ||||
| @@ -3532,4 +3629,3 @@ Z05_UT|IND|Uttarakhand|259 | ||||
| Z09_UT|IND|Uttarakhand|987 | ||||
| Z06_JK|PAK|Azad Kashmir|13931 | ||||
| Z06_NA|PAK|Gilgit-Baltistan|68053 | ||||
| GBR_EN|GBR|England|417 | ||||
|   | ||||
							
								
								
									
										4893
									
								
								app/src/main/assets/loxim01.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.4 MiB | 
| Before Width: | Height: | Size: 6.5 MiB After Width: | Height: | Size: 6.6 MiB | 
							
								
								
									
										4893
									
								
								app/src/main/assets/webmercator01.svg
									
									
									
									
									
										Normal file
									
								
							
							
						
						| After Width: | Height: | Size: 6.6 MiB | 
| @@ -1,57 +1,52 @@ | ||||
| package net.helcel.beans.activity | ||||
|  | ||||
| import android.graphics.Color | ||||
| import android.os.Bundle | ||||
| import android.util.Log | ||||
| import android.view.MenuItem | ||||
| import androidx.appcompat.app.AppCompatActivity | ||||
| import com.github.mikephil.charting.charts.PieChart | ||||
| import com.github.mikephil.charting.data.PieData | ||||
| import com.github.mikephil.charting.data.PieDataSet | ||||
| import com.github.mikephil.charting.data.PieEntry | ||||
| import com.github.mikephil.charting.formatter.PercentFormatter | ||||
| import com.github.mikephil.charting.utils.MPPointF | ||||
| import androidx.fragment.app.Fragment | ||||
| import androidx.recyclerview.widget.LinearLayoutManager | ||||
| import androidx.recyclerview.widget.RecyclerView | ||||
| import androidx.viewpager2.adapter.FragmentStateAdapter | ||||
| import androidx.viewpager2.widget.ViewPager2 | ||||
| import com.google.android.material.tabs.TabLayoutMediator | ||||
| import net.helcel.beans.R | ||||
| import net.helcel.beans.countries.World | ||||
| import net.helcel.beans.helper.Data.groups | ||||
| import net.helcel.beans.helper.Data.visits | ||||
| import net.helcel.beans.helper.Theme.colorWrapper | ||||
| import net.helcel.beans.activity.adapter.StatsListAdapter | ||||
| import net.helcel.beans.databinding.ActivityStatBinding | ||||
| import net.helcel.beans.helper.Theme.createActionBar | ||||
|  | ||||
| private val MODE_LIST = listOf("World", "Country", "Region") | ||||
|  | ||||
| class StatActivity : AppCompatActivity() { | ||||
|  | ||||
|     private lateinit var chart: PieChart | ||||
|     private lateinit var _binding: ActivityStatBinding | ||||
|     private var activeMode: String = "World" | ||||
|  | ||||
|     override fun onCreate(savedInstanceState: Bundle?) { | ||||
|         super.onCreate(savedInstanceState) | ||||
|  | ||||
|         setContentView(R.layout.activity_stat) | ||||
|         _binding = ActivityStatBinding.inflate(layoutInflater) | ||||
|         setContentView(_binding.root) | ||||
|         createActionBar(this, getString(R.string.action_stat)) | ||||
|          | ||||
|         _binding.stats.layoutManager = | ||||
|             LinearLayoutManager(this, RecyclerView.VERTICAL, false) | ||||
|         val adapter = StatsListAdapter(_binding.stats) | ||||
|         _binding.stats.adapter = adapter | ||||
|  | ||||
|         chart = findViewById(R.id.chart) | ||||
|         chart.setUsePercentValues(true) | ||||
|         chart.description.isEnabled = false | ||||
|         chart.setExtraOffsets(5F, 10F, 5F, 5F) | ||||
|         _binding.pager.adapter = object : FragmentStateAdapter(supportFragmentManager, lifecycle) { | ||||
|             override fun getItemCount(): Int = 3 | ||||
|             override fun createFragment(position: Int): Fragment = Fragment() | ||||
|         } | ||||
|         TabLayoutMediator(_binding.tab, _binding.pager) { tab, position -> | ||||
|             tab.text = MODE_LIST[position] | ||||
|         }.attach() | ||||
|  | ||||
|         chart.centerText = "Country Area" | ||||
|  | ||||
|         chart.setDrawCenterText(true) | ||||
|         chart.isDrawHoleEnabled = true | ||||
|         chart.setTransparentCircleColor(Color.TRANSPARENT) | ||||
|         chart.setHoleColor(Color.TRANSPARENT) | ||||
|         chart.setCenterTextColor(colorWrapper(this, android.R.attr.colorForeground).color) | ||||
|         chart.setTransparentCircleAlpha(0) | ||||
|         chart.holeRadius = 40F | ||||
|         chart.transparentCircleRadius = 40F | ||||
|         chart.rotationAngle = 0F | ||||
|         chart.isRotationEnabled = false | ||||
|         chart.isHighlightPerTapEnabled = false | ||||
|  | ||||
|         chart.legend.isEnabled = false | ||||
|  | ||||
|         bind() | ||||
|         _binding.pager.registerOnPageChangeCallback(object : ViewPager2.OnPageChangeCallback() { | ||||
|             override fun onPageSelected(position: Int) { | ||||
|                 activeMode = MODE_LIST[position] | ||||
|                 adapter.refreshMode(activeMode) | ||||
|             } | ||||
|         }) | ||||
|         adapter.refreshMode(activeMode) | ||||
|     } | ||||
|  | ||||
|     override fun onOptionsItemSelected(item: MenuItem): Boolean { | ||||
| @@ -59,46 +54,4 @@ class StatActivity : AppCompatActivity() { | ||||
|         return super.onOptionsItemSelected(item) | ||||
|     } | ||||
|  | ||||
|  | ||||
|     private fun bind() { | ||||
|         val entries = ArrayList<PieEntry>() | ||||
|         val VIS_continents = World.WWW.children.groupBy { visits.getVisited(it) } | ||||
|             .map { Pair(it.key, it.value.map { c -> c.area }.fold(0) { acc, i -> acc + i }) } | ||||
|         val VIS_country = | ||||
|             World.WWW.children.map { it.children }.flatten().groupBy { visits.getVisited(it) } | ||||
|                 .map { Pair(it.key, it.value.map { c -> c.area }.fold(0) { acc, i -> acc + i }) } | ||||
|         val vis = VIS_country | ||||
|         Log.d("VIS", vis.toString()) | ||||
|         val max = vis.map { it.second }.fold(0) { acc, i -> acc + i } | ||||
|         vis.forEach { | ||||
|             entries.add( | ||||
|                 PieEntry( | ||||
|                     it.second.toFloat().div(max.toFloat()), | ||||
|                     groups.getGroupFromKey(it.first).name | ||||
|                 ) | ||||
|             ) | ||||
|         } | ||||
|         val dataSet = PieDataSet(entries, "GG1") | ||||
|  | ||||
|         dataSet.valueTextColor = Color.BLACK | ||||
|         dataSet.sliceSpace = 3f | ||||
|         dataSet.iconsOffset = MPPointF(0f, 40f) | ||||
|         dataSet.selectionShift = 5f | ||||
|  | ||||
|  | ||||
|         dataSet.setDrawIcons(true) | ||||
|         dataSet.colors = vis.map { groups.getGroupFromKey(it.first).color.color }.toList() | ||||
|  | ||||
|         val data = PieData(dataSet) | ||||
|         data.setDrawValues(false) | ||||
|         data.setValueFormatter(PercentFormatter()) | ||||
|         data.setValueTextSize(11f) | ||||
|         data.setValueTextColor(Color.BLACK) | ||||
|         chart.setEntryLabelColor(Color.BLACK) | ||||
|         chart.data = data | ||||
|         chart.highlightValues(null) | ||||
|         chart.invalidate() | ||||
|     } | ||||
|  | ||||
|  | ||||
| } | ||||
| @@ -13,29 +13,31 @@ import net.helcel.beans.activity.fragment.EditPlaceColorFragment | ||||
| import net.helcel.beans.activity.fragment.EditPlaceFragment | ||||
| import net.helcel.beans.countries.GeoLoc | ||||
| import net.helcel.beans.databinding.ItemListGeolocBinding | ||||
| import net.helcel.beans.helper.Data | ||||
| import net.helcel.beans.helper.Settings | ||||
| import net.helcel.beans.helper.* | ||||
| import net.helcel.beans.helper.Theme.colorWrapper | ||||
|  | ||||
| class GeolocListAdapter( | ||||
|     private val ctx: EditPlaceFragment, private val l: GeoLoc, private val pager: ViewPagerAdapter | ||||
|     private val ctx: EditPlaceFragment, private val l: GeoLoc, private val pager: ViewPagerAdapter, | ||||
|     private val parentHolder: FoldingListViewHolder? | ||||
| ) : RecyclerView.Adapter<GeolocListAdapter.FoldingListViewHolder>() { | ||||
|  | ||||
|     private val sortedList = l.children.toList().sortedBy { it.fullName } | ||||
|  | ||||
|     override fun onCreateViewHolder(viewGroup: ViewGroup, viewType: Int): FoldingListViewHolder { | ||||
|         val binding = ItemListGeolocBinding.inflate( | ||||
|             LayoutInflater.from(viewGroup.context), | ||||
|             viewGroup, | ||||
|             false | ||||
|         ) | ||||
|         return FoldingListViewHolder(ctx.requireActivity(), binding) | ||||
|         return FoldingListViewHolder(ctx.requireActivity(), binding, parentHolder, l) | ||||
|     } | ||||
|  | ||||
|     override fun onBindViewHolder(holder: FoldingListViewHolder, position: Int) { | ||||
|         val el = l.children[position] | ||||
|         val el = sortedList[position] | ||||
|         holder.bind(el) | ||||
|         holder.addListeners(el) { | ||||
|             if (el.children.isNotEmpty()) | ||||
|                 pager.addFragment(ctx, EditPlaceFragment(el, pager)) | ||||
|                 pager.addFragment(ctx, EditPlaceFragment(el, pager, holder)) | ||||
|             true | ||||
|         } | ||||
|     } | ||||
| @@ -46,21 +48,13 @@ class GeolocListAdapter( | ||||
|  | ||||
|     class FoldingListViewHolder( | ||||
|         private val ctx: FragmentActivity, | ||||
|         private val _binding: ItemListGeolocBinding | ||||
|     ) : RecyclerView.ViewHolder(_binding.root) { | ||||
|         private val _binding: ItemListGeolocBinding, | ||||
|         private val _parentHolder: FoldingListViewHolder? = null, | ||||
|         private val _parentGeoLoc: GeoLoc, | ||||
|     ) : RecyclerView.ViewHolder(_binding.root), DialogCloser { | ||||
|  | ||||
|         private fun bindGroup(el: GeoLoc) { | ||||
|             val numerator = el.children.map { Data.visits.getVisited(it) != 0 }.count { it } | ||||
|             val denominator = el.children.size | ||||
|  | ||||
|             _binding.count.text = when (Settings.getStatPref(ctx)) { | ||||
|                 ctx.getString(R.string.percentages) -> ctx.getString( | ||||
|                     R.string.percentage, | ||||
|                     (100 * (numerator.toFloat() / denominator.toFloat())).toInt() | ||||
|                 ) | ||||
|  | ||||
|                 else -> ctx.getString(R.string.rate, numerator, denominator) | ||||
|             } | ||||
|             refreshCount(el) | ||||
|             _binding.textView.setTypeface(null, Typeface.BOLD) | ||||
|             _binding.textView.backgroundTintList = ColorStateList.valueOf( | ||||
|                 colorWrapper( | ||||
| @@ -91,11 +85,11 @@ class GeolocListAdapter( | ||||
|                     if (_binding.checkBox.isChecked) { | ||||
|                         // If one has just checked the box (assign unique group) | ||||
|                         Data.selected_group = Data.groups.getUniqueEntry() | ||||
|                         onColorDialogDismiss(false) | ||||
|                         onDialogDismiss(false) | ||||
|                     } else { | ||||
|                         // If one has just unchecked the box (unassign unique group) | ||||
|                         Data.selected_group = null | ||||
|                         onColorDialogDismiss(true) | ||||
|                         onDialogDismiss(true) | ||||
|                     } | ||||
|                 } else { | ||||
|                     Data.selected_group = null | ||||
| @@ -104,39 +98,79 @@ class GeolocListAdapter( | ||||
|                         "AddColorDialogFragment" | ||||
|                     ) | ||||
|                 } | ||||
|                 _parentHolder?.refresh(_parentGeoLoc) | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         fun onColorDialogDismiss(clear: Boolean) { | ||||
|         override fun onDialogDismiss(clear: Boolean) { | ||||
|             if (clear) { | ||||
|                 Data.visits.setVisited(Data.selected_geoloc, 0) | ||||
|                 Data.visits.setVisited(Data.selected_geoloc, NO_GROUP) | ||||
|                 Data.saveData() | ||||
|             } | ||||
|             if (Data.selected_group != null && Data.selected_geoloc != null) { | ||||
|                 Data.visits.setVisited(Data.selected_geoloc, Data.selected_group?.key ?: 0) | ||||
|                 Data.visits.setVisited(Data.selected_geoloc, Data.selected_group?.key ?: NO_GROUP) | ||||
|                 Data.saveData() | ||||
|             } | ||||
|             Data.selected_geoloc?.let { refreshCheck(it) } | ||||
|             Data.selected_geoloc = null | ||||
|             Data.selected_group = null | ||||
|             _parentHolder?.refresh(_parentGeoLoc) | ||||
|         } | ||||
|  | ||||
|         private fun refreshCheck(geoLoc: GeoLoc) { | ||||
|             _binding.checkBox.checkedState = | ||||
|                 if (Data.visits.getVisited(geoLoc) == AUTO_GROUP && !Settings.isRegional(ctx) && geoLoc.type == GeoLoc.LocType.COUNTRY) { | ||||
|                     MaterialCheckBox.STATE_CHECKED | ||||
|                 } else if (Data.visits.getVisited(geoLoc) !in listOf(NO_GROUP, AUTO_GROUP)) { | ||||
|                     MaterialCheckBox.STATE_CHECKED | ||||
|                 } else if (geoLoc.children.isNotEmpty() && geoLoc.children.all { | ||||
|                         Data.visits.getVisited( | ||||
|                             it | ||||
|                         ) != NO_GROUP | ||||
|                     }) { | ||||
|                     Data.visits.setVisited(geoLoc, AUTO_GROUP) | ||||
|                     MaterialCheckBox.STATE_CHECKED | ||||
|                 } else if (geoLoc.children.any { Data.visits.getVisited(it) != NO_GROUP }) { | ||||
|                     Data.visits.setVisited(geoLoc, AUTO_GROUP) | ||||
|                     MaterialCheckBox.STATE_INDETERMINATE | ||||
|                 } else { | ||||
|                     Data.visits.setVisited(geoLoc, NO_GROUP) | ||||
|                     MaterialCheckBox.STATE_UNCHECKED | ||||
|                 } | ||||
|             Data.saveData() | ||||
|  | ||||
|             var col = Data.groups.getGroupFromKey(Data.visits.getVisited(geoLoc)).color | ||||
|             if (col.color == Color.TRANSPARENT) { | ||||
|                 col = colorWrapper( | ||||
|                     ctx, | ||||
|                     android.R.attr.panelColorBackground | ||||
|                 ) | ||||
|             if (Data.visits.getVisited(geoLoc) == AUTO_GROUP) { | ||||
|                 col = colorWrapper(ctx, android.R.attr.colorPrimary) | ||||
|             } else if (col.color == Color.TRANSPARENT) { | ||||
|                 col = colorWrapper(ctx, android.R.attr.panelColorBackground) | ||||
|                 col.alpha = 64 | ||||
|             } | ||||
|             _binding.checkBox.checkedState = | ||||
|                 if (Data.visits.getVisited(geoLoc) != 0) MaterialCheckBox.STATE_CHECKED | ||||
|                 else if (geoLoc.children.any { Data.visits.getVisited(it) != 0 }) MaterialCheckBox.STATE_INDETERMINATE | ||||
|                 else MaterialCheckBox.STATE_UNCHECKED | ||||
|  | ||||
|             _binding.checkBox.buttonTintList = ColorStateList.valueOf(col.color) | ||||
|         } | ||||
|  | ||||
|         private fun refreshCount(geoLoc: GeoLoc) { | ||||
|             val numerator = | ||||
|                 geoLoc.children.map { Data.visits.getVisited(it) != NO_GROUP }.count { it } | ||||
|             val denominator = geoLoc.children.size | ||||
|             _binding.count.text = when (Settings.getStatPref(ctx)) { | ||||
|                 ctx.getString(R.string.percentages) -> ctx.getString( | ||||
|                     R.string.percentage, | ||||
|                     (100 * (numerator.toFloat() / denominator.toFloat())).toInt() | ||||
|                 ) | ||||
|  | ||||
|                 else -> ctx.getString(R.string.rate, numerator, denominator) | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         private fun refresh(geoLoc: GeoLoc) { | ||||
|             // Refresh | ||||
|             refreshCheck(geoLoc) | ||||
|             refreshCount(geoLoc) | ||||
|  | ||||
|             // Recursively refresh parent | ||||
|             _parentHolder?.refresh(_parentGeoLoc) | ||||
|         } | ||||
|  | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -13,7 +13,8 @@ import net.helcel.beans.helper.Theme.getContrastColor | ||||
|  | ||||
| class GroupListAdapter( | ||||
|     private val activity: FragmentActivity, | ||||
|     private val selectDialog: DialogFragment | ||||
|     private val selectDialog: DialogFragment, | ||||
|     private val delete: Boolean = false | ||||
| ) : RecyclerView.Adapter<GroupListAdapter.GroupViewHolder>() { | ||||
|  | ||||
|     override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): GroupViewHolder { | ||||
| @@ -63,6 +64,7 @@ class GroupListAdapter( | ||||
|                 Data.selected_group = entry.second | ||||
|                 selectDialog.dismiss() | ||||
|             } | ||||
|             if (!delete) { | ||||
|                 _binding.groupColor.setOnLongClickListener { | ||||
|                     dialogFragment.show( | ||||
|                         activity.supportFragmentManager, | ||||
| @@ -72,4 +74,5 @@ class GroupListAdapter( | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,101 @@ | ||||
| package net.helcel.beans.activity.adapter | ||||
|  | ||||
| import android.view.LayoutInflater | ||||
| import android.view.ViewGroup | ||||
| import androidx.recyclerview.widget.RecyclerView | ||||
| import net.helcel.beans.countries.GeoLoc | ||||
| import net.helcel.beans.countries.World | ||||
| import net.helcel.beans.databinding.ItemListGroupBinding | ||||
| import net.helcel.beans.helper.Data | ||||
| import net.helcel.beans.helper.Groups | ||||
| import net.helcel.beans.helper.Theme.getContrastColor | ||||
|  | ||||
| class StatsListAdapter(private val stats: RecyclerView) : | ||||
|     RecyclerView.Adapter<StatsListAdapter.StatsViewHolder>() { | ||||
|  | ||||
|     override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): StatsViewHolder { | ||||
|         val binding = | ||||
|             ItemListGroupBinding.inflate(LayoutInflater.from(parent.context), parent, false) | ||||
|  | ||||
|  | ||||
|         return StatsViewHolder(binding) | ||||
|     } | ||||
|  | ||||
|     override fun onBindViewHolder(holder: StatsViewHolder, pos: Int) { | ||||
|         holder.bind(Data.groups.getGroupFromPos(pos)) | ||||
|     } | ||||
|  | ||||
|     override fun getItemCount(): Int { | ||||
|         return Data.groups.size() | ||||
|     } | ||||
|  | ||||
|     fun refreshMode(mode: String) { | ||||
|         for (i in 0 until itemCount) { | ||||
|             val viewHolder = stats.findViewHolderForAdapterPosition(i) as? StatsViewHolder | ||||
|             viewHolder?.refresh(mode) | ||||
|         } | ||||
|  | ||||
|     } | ||||
|  | ||||
|     inner class StatsViewHolder( | ||||
|         private val _binding: ItemListGroupBinding | ||||
|     ) : RecyclerView.ViewHolder(_binding.root) { | ||||
|  | ||||
|         private lateinit var data: Pair<Int, Groups.Group> | ||||
|         private var countMode: Boolean = true | ||||
|         private var locMode: String = "World" | ||||
|  | ||||
|         private lateinit var wwwCount: List<GeoLoc> | ||||
|         private lateinit var countryCount: List<GeoLoc> | ||||
|         private lateinit var stateCount: List<GeoLoc> | ||||
|         fun bind(entry: Pair<Int, Groups.Group>) { | ||||
|             data = entry | ||||
|             _binding.groupColor.text = entry.second.name | ||||
|  | ||||
|             val entryColor = data.second.color.color | ||||
|             val contrastEntryColor = getContrastColor(entryColor) | ||||
|             _binding.groupColor.setBackgroundColor(entryColor) | ||||
|             _binding.groupColor.setTextColor(contrastEntryColor) | ||||
|             _binding.name.setTextColor(contrastEntryColor) | ||||
|  | ||||
|             _binding.groupColor.setOnClickListener { | ||||
|                 countMode = !countMode | ||||
|                 refresh(locMode) | ||||
|             } | ||||
|             compute() | ||||
|             refresh(locMode) | ||||
|         } | ||||
|  | ||||
|         private fun compute() { | ||||
|             val visited = Data.visits.getVisitedByValue(data.first) | ||||
|             wwwCount = World.WWW.children.filter { it.code in visited } | ||||
|             countryCount = | ||||
|                 World.WWW.children.map { it.children.filter { itt -> itt.code in visited } } | ||||
|                     .flatten() | ||||
|             stateCount = | ||||
|                 World.WWW.children.map { it.children.map { itt -> itt.children.filter { ittt -> ittt.code in visited } } } | ||||
|                     .flatten().flatten() | ||||
|         } | ||||
|  | ||||
|         fun refresh(mode: String) { | ||||
|             locMode = mode | ||||
|             if (countMode) { | ||||
|                 _binding.name.text = when (locMode) { | ||||
|                     "World" -> wwwCount.size | ||||
|                     "Country" -> countryCount.size | ||||
|                     "Region" -> stateCount.size | ||||
|                     else -> "?" | ||||
|                 }.toString() | ||||
|             } else { | ||||
|                 _binding.name.text = when (locMode) { | ||||
|                     "World" -> wwwCount.sumOf { it.area } | ||||
|                     "Country" -> countryCount.sumOf { it.area } | ||||
|                     "Region" -> stateCount.sumOf { it.area } | ||||
|                     else -> "?" | ||||
|                 }.toString() | ||||
|             } | ||||
|  | ||||
|         } | ||||
|  | ||||
|     } | ||||
| } | ||||
| @@ -6,6 +6,7 @@ import androidx.lifecycle.Lifecycle | ||||
| import androidx.viewpager2.adapter.FragmentStateAdapter | ||||
| import androidx.viewpager2.widget.ViewPager2 | ||||
| import net.helcel.beans.activity.fragment.EditPlaceFragment | ||||
| import kotlin.math.max | ||||
|  | ||||
| class ViewPagerAdapter( | ||||
|     fragmentManager: FragmentManager, | ||||
| @@ -17,15 +18,13 @@ class ViewPagerAdapter( | ||||
|     private val fragmentList: MutableList<EditPlaceFragment> = ArrayList() | ||||
|  | ||||
|     fun addFragment(src: EditPlaceFragment?, target: EditPlaceFragment) { | ||||
|         if (src != null) { | ||||
|             while (fragmentList.last() != src) { | ||||
|                 fragmentList.removeLast() | ||||
|                 notifyItemRemoved(fragmentList.size) | ||||
|         val idx = fragmentList.indexOf(src) | ||||
|         viewPager.currentItem = max(0, idx) | ||||
|         if (src != null && idx >= 0) { | ||||
|             fragmentList.subList(idx + 1, fragmentList.size).clear() | ||||
|         } | ||||
|         } | ||||
|         println(src.toString() + " -  " + target.toString()) | ||||
|         fragmentList.add(target) | ||||
|         notifyItemInserted(fragmentList.size) | ||||
|         notifyItemRangeChanged(max(0, idx), fragmentList.size) | ||||
|         viewPager.currentItem = fragmentList.size - 1 | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -52,8 +52,8 @@ class EditGroupAddFragment( | ||||
|                 .setPositiveButton(android.R.string.ok) { _, _ -> | ||||
|                     val pos = Data.groups.findGroupPos(key) | ||||
|                     // Remove all countries belonging to that group | ||||
|                     // Delete the group | ||||
|                     Data.visits.deleteVisited(key) | ||||
|                     // Delete the group | ||||
|                     Data.groups.deleteGroup(key) | ||||
|                     Data.saveData() | ||||
|                     onDelCb(pos) | ||||
|   | ||||
| @@ -3,17 +3,19 @@ package net.helcel.beans.activity.fragment | ||||
| import android.app.Dialog | ||||
| import android.content.DialogInterface | ||||
| import android.os.Bundle | ||||
| import android.view.View | ||||
| import androidx.fragment.app.DialogFragment | ||||
| import androidx.recyclerview.widget.LinearLayoutManager | ||||
| import androidx.recyclerview.widget.RecyclerView | ||||
| import com.google.android.material.dialog.MaterialAlertDialogBuilder | ||||
| import net.helcel.beans.activity.adapter.GeolocListAdapter | ||||
| import net.helcel.beans.R | ||||
| import net.helcel.beans.activity.adapter.GroupListAdapter | ||||
| import net.helcel.beans.databinding.FragmentEditPlacesColorsBinding | ||||
| import net.helcel.beans.helper.Data | ||||
| import net.helcel.beans.helper.DialogCloser | ||||
|  | ||||
|  | ||||
| class EditPlaceColorFragment(private val parent: GeolocListAdapter.FoldingListViewHolder) : | ||||
| class EditPlaceColorFragment(private val parent: DialogCloser, private val delete: Boolean = false) : | ||||
|     DialogFragment() { | ||||
|  | ||||
|     private lateinit var _binding: FragmentEditPlacesColorsBinding | ||||
| @@ -21,7 +23,8 @@ class EditPlaceColorFragment(private val parent: GeolocListAdapter.FoldingListVi | ||||
|     private var clear: Boolean = false | ||||
|  | ||||
|     override fun onCreateDialog(savedInstanceState: Bundle?): Dialog { | ||||
|         val builder = MaterialAlertDialogBuilder(requireContext()) | ||||
|         val ctx = requireContext() | ||||
|         val builder = MaterialAlertDialogBuilder(ctx) | ||||
|         _binding = FragmentEditPlacesColorsBinding.inflate(layoutInflater) | ||||
|         _binding.btnAdd.setOnClickListener { | ||||
|             EditGroupAddFragment(0, { | ||||
| @@ -34,16 +37,25 @@ class EditPlaceColorFragment(private val parent: GeolocListAdapter.FoldingListVi | ||||
|         } | ||||
|  | ||||
|         val dialog = builder.setView(_binding.root).create() | ||||
|         listAdapt = GroupListAdapter(requireActivity(), this) | ||||
|         listAdapt = GroupListAdapter(requireActivity(), this, delete) | ||||
|         _binding.groupsColor.layoutManager = | ||||
|             LinearLayoutManager(requireContext(), RecyclerView.VERTICAL, false) | ||||
|             LinearLayoutManager(ctx, RecyclerView.VERTICAL, false) | ||||
|         _binding.groupsColor.adapter = listAdapt | ||||
|  | ||||
|         if (delete) { | ||||
|             _binding.btnAdd.visibility = View.GONE | ||||
|             _binding.btnClear.text = ctx.getString(R.string.cancel) | ||||
|             with (_binding.warningText) { | ||||
|                 visibility = View.VISIBLE | ||||
|                 text = ctx.getString(R.string.select_group) | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return dialog | ||||
|     } | ||||
|  | ||||
|     override fun onDismiss(dialog: DialogInterface) { | ||||
|         super.onDismiss(dialog) | ||||
|         parent.onColorDialogDismiss(clear) | ||||
|         parent.onDialogDismiss(clear) | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -8,11 +8,12 @@ import androidx.fragment.app.Fragment | ||||
| import androidx.recyclerview.widget.LinearLayoutManager | ||||
| import androidx.recyclerview.widget.RecyclerView | ||||
| import net.helcel.beans.activity.adapter.GeolocListAdapter | ||||
| import net.helcel.beans.activity.adapter.GeolocListAdapter.FoldingListViewHolder | ||||
| import net.helcel.beans.activity.adapter.ViewPagerAdapter | ||||
| import net.helcel.beans.countries.GeoLoc | ||||
| import net.helcel.beans.databinding.FragmentEditPlacesBinding | ||||
|  | ||||
| class EditPlaceFragment(val loc: GeoLoc, private val pager: ViewPagerAdapter) : Fragment() { | ||||
| class EditPlaceFragment(val loc: GeoLoc, private val pager: ViewPagerAdapter, private val holder: FoldingListViewHolder? = null) : Fragment() { | ||||
|     private lateinit var _binding: FragmentEditPlacesBinding | ||||
|  | ||||
|     override fun onCreateView( | ||||
| @@ -26,7 +27,7 @@ class EditPlaceFragment(val loc: GeoLoc, private val pager: ViewPagerAdapter) : | ||||
|         _binding.list.setHasFixedSize(true) | ||||
|         _binding.list.layoutManager = | ||||
|             LinearLayoutManager(requireContext(), RecyclerView.VERTICAL, false) | ||||
|         _binding.list.adapter = GeolocListAdapter(this, loc, pager) | ||||
|         _binding.list.adapter = GeolocListAdapter(this, loc, pager, holder) | ||||
|         return _binding.root | ||||
|     } | ||||
| } | ||||
| @@ -5,29 +5,54 @@ import android.os.Bundle | ||||
| import androidx.appcompat.app.AppCompatDelegate | ||||
| import androidx.preference.Preference | ||||
| import androidx.preference.PreferenceFragmentCompat | ||||
| import androidx.preference.PreferenceManager | ||||
| import net.helcel.beans.R | ||||
| import net.helcel.beans.countries.GeoLocImporter | ||||
| import net.helcel.beans.helper.Data | ||||
| import net.helcel.beans.helper.DialogCloser | ||||
|  | ||||
|  | ||||
| class SettingsFragment : PreferenceFragmentCompat() { | ||||
| class SettingsFragment : PreferenceFragmentCompat(), DialogCloser { | ||||
|     private var savedInstanceState: Bundle? = null | ||||
|     private var rootKey: String? = null | ||||
|  | ||||
|     override fun onCreatePreferences(savedInstanceState: Bundle?, rootKey: String?) { | ||||
|         this.savedInstanceState = savedInstanceState | ||||
|         this.rootKey = rootKey | ||||
|  | ||||
|         setPreferencesFromResource(R.xml.fragment_settings, rootKey) | ||||
|         val ctx = requireContext() | ||||
|         findPreference<Preference>(getString(R.string.key_regional))?.setOnPreferenceChangeListener { _, key -> | ||||
|             when (key as String) { | ||||
|                 ctx.getString(R.string.off) -> GeoLocImporter.clearStates() | ||||
|                 ctx.getString(R.string.on) -> GeoLocImporter.importStates(ctx) | ||||
|                 else -> GeoLocImporter.clearStates() | ||||
|             } | ||||
|             true | ||||
|         } | ||||
|  | ||||
|         // Select Light/Dark/System Mode | ||||
|         findPreference<Preference>(getString(R.string.key_theme))?.setOnPreferenceChangeListener { _, key -> | ||||
|             setTheme(ctx, key as String) | ||||
|         } | ||||
|  | ||||
|         // Toggle groups | ||||
|         findPreference<Preference>(getString(R.string.key_group))?.setOnPreferenceChangeListener { _, key -> | ||||
|             if (key as String == ctx.getString(R.string.off)) { | ||||
|                 val fragment = EditPlaceColorFragment(this, true) | ||||
|                 fragment.show( | ||||
|                     this.parentFragmentManager, | ||||
|                     "AddColorDialogFragment" | ||||
|                 ) | ||||
|                 false | ||||
|             } else { | ||||
|                 true | ||||
|             } | ||||
|         } | ||||
|  | ||||
|  | ||||
|         // Toggle regional geolocs | ||||
|         findPreference<Preference>(getString(R.string.key_regional))?.setOnPreferenceChangeListener { _, key -> | ||||
|             when (key as String) { | ||||
|                 ctx.getString(R.string.off) -> GeoLocImporter.clearStates() | ||||
|                 ctx.getString(R.string.on) -> GeoLocImporter.importStates(ctx, true) | ||||
|             } | ||||
|             true | ||||
|         } | ||||
|  | ||||
|  | ||||
|         // Open license fragment | ||||
|         findPreference<Preference>(getString(R.string.licenses))?.setOnPreferenceClickListener { | ||||
|             requireActivity().supportFragmentManager.beginTransaction() | ||||
| @@ -59,4 +84,30 @@ class SettingsFragment : PreferenceFragmentCompat() { | ||||
|             return true | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     override fun onDialogDismiss(clear: Boolean) { | ||||
|         // When turning groups off, select one group to keep and reassign everything | ||||
|         Data.selected_group?.let { selectedGroup -> | ||||
|             // Reassign all visited that are not to selectedGroup to selectedGroup | ||||
|             Data.visits.reassignAllVisitedtoGroup(selectedGroup.key) | ||||
|  | ||||
|             // Delete all groups that are not selectedGroup | ||||
|             Data.groups.deleteAllExcept(selectedGroup.key) | ||||
|  | ||||
|             // Save and clear global variables | ||||
|             Data.saveData() | ||||
|             Data.selected_geoloc = null | ||||
|             Data.selected_group = null | ||||
|  | ||||
|             // Actually change preference | ||||
|             val ctx = requireContext() | ||||
|             val sp = PreferenceManager.getDefaultSharedPreferences(ctx) | ||||
|             sp.edit().putString(ctx.getString(R.string.key_group), ctx.getString(R.string.off)) | ||||
|                 .apply() | ||||
|  | ||||
|             // Refresh entire preference fragment to reflect changes | ||||
|             preferenceScreen.removeAll() | ||||
|             onCreatePreferences(savedInstanceState, rootKey) | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -8,8 +8,6 @@ enum class Country( | ||||
|     HKG("Hong Kong", 1104), | ||||
|     MAC("Macao", 32), | ||||
|     ANT("Netherlands Antilles", 800), | ||||
|  | ||||
|  | ||||
|     AFG("Afghanistan", 645487), | ||||
|     XAD("Akrotiri and Dhekelia", 234), | ||||
|     ALA("Åland", 1483), | ||||
| @@ -217,7 +215,7 @@ enum class Country( | ||||
|     SLB("Solomon Islands", 28686), | ||||
|     SOM("Somalia", 637672), | ||||
|     ZAF("South Africa", 1224059), | ||||
|     SGS("South Georgia and the South Sand", 4085), | ||||
|     SGS("South Georgia and the South Sandwich Islands", 4085), | ||||
|     KOR("South Korea", 100721), | ||||
|     SSD("South Sudan", 632186), | ||||
|     ESP("Spain", 506617), | ||||
| @@ -248,7 +246,7 @@ enum class Country( | ||||
|     ARE("United Arab Emirates", 71429), | ||||
|     GBR("United Kingdom", 244732), | ||||
|     USA("United States", 9477483), | ||||
|     UMI("United States Minor Outlying Isl", 47), | ||||
|     UMI("United States Minor Outlying Islands", 47), | ||||
|     URY("Uruguay", 178103), | ||||
|     UZB("Uzbekistan", 447894), | ||||
|     VUT("Vanuatu", 12384), | ||||
| @@ -265,5 +263,5 @@ enum class Country( | ||||
|  | ||||
|     override val code = this.name | ||||
|     override val type = GeoLoc.LocType.COUNTRY | ||||
|     override val children: MutableList<GeoLoc> = ArrayList() | ||||
|     override val children: MutableSet<GeoLoc> = HashSet() | ||||
| } | ||||
|   | ||||
| @@ -15,7 +15,7 @@ interface GeoLoc { | ||||
|     val area: Int | ||||
|  | ||||
|     val type: LocType | ||||
|     val children: List<GeoLoc> | ||||
|     val children: Set<GeoLoc> | ||||
|  | ||||
|     fun shouldShowChildren(ctx: Context): Boolean { | ||||
|         if (children.isEmpty()) | ||||
|   | ||||
| @@ -1,14 +1,17 @@ | ||||
| package net.helcel.beans.countries | ||||
|  | ||||
| import android.content.Context | ||||
| import net.helcel.beans.helper.AUTO_GROUP | ||||
| import net.helcel.beans.helper.Data | ||||
| import net.helcel.beans.helper.NO_GROUP | ||||
| import net.helcel.beans.helper.Settings | ||||
| import java.io.BufferedReader | ||||
| import java.io.InputStreamReader | ||||
|  | ||||
| object GeoLocImporter { | ||||
|  | ||||
|     fun importStates(ctx: Context) { | ||||
|         if (!Settings.isRegional(ctx)) { | ||||
|     fun importStates(ctx: Context, force: Boolean = false) { | ||||
|         if (!Settings.isRegional(ctx) and !force) { | ||||
|             return | ||||
|         } | ||||
|         val fs = BufferedReader(InputStreamReader(ctx.assets.open("geoloc_state.txt"))) | ||||
| @@ -20,6 +23,19 @@ object GeoLocImporter { | ||||
|     } | ||||
|  | ||||
|     fun clearStates() { | ||||
|         Country.entries.forEach { it.children.clear() } | ||||
|         Country.entries.forEach { country -> | ||||
|             if (country.children.any { region -> | ||||
|                 Data.visits.getVisited(region) != NO_GROUP | ||||
|             }) { | ||||
|                 if (Data.visits.getVisited(country) == NO_GROUP) { | ||||
|                     Data.visits.setVisited(country, AUTO_GROUP) | ||||
|                 } | ||||
|                 country.children.forEach { region -> | ||||
|                     Data.visits.setVisited(region, NO_GROUP) | ||||
|                 } | ||||
|                 Data.saveData() | ||||
|             } | ||||
|             country.children.clear() | ||||
|         } | ||||
|     } | ||||
| } | ||||
| @@ -2,10 +2,12 @@ package net.helcel.beans.countries | ||||
|  | ||||
| import net.helcel.beans.countries.Country.* | ||||
|  | ||||
| enum class Group(override val fullName: String, override val children: List<GeoLoc>) : GeoLoc { | ||||
| enum class Group(override val fullName: String, override val children: Set<GeoLoc>) : GeoLoc { | ||||
|  | ||||
|     EEE( | ||||
|         "Europe", listOf( | ||||
|         "Europe", setOf( | ||||
|             XAD, | ||||
|             ALA,// Åland Islands: an autonomous region of Finland, but not a member of the EU or UN | ||||
|             ALB, | ||||
|             AND, | ||||
|             AUT, | ||||
| @@ -18,14 +20,19 @@ enum class Group(override val fullName: String, override val children: List<GeoL | ||||
|             CZE, | ||||
|             DNK, | ||||
|             EST, | ||||
|             FRO, // Faroe Islands: an autonomous region of Denmark | ||||
|             FIN, | ||||
|             FRA, | ||||
|             DEU, | ||||
|             GIB, // Gibraltar: a British overseas territory located at the southern tip of the Iberian Peninsula | ||||
|             GRC, | ||||
|             GGY, // Guernsey: a British Crown dependency in the English Channel | ||||
|             HUN, | ||||
|             ISL, | ||||
|             IRL, | ||||
|             IMN, // Isle of Man: a British Crown dependency located in the Irish Sea | ||||
|             ITA, | ||||
|             JEY, // Jersey: a British Crown dependency located in the English Channel | ||||
|             KAZ, | ||||
|             XKO, | ||||
|             LVA, | ||||
| @@ -48,25 +55,28 @@ enum class Group(override val fullName: String, override val children: List<GeoL | ||||
|             SVK, | ||||
|             SVN, | ||||
|             ESP, | ||||
|             SJM, // Svalbard and Jan Mayen: an archipelago administered by Norway | ||||
|             SWE, | ||||
|             CHE, | ||||
|             UKR, | ||||
|             GBR, | ||||
|             VAT, | ||||
|             XAD, | ||||
|         ) | ||||
|     ), | ||||
|     ABB( | ||||
|         "Asia", listOf( | ||||
|         "Asia", setOf( | ||||
|             AFG, | ||||
|             ARM, | ||||
|             AZE, | ||||
|             BHR, | ||||
|             BGD, | ||||
|             BTN, | ||||
|             IOT, // British Indian Ocean Territory: a British overseas territory in the Indian Ocean | ||||
|             BRN, | ||||
|             KHM, | ||||
|             CCK, // Cocos (Keeling) Islands: an Australian external territory in the Indian Ocean | ||||
|             CHN, | ||||
|             CXR, // Christmas Island: an Australian external territory in the Indian Ocean | ||||
|             GEO, | ||||
|             HKG, | ||||
|             IND, | ||||
| @@ -111,7 +121,7 @@ enum class Group(override val fullName: String, override val children: List<GeoL | ||||
|         ) | ||||
|     ), | ||||
|     FFF( | ||||
|         "Africa", listOf( | ||||
|         "Africa", setOf( | ||||
|             DZA, | ||||
|             AGO, | ||||
|             BDI, | ||||
| @@ -131,8 +141,8 @@ enum class Group(override val fullName: String, override val children: List<GeoL | ||||
|             EGY, | ||||
|             GNQ, | ||||
|             ERI, | ||||
|             SWZ, | ||||
|             ETH, | ||||
|             ATF, // French Southern and Antarctic Lands: a territory of France located in the southern Indian Ocean | ||||
|             GAB, | ||||
|             GMB, | ||||
|             GHA, | ||||
| @@ -165,6 +175,7 @@ enum class Group(override val fullName: String, override val children: List<GeoL | ||||
|             SSD, | ||||
|             SHN, | ||||
|             SDN, | ||||
|             SWZ, | ||||
|             TZA, | ||||
|             TGO, | ||||
|             TUN, | ||||
| @@ -176,7 +187,7 @@ enum class Group(override val fullName: String, override val children: List<GeoL | ||||
|         ) | ||||
|     ), | ||||
|     NNN( | ||||
|         "North America", listOf( | ||||
|         "North America", setOf( | ||||
|             ABW, | ||||
|             AIA, | ||||
|             ATG, | ||||
| @@ -184,9 +195,11 @@ enum class Group(override val fullName: String, override val children: List<GeoL | ||||
|             BRB, | ||||
|             BLZ, | ||||
|             BMU, | ||||
|             BES, // Bonaire, Sint Eustatius and Saba: special municipalities of the Netherlands in the Caribbean | ||||
|             VGB, | ||||
|             CAN, | ||||
|             CYM, | ||||
|             XCL, | ||||
|             CRI, | ||||
|             CUB, | ||||
|             CUW, | ||||
| @@ -208,19 +221,22 @@ enum class Group(override val fullName: String, override val children: List<GeoL | ||||
|             NIC, | ||||
|             PAN, | ||||
|             PRI, | ||||
|             BLM, // Saint Barthélemy: an overseas collectivity of France in the Caribbean | ||||
|             KNA, | ||||
|             LCA, | ||||
|             MAF, | ||||
|             SPM, | ||||
|             VCT, | ||||
|             SXM, // Sint Maarten: a constituent country of the Kingdom of the Netherlands in the Caribbean | ||||
|             TTO, | ||||
|             TCA, | ||||
|             USA, | ||||
|             XCL, | ||||
|             UMI, // United States Minor Outlying Islands: a collection of nine insular areas of the United States | ||||
|             VIR, // United States Virgin Islands: an unincorporated territory of the United States in the Caribbean | ||||
|         ) | ||||
|     ), | ||||
|     SRR( | ||||
|         "South America", listOf( | ||||
|         "South America", setOf( | ||||
|             ARG, | ||||
|             BOL, | ||||
|             BRA, | ||||
| @@ -238,7 +254,7 @@ enum class Group(override val fullName: String, override val children: List<GeoL | ||||
|         ) | ||||
|     ), | ||||
|     UUU( | ||||
|         "Oceania", listOf( | ||||
|         "Oceania", setOf( | ||||
|             ASM, | ||||
|             AUS, | ||||
|             COK, | ||||
| @@ -257,6 +273,7 @@ enum class Group(override val fullName: String, override val children: List<GeoL | ||||
|             PLW, | ||||
|             PNG, | ||||
|             PCN, | ||||
|             WSM, // Samoa: an independent island nation in the South Pacific | ||||
|             SLB, | ||||
|             TKL, | ||||
|             TON, | ||||
| @@ -267,39 +284,22 @@ enum class Group(override val fullName: String, override val children: List<GeoL | ||||
|     ), | ||||
|  | ||||
|     XXX( | ||||
|         "Others", listOf( | ||||
|         "Others", setOf( | ||||
|             ATA, // Antarctica: not in any other region | ||||
|             ALA,// Åland Islands: an autonomous region of Finland, but not a member of the EU or UN | ||||
|             BES,// Bonaire, Sint Eustatius and Saba: special municipalities of the Netherlands in the Caribbean | ||||
|             BVT,// Bouvet Island: an uninhabited territory of Norway in the South Atlantic | ||||
|             IOT,// British Indian Ocean Territory: a British overseas territory in the Indian Ocean | ||||
|             CXR,// Christmas Island: an Australian external territory in the Indian Ocean | ||||
|             CCK,// Cocos (Keeling) Islands: an Australian external territory in the Indian Ocean | ||||
|             FRO,// Faroe Islands: an autonomous region of Denmark | ||||
|             ATF,// French Southern and Antarctic Lands: a territory of France located in the southern Indian Ocean | ||||
|             GIB,// Gibraltar: a British overseas territory located at the southern tip of the Iberian Peninsula | ||||
|             GGY,// Guernsey: a British Crown dependency in the English Channel | ||||
|             HMD,// Heard Island and McDonald Islands: an uninhabited Australian external territory in the southern Indian Ocean | ||||
|             IMN,// Isle of Man: a British Crown dependency located in the Irish Sea | ||||
|             JEY,// Jersey: a British Crown dependency located in the English Channel | ||||
|             BLM,// Saint Barthélemy: an overseas collectivity of France in the Caribbean | ||||
|             WSM, // Samoa: an independent island nation in the South Pacific | ||||
|             SXM, // Sint Maarten: a constituent country of the Kingdom of the Netherlands in the Caribbean | ||||
|             BVT, // Bouvet Island: an uninhabited territory of Norway in the South Atlantic | ||||
|             HMD, // Heard Island and McDonald Islands: an uninhabited Australian external territory in the southern Indian Ocean | ||||
|             SGS, // South Georgia and the South Sandwich Islands: a British overseas territory in the southern Atlantic Ocean | ||||
|             SJM, // Svalbard and Jan Mayen: an archipelago administered by Norway | ||||
|             UMI, // United States Minor Outlying Islands: a collection of nine insular areas of the United States | ||||
|             VIR, // United States Virgin Islands: an unincorporated territory of the United States in the Caribbean | ||||
|         ) | ||||
|     ), | ||||
|  | ||||
|     ZZZ( | ||||
|         "Undefined", listOf( | ||||
|         "Undefined", setOf( | ||||
|         ) | ||||
|     ), | ||||
|  | ||||
|  | ||||
|     NTT( | ||||
|         "NATO", listOf( | ||||
|         "NATO", setOf( | ||||
|             ALB, BEL, BGR, CAN, HRV, CZE, DNK, EST, FRA, DEU, GRC, HUN, ISL, ITA, LVA, LTU, LUX, | ||||
|             MNE, NLD, NOR, POL, PRT, ROU, SVK, SVN, ESP, TUR, GBR, USA | ||||
|         ) | ||||
|   | ||||
| @@ -3,6 +3,17 @@ package net.helcel.beans.countries | ||||
| class State(override val code: String, override val fullName: String, override val area: Int) : | ||||
|     GeoLoc { | ||||
|  | ||||
|     override val children = emptyList<GeoLoc>() | ||||
|     override val children = emptySet<GeoLoc>() | ||||
|     override val type = GeoLoc.LocType.STATE | ||||
|  | ||||
|     override fun hashCode(): Int { | ||||
|         return code.hashCode() | ||||
|     } | ||||
|  | ||||
|     override fun equals(other: Any?): Boolean { | ||||
|         if (other is GeoLoc) { | ||||
|             return other.code == this.code | ||||
|         } | ||||
|         return false | ||||
|     } | ||||
| } | ||||
| @@ -2,11 +2,13 @@ package net.helcel.beans.countries | ||||
|  | ||||
| import net.helcel.beans.countries.Group.* | ||||
|  | ||||
| enum class World(override val fullName: String, override val children: List<GeoLoc>) : GeoLoc { | ||||
| enum class World(override val fullName: String, override val children: Set<GeoLoc>) : GeoLoc { | ||||
|  | ||||
|     WWW("World", listOf( | ||||
|     WWW( | ||||
|         "World", setOf( | ||||
|             EEE, ABB, FFF, NNN, SRR, UUU, XXX | ||||
|     )); | ||||
|         ) | ||||
|     ); | ||||
|  | ||||
|     override val area = children.fold(0) { acc, i -> | ||||
|         acc + i.area | ||||
|   | ||||
| @@ -34,7 +34,7 @@ fun loadData(ctx: Context, id:Int) { | ||||
|  | ||||
|     // Add default group "Visited" with app's color if there is no group already | ||||
|     if (groups.size() == 0) { | ||||
|         groups.setGroup(1, "Visited", ColorDrawable(ContextCompat.getColor(ctx, R.color.blue))) | ||||
|         groups.setGroup(DEFAULT_GROUP, "Visited", ColorDrawable(ContextCompat.getColor(ctx, R.color.blue))) | ||||
|         saveData() | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -0,0 +1,5 @@ | ||||
| package net.helcel.beans.helper | ||||
|  | ||||
| interface DialogCloser { | ||||
|     fun onDialogDismiss(clear: Boolean) | ||||
| } | ||||
| @@ -13,6 +13,10 @@ import kotlin.random.Random | ||||
| private const val randSeed = 0 | ||||
| private val rnd = Random(randSeed) | ||||
|  | ||||
| const val NO_GROUP = 0 | ||||
| const val DEFAULT_GROUP = 1 | ||||
| const val AUTO_GROUP = -1 | ||||
|  | ||||
| @Serializable | ||||
| class Groups(val id: Int, private val grps: HashMap<Int, Group>) { | ||||
|  | ||||
| @@ -24,13 +28,18 @@ class Groups(val id: Int, private val grps: HashMap<Int, Group>) { | ||||
|         grps.remove(key) | ||||
|     } | ||||
|  | ||||
|     fun deleteAllExcept(grp: Int) { | ||||
|         val keysToDelete = grps.keys.filter { it != grp } | ||||
|         keysToDelete.forEach { grps.remove(it) } | ||||
|     } | ||||
|  | ||||
|     fun getGroupFromKey(key: Int): Group { | ||||
|         return grps.getOrDefault(key, EmptyGroup()) | ||||
|     } | ||||
|  | ||||
|     fun genKey(): Int { | ||||
|         val key = rnd.nextInt() | ||||
|         if (grps.containsKey(key) || key == 0) return genKey() | ||||
|         if (grps.containsKey(key) || key in listOf(NO_GROUP, DEFAULT_GROUP, AUTO_GROUP)) return genKey() | ||||
|         return key | ||||
|     } | ||||
|  | ||||
| @@ -56,6 +65,10 @@ class Groups(val id: Int, private val grps: HashMap<Int, Group>) { | ||||
|         return grps.keys.toList().indexOf(key) | ||||
|     } | ||||
|  | ||||
|     fun forEach(action: (Map.Entry<Int, Group>) -> Unit) { | ||||
|         grps.forEach { action(it) } | ||||
|     } | ||||
|  | ||||
|     class EmptyGroup : Group(0, "") | ||||
|  | ||||
|     @Serializable | ||||
|   | ||||
| @@ -27,7 +27,7 @@ class Visits(val id: Int, private val locs: HashMap<String, Int>) { | ||||
|     } | ||||
|  | ||||
|     fun getVisited(key: GeoLoc): Int { | ||||
|         return locs.getOrDefault(key.code, 0) | ||||
|         return getVisited(key.code) | ||||
|     } | ||||
|  | ||||
|     private fun getVisited(key: String): Int { | ||||
| @@ -42,6 +42,19 @@ class Visits(val id: Int, private val locs: HashMap<String, Int>) { | ||||
|         return locs.keys.groupBy { getVisited(it) } | ||||
|     } | ||||
|  | ||||
|     fun getVisitedByValue(key: Int): List<String> { | ||||
|         return locs.filter { it.value == key }.keys.toList() | ||||
|     } | ||||
|  | ||||
|     fun reassignAllVisitedtoGroup(group: Int) { | ||||
|         val keys = locs.filter { (_, grp) -> | ||||
|             grp !in listOf(NO_GROUP, AUTO_GROUP) | ||||
|         }.keys | ||||
|         keys.forEach { | ||||
|             locs[it] = group | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     @OptIn(ExperimentalSerializationApi::class) | ||||
|     @Serializer(Visits::class) | ||||
|     class VisitsSerializer { | ||||
|   | ||||
| @@ -2,49 +2,65 @@ package net.helcel.beans.svg | ||||
|  | ||||
| import android.content.Context | ||||
| import net.helcel.beans.countries.World | ||||
| import net.helcel.beans.helper.AUTO_GROUP | ||||
| import net.helcel.beans.helper.Data | ||||
| import net.helcel.beans.helper.Data.groups | ||||
| import net.helcel.beans.helper.Data.visits | ||||
| import net.helcel.beans.helper.NO_GROUP | ||||
| import net.helcel.beans.helper.Settings | ||||
| import net.helcel.beans.helper.Theme.colorToHex6 | ||||
| import net.helcel.beans.helper.Theme.colorWrapper | ||||
|  | ||||
| class CSSWrapper(ctx: Context) { | ||||
| class CSSWrapper(private val ctx: Context) { | ||||
|  | ||||
|     private val colorForeground: String = | ||||
|         colorToHex6(colorWrapper(ctx, android.R.attr.panelColorBackground)) | ||||
|     private val colorBackground: String = | ||||
|         colorToHex6(colorWrapper(ctx, android.R.attr.colorBackground)) | ||||
|  | ||||
|     private val baseCSS: String | ||||
|     private val continents: String = World.WWW.children.joinToString(",") { "#${it.code}2" } | ||||
|     private val countries: String = World.WWW.children.joinToString(",") { itt -> | ||||
|         itt.children.joinToString(",") { "#${it.code}2" } | ||||
|     } | ||||
|     private val regional: String = World.WWW.children.joinToString(",") { itt -> | ||||
|         itt.children.joinToString(",") { "#${it.code}1" } | ||||
|     } | ||||
|     private val countryOnlyCSS: String = | ||||
|         "svg{fill:$colorForeground;stroke:$colorBackground;stroke-width:0.1;}" + | ||||
|                 "${regional}{display:none;}" | ||||
|     private val countryRegionalCSS: String = | ||||
|         "svg{fill:$colorForeground;stroke:$colorBackground;stroke-width:0.01;}" + | ||||
|                 "$continents,$countries{fill:none;stroke:$colorBackground;stroke-width:0.1;}" | ||||
|     private var customCSS: String = "" | ||||
|  | ||||
|     init { | ||||
|         val www = World.WWW.children.joinToString(",") { "#${it.code}2" } | ||||
|         val ccc = World.WWW.children.joinToString(",") { itt -> | ||||
|             itt.children.joinToString(",") { "#${it.code}2" } | ||||
|         } | ||||
|         baseCSS = "svg{fill:$colorForeground;stroke:$colorBackground;stroke-width:0.01;}" + | ||||
|                 "$www,$ccc{stroke:$colorBackground;stroke-width:0.1;fill:none}" | ||||
|         refresh() | ||||
|     } | ||||
|  | ||||
|     fun refresh() { | ||||
|     private fun refresh() { | ||||
|         val id = if (Settings.isRegional(ctx)) "1" else "2" | ||||
|         customCSS = visits.getVisitedByValue().map { (k, v) -> | ||||
|             if (groups.getGroupFromKey(k).key == 0) | ||||
|             if (!Settings.isRegional(ctx) && k == AUTO_GROUP) { | ||||
|                 v.joinToString(",") { "#${it}$id,#${it}" } + "{fill:${ | ||||
|                     colorToHex6(colorWrapper(ctx, android.R.attr.colorPrimary)) | ||||
|                 };}" | ||||
|             } | ||||
|             else if (groups.getGroupFromKey(k).key == NO_GROUP) | ||||
|                 "" | ||||
|             else | ||||
|                 v.joinToString(",") { "#${it}1,#${it}" } + "{fill:${ | ||||
|                     colorToHex6( | ||||
|                         groups.getGroupFromKey( | ||||
|                             k | ||||
|                         ).color | ||||
|                     ) | ||||
|                 v.joinToString(",") { "#${it}$id,#${it}" } + "{fill:${ | ||||
|                     colorToHex6(groups.getGroupFromKey(k).color) | ||||
|                 };}" | ||||
|         }.joinToString("") | ||||
|     } | ||||
|  | ||||
|     fun get(): String { | ||||
|         refresh() | ||||
|         return baseCSS + customCSS | ||||
|         return if (Settings.isRegional(ctx)) { | ||||
|             countryRegionalCSS + customCSS | ||||
|         } else { | ||||
|             countryOnlyCSS + customCSS | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										16
									
								
								app/src/main/res/drawable/group.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,16 @@ | ||||
| <vector | ||||
| android:height="24dp" | ||||
| android:viewportHeight="24" | ||||
| android:viewportWidth="24" | ||||
| android:width="24dp" | ||||
| xmlns:android="http://schemas.android.com/apk/res/android" > | ||||
|  | ||||
| <path android:fillColor="?attr/colorOnBackground" android:pathData="M12,2C6.48,2 2,6.48 2,12s4.48,10 10,10 10,-4.48 10,-10S17.52,2 12,2zM12,20c-4.41,0 -8,-3.59 -8,-8s3.59,-8 8,-8 8,3.59 8,8 -3.59,8 -8,8z"/> | ||||
|  | ||||
| <path android:fillColor="?attr/colorPrimary" android:pathData="M8,14m-2,0a2,2 0,1 1,4 0a2,2 0,1 1,-4 0"/> | ||||
|  | ||||
| <path android:fillColor="?attr/colorPrimary" android:pathData="M12,8m-2,0a2,2 0,1 1,4 0a2,2 0,1 1,-4 0"/> | ||||
|  | ||||
| <path android:fillColor="?attr/colorPrimary" android:pathData="M16,14m-2,0a2,2 0,1 1,4 0a2,2 0,1 1,-4 0"/> | ||||
|  | ||||
| </vector> | ||||
							
								
								
									
										12
									
								
								app/src/main/res/drawable/zoomin.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						| @@ -0,0 +1,12 @@ | ||||
| <vector | ||||
| android:height="24dp" | ||||
| android:viewportHeight="24" | ||||
| android:viewportWidth="24" | ||||
| android:width="24dp" | ||||
| xmlns:android="http://schemas.android.com/apk/res/android" > | ||||
|  | ||||
| <path android:fillColor="?attr/colorOnBackground" android:pathData="M15.5,14h-0.79l-0.28,-0.27C15.41,12.59 16,11.11 16,9.5 16,5.91 13.09,3 9.5,3S3,5.91 3,9.5 5.91,16 9.5,16c1.61,0 3.09,-0.59 4.23,-1.57l0.27,0.28v0.79l5,4.99L20.49,19l-4.99,-5zM9.5,14C7.01,14 5,11.99 5,9.5S7.01,5 9.5,5 14,7.01 14,9.5 11.99,14 9.5,14z"/> | ||||
|  | ||||
| <path android:fillColor="?attr/colorPrimary" android:pathData="M12,10h-2v2H9v-2H7V9h2V7h1v2h2v1z"/> | ||||
|  | ||||
| </vector> | ||||
| @@ -1,5 +1,6 @@ | ||||
| <?xml version="1.0" encoding="utf-8"?> | ||||
| <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||||
|     xmlns:app="http://schemas.android.com/apk/res-auto" | ||||
|     xmlns:tools="http://schemas.android.com/tools" | ||||
|     android:layout_width="match_parent" | ||||
|     android:layout_height="match_parent" | ||||
| @@ -7,9 +8,59 @@ | ||||
|     android:theme="@style/Theme.Beans" | ||||
|     tools:context=".activity.StatActivity"> | ||||
|  | ||||
|     <com.github.mikephil.charting.charts.PieChart | ||||
|         android:id="@+id/chart" | ||||
|     <com.google.android.material.tabs.TabLayout | ||||
|         android:id="@+id/tab" | ||||
|         android:layout_width="match_parent" | ||||
|         android:layout_height="match_parent" /> | ||||
|         android:layout_height="wrap_content" /> | ||||
|  | ||||
|     <androidx.viewpager2.widget.ViewPager2 | ||||
|         android:id="@+id/pager" | ||||
|         android:layout_width="match_parent" | ||||
|         android:layout_height="0dp" | ||||
|         android:layout_weight="1" | ||||
|         android:visibility="gone" /> | ||||
|  | ||||
|     <androidx.constraintlayout.widget.ConstraintLayout | ||||
|         android:layout_width="match_parent" | ||||
|         android:layout_height="wrap_content" | ||||
|         android:paddingBottom="10dp"> | ||||
|  | ||||
|         <com.google.android.material.button.MaterialButton | ||||
|             android:id="@+id/group_color" | ||||
|             android:layout_width="0dp" | ||||
|             android:layout_height="wrap_content" | ||||
|             android:layout_marginTop="2dp" | ||||
|             android:layout_marginBottom="2dp" | ||||
|             android:paddingStart="56dp" | ||||
|             android:text="@string/total" | ||||
|             android:textAlignment="textStart" | ||||
|             android:textColor="?attr/colorOnPrimary" | ||||
|             app:cornerRadius="0dp" | ||||
|             app:layout_constraintBottom_toBottomOf="parent" | ||||
|             app:layout_constraintEnd_toEndOf="parent" | ||||
|             app:layout_constraintStart_toStartOf="parent" | ||||
|             app:layout_constraintTop_toTopOf="parent" | ||||
|             tools:ignore="RtlSymmetry" /> | ||||
|  | ||||
|         <com.google.android.material.textview.MaterialTextView | ||||
|             android:id="@+id/name" | ||||
|             android:layout_width="wrap_content" | ||||
|             android:layout_height="50dp" | ||||
|             android:gravity="start|center_vertical" | ||||
|             android:paddingStart="20dp" | ||||
|             android:paddingEnd="52dp" | ||||
|             android:text="TODO" | ||||
|             android:textColor="?attr/colorOnPrimary" | ||||
|             app:layout_constraintBottom_toBottomOf="@id/group_color" | ||||
|             app:layout_constraintEnd_toEndOf="@id/group_color" | ||||
|             app:layout_constraintTop_toTopOf="@id/group_color" /> | ||||
|  | ||||
|     </androidx.constraintlayout.widget.ConstraintLayout> | ||||
|  | ||||
|  | ||||
|     <androidx.recyclerview.widget.RecyclerView | ||||
|         android:id="@+id/stats" | ||||
|         android:layout_width="match_parent" | ||||
|         android:layout_height="wrap_content" /> | ||||
|  | ||||
| </LinearLayout> | ||||
| @@ -6,6 +6,13 @@ | ||||
|     android:orientation="vertical" | ||||
|     android:padding="16dp"> | ||||
|  | ||||
|     <TextView | ||||
|         android:id="@+id/warning_text" | ||||
|         android:layout_width="match_parent" | ||||
|         android:layout_height="wrap_content" | ||||
|         android:layout_marginBottom="10dp" | ||||
|         android:visibility="gone" /> | ||||
|  | ||||
|     <ScrollView | ||||
|         android:layout_width="match_parent" | ||||
|         android:layout_height="wrap_content" | ||||
|   | ||||
| @@ -21,6 +21,7 @@ | ||||
|     <string name="foss_licenses">Free and open source dependencies and licenses</string> | ||||
|     <string name="about_beans">About the Beans application</string> | ||||
|     <string name="delete_group">Are your sure you want to delete this group and remove all its country mappings?</string> | ||||
|     <string name="select_group">Select one group you want to keep. All others will be deleted and its mappings reassigned to the group you choose here.</string> | ||||
|     <string name="add">Add</string> | ||||
|     <string name="clear">Clear</string> | ||||
|     <string name="logo">Logo</string> | ||||
| @@ -34,4 +35,5 @@ | ||||
|     <string name="delete">Delete</string> | ||||
|     <string name="cancel">Cancel</string> | ||||
|     <string name="ok">Ok</string> | ||||
|     <string name="total">Total</string> | ||||
| </resources> | ||||
| @@ -4,23 +4,13 @@ | ||||
|     android:theme="@style/Theme.Beans"> | ||||
|  | ||||
|     <ListPreference | ||||
|         app:defaultValue="@string/off" | ||||
|         app:defaultValue="@string/system" | ||||
|         app:enabled="true" | ||||
|         app:entries="@array/entries_onoff" | ||||
|         app:entryValues="@array/entries_onoff" | ||||
|         app:icon="@drawable/edit" | ||||
|         app:key="@string/key_group" | ||||
|         app:title="@string/key_group" | ||||
|         app:useSimpleSummaryProvider="true" /> | ||||
|  | ||||
|     <ListPreference | ||||
|         app:defaultValue="@string/off" | ||||
|         app:enabled="true" | ||||
|         app:entries="@array/entries_onoff" | ||||
|         app:entryValues="@array/entries_onoff" | ||||
|         app:icon="@drawable/edit" | ||||
|         app:key="@string/key_regional" | ||||
|         app:title="@string/key_regional" | ||||
|         app:entries="@array/entries_theme" | ||||
|         app:entryValues="@array/entries_theme" | ||||
|         app:icon="@drawable/palette" | ||||
|         app:key="@string/key_theme" | ||||
|         app:title="@string/key_theme" | ||||
|         app:useSimpleSummaryProvider="true" /> | ||||
|  | ||||
|     <ListPreference | ||||
| @@ -34,18 +24,30 @@ | ||||
|         app:useSimpleSummaryProvider="true" /> | ||||
|  | ||||
|     <ListPreference | ||||
|         app:defaultValue="@string/system" | ||||
|         app:defaultValue="@string/off" | ||||
|         app:enabled="true" | ||||
|         app:entries="@array/entries_theme" | ||||
|         app:entryValues="@array/entries_theme" | ||||
|         app:icon="@drawable/palette" | ||||
|         app:key="@string/key_theme" | ||||
|         app:title="@string/key_theme" | ||||
|         app:allowDividerAbove="true" | ||||
|         app:entries="@array/entries_onoff" | ||||
|         app:entryValues="@array/entries_onoff" | ||||
|         app:icon="@drawable/group" | ||||
|         app:key="@string/key_group" | ||||
|         app:title="@string/key_group" | ||||
|         app:useSimpleSummaryProvider="true" /> | ||||
|  | ||||
|     <ListPreference | ||||
|         app:defaultValue="@string/off" | ||||
|         app:enabled="true" | ||||
|         app:entries="@array/entries_onoff" | ||||
|         app:entryValues="@array/entries_onoff" | ||||
|         app:icon="@drawable/zoomin" | ||||
|         app:key="@string/key_regional" | ||||
|         app:title="@string/key_regional" | ||||
|         app:useSimpleSummaryProvider="true" /> | ||||
|  | ||||
|     <Preference | ||||
|         android:summary="@string/foss_licenses" | ||||
|         app:enabled="true" | ||||
|         app:allowDividerAbove="true" | ||||
|         app:icon="@drawable/licenses" | ||||
|         app:key="@string/licenses" | ||||
|         app:title="@string/licenses" /> | ||||
|   | ||||
							
								
								
									
										17
									
								
								genenum.js
									
									
									
									
									
								
							
							
						
						| @@ -58,12 +58,25 @@ const groups = { | ||||
| var dict0 = {} | ||||
| var dict1 = {} | ||||
|  | ||||
| const formatStr = (str)=> str.replace(/(?<!\b\w)\B[A-Z]|,(?!$)/g, match => { | ||||
| const formatStr = (str)=> str.replace(/(?<!\b\w\u00E0-\u00FC)\B[A-Z\u00C0-\u00DC]|,(?!$)/g, match => { | ||||
|   if (match.startsWith(',')) { | ||||
|       return ', '; | ||||
|   } else { | ||||
|       return ' ' + match; | ||||
|   }}) | ||||
|   }}).replace("ofthe "," of the ").replace("dela ", " de la ").replace("delos ", " de los ").replace("áD","á D") | ||||
|   .replace("Côted'","Côte d'").replace("leof ","le of ").replace("dde ","d de ").replace("iode ","io de ").replace("àde ","à de ") | ||||
|   .replace("yof ","y of ").replace("Andrésy ","Andrés y") | ||||
|   .replace("aand ","a and ").replace("iand ", "i and ").replace("tsand ","ts and ").replace("onand ","on and ").replace("reand ", "re and ") | ||||
|   .replace("odel ","o del ").replace("adel ", "a del ").replace("ndel ","n del ").replace("zdel ","z del ").replace("falde ", "fal de ").replace("casdel ","cas del ") | ||||
|   .replace("odosÓ", "o dos Ó") | ||||
|   .replace("Grandedo ", "Grande do ").replace("Grandede ","Grande de ") | ||||
|   .replace("Santiagode ","Santiago de ").replace("Joséde ","José de ").replace("Pedrode ","Pedro de ") | ||||
|   .replace("andthe "," and the ") | ||||
|   .replace("emunicipality", "e municipality").replace("Villede ", "Ville de ") | ||||
|   .replace("Valledel ","Valle del ").replace("Valde ","Val de ").replace("Îlesdu ","Îles du ") | ||||
|   .replace("sÉ","s É").replace("áO","á O").replace("N C Tof ","NCT of ").replace("N A","NA") | ||||
|   .replace("Nortede ", "Norte de ") | ||||
|   .trim() | ||||
|  | ||||
| const parse0 = (country) => { | ||||
|   const filepath = `temp/0/${country}.json` | ||||
|   | ||||
							
								
								
									
										29
									
								
								gensvg.sh
									
									
									
									
									
								
							
							
						
						| @@ -6,6 +6,7 @@ GADM_VERSION="4.1" | ||||
| GADM_BASEPATH="https://geodata.ucdavis.edu/gadm" | ||||
|  | ||||
| mapshaper="./node_modules/mapshaper/bin/mapshaper" | ||||
| ATA_URL="https://media.githubusercontent.com/media/wmgeolab/geoBoundaries/905b0baf5f4fb3b9ccf45293647dcacdb2b799d4/releaseData/gbOpen/ATA/ADM0/geoBoundaries-ATA-ADM0_simplified.geojson" | ||||
|  | ||||
| countries=( | ||||
|   "AFG" "XAD" "ALA" "ALB" "DZA" "ASM" "AND" "AGO" "AIA" "ATG" "ARG" "ARM" "ABW" "AUS" "AUT" "AZE" | ||||
| @@ -67,7 +68,10 @@ download_1() { | ||||
|         jq '.features[] |= . + {properties: (.properties | .GID_1 = (.GID_0 + "_" + ( | ||||
|             if .HASC_1 != "NA" then (.HASC_1 | split(".") | .[-1]) | ||||
|             elif .ISO_1 != "NA" then (.ISO_1 | split("-") | .[-1]) | ||||
|             else (.CC_1) | ||||
|             elif .CC_1 != "NA" then (.CC_1) | ||||
|             elif .NAME_1 != "NA" then (.NAME_1) | ||||
|             elif .GID_1 != "NA" then (.GID_1 | split(".") | .[-1]) | ||||
|             else .GID_1 | ||||
|             end | ||||
|             )))}' "$output_dir/gadm41_${1}_1.json"  > "$output_dir/$1.json.1" | ||||
|         sed -E 's/"[gadm41_]*([A-Z]*)_1"/"\1"/g' "$output_dir/$1.json.1" > "$output_dir/$1.json" | ||||
| @@ -76,7 +80,7 @@ download_1() { | ||||
|  | ||||
|  | ||||
| toSVG_0() { | ||||
|     local input_files=() | ||||
|     local input_files=("ATA") | ||||
|  | ||||
|     for country in "${countries[@]}" | ||||
|     do | ||||
| @@ -94,7 +98,7 @@ toSVG_0() { | ||||
| } | ||||
|  | ||||
| toSVG_1() { | ||||
|     input_files=() | ||||
|     input_files=("ATA") | ||||
|  | ||||
|     for country in "${countries[@]}" | ||||
|     do | ||||
| @@ -113,12 +117,12 @@ toSVG_1() { | ||||
|  | ||||
|  | ||||
| toSVG_01() { | ||||
|     input_files=() | ||||
|     input_files=("./temp/1/ATA.json" "./temp/0/ATA.json") | ||||
|  | ||||
|     for country in "${countries[@]}" | ||||
|     do | ||||
|         input_file0="./temp/0/${country}.json" | ||||
|         input_file1="./temp/1/${country}.json" | ||||
|         input_file0="./temp/0/${country}.json" | ||||
|         if [ -f "$input_file1" ]; then | ||||
|             input_files+=("$input_file1") | ||||
|         fi | ||||
| @@ -127,8 +131,13 @@ toSVG_01() { | ||||
|         fi | ||||
|     done | ||||
|  | ||||
|     "$mapshaper" -i combine-files ${input_files[@]} -proj webmercator -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/mercator01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     "$mapshaper" -i combine-files ${input_files[@]} -proj aeqd +lat_0=90 -simplify 0.005 weighted keep-shapes resolution=1200x1200 -o ./app/src/main/assets/aeqd01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|  | ||||
|     # "$mapshaper" -i combine-files ${input_files[@]} -proj eqdc +lat_1=55 +lat_2=60 -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/eqdc01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     # "$mapshaper" -i combine-files ${input_files[@]} -proj loxim -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/loxim01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     # "$mapshaper" -i combine-files ${input_files[@]} -proj eqearth -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/eqearth01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     "$mapshaper" -i combine-files ${input_files[@]} -proj merc +lat_ts=47.36667 -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/mercator01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     # "$mapshaper" -i combine-files ${input_files[@]} -proj webmercator -simplify 0.005 weighted keep-shapes resolution=1200x1200  -o ./app/src/main/assets/webmercator01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
|     # "$mapshaper" -i combine-files ${input_files[@]} -proj aeqd +lat_0=90 -simplify 0.005 weighted keep-shapes resolution=1200x1200 -o ./app/src/main/assets/aeqd01.svg svg-data=GID_0,COUNTRY,GID,NAME id-field=GID | ||||
| } | ||||
|  | ||||
| do_1() { | ||||
| @@ -136,15 +145,17 @@ do_1() { | ||||
|     do | ||||
|         download_1 "$country" | ||||
|     done | ||||
|     wget -q -O "./temp/1/ATA.json" "$ATA_URL" | ||||
| } | ||||
| do_0() { | ||||
|     for country in "${countries[@]}" | ||||
|     do | ||||
|         download_0 "$country" | ||||
|     done | ||||
|     wget -q -O "./temp/1/ATA.json" "$ATA_URL" | ||||
| } | ||||
| # do_0 | ||||
| do_0 | ||||
| do_1 | ||||
| # toSVG_0 | ||||
| toSVG_1 | ||||
| # toSVG_1 | ||||
| toSVG_01 | ||||