Skip to content

Commit

Permalink
use single websocket for client graphql subsciption
Browse files Browse the repository at this point in the history
  • Loading branch information
mxfactorial committed Sep 6, 2024
1 parent bf43b4a commit 5e3d2a8
Showing 1 changed file with 38 additions and 17 deletions.
55 changes: 38 additions & 17 deletions client/src/routes/measure/+page.svelte
Original file line number Diff line number Diff line change
Expand Up @@ -9,41 +9,48 @@
let priceTag: HTMLDivElement;
let map: google.maps.Map;
let markers = [] as any[]; // todo: google.maps.marker.AdvancedMarkerElement does not expect setMap method
let currentWsClient: { dispose: () => void } | null = null;
let messageCount = 0;
let wsClient: any = null; // todo: graphql-ws Client type
let stop = false;
let defaultCoordinates = { lat: 39.8283, lng: -98.5795 }; // usa
async function subscribeGdp(
date: string,
country: string,
region: string,
municipality: string | null
) {
// terminate previous websocket connection
if (currentWsClient) {
currentWsClient.dispose();
currentWsClient = null;
if (wsClient) {
stop = true;
} else {
wsClient = createWSClient({
url: b64.decode(process.env.GRAPHQL_SUBSCRIPTIONS_URI as string),
lazy: false
});
}
const wsClient = createWSClient({
url: b64.decode(process.env.GRAPHQL_SUBSCRIPTIONS_URI as string)
});
currentWsClient = wsClient;
const query = `subscription QueryGdp($date: String!, $country: String, $region: String, $municipality: String) {
queryGdp(date: $date, country: $country, region: $region, municipality: $municipality)
}`;
const variables: any = { date, country, region };
if (municipality) {
variables.municipality = municipality;
}
const subscription: any = wsClient.iterate({
query,
let subscription = wsClient.iterate({
query: `subscription QueryGdp($date: String!, $country: String, $region: String, $municipality: String) {
queryGdp(date: $date, country: $country, region: $region, municipality: $municipality)
}`,
variables
});
messageCount = 0;
for await (const { data } of subscription) {
if (stop) {
// console.log('stopping subscription');
stop = false;
break;
}
if (messageCount == 0) {
// console.log('starting subscription');
}
messageCount++;
price = data.queryGdp.toFixed(3);
}
Expand All @@ -58,6 +65,11 @@
async function handleSearch(event: Event) {
event.preventDefault();
if (searchQuery.trim() === '') {
resetMap();
return;
}
// parse location from search query
let location;
if (searchQuery.includes('gdp')) {
Expand All @@ -72,8 +84,8 @@
location = 'sacramento california';
}
const queryVars = parseQuery(location);
changeMapCenter(location);
const queryVars = parseQuery(location);
await subscribeGdp(queryVars.time, queryVars.country, queryVars.region, queryVars.municipality);
}
Expand Down Expand Up @@ -108,7 +120,7 @@
loader.load().then((google) => {
const { Map } = google.maps;
map = new Map(document.getElementById('map') as HTMLElement, {
center: { lat: 39.8283, lng: -98.5795 }, // usa coordinates
center: defaultCoordinates, // usa coordinates
zoom: 4,
mapId: '4504f8b37365c3d0'
});
Expand All @@ -126,6 +138,15 @@
}, 100); // check every 100 milliseconds
}
function resetMap() {
if (map) {
markers.forEach((marker) => marker.setMap(null));
markers = [];
map.setCenter(defaultCoordinates);
map.setZoom(4);
}
}
function changeMapCenter(location: string) {
if (map) {
// clear existing markers
Expand Down

0 comments on commit 5e3d2a8

Please sign in to comment.