From 717e424697974c0673f55e95309c9f15c3571f07 Mon Sep 17 00:00:00 2001 From: SamuelLouf <104774504+samuellouf@users.noreply.github.com> Date: Fri, 4 Aug 2023 17:11:51 +0200 Subject: [PATCH 1/9] Add files via upload --- extensions/SamuelLouf/weather.js | 467 +++++++++++++++++++++++++++++++ 1 file changed, 467 insertions(+) create mode 100644 extensions/SamuelLouf/weather.js diff --git a/extensions/SamuelLouf/weather.js b/extensions/SamuelLouf/weather.js new file mode 100644 index 0000000000..ae9a0bf71c --- /dev/null +++ b/extensions/SamuelLouf/weather.js @@ -0,0 +1,467 @@ +/*! + * Copyright 2023 SamuelLouf + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/*! + * Inspired from the ScratchX "Weather" extension + * https://khanning.github.io/scratch-weather-extension/ + */ + +(function (Scratch) { + "use strict"; + + localStorage.TurboWarpGeolocationExtension_coordinates = '{}'; + + const icon = ''; + + const getGeolocation_bg_func_delay = ms => new Promise(res => setTimeout(res, ms)); + + function getGeolocation_bg_func_success(pos) { + const crd = pos.coords; + TurboWarpGeolocationExtension_coordinates = { + success: true, + latitude: crd.latitude, + longitude: crd.longitude, + accuracy: crd.accuracy + }; + localStorage.TurboWarpGeolocationExtension_coordinates = JSON.stringify(TurboWarpGeolocationExtension_coordinates); + } + + function getGeolocation_bg_func_error(err) { + TurboWarpGeolocationExtension_coordinates = { + success: false, + error: { + code: err.code, + message: err.message + } + }; + localStorage.TurboWarpGeolocationExtension_coordinates = JSON.stringify(TurboWarpGeolocationExtension_coordinates); + } + + async function getGeolocation() { + localStorage.TurboWarpGeolocationExtension_coordinates = '{}'; + navigator.geolocation.getCurrentPosition(getGeolocation_bg_func_success, getGeolocation_bg_func_error, {enableHighAccuracy: true,timeout: 5000,maximumAge: 0}); + while (localStorage.TurboWarpGeolocationExtension_coordinates == '{}'){ + await getGeolocation_bg_func_delay(100); + } + return JSON.parse(localStorage.TurboWarpGeolocationExtension_coordinates); + } + + async function getCurrentWeather(coordinates='here') { + if (coordinates == 'here'){ + var coordinates = await getGeolocation(); + } + var fetched_json = await Scratch.fetch('https://api.open-meteo.com/v1/forecast?latitude=' + coordinates.latitude + '&longitude=' + coordinates.longitude + '¤t_weather=true&hourly=temperature_2m,relativehumidity_2m,windspeed_10m').then(r => r.text()).catch(() => ''); + fetched_json = JSON.parse(fetched_json); + return fetched_json.current_weather; + } + + class Weather { + getInfo() { + return { + id: 'samuelloufweather', + name: 'Weather', + color1: '#ff8800', + menuIconURI: icon, + blocks: [ + { + opcode: 'when_is_current_weather_at', + blockType: Scratch.BlockType.HAT, + text: 'when current [METEO] at latitude [latitude] longitude [longitude] [OPERATORS] [value] degrees', + isEdgeActivated: true, + arguments: { + METEO: { + type: Scratch.ArgumentType.REPORTER, + menu: 'meteo_now_no_json_menu' + }, + latitude: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 49.0770938 + }, + longitude: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 2.0296714 + }, + OPERATORS: { + type: Scratch.ArgumentType.REPORTER, + menu: 'operators_menu', + defaultValue: '>' + }, + value: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 20 + } + } + }, + { + opcode: 'is_current_weather_at', + blockType: Scratch.BlockType.BOOLEAN, + text: 'is current [METEO] at latitude [latitude] longitude [longitude] [OPERATORS] [value] degrees', + arguments: { + METEO: { + type: Scratch.ArgumentType.REPORTER, + menu: 'meteo_now_no_json_menu' + }, + latitude: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 49.0770938 + }, + longitude: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 2.0296714 + }, + OPERATORS: { + type: Scratch.ArgumentType.REPORTER, + menu: 'operators_menu', + defaultValue: '>' + }, + value: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 20 + } + } + }, + { + opcode: 'get_current_weather_at', + blockType: Scratch.BlockType.REPORTER, + text: 'get current [METEO] at latitude [latitude] longitude [longitude]', + arguments: { + METEO: { + type: Scratch.ArgumentType.REPORTER, + menu: 'meteo_now_menu' + }, + latitude: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 49.0770938 + }, + longitude: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 2.0296714 + } + } + }, + "---", + "---", + { + opcode: 'when_is_current_weather_in', + blockType: Scratch.BlockType.HAT, + text: 'when current [METEO] in [place] [OPERATORS] [value] degrees', + isEdgeActivated: true, + arguments: { + METEO: { + type: Scratch.ArgumentType.REPORTER, + menu: 'meteo_now_no_json_menu' + }, + place: { + type: Scratch.ArgumentType.STRING, + defaultValue: 'Paris, France' + }, + OPERATORS: { + type: Scratch.ArgumentType.REPORTER, + menu: 'operators_menu', + defaultValue: '>' + }, + value: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 20 + } + } + }, + { + opcode: 'is_current_weather_in', + blockType: Scratch.BlockType.BOOLEAN, + text: 'is current [METEO] in [place] [OPERATORS] [value] degrees', + arguments: { + METEO: { + type: Scratch.ArgumentType.REPORTER, + menu: 'meteo_now_no_json_menu' + }, + place: { + type: Scratch.ArgumentType.STRING, + defaultValue: 'Paris, France' + }, + OPERATORS: { + type: Scratch.ArgumentType.REPORTER, + menu: 'operators_menu', + defaultValue: '>' + }, + value: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 20 + } + } + }, + { + opcode: 'get_current_weather_in', + blockType: Scratch.BlockType.REPORTER, + text: 'get current [METEO] in [place]', + arguments: { + METEO: { + type: Scratch.ArgumentType.REPORTER, + menu: 'meteo_now_menu' + }, + place: { + type: Scratch.ArgumentType.STRING, + defaultValue: 'Paris, France' + } + } + }, + "---", + "---", + { + opcode: 'when_is_current_weather_here', + blockType: Scratch.BlockType.HAT, + text: 'when current [METEO] in here [OPERATORS] [value] degrees', + isEdgeActivated: true, + arguments: { + METEO: { + type: Scratch.ArgumentType.REPORTER, + menu: 'meteo_now_no_json_menu' + }, + OPERATORS: { + type: Scratch.ArgumentType.REPORTER, + menu: 'operators_menu', + defaultValue: '>' + }, + value: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 20 + } + } + }, + { + opcode: 'is_current_weather_here', + blockType: Scratch.BlockType.BOOLEAN, + text: 'is current [METEO] in here [OPERATORS] [value] degrees', + arguments: { + METEO: { + type: Scratch.ArgumentType.REPORTER, + menu: 'meteo_now_no_json_menu' + }, + OPERATORS: { + type: Scratch.ArgumentType.REPORTER, + menu: 'operators_menu', + defaultValue: '>' + }, + value: { + type: Scratch.ArgumentType.NUMBER, + defaultValue: 20 + } + } + }, + { + opcode: 'get_current_weather_here', + blockType: Scratch.BlockType.REPORTER, + text: 'get current [METEO] in here', + arguments: { + METEO: { + type: Scratch.ArgumentType.REPORTER, + menu: 'meteo_now_menu' + } + } + }, + ], + menus: { + meteo_now_menu: { + acceptReporters: true, + items: ['temperature (C)', 'temperature (F)', 'weather code', 'wind direction', 'wind speed (km/h)', 'wind speed (mph)' ,'all (JSON)'] + }, + meteo_now_no_json_menu: { + acceptReporters: true, + items: ['temperature (C)', 'temperature (F)', 'weather code', 'wind direction', 'wind speed (km/h)', 'wind speed (mph)'] + }, + operators_menu: { + acceptReporters: true, + items: ['<', '>', '=', '≈'] + } + } + }; + } + + when_is_current_weather_at(args){ + return this.is_current_weather_at(args); + } + + async is_current_weather_at (args){ + var response = await this.get_current_weather_at(args); + if (args.OPERATORS == '<'){ + return Number(response) < Number(args.value); + } else if (args.OPERATORS == '>'){ + return Number(response) > Number(args.value); + } else if (args.OPERATORS == '='){ + return Number(response) == Number(args.value); + } else if (args.OPERATORS == '≈'){ + if (args.METEO.includes('temperature')){ + if (args.METEO.includes('(C)')){ + return Number(args.value)-2.5 < Number(response) && Number(response) < Number(args.value)+2.5; + } else { + return Number(args.value)-3.6 < Number(response) && Number(response) < Number(args.value)+3.6; + } + } else if (args.METEO.includes('wind speed')){ + if (args.METEO.includes('(km/h)')){ + return Number(args.value)-10 < Number(response) && Number(response) < Number(args.value)+10; + } else { + return Number(args.value)-6.2 < Number(response) && Number(response) < Number(args.value)+6.2; + } + } + } + } + + async get_current_weather_at(args) { + var current_weather = await getCurrentWeather(args); + + if (args.METEO.includes('temperature')){ + if (args.METEO.includes('(C)')){ + return current_weather.temperature; + } else { + var temperature = (current_weather.temperature*9/5)+32; + const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} + const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} + return Number(String(itemOfFromString(1, temperature, '.')) + '.' + letters_of(itemOfFromString(2, temperature, '.'), 1, 2)); + } + } else if (args.METEO == 'all (JSON)'){ + return JSON.stringify(current_weather); + } else if (args.METEO.includes('wind speed')){ + if (args.METEO.includes('(km/h)')){ + return current_weather.windspeed; + } else { + var wind_speed = current_weather.windspeed/1.609; + const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} + const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} + return Number(String(itemOfFromString(1, wind_speed, '.')) + '.' + letters_of(itemOfFromString(2, wind_speed, '.'), 1, 2)); + } + } else { + return current_weather[args.METEO.replace(' ', '')]; + } + } + + when_is_current_weather_in(args){ + return this.is_current_weather_in(args); + } + + async is_current_weather_in (args){ + var response = await this.get_current_weather_in(args); + if (args.OPERATORS == '<'){ + return Number(response) < Number(args.value); + } else if (args.OPERATORS == '>'){ + return Number(response) > Number(args.value); + } else if (args.OPERATORS == '='){ + return Number(response) == Number(args.value); + } else if (args.OPERATORS == '≈'){ + if (args.METEO.includes('temperature')){ + if (args.METEO.includes('(C)')){ + return Number(args.value)-2.5 < Number(response) && Number(response) < Number(args.value)+2.5; + } else { + return Number(args.value)-3.6 < Number(response) && Number(response) < Number(args.value)+3.6; + } + } else if (args.METEO.includes('wind speed')){ + if (args.METEO.includes('(km/h)')){ + return Number(args.value)-10 < Number(response) && Number(response) < Number(args.value)+10; + } else { + return Number(args.value)-6.2 < Number(response) && Number(response) < Number(args.value)+6.2; + } + } + } + } + + async get_current_weather_in (args){ + var geolocation_of_place = await Scratch.fetch('https://geocode.maps.co/search?q='+escape(args.place)).then(r => r.text()).catch(() => ''); + geolocation_of_place = JSON.parse(geolocation_of_place); + var current_weather = await getCurrentWeather({latitude: Number(geolocation_of_place[0].lat), longitude: Number(geolocation_of_place[0].lon)}); + + if (args.METEO.includes('temperature')){ + if (args.METEO.includes('(C)')){ + return current_weather.temperature; + } else { + var temperature = (current_weather.temperature*9/5)+32; + const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} + const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} + return Number(String(itemOfFromString(1, temperature, '.')) + '.' + letters_of(itemOfFromString(2, temperature, '.'), 1, 2)); + } + } else if (args.METEO == 'all (JSON)'){ + return JSON.stringify(current_weather); + } else if (args.METEO.includes('wind speed')){ + if (args.METEO.includes('(km/h)')){ + return current_weather.windspeed; + } else { + var wind_speed = current_weather.windspeed/1.609; + const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} + const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} + return Number(String(itemOfFromString(1, wind_speed, '.')) + '.' + letters_of(itemOfFromString(2, wind_speed, '.'), 1, 2)); + } + } else { + return current_weather[args.METEO.replace(' ', '')]; + } + } + + when_is_current_weather_here(args){ + return this.is_current_weather_here(args); + } + + async get_current_weather_here(args) { + var current_weather = await getCurrentWeather(); + + if (args.METEO.includes('temperature')){ + if (args.METEO.includes('(C)')){ + return current_weather.temperature; + } else { + var temperature = (current_weather.temperature*9/5)+32; + const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} + const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} + return Number(String(itemOfFromString(1, temperature, '.')) + '.' + letters_of(itemOfFromString(2, temperature, '.'), 1, 2)); + } + } else if (args.METEO == 'all (JSON)'){ + return JSON.stringify(current_weather); + } else if (args.METEO.includes('wind speed')){ + if (args.METEO.includes('(km/h)')){ + return current_weather.windspeed; + } else { + var wind_speed = current_weather.windspeed/1.609; + const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} + const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} + return Number(String(itemOfFromString(1, wind_speed, '.')) + '.' + letters_of(itemOfFromString(2, wind_speed, '.'), 1, 2)); + } + } else { + return current_weather[args.METEO.replace(' ', '')]; + } + } + + async is_current_weather_here (args){ + var response = await this.get_current_weather_here(args); + if (args.OPERATORS == '<'){ + return Number(response) < Number(args.value); + } else if (args.OPERATORS == '>'){ + return Number(response) > Number(args.value); + } else if (args.OPERATORS == '='){ + return Number(response) == Number(args.value); + } else if (args.OPERATORS == '≈'){ + if (args.METEO.includes('temperature')){ + if (args.METEO.includes('(C)')){ + return Number(args.value)-2.5 < Number(response) && Number(response) < Number(args.value)+2.5; + } else { + return Number(args.value)-3.6 < Number(response) && Number(response) < Number(args.value)+3.6; + } + } else if (args.METEO.includes('wind speed')){ + if (args.METEO.includes('(km/h)')){ + return Number(args.value)-10 < Number(response) && Number(response) < Number(args.value)+10; + } else { + return Number(args.value)-6.2 < Number(response) && Number(response) < Number(args.value)+6.2; + } + } + } + } + } + Scratch.extensions.register(new Weather()); +})(Scratch); \ No newline at end of file From 363620d994aceeb50cda464df6ff842bc0dc37c0 Mon Sep 17 00:00:00 2001 From: SamuelLouf <104774504+samuellouf@users.noreply.github.com> Date: Fri, 4 Aug 2023 17:15:19 +0200 Subject: [PATCH 2/9] Update index.ejs Added my extension --- website/index.ejs | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/website/index.ejs b/website/index.ejs index da2953cdf6..3b060d3318 100644 --- a/website/index.ejs +++ b/website/index.ejs @@ -769,6 +769,12 @@

