Not sure how to populate an array within a method that has Promises within it
I have a method that performs some basic mathematical calculations in my Ionic
app after fetching data from SQLite
DB. I want to show these results on a page but the problem is that I am not sure how to put all these calculated values in an object array.
I tried following but the editor is complaining about not resolving promises. To me it looks like I already resolved them by extracting a numeric value from each and assigning them to local variables such as grossMarketable, aphMarketable, amountSold
and totalContractDollarAmount
.
home.ts
private calculate() {
console.log("**********Starting calculations now.....");
let calculations: CalcModel = ;
for (let i = 0; i < this.userCropTxModels.length; i++) {
let userCropTxModel = this.userCropTxModels[i];
console.log("userCropTxModel: " + userCropTxModel);
let grossMarketable = this.userCropProvider.getGrossMarketableByCropId(userCropTxModel.cropId)
.then(grossMarketable => {
console.log("grossMarketable: " + grossMarketable);
return grossMarketable;
})
.catch((e) => console.error(JSON.stringify(e)));
let aphMarketable = this.userCropProvider.getAPHMarketableByCropId(userCropTxModel.cropId)
.then(aphMarketable => {
console.log("aphMarketable: " + aphMarketable);
})
.catch((e) => console.error(JSON.stringify(e)));
let amountSold = this.userContractProvider.getTotalContractedBushelsByCropId(userCropTxModel.cropId)
.then(amountSold => {
console.log("amountSold: " + amountSold);
})
.catch((e) => console.error(JSON.stringify(e)));
let totalContractDollarAmount = this.userContractProvider.getTotalContractDollarAmountByCropId(userCropTxModel.cropId)
.then(totalContractDollarAmount => {
console.log("totalContractDollarAmount: " + totalContractDollarAmount);
})
.catch((e) => console.error(JSON.stringify(e)));
console.log("grossMarketable: " + grossMarketable);
console.log("aphMarketable: " + aphMarketable);
console.log("amountSold: " + amountSold);
console.log("totalContractDollarAmount: " + totalContractDollarAmount);
/**************************************************
//THE EDITOR IS SHOWING RED MARKS BELOW
***********************************************/
calculations.push({
cropName: 'Corn',
grossMarketable: grossMarketable,
grossMarketable: grossMarketable,
amountSold: amountSold,
totalContractDollarAmount: totalContractDollarAmount
});
}
console.log("calculations: " + calculations);
}
user-crop.ts (code snippet of UserCropProvider)
getGrossMarketableByCropId(cropId: number): Promise<number> {
return this.databaseProvider.getDatabase().then(database => {
return database.executeSql(SQL_SELECT_GROSS_MARKETABLE_BY_CROP_ID, [cropId])
.then((data) => {
let grossMarketable: number = 0;
for (let i = 0; i < data.rows.length; i++) {
grossMarketable = data.rows.item(i).GROSS_MARKETABLE
}
return grossMarketable;
});
});
}
CalcModel.ts
export interface CalcModel {
cropName: string;
grossMarketable: number;
aphMarketable: number;
amountSold: number;
totalContractDollarAmount: number;
}
javascript angular typescript ionic-framework promise
add a comment |
I have a method that performs some basic mathematical calculations in my Ionic
app after fetching data from SQLite
DB. I want to show these results on a page but the problem is that I am not sure how to put all these calculated values in an object array.
I tried following but the editor is complaining about not resolving promises. To me it looks like I already resolved them by extracting a numeric value from each and assigning them to local variables such as grossMarketable, aphMarketable, amountSold
and totalContractDollarAmount
.
home.ts
private calculate() {
console.log("**********Starting calculations now.....");
let calculations: CalcModel = ;
for (let i = 0; i < this.userCropTxModels.length; i++) {
let userCropTxModel = this.userCropTxModels[i];
console.log("userCropTxModel: " + userCropTxModel);
let grossMarketable = this.userCropProvider.getGrossMarketableByCropId(userCropTxModel.cropId)
.then(grossMarketable => {
console.log("grossMarketable: " + grossMarketable);
return grossMarketable;
})
.catch((e) => console.error(JSON.stringify(e)));
let aphMarketable = this.userCropProvider.getAPHMarketableByCropId(userCropTxModel.cropId)
.then(aphMarketable => {
console.log("aphMarketable: " + aphMarketable);
})
.catch((e) => console.error(JSON.stringify(e)));
let amountSold = this.userContractProvider.getTotalContractedBushelsByCropId(userCropTxModel.cropId)
.then(amountSold => {
console.log("amountSold: " + amountSold);
})
.catch((e) => console.error(JSON.stringify(e)));
let totalContractDollarAmount = this.userContractProvider.getTotalContractDollarAmountByCropId(userCropTxModel.cropId)
.then(totalContractDollarAmount => {
console.log("totalContractDollarAmount: " + totalContractDollarAmount);
})
.catch((e) => console.error(JSON.stringify(e)));
console.log("grossMarketable: " + grossMarketable);
console.log("aphMarketable: " + aphMarketable);
console.log("amountSold: " + amountSold);
console.log("totalContractDollarAmount: " + totalContractDollarAmount);
/**************************************************
//THE EDITOR IS SHOWING RED MARKS BELOW
***********************************************/
calculations.push({
cropName: 'Corn',
grossMarketable: grossMarketable,
grossMarketable: grossMarketable,
amountSold: amountSold,
totalContractDollarAmount: totalContractDollarAmount
});
}
console.log("calculations: " + calculations);
}
user-crop.ts (code snippet of UserCropProvider)
getGrossMarketableByCropId(cropId: number): Promise<number> {
return this.databaseProvider.getDatabase().then(database => {
return database.executeSql(SQL_SELECT_GROSS_MARKETABLE_BY_CROP_ID, [cropId])
.then((data) => {
let grossMarketable: number = 0;
for (let i = 0; i < data.rows.length; i++) {
grossMarketable = data.rows.item(i).GROSS_MARKETABLE
}
return grossMarketable;
});
});
}
CalcModel.ts
export interface CalcModel {
cropName: string;
grossMarketable: number;
aphMarketable: number;
amountSold: number;
totalContractDollarAmount: number;
}
javascript angular typescript ionic-framework promise
The promises are not resolved. To write synchronous-looking code with promises, you can use async/await keywords. Alternatively use a single Promise.all(...) callback to ensure your 4 promises are resolved by array time
– ne1410s
Jan 3 at 6:01
How do I get the numeric value from that promise and assign it to the interface's variable? That's where I am confused most.
– user2325154
Jan 3 at 6:03
1
everything in home.ts is ASYNC, you need to make sure that all of the promises are resolved before you start to push data inside calculations array. as @ne1410s said you can use promise.all() or forkjoin() to achieve that
– Mohit Patil
Jan 3 at 6:11
add a comment |
I have a method that performs some basic mathematical calculations in my Ionic
app after fetching data from SQLite
DB. I want to show these results on a page but the problem is that I am not sure how to put all these calculated values in an object array.
I tried following but the editor is complaining about not resolving promises. To me it looks like I already resolved them by extracting a numeric value from each and assigning them to local variables such as grossMarketable, aphMarketable, amountSold
and totalContractDollarAmount
.
home.ts
private calculate() {
console.log("**********Starting calculations now.....");
let calculations: CalcModel = ;
for (let i = 0; i < this.userCropTxModels.length; i++) {
let userCropTxModel = this.userCropTxModels[i];
console.log("userCropTxModel: " + userCropTxModel);
let grossMarketable = this.userCropProvider.getGrossMarketableByCropId(userCropTxModel.cropId)
.then(grossMarketable => {
console.log("grossMarketable: " + grossMarketable);
return grossMarketable;
})
.catch((e) => console.error(JSON.stringify(e)));
let aphMarketable = this.userCropProvider.getAPHMarketableByCropId(userCropTxModel.cropId)
.then(aphMarketable => {
console.log("aphMarketable: " + aphMarketable);
})
.catch((e) => console.error(JSON.stringify(e)));
let amountSold = this.userContractProvider.getTotalContractedBushelsByCropId(userCropTxModel.cropId)
.then(amountSold => {
console.log("amountSold: " + amountSold);
})
.catch((e) => console.error(JSON.stringify(e)));
let totalContractDollarAmount = this.userContractProvider.getTotalContractDollarAmountByCropId(userCropTxModel.cropId)
.then(totalContractDollarAmount => {
console.log("totalContractDollarAmount: " + totalContractDollarAmount);
})
.catch((e) => console.error(JSON.stringify(e)));
console.log("grossMarketable: " + grossMarketable);
console.log("aphMarketable: " + aphMarketable);
console.log("amountSold: " + amountSold);
console.log("totalContractDollarAmount: " + totalContractDollarAmount);
/**************************************************
//THE EDITOR IS SHOWING RED MARKS BELOW
***********************************************/
calculations.push({
cropName: 'Corn',
grossMarketable: grossMarketable,
grossMarketable: grossMarketable,
amountSold: amountSold,
totalContractDollarAmount: totalContractDollarAmount
});
}
console.log("calculations: " + calculations);
}
user-crop.ts (code snippet of UserCropProvider)
getGrossMarketableByCropId(cropId: number): Promise<number> {
return this.databaseProvider.getDatabase().then(database => {
return database.executeSql(SQL_SELECT_GROSS_MARKETABLE_BY_CROP_ID, [cropId])
.then((data) => {
let grossMarketable: number = 0;
for (let i = 0; i < data.rows.length; i++) {
grossMarketable = data.rows.item(i).GROSS_MARKETABLE
}
return grossMarketable;
});
});
}
CalcModel.ts
export interface CalcModel {
cropName: string;
grossMarketable: number;
aphMarketable: number;
amountSold: number;
totalContractDollarAmount: number;
}
javascript angular typescript ionic-framework promise
I have a method that performs some basic mathematical calculations in my Ionic
app after fetching data from SQLite
DB. I want to show these results on a page but the problem is that I am not sure how to put all these calculated values in an object array.
I tried following but the editor is complaining about not resolving promises. To me it looks like I already resolved them by extracting a numeric value from each and assigning them to local variables such as grossMarketable, aphMarketable, amountSold
and totalContractDollarAmount
.
home.ts
private calculate() {
console.log("**********Starting calculations now.....");
let calculations: CalcModel = ;
for (let i = 0; i < this.userCropTxModels.length; i++) {
let userCropTxModel = this.userCropTxModels[i];
console.log("userCropTxModel: " + userCropTxModel);
let grossMarketable = this.userCropProvider.getGrossMarketableByCropId(userCropTxModel.cropId)
.then(grossMarketable => {
console.log("grossMarketable: " + grossMarketable);
return grossMarketable;
})
.catch((e) => console.error(JSON.stringify(e)));
let aphMarketable = this.userCropProvider.getAPHMarketableByCropId(userCropTxModel.cropId)
.then(aphMarketable => {
console.log("aphMarketable: " + aphMarketable);
})
.catch((e) => console.error(JSON.stringify(e)));
let amountSold = this.userContractProvider.getTotalContractedBushelsByCropId(userCropTxModel.cropId)
.then(amountSold => {
console.log("amountSold: " + amountSold);
})
.catch((e) => console.error(JSON.stringify(e)));
let totalContractDollarAmount = this.userContractProvider.getTotalContractDollarAmountByCropId(userCropTxModel.cropId)
.then(totalContractDollarAmount => {
console.log("totalContractDollarAmount: " + totalContractDollarAmount);
})
.catch((e) => console.error(JSON.stringify(e)));
console.log("grossMarketable: " + grossMarketable);
console.log("aphMarketable: " + aphMarketable);
console.log("amountSold: " + amountSold);
console.log("totalContractDollarAmount: " + totalContractDollarAmount);
/**************************************************
//THE EDITOR IS SHOWING RED MARKS BELOW
***********************************************/
calculations.push({
cropName: 'Corn',
grossMarketable: grossMarketable,
grossMarketable: grossMarketable,
amountSold: amountSold,
totalContractDollarAmount: totalContractDollarAmount
});
}
console.log("calculations: " + calculations);
}
user-crop.ts (code snippet of UserCropProvider)
getGrossMarketableByCropId(cropId: number): Promise<number> {
return this.databaseProvider.getDatabase().then(database => {
return database.executeSql(SQL_SELECT_GROSS_MARKETABLE_BY_CROP_ID, [cropId])
.then((data) => {
let grossMarketable: number = 0;
for (let i = 0; i < data.rows.length; i++) {
grossMarketable = data.rows.item(i).GROSS_MARKETABLE
}
return grossMarketable;
});
});
}
CalcModel.ts
export interface CalcModel {
cropName: string;
grossMarketable: number;
aphMarketable: number;
amountSold: number;
totalContractDollarAmount: number;
}
javascript angular typescript ionic-framework promise
javascript angular typescript ionic-framework promise
asked Jan 3 at 5:48
user2325154user2325154
1,77493880
1,77493880
The promises are not resolved. To write synchronous-looking code with promises, you can use async/await keywords. Alternatively use a single Promise.all(...) callback to ensure your 4 promises are resolved by array time
– ne1410s
Jan 3 at 6:01
How do I get the numeric value from that promise and assign it to the interface's variable? That's where I am confused most.
– user2325154
Jan 3 at 6:03
1
everything in home.ts is ASYNC, you need to make sure that all of the promises are resolved before you start to push data inside calculations array. as @ne1410s said you can use promise.all() or forkjoin() to achieve that
– Mohit Patil
Jan 3 at 6:11
add a comment |
The promises are not resolved. To write synchronous-looking code with promises, you can use async/await keywords. Alternatively use a single Promise.all(...) callback to ensure your 4 promises are resolved by array time
– ne1410s
Jan 3 at 6:01
How do I get the numeric value from that promise and assign it to the interface's variable? That's where I am confused most.
– user2325154
Jan 3 at 6:03
1
everything in home.ts is ASYNC, you need to make sure that all of the promises are resolved before you start to push data inside calculations array. as @ne1410s said you can use promise.all() or forkjoin() to achieve that
– Mohit Patil
Jan 3 at 6:11
The promises are not resolved. To write synchronous-looking code with promises, you can use async/await keywords. Alternatively use a single Promise.all(...) callback to ensure your 4 promises are resolved by array time
– ne1410s
Jan 3 at 6:01
The promises are not resolved. To write synchronous-looking code with promises, you can use async/await keywords. Alternatively use a single Promise.all(...) callback to ensure your 4 promises are resolved by array time
– ne1410s
Jan 3 at 6:01
How do I get the numeric value from that promise and assign it to the interface's variable? That's where I am confused most.
– user2325154
Jan 3 at 6:03
How do I get the numeric value from that promise and assign it to the interface's variable? That's where I am confused most.
– user2325154
Jan 3 at 6:03
1
1
everything in home.ts is ASYNC, you need to make sure that all of the promises are resolved before you start to push data inside calculations array. as @ne1410s said you can use promise.all() or forkjoin() to achieve that
– Mohit Patil
Jan 3 at 6:11
everything in home.ts is ASYNC, you need to make sure that all of the promises are resolved before you start to push data inside calculations array. as @ne1410s said you can use promise.all() or forkjoin() to achieve that
– Mohit Patil
Jan 3 at 6:11
add a comment |
1 Answer
1
active
oldest
votes
Create a promise.all for each user crop model, with inside the list of promises of your async requests.
When you resolve the inner ones, get back a single calculation object.
When you resolve all of them, get your calculations list:
Your code should look something like:
private calculate() {
const promises: Promise<any> = ;
for (let i = 0; i < this.userCropTxModels.length; i++) {
let userCropTxModel = this.userCropTxModels[i];
promises.push(Promise.all([
this.userCropProvider.getGrossMarketableByCropId(userCropTxModel.cropId),
this.userCropProvider.getAPHMarketableByCropId(userCropTxModel.cropId),
this.userContractProvider.getTotalContractedBushelsByCropId(userCropTxModel.cropId),
this.userContractProvider.getTotalContractDollarAmountByCropId(userCropTxModel.cropId)
]).then(data => ({
cropName: 'Corn',
grossMarketable: data[0],
amountSold: data[1],
totalContractDollarAmount: data[2]
})));
}
Promise.all(promises).then(calculations => console.log(calculations));
}
EDIT
A bit of refactor. I don't know if it works, I am just coding without even trying, but just a bit cleaner:
private calculate() {
const promises: Promise<any> = this.userCropTxModels.map(userCropModel => Promise.all([
this.userCropProvider.getGrossMarketableByCropId(userCropModel.cropId),
this.userCropProvider.getAPHMarketableByCropId(userCropModel.cropId),
this.userContractProvider.getTotalContractedBushelsByCropId(userCropModel.cropId),
this.userContractProvider.getTotalContractDollarAmountByCropId(userCropModel.cropId)
]).then(data => ({
cropName: 'Corn',
grossMarketable: data[0],
amountSold: data[1],
totalContractDollarAmount: data[2]
})));
Promise.all(promises).then(calculations => console.log(calculations));
}
You can even use async/await if you want to write sync/style code
Let me try this
– user2325154
Jan 3 at 6:09
All theconsole.log
statements are getting shown in red in editor hence I commented those out. The finalconsole.log(calculations)
statement never got printed.
– user2325154
Jan 3 at 6:12
sorry the console logs should be removed, I forgot to remove them after the copy and paste
– quirimmo
Jan 3 at 6:12
there was also a typo at the last line:calculationS
inside the then
– quirimmo
Jan 3 at 6:14
Perfect that worked. Thanks so much. A quick question though. In order to build thecalculations
array we never used theCalcModel
interface? Can I use this samecalculations
array to display all these values on a page or do I need to typecast it to CalcModel object and then use it?
– user2325154
Jan 3 at 6:23
|
show 3 more comments
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54016961%2fnot-sure-how-to-populate-an-array-within-a-method-that-has-promises-within-it%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
Create a promise.all for each user crop model, with inside the list of promises of your async requests.
When you resolve the inner ones, get back a single calculation object.
When you resolve all of them, get your calculations list:
Your code should look something like:
private calculate() {
const promises: Promise<any> = ;
for (let i = 0; i < this.userCropTxModels.length; i++) {
let userCropTxModel = this.userCropTxModels[i];
promises.push(Promise.all([
this.userCropProvider.getGrossMarketableByCropId(userCropTxModel.cropId),
this.userCropProvider.getAPHMarketableByCropId(userCropTxModel.cropId),
this.userContractProvider.getTotalContractedBushelsByCropId(userCropTxModel.cropId),
this.userContractProvider.getTotalContractDollarAmountByCropId(userCropTxModel.cropId)
]).then(data => ({
cropName: 'Corn',
grossMarketable: data[0],
amountSold: data[1],
totalContractDollarAmount: data[2]
})));
}
Promise.all(promises).then(calculations => console.log(calculations));
}
EDIT
A bit of refactor. I don't know if it works, I am just coding without even trying, but just a bit cleaner:
private calculate() {
const promises: Promise<any> = this.userCropTxModels.map(userCropModel => Promise.all([
this.userCropProvider.getGrossMarketableByCropId(userCropModel.cropId),
this.userCropProvider.getAPHMarketableByCropId(userCropModel.cropId),
this.userContractProvider.getTotalContractedBushelsByCropId(userCropModel.cropId),
this.userContractProvider.getTotalContractDollarAmountByCropId(userCropModel.cropId)
]).then(data => ({
cropName: 'Corn',
grossMarketable: data[0],
amountSold: data[1],
totalContractDollarAmount: data[2]
})));
Promise.all(promises).then(calculations => console.log(calculations));
}
You can even use async/await if you want to write sync/style code
Let me try this
– user2325154
Jan 3 at 6:09
All theconsole.log
statements are getting shown in red in editor hence I commented those out. The finalconsole.log(calculations)
statement never got printed.
– user2325154
Jan 3 at 6:12
sorry the console logs should be removed, I forgot to remove them after the copy and paste
– quirimmo
Jan 3 at 6:12
there was also a typo at the last line:calculationS
inside the then
– quirimmo
Jan 3 at 6:14
Perfect that worked. Thanks so much. A quick question though. In order to build thecalculations
array we never used theCalcModel
interface? Can I use this samecalculations
array to display all these values on a page or do I need to typecast it to CalcModel object and then use it?
– user2325154
Jan 3 at 6:23
|
show 3 more comments
Create a promise.all for each user crop model, with inside the list of promises of your async requests.
When you resolve the inner ones, get back a single calculation object.
When you resolve all of them, get your calculations list:
Your code should look something like:
private calculate() {
const promises: Promise<any> = ;
for (let i = 0; i < this.userCropTxModels.length; i++) {
let userCropTxModel = this.userCropTxModels[i];
promises.push(Promise.all([
this.userCropProvider.getGrossMarketableByCropId(userCropTxModel.cropId),
this.userCropProvider.getAPHMarketableByCropId(userCropTxModel.cropId),
this.userContractProvider.getTotalContractedBushelsByCropId(userCropTxModel.cropId),
this.userContractProvider.getTotalContractDollarAmountByCropId(userCropTxModel.cropId)
]).then(data => ({
cropName: 'Corn',
grossMarketable: data[0],
amountSold: data[1],
totalContractDollarAmount: data[2]
})));
}
Promise.all(promises).then(calculations => console.log(calculations));
}
EDIT
A bit of refactor. I don't know if it works, I am just coding without even trying, but just a bit cleaner:
private calculate() {
const promises: Promise<any> = this.userCropTxModels.map(userCropModel => Promise.all([
this.userCropProvider.getGrossMarketableByCropId(userCropModel.cropId),
this.userCropProvider.getAPHMarketableByCropId(userCropModel.cropId),
this.userContractProvider.getTotalContractedBushelsByCropId(userCropModel.cropId),
this.userContractProvider.getTotalContractDollarAmountByCropId(userCropModel.cropId)
]).then(data => ({
cropName: 'Corn',
grossMarketable: data[0],
amountSold: data[1],
totalContractDollarAmount: data[2]
})));
Promise.all(promises).then(calculations => console.log(calculations));
}
You can even use async/await if you want to write sync/style code
Let me try this
– user2325154
Jan 3 at 6:09
All theconsole.log
statements are getting shown in red in editor hence I commented those out. The finalconsole.log(calculations)
statement never got printed.
– user2325154
Jan 3 at 6:12
sorry the console logs should be removed, I forgot to remove them after the copy and paste
– quirimmo
Jan 3 at 6:12
there was also a typo at the last line:calculationS
inside the then
– quirimmo
Jan 3 at 6:14
Perfect that worked. Thanks so much. A quick question though. In order to build thecalculations
array we never used theCalcModel
interface? Can I use this samecalculations
array to display all these values on a page or do I need to typecast it to CalcModel object and then use it?
– user2325154
Jan 3 at 6:23
|
show 3 more comments
Create a promise.all for each user crop model, with inside the list of promises of your async requests.
When you resolve the inner ones, get back a single calculation object.
When you resolve all of them, get your calculations list:
Your code should look something like:
private calculate() {
const promises: Promise<any> = ;
for (let i = 0; i < this.userCropTxModels.length; i++) {
let userCropTxModel = this.userCropTxModels[i];
promises.push(Promise.all([
this.userCropProvider.getGrossMarketableByCropId(userCropTxModel.cropId),
this.userCropProvider.getAPHMarketableByCropId(userCropTxModel.cropId),
this.userContractProvider.getTotalContractedBushelsByCropId(userCropTxModel.cropId),
this.userContractProvider.getTotalContractDollarAmountByCropId(userCropTxModel.cropId)
]).then(data => ({
cropName: 'Corn',
grossMarketable: data[0],
amountSold: data[1],
totalContractDollarAmount: data[2]
})));
}
Promise.all(promises).then(calculations => console.log(calculations));
}
EDIT
A bit of refactor. I don't know if it works, I am just coding without even trying, but just a bit cleaner:
private calculate() {
const promises: Promise<any> = this.userCropTxModels.map(userCropModel => Promise.all([
this.userCropProvider.getGrossMarketableByCropId(userCropModel.cropId),
this.userCropProvider.getAPHMarketableByCropId(userCropModel.cropId),
this.userContractProvider.getTotalContractedBushelsByCropId(userCropModel.cropId),
this.userContractProvider.getTotalContractDollarAmountByCropId(userCropModel.cropId)
]).then(data => ({
cropName: 'Corn',
grossMarketable: data[0],
amountSold: data[1],
totalContractDollarAmount: data[2]
})));
Promise.all(promises).then(calculations => console.log(calculations));
}
You can even use async/await if you want to write sync/style code
Create a promise.all for each user crop model, with inside the list of promises of your async requests.
When you resolve the inner ones, get back a single calculation object.
When you resolve all of them, get your calculations list:
Your code should look something like:
private calculate() {
const promises: Promise<any> = ;
for (let i = 0; i < this.userCropTxModels.length; i++) {
let userCropTxModel = this.userCropTxModels[i];
promises.push(Promise.all([
this.userCropProvider.getGrossMarketableByCropId(userCropTxModel.cropId),
this.userCropProvider.getAPHMarketableByCropId(userCropTxModel.cropId),
this.userContractProvider.getTotalContractedBushelsByCropId(userCropTxModel.cropId),
this.userContractProvider.getTotalContractDollarAmountByCropId(userCropTxModel.cropId)
]).then(data => ({
cropName: 'Corn',
grossMarketable: data[0],
amountSold: data[1],
totalContractDollarAmount: data[2]
})));
}
Promise.all(promises).then(calculations => console.log(calculations));
}
EDIT
A bit of refactor. I don't know if it works, I am just coding without even trying, but just a bit cleaner:
private calculate() {
const promises: Promise<any> = this.userCropTxModels.map(userCropModel => Promise.all([
this.userCropProvider.getGrossMarketableByCropId(userCropModel.cropId),
this.userCropProvider.getAPHMarketableByCropId(userCropModel.cropId),
this.userContractProvider.getTotalContractedBushelsByCropId(userCropModel.cropId),
this.userContractProvider.getTotalContractDollarAmountByCropId(userCropModel.cropId)
]).then(data => ({
cropName: 'Corn',
grossMarketable: data[0],
amountSold: data[1],
totalContractDollarAmount: data[2]
})));
Promise.all(promises).then(calculations => console.log(calculations));
}
You can even use async/await if you want to write sync/style code
edited Jan 3 at 6:30
answered Jan 3 at 6:03
quirimmoquirimmo
7,67811436
7,67811436
Let me try this
– user2325154
Jan 3 at 6:09
All theconsole.log
statements are getting shown in red in editor hence I commented those out. The finalconsole.log(calculations)
statement never got printed.
– user2325154
Jan 3 at 6:12
sorry the console logs should be removed, I forgot to remove them after the copy and paste
– quirimmo
Jan 3 at 6:12
there was also a typo at the last line:calculationS
inside the then
– quirimmo
Jan 3 at 6:14
Perfect that worked. Thanks so much. A quick question though. In order to build thecalculations
array we never used theCalcModel
interface? Can I use this samecalculations
array to display all these values on a page or do I need to typecast it to CalcModel object and then use it?
– user2325154
Jan 3 at 6:23
|
show 3 more comments
Let me try this
– user2325154
Jan 3 at 6:09
All theconsole.log
statements are getting shown in red in editor hence I commented those out. The finalconsole.log(calculations)
statement never got printed.
– user2325154
Jan 3 at 6:12
sorry the console logs should be removed, I forgot to remove them after the copy and paste
– quirimmo
Jan 3 at 6:12
there was also a typo at the last line:calculationS
inside the then
– quirimmo
Jan 3 at 6:14
Perfect that worked. Thanks so much. A quick question though. In order to build thecalculations
array we never used theCalcModel
interface? Can I use this samecalculations
array to display all these values on a page or do I need to typecast it to CalcModel object and then use it?
– user2325154
Jan 3 at 6:23
Let me try this
– user2325154
Jan 3 at 6:09
Let me try this
– user2325154
Jan 3 at 6:09
All the
console.log
statements are getting shown in red in editor hence I commented those out. The final console.log(calculations)
statement never got printed.– user2325154
Jan 3 at 6:12
All the
console.log
statements are getting shown in red in editor hence I commented those out. The final console.log(calculations)
statement never got printed.– user2325154
Jan 3 at 6:12
sorry the console logs should be removed, I forgot to remove them after the copy and paste
– quirimmo
Jan 3 at 6:12
sorry the console logs should be removed, I forgot to remove them after the copy and paste
– quirimmo
Jan 3 at 6:12
there was also a typo at the last line:
calculationS
inside the then– quirimmo
Jan 3 at 6:14
there was also a typo at the last line:
calculationS
inside the then– quirimmo
Jan 3 at 6:14
Perfect that worked. Thanks so much. A quick question though. In order to build the
calculations
array we never used the CalcModel
interface? Can I use this same calculations
array to display all these values on a page or do I need to typecast it to CalcModel object and then use it?– user2325154
Jan 3 at 6:23
Perfect that worked. Thanks so much. A quick question though. In order to build the
calculations
array we never used the CalcModel
interface? Can I use this same calculations
array to display all these values on a page or do I need to typecast it to CalcModel object and then use it?– user2325154
Jan 3 at 6:23
|
show 3 more comments
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54016961%2fnot-sure-how-to-populate-an-array-within-a-method-that-has-promises-within-it%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
The promises are not resolved. To write synchronous-looking code with promises, you can use async/await keywords. Alternatively use a single Promise.all(...) callback to ensure your 4 promises are resolved by array time
– ne1410s
Jan 3 at 6:01
How do I get the numeric value from that promise and assign it to the interface's variable? That's where I am confused most.
– user2325154
Jan 3 at 6:03
1
everything in home.ts is ASYNC, you need to make sure that all of the promises are resolved before you start to push data inside calculations array. as @ne1410s said you can use promise.all() or forkjoin() to achieve that
– Mohit Patil
Jan 3 at 6:11