Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/wilfredpine/philippine-address-selector

Autofill selects input of Region, Province, City/Municipality, and Barangay in the Philippines.
https://github.com/wilfredpine/philippine-address-selector

address autofill barangay city html javascript jquery json municipalities philippines regions select selector web

Last synced: 2 months ago
JSON representation

Autofill selects input of Region, Province, City/Municipality, and Barangay in the Philippines.

Awesome Lists containing this project

README

        

# Address Selector - Philippines
### PH Address JSON file from https://github.com/isaacdarcilla/philippine-addresses

![This is an image](https://lh3.googleusercontent.com/pw/AM-JKLU7NduoFSLoDW5Nz6l33o8-xRkynZIVAxuFjCYkKKmgtrTHxSSVz3gISZEsn9lb0OGG4MqIo0xAkygD0-5d0CV9VOpaqifVgEFgxc5k8ZYG3aiFvpLtUgq9XF69ONIwhKu9psfNKxDg8-XT4uf474DA=w909-h549-no?authuser=0)

### PSA PSGC
https://www.psa.gov.ph/classification/psgc

### Requirements:
- JQUERY

```html

```

- HTML Tags

```html





```

- Javascript

Load Region
```javascript
// load region
let dropdown = $('#region');
dropdown.empty();
dropdown.append('Choose Region');
dropdown.prop('selectedIndex', 0);
const url = 'ph-json/region.json';
// Populate dropdown with list of regions
$.getJSON(url, function (data) {
$.each(data, function (key, entry) {
dropdown.append($('').attr('value', entry.region_code).text(entry.region_name));
})
});
```

Change or Select Region
```javascript
// load provinces
$('#region').on('change', my_handlers.fill_provinces);
```

Load Province Function
```javascript
function(){
//selected region
var region_code = $(this).val();

// set selected text to input
var region_text = $(this).find("option:selected").text();
let region_input = $('#region-text');
region_input.val(region_text);

//province
let dropdown = $('#province');
dropdown.empty();
dropdown.append('Choose State/Province');
dropdown.prop('selectedIndex', 0);

// filter & fill
var url = 'ph-json/province.json';
$.getJSON(url, function(data) {
var result = data.filter(function(value){
return value.region_code == region_code;
});

result.sort(function (a, b) {
return a.province_name.localeCompare(b.province_name);
});

$.each(result, function (key, entry) {
dropdown.append($('').attr('value', entry.province_code).text(entry.province_name));
})

});
}
```

### Full Code

#### HTML
https://github.com/wilfredpine/philippine-address-selector/blob/main/index.html

#### JS
https://github.com/wilfredpine/philippine-address-selector/blob/main/ph-address-selector.js