You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

173 lines
5.4 KiB

import React from 'react'
import L from 'leaflet'
import { ReactDOMServer, renderToStaticMarkup } from 'react-dom/server'
import ComponentPopUpNpwp from './ComponentPopUpNpwp'
import jquery from 'jquery'
import { Label } from 'reactstrap'
import { Divider } from 'primereact/divider'
let latitude
let longitude
function success(position) {
latitude = position.coords.latitude
longitude = position.coords.longitude
}
function error() {
console.log('Unable to retrieve your location')
}
function getLocation() {
navigator.geolocation.getCurrentPosition(success, error)
}
const onClickDirection = (koordinatAwal, KoordinatAkhir) => {
const lat1 = koordinatAwal.lat
const lng1 = koordinatAwal.lng
const lat2 = KoordinatAkhir.lat
const lng2 = KoordinatAkhir.lng
const targetLink = `https://www.google.com/maps/dir/${lat1 ? `${lat1},${lng1}` : ''}/'${lat2},${lng2}'/`
window.open(targetLink, '_blank')
}
L.TileLayer.MatoaNpwp = L.TileLayer.WMS.extend({
onAdd(map) {
// Triggered when the layer is added to a map.
// Register a click listener, then do all the upstream WMS things
L.TileLayer.WMS.prototype.onAdd.call(this, map)
map.on('click', this.getFeatureInfo, this)
getLocation()
// map.on('move', () => console.log(this))
// console.log(this)
},
onRemove(map) {
// Triggered when the layer is removed from a map.
// Unregister a click listener, then do all the upstream WMS things
L.TileLayer.WMS.prototype.onRemove.call(this, map)
map.off('click', this.getFeatureInfo, this)
},
async getFeatureInfo(evt) {
// Make an AJAX request to the server and hope for the best
const url = this.getFeatureInfoUrl(evt.latlng),
showResults = L.Util.bind(this.showGetFeatureInfo, this)
await fetch(url)
.then((response) => response.json())
.then((data) => {
// console.log(data)
const err = typeof data === 'object' ? null : data
const numberReturned = data?.numberReturned
if (numberReturned === 1) {
// showResults(err, evt.latlng, JSON.stringify(data))
showResults(err, evt.latlng, data.features[0].properties)
// const id_md = data.features[0].properties.i
}
if (numberReturned > 1) {
showList(err, evt.latlng, data)
}
})
.catch((err) => {
// showResults(JSON.stringify(err))
})
},
getFeatureInfoUrl(latlng) {
// return
// const map = useMap()
// Construct a GetFeatureInfo request URL given a point
const point = this._map.latLngToContainerPoint(latlng)
const size = this._map.getSize()
// https://docs.geoserver.org/latest/en/user/services/wms/reference.html#wms-getfeatureinfo
const params = {
request: 'GetFeatureInfo',
service: 'WMS',
crs: 'EPSG:4326',
styles: this.wmsParams.styles,
transparent: this.wmsParams.transparent,
version: this.wmsParams.version,
format: this.wmsParams.format,
bbox: this._map.getBounds().toBBoxString(),
height: size.y,
// height: this.wmsParams.height,
width: size.x,
// width: this.wmsParams.width,
layers: this.wmsParams.layers,
viewparams: this.wmsParams.viewparams,
cql_filter: this.wmsParams.cql_filter,
query_layers: this.wmsParams.layers,
info_format: 'application/json',
feature_count: 1
}
params[params.version === '1.3.0' ? 'i' : 'x'] = Math.round(point.x)
params[params.version === '1.3.0' ? 'j' : 'y'] = Math.round(point.y)
return this._url + L.Util.getParamString(params, this._url, true)
},
async showGetFeatureInfo(err, latlng, content) {
if (err) {
console.log(err)
}
let data = null
await jquery.ajax({
url: '/engineN/kewilayahan/peta/matoalokasi',
type: 'post',
dataType: 'json',
data: { uuid: content.UUID },
success: (response) => {
data = response
// console.log(response)
}
})
const popup = L.popup({ maxWidth: 800, minWidth: 200, namaLayer: this.wmsParams.layers })
.setLatLng(latlng)
.setContent(ComponentPopUpNpwp({ ...content, ...data }))
.openOn(this._map)
// popup.on('popupclose', (e) => {
// store.dispatch(setIsOpenPopUp(false))
// console.log(e)
// })
const popupTampil = popup._contentNode
const arah = popupTampil.querySelectorAll('.arah')
const poiName = popupTampil.querySelectorAll('.poi-name')
const tutupBox = popupTampil.querySelector('.tutup-box')
// const alamat = popupTampil.querySelector('#popup-alamat')
// const nm_kpp_zona = popupTampil.querySelector('#popup-nm_kpp_zona')
// const nama_ar_zona = popupTampil.querySelector('#popup-nama_ar_zona')
// const Alamat = () => {
// return (
// <>
// <Divider type="solid" />
// <Label>{data.alamat}</Label>
// <Label>{data.nm_kpp_zona}</Label>
// <Label>{data.nama_ar_zona}</Label>
// <Divider />
// </>
// )
// }
// alamat.innerHTML = renderToStaticMarkup(<Alamat />)
tutupBox.addEventListener('click', () => {
popup.close()
})
arah[0].addEventListener('click', () => {
onClickDirection({ lat: latitude ?? '', lng: longitude ?? '' }, { lat: content.GEO_LOK_LAT, lng: content.GEO_LOK_LING })
})
poiName[0].addEventListener('click', () => {
// onClickPoiName(id_md)
})
}
})
L.tileLayer.matoaNpwp = function (url, options) {
return new L.TileLayer.MatoaNpwp(url, options)
}