McUtils

Helpful utilities for any fast food employee. Created by LilyMakesThings.

+ +
+ <%- banner('SamuelLouf/weather') %> +

Weather

+

Tools to get the current temperature, wind speed, wind direction... all over the world. Created by SamuelLouf.

+
From 0e5b43672167a1c6289faff51d6d2e882b58c00d Mon Sep 17 00:00:00 2001 From: SamuelLouf <104774504+samuellouf@users.noreply.github.com> Date: Sat, 5 Aug 2023 17:29:48 +0200 Subject: [PATCH 3/9] Update weather.js Removed most/all of the trailing spaces, defined the "TurboWarpGeolocationExtension_coordinates" variable, spaced "=" at line 62, remove "var" at line 64. --- extensions/SamuelLouf/weather.js | 42 ++++++++++++++++---------------- 1 file changed, 21 insertions(+), 21 deletions(-) diff --git a/extensions/SamuelLouf/weather.js b/extensions/SamuelLouf/weather.js index ae9a0bf71c..8803c55d80 100644 --- a/extensions/SamuelLouf/weather.js +++ b/extensions/SamuelLouf/weather.js @@ -1,12 +1,12 @@ /*! * Copyright 2023 SamuelLouf - * + * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 - * + * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. @@ -23,14 +23,14 @@ "use strict"; localStorage.TurboWarpGeolocationExtension_coordinates = '{}'; - + const icon = ''; - + const getGeolocation_bg_func_delay = ms => new Promise(res => setTimeout(res, ms)); function getGeolocation_bg_func_success(pos) { const crd = pos.coords; - TurboWarpGeolocationExtension_coordinates = { + var TurboWarpGeolocationExtension_coordinates = { success: true, latitude: crd.latitude, longitude: crd.longitude, @@ -38,9 +38,9 @@ }; localStorage.TurboWarpGeolocationExtension_coordinates = JSON.stringify(TurboWarpGeolocationExtension_coordinates); } - + function getGeolocation_bg_func_error(err) { - TurboWarpGeolocationExtension_coordinates = { + var TurboWarpGeolocationExtension_coordinates = { success: false, error: { code: err.code, @@ -59,15 +59,15 @@ return JSON.parse(localStorage.TurboWarpGeolocationExtension_coordinates); } - async function getCurrentWeather(coordinates='here') { + async function getCurrentWeather(coordinates = 'here') { if (coordinates == 'here'){ - var coordinates = await getGeolocation(); + coordinates = await getGeolocation(); } var fetched_json = await Scratch.fetch('https://api.open-meteo.com/v1/forecast?latitude=' + coordinates.latitude + '&longitude=' + coordinates.longitude + '¤t_weather=true&hourly=temperature_2m,relativehumidity_2m,windspeed_10m').then(r => r.text()).catch(() => ''); fetched_json = JSON.parse(fetched_json); return fetched_json.current_weather; } - + class Weather { getInfo() { return { @@ -109,7 +109,7 @@ opcode: 'is_current_weather_at', blockType: Scratch.BlockType.BOOLEAN, text: 'is current [METEO] at latitude [latitude] longitude [longitude] [OPERATORS] [value] degrees', - arguments: { + arguments: { METEO: { type: Scratch.ArgumentType.REPORTER, menu: 'meteo_now_no_json_menu' @@ -136,8 +136,8 @@ { opcode: 'get_current_weather_at', blockType: Scratch.BlockType.REPORTER, - text: 'get current [METEO] at latitude [latitude] longitude [longitude]', - arguments: { + text: 'current [METEO] at latitude [latitude] longitude [longitude]', + arguments: { METEO: { type: Scratch.ArgumentType.REPORTER, menu: 'meteo_now_menu' @@ -183,7 +183,7 @@ opcode: 'is_current_weather_in', blockType: Scratch.BlockType.BOOLEAN, text: 'is current [METEO] in [place] [OPERATORS] [value] degrees', - arguments: { + arguments: { METEO: { type: Scratch.ArgumentType.REPORTER, menu: 'meteo_now_no_json_menu' @@ -206,8 +206,8 @@ { opcode: 'get_current_weather_in', blockType: Scratch.BlockType.REPORTER, - text: 'get current [METEO] in [place]', - arguments: { + text: 'current [METEO] in [place]', + arguments: { METEO: { type: Scratch.ArgumentType.REPORTER, menu: 'meteo_now_menu' @@ -245,7 +245,7 @@ opcode: 'is_current_weather_here', blockType: Scratch.BlockType.BOOLEAN, text: 'is current [METEO] in here [OPERATORS] [value] degrees', - arguments: { + arguments: { METEO: { type: Scratch.ArgumentType.REPORTER, menu: 'meteo_now_no_json_menu' @@ -264,8 +264,8 @@ { opcode: 'get_current_weather_here', blockType: Scratch.BlockType.REPORTER, - text: 'get current [METEO] in here', - arguments: { + text: 'current [METEO] in here', + arguments: { METEO: { type: Scratch.ArgumentType.REPORTER, menu: 'meteo_now_menu' @@ -321,7 +321,7 @@ async get_current_weather_at(args) { var current_weather = await getCurrentWeather(args); - + if (args.METEO.includes('temperature')){ if (args.METEO.includes('(C)')){ return current_weather.temperature; @@ -464,4 +464,4 @@ } } Scratch.extensions.register(new Weather()); -})(Scratch); \ No newline at end of file +})(Scratch); From 1cbad11277c1e346a596b4bab05b2f66854c0e84 Mon Sep 17 00:00:00 2001 From: SamuelLouf <104774504+samuellouf@users.noreply.github.com> Date: Sat, 5 Aug 2023 17:54:54 +0200 Subject: [PATCH 4/9] Update weather.js Added spaces to the operators. --- extensions/SamuelLouf/weather.js | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/extensions/SamuelLouf/weather.js b/extensions/SamuelLouf/weather.js index 8803c55d80..28b2c53584 100644 --- a/extensions/SamuelLouf/weather.js +++ b/extensions/SamuelLouf/weather.js @@ -305,15 +305,15 @@ } else if (args.OPERATORS == '≈'){ if (args.METEO.includes('temperature')){ if (args.METEO.includes('(C)')){ - return Number(args.value)-2.5 < Number(response) && Number(response) < Number(args.value)+2.5; + return Number(args.value) - 2.5 < Number(response) && Number(response) < Number(args.value) + 2.5; } else { - return Number(args.value)-3.6 < Number(response) && Number(response) < Number(args.value)+3.6; + return Number(args.value) - 3.6 < Number(response) && Number(response) < Number(args.value) + 3.6; } } else if (args.METEO.includes('wind speed')){ if (args.METEO.includes('(km/h)')){ - return Number(args.value)-10 < Number(response) && Number(response) < Number(args.value)+10; + return Number(args.value) - 10 < Number(response) && Number(response) < Number(args.value) + 10; } else { - return Number(args.value)-6.2 < Number(response) && Number(response) < Number(args.value)+6.2; + return Number(args.value) - 6.2 < Number(response) && Number(response) < Number(args.value) + 6.2; } } } @@ -326,7 +326,7 @@ if (args.METEO.includes('(C)')){ return current_weather.temperature; } else { - var temperature = (current_weather.temperature*9/5)+32; + var temperature = (current_weather.temperature * 9 / 5) + 32; const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, temperature, '.')) + '.' + letters_of(itemOfFromString(2, temperature, '.'), 1, 2)); From 96b4c2083b65de5bc7b5ca5f68e0310c45ba19a1 Mon Sep 17 00:00:00 2001 From: SamuelLouf <104774504+samuellouf@users.noreply.github.com> Date: Sat, 5 Aug 2023 18:02:30 +0200 Subject: [PATCH 5/9] Update weather.js Added even more spaces. --- extensions/SamuelLouf/weather.js | 26 +++++++++++++------------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/extensions/SamuelLouf/weather.js b/extensions/SamuelLouf/weather.js index 28b2c53584..90c1ae4354 100644 --- a/extensions/SamuelLouf/weather.js +++ b/extensions/SamuelLouf/weather.js @@ -337,7 +337,7 @@ if (args.METEO.includes('(km/h)')){ return current_weather.windspeed; } else { - var wind_speed = current_weather.windspeed/1.609; + var wind_speed = current_weather.windspeed / 1.609; const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, wind_speed, '.')) + '.' + letters_of(itemOfFromString(2, wind_speed, '.'), 1, 2)); @@ -362,15 +362,15 @@ } else if (args.OPERATORS == '≈'){ if (args.METEO.includes('temperature')){ if (args.METEO.includes('(C)')){ - return Number(args.value)-2.5 < Number(response) && Number(response) < Number(args.value)+2.5; + return Number(args.value) - 2.5 < Number(response) && Number(response) < Number(args.value) + 2.5; } else { - return Number(args.value)-3.6 < Number(response) && Number(response) < Number(args.value)+3.6; + return Number(args.value) - 3.6 < Number(response) && Number(response) < Number(args.value) + 3.6; } } else if (args.METEO.includes('wind speed')){ if (args.METEO.includes('(km/h)')){ - return Number(args.value)-10 < Number(response) && Number(response) < Number(args.value)+10; + return Number(args.value) - 10 < Number(response) && Number(response) < Number(args.value) + 10; } else { - return Number(args.value)-6.2 < Number(response) && Number(response) < Number(args.value)+6.2; + return Number(args.value) - 6.2 < Number(response) && Number(response) < Number(args.value) + 6.2; } } } @@ -385,7 +385,7 @@ if (args.METEO.includes('(C)')){ return current_weather.temperature; } else { - var temperature = (current_weather.temperature*9/5)+32; + var temperature = (current_weather.temperature * 9 / 5 ) + 32; const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, temperature, '.')) + '.' + letters_of(itemOfFromString(2, temperature, '.'), 1, 2)); @@ -396,7 +396,7 @@ if (args.METEO.includes('(km/h)')){ return current_weather.windspeed; } else { - var wind_speed = current_weather.windspeed/1.609; + var wind_speed = current_weather.windspeed / 1.609; const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, wind_speed, '.')) + '.' + letters_of(itemOfFromString(2, wind_speed, '.'), 1, 2)); @@ -417,7 +417,7 @@ if (args.METEO.includes('(C)')){ return current_weather.temperature; } else { - var temperature = (current_weather.temperature*9/5)+32; + var temperature = (current_weather.temperature * 9 / 5) + 32; const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, temperature, '.')) + '.' + letters_of(itemOfFromString(2, temperature, '.'), 1, 2)); @@ -428,7 +428,7 @@ if (args.METEO.includes('(km/h)')){ return current_weather.windspeed; } else { - var wind_speed = current_weather.windspeed/1.609; + var wind_speed = current_weather.windspeed / 1.609; const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, wind_speed, '.')) + '.' + letters_of(itemOfFromString(2, wind_speed, '.'), 1, 2)); @@ -449,15 +449,15 @@ } else if (args.OPERATORS == '≈'){ if (args.METEO.includes('temperature')){ if (args.METEO.includes('(C)')){ - return Number(args.value)-2.5 < Number(response) && Number(response) < Number(args.value)+2.5; + return Number(args.value) - 2.5 < Number(response) && Number(response) < Number(args.value) + 2.5; } else { - return Number(args.value)-3.6 < Number(response) && Number(response) < Number(args.value)+3.6; + return Number(args.value) - 3.6 < Number(response) && Number(response) < Number(args.value)+3.6; } } else if (args.METEO.includes('wind speed')){ if (args.METEO.includes('(km/h)')){ - return Number(args.value)-10 < Number(response) && Number(response) < Number(args.value)+10; + return Number(args.value) - 10 < Number(response) && Number(response) < Number(args.value) + 10; } else { - return Number(args.value)-6.2 < Number(response) && Number(response) < Number(args.value)+6.2; + return Number(args.value) - 6.2 < Number(response) && Number(response) < Number(args.value) + 6.2; } } } From 1108a08aa51b609314e412d81d57e0f36a1e964a Mon Sep 17 00:00:00 2001 From: SamuelLouf <104774504+samuellouf@users.noreply.github.com> Date: Sat, 5 Aug 2023 18:13:41 +0200 Subject: [PATCH 6/9] Update weather.js I added semicolons and even more spaces. --- extensions/SamuelLouf/weather.js | 30 ++++++++++++++++-------------- 1 file changed, 16 insertions(+), 14 deletions(-) diff --git a/extensions/SamuelLouf/weather.js b/extensions/SamuelLouf/weather.js index 90c1ae4354..cac070b668 100644 --- a/extensions/SamuelLouf/weather.js +++ b/extensions/SamuelLouf/weather.js @@ -68,6 +68,20 @@ return fetched_json.current_weather; } + + const letters_of = (text, from, to) => { + args.STRING = text.toString(); + args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0; + return args.STRING.substring(args.LETTER1 - 1, args.LETTER2); + } + + const itemOfFromString = (no, from, splitby) => { + var input1 = (Number(no) - 1); + var input2 = String(from); + var input3 = splitby; + return input2.split(input3)[input1] || ''; + } + class Weather { getInfo() { return { @@ -327,8 +341,6 @@ return current_weather.temperature; } else { var temperature = (current_weather.temperature * 9 / 5) + 32; - const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} - const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, temperature, '.')) + '.' + letters_of(itemOfFromString(2, temperature, '.'), 1, 2)); } } else if (args.METEO == 'all (JSON)'){ @@ -338,8 +350,6 @@ return current_weather.windspeed; } else { var wind_speed = current_weather.windspeed / 1.609; - const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} - const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, wind_speed, '.')) + '.' + letters_of(itemOfFromString(2, wind_speed, '.'), 1, 2)); } } else { @@ -377,7 +387,7 @@ } async get_current_weather_in (args){ - var geolocation_of_place = await Scratch.fetch('https://geocode.maps.co/search?q='+escape(args.place)).then(r => r.text()).catch(() => ''); + var geolocation_of_place = await Scratch.fetch('https://geocode.maps.co/search?q=' + encodeURIComponent(args.place)).then(r => r.text()).catch(() => ''); geolocation_of_place = JSON.parse(geolocation_of_place); var current_weather = await getCurrentWeather({latitude: Number(geolocation_of_place[0].lat), longitude: Number(geolocation_of_place[0].lon)}); @@ -386,8 +396,6 @@ return current_weather.temperature; } else { var temperature = (current_weather.temperature * 9 / 5 ) + 32; - const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} - const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, temperature, '.')) + '.' + letters_of(itemOfFromString(2, temperature, '.'), 1, 2)); } } else if (args.METEO == 'all (JSON)'){ @@ -397,8 +405,6 @@ return current_weather.windspeed; } else { var wind_speed = current_weather.windspeed / 1.609; - const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} - const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, wind_speed, '.')) + '.' + letters_of(itemOfFromString(2, wind_speed, '.'), 1, 2)); } } else { @@ -418,8 +424,6 @@ return current_weather.temperature; } else { var temperature = (current_weather.temperature * 9 / 5) + 32; - const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} - const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, temperature, '.')) + '.' + letters_of(itemOfFromString(2, temperature, '.'), 1, 2)); } } else if (args.METEO == 'all (JSON)'){ @@ -429,8 +433,6 @@ return current_weather.windspeed; } else { var wind_speed = current_weather.windspeed / 1.609; - const letters_of = (text, from, to) => {args.STRING = text.toString();args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0;return args.STRING.substring(args.LETTER1 - 1, args.LETTER2);} - const itemOfFromString = (no, from, splitby) => {var input1 = (Number(no) - 1);var input2 = String(from);var input3 = splitby;return input2.split(input3)[input1] || '';} return Number(String(itemOfFromString(1, wind_speed, '.')) + '.' + letters_of(itemOfFromString(2, wind_speed, '.'), 1, 2)); } } else { @@ -451,7 +453,7 @@ if (args.METEO.includes('(C)')){ return Number(args.value) - 2.5 < Number(response) && Number(response) < Number(args.value) + 2.5; } else { - return Number(args.value) - 3.6 < Number(response) && Number(response) < Number(args.value)+3.6; + return Number(args.value) - 3.6 < Number(response) && Number(response) < Number(args.value) + 3.6; } } else if (args.METEO.includes('wind speed')){ if (args.METEO.includes('(km/h)')){ From 0da79e1ecd03380a2aeceb497af7dd84513567c6 Mon Sep 17 00:00:00 2001 From: SamuelLouf <104774504+samuellouf@users.noreply.github.com> Date: Sat, 5 Aug 2023 18:15:40 +0200 Subject: [PATCH 7/9] Update weather.js Removed "args." in the definition of "letters_of". --- extensions/SamuelLouf/weather.js | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/extensions/SamuelLouf/weather.js b/extensions/SamuelLouf/weather.js index cac070b668..51e1cbec74 100644 --- a/extensions/SamuelLouf/weather.js +++ b/extensions/SamuelLouf/weather.js @@ -70,11 +70,11 @@ const letters_of = (text, from, to) => { - args.STRING = text.toString(); - args.LETTER1 = Number(from) || 0;args.LETTER2 = Number(to) || 0; - return args.STRING.substring(args.LETTER1 - 1, args.LETTER2); + STRING = text.toString(); + LETTER1 = Number(from) || 0;LETTER2 = Number(to) || 0; + return STRING.substring(LETTER1 - 1, LETTER2); } - + const itemOfFromString = (no, from, splitby) => { var input1 = (Number(no) - 1); var input2 = String(from); From 450063286142e77d177d8e97680c6626fd32c425 Mon Sep 17 00:00:00 2001 From: SamuelLouf <104774504+samuellouf@users.noreply.github.com> Date: Sat, 5 Aug 2023 18:18:28 +0200 Subject: [PATCH 8/9] Update weather.js Defined "STRING", "LETTER1" and "LETTER2". --- extensions/SamuelLouf/weather.js | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/extensions/SamuelLouf/weather.js b/extensions/SamuelLouf/weather.js index 51e1cbec74..b0380cb479 100644 --- a/extensions/SamuelLouf/weather.js +++ b/extensions/SamuelLouf/weather.js @@ -70,8 +70,9 @@ const letters_of = (text, from, to) => { - STRING = text.toString(); - LETTER1 = Number(from) || 0;LETTER2 = Number(to) || 0; + var STRING = text.toString(); + var LETTER1 = Number(from) || 0; + var LETTER2 = Number(to) || 0; return STRING.substring(LETTER1 - 1, LETTER2); } From 3f4cae2b66083efc97fe2822c0f9b2cf0455ba87 Mon Sep 17 00:00:00 2001 From: SamuelLouf <104774504+samuellouf@users.noreply.github.com> Date: Sat, 5 Aug 2023 18:21:12 +0200 Subject: [PATCH 9/9] Update weather.js Replaced "const" by "function" at lines 72 and 79. --- extensions/SamuelLouf/weather.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/extensions/SamuelLouf/weather.js b/extensions/SamuelLouf/weather.js index b0380cb479..0a1ca9d330 100644 --- a/extensions/SamuelLouf/weather.js +++ b/extensions/SamuelLouf/weather.js @@ -69,14 +69,14 @@ } - const letters_of = (text, from, to) => { + function letters_of(text, from, to) { var STRING = text.toString(); var LETTER1 = Number(from) || 0; var LETTER2 = Number(to) || 0; return STRING.substring(LETTER1 - 1, LETTER2); } - const itemOfFromString = (no, from, splitby) => { + function itemOfFromString(no, from, splitby){ var input1 = (Number(no) - 1); var input2 = String(from); var input3 = splitby;