I have a function inside a function inside a function in javascript. I get my value in the inner most function, but I need to return it in the outer most one. Like this:
import convertPrice from "./convertPrice";
import getCountryInfoByLanguage from "./getCountryInfoByLanguage";
import axios from "axios";
export default (language, price) => {
let countryCode, currency, formattedPrice;
navigator.geolocation.getCurrentPosition(position => {
axios
.get(
`http://api.geonames.org/countryCodeJSON?lat=${
position.coords.latitude
}&lng=${position.coords.longitude}&username=...`
)
.then(response => {
countryCode = getCountryInfoByLanguage(
response.data.languages.split(",")[0]
).countryCode;
currency = getCountryInfoByLanguage(
response.data.languages.split(",")[0]
).currency;
const convertedPrice =
Math.round(convertPrice(price, currency) * 10) / 10;
formattedPrice = convertedPrice.toLocaleString(countryCode, {
style: "currency",
currency: currency
});
console.log(formattedPrice);
return formattedPrice; //This is where the value gets properly returned
});
});
//this is where I want the value to be returned
};