diff --git a/js/src/forum/components/MapModal.tsx b/js/src/forum/components/MapModal.tsx index 44a9632..e8908b0 100644 --- a/js/src/forum/components/MapModal.tsx +++ b/js/src/forum/components/MapModal.tsx @@ -6,6 +6,7 @@ import { handleCopyIP } from '../helpers/ClipboardHelper'; import LabelValue from 'flarum/common/components/LabelValue'; import type Mithril from 'mithril'; import LoadingIndicator from 'flarum/common/components/LoadingIndicator'; +import ItemList from 'flarum/common/utils/ItemList'; interface MapModalAttrs extends IInternalModalAttrs { ipInfo?: IPInfo; @@ -14,10 +15,12 @@ interface MapModalAttrs extends IInternalModalAttrs { export default class MapModal extends Modal { ipInfo: IPInfo | undefined; + ipAddr!: string; oninit(vnode: Mithril.Vnode) { super.oninit(vnode); this.ipInfo = this.attrs.ipInfo; + this.ipAddr = this.attrs.ipAddr; } className() { @@ -42,22 +45,8 @@ export default class MapModal extends Modal { return (
- - {this.attrs.ipAddr} - - } - /> - {ipInfo.countryCode() && } - {ipInfo.zipCode() && } - {ipInfo.isp() && } - {ipInfo.organization() && ( - - )} - {ipInfo.as() && } - {} + {this.dataItems().toArray()} + {ipInfo.threatLevel() && } {ipInfo.threatTypes().length > 0 && ( @@ -65,10 +54,65 @@ export default class MapModal extends Modal { {ipInfo.error() && }

-
- -
+
{this.mapItems().toArray()}
); } + + dataItems(): ItemList { + const items = new ItemList(); + + items.add( + 'ipAddress', + + {this.ipAddr} + + } + />, + 100 + ); + + if (this.ipInfo) { + this.ipInfo.countryCode?.() && + items.add( + 'countryCode', + , + 90 + ); + + this.ipInfo.zipCode?.() && + items.add('zipCode', , 80); + + this.ipInfo.isp?.() && + items.add('isp', , 70); + + this.ipInfo.organization?.() && + items.add( + 'organization', + , + 60 + ); + + this.ipInfo.as?.() && items.add('as', , 50); + + items.add( + 'mobileNetwork', + , + 40 + ); + } + + return items; + } + + mapItems(): ItemList { + const items = new ItemList(); + + items.add('mapContainer', , 100); + + return items; + } } diff --git a/js/src/forum/components/ZipCodeMap.js b/js/src/forum/components/ZipCodeMap.tsx similarity index 56% rename from js/src/forum/components/ZipCodeMap.js rename to js/src/forum/components/ZipCodeMap.tsx index 43a6402..fb7c93e 100644 --- a/js/src/forum/components/ZipCodeMap.js +++ b/js/src/forum/components/ZipCodeMap.tsx @@ -1,24 +1,31 @@ import app from 'flarum/forum/app'; -import Component from 'flarum/common/Component'; +import Component, { ComponentAttrs } from 'flarum/common/Component'; import LoadingIndicator from 'flarum/common/components/LoadingIndicator'; +// @ts-expect-error import load from 'external-load'; +import type Mithril from 'mithril'; +import IPInfo from '../models/IPInfo'; -let addedResources = false; -const addResources = async () => { - if (addedResources) return; +const leafletCDN = 'https://unpkg.com/leaflet@1.9.4/dist/'; - await load.css('https://unpkg.com/leaflet@1.9.4/dist/leaflet.css'); - await load.js('https://unpkg.com/leaflet@1.9.4/dist/leaflet.js'); +export interface ZipCodeMapAttrs extends ComponentAttrs { + ipInfo: IPInfo; +} - addedResources = true; -}; +export default class ZipCodeMap extends Component { + ipInfo!: IPInfo; + loading = false; + map: any; + data: any; + addedResources = false; -export default class ZipCodeMap extends Component { - oninit(vnode) { + oninit(vnode: Mithril.Vnode) { super.oninit(vnode); this.ipInfo = this.attrs.ipInfo; + this.addResources(); + this.data = null; if (this.ipInfo.latitude() && this.ipInfo.longitude()) { @@ -30,6 +37,15 @@ export default class ZipCodeMap extends Component { } } + async addResources() { + if (this.addedResources) return; + + await load.css(leafletCDN + 'leaflet.css'); + await load.js(leafletCDN + 'leaflet.js'); + + this.addedResources = true; + } + view() { if (this.loading) { return ; @@ -42,58 +58,50 @@ export default class ZipCodeMap extends Component { return
; } - searchLatLon() { + async searchLatLon() { if (this.loading) return; this.loading = true; - return addResources().then( - app - .request({ - url: `https://nominatim.openstreetmap.org/reverse`, - method: 'GET', - params: { - lat: this.ipInfo.latitude(), - lon: this.ipInfo.longitude(), - format: 'json', - }, - }) - .then((data) => { - this.data = data; - this.loading = false; - - m.redraw(); - }) - ); + const data = await app.request({ + url: `https://nominatim.openstreetmap.org/reverse`, + method: 'GET', + params: { + lat: this.ipInfo.latitude(), + lon: this.ipInfo.longitude(), + format: 'json', + }, + }); + + this.data = data; + this.loading = false; + + m.redraw(); } - searchZip() { + async searchZip() { if (this.loading) return; this.loading = true; - return addResources().then( - app - .request({ - url: `https://nominatim.openstreetmap.org/search`, - method: 'GET', - params: { - q: this.ipInfo.zipCode(), - countrycodes: this.ipInfo.countryCode(), - limit: 1, - format: 'json', - }, - }) - .then((data) => { - this.data = data[0]; - this.loading = false; - - m.redraw(); - }) - ); + const data = await app.request({ + url: `https://nominatim.openstreetmap.org/search`, + method: 'GET', + params: { + q: this.ipInfo.zipCode(), + countrycodes: this.ipInfo.countryCode(), + limit: 1, + format: 'json', + }, + }); + + this.data = data[0]; + this.loading = false; + + m.redraw(); } - configMap(vnode) { + configMap(vnode: Mithril.VnodeDOM) { if (!this.data) return; const { boundingbox: bounding, display_name: displayName } = this.data; @@ -110,13 +118,16 @@ export default class ZipCodeMap extends Component { const zoomLevel = 5; // Set your preferred zoom level here + // @ts-expect-error this.map = L.map(vnode.dom).setView([centerLat, centerLon], zoomLevel); + // @ts-expect-error L.tileLayer('https://tile.openstreetmap.org/{z}/{x}/{y}.png', { attribution: '© OpenStreetMap contributors', }).addTo(this.map); // Set a marker at the center of the bounding box + // @ts-expect-error L.marker([centerLat, centerLon]).addTo(this.map).bindPopup(displayName).openPopup(); } }