Calculate product prices based on options












0















I have a list of products where each product has 3 html select menu's that need to follow some rules:




  1. every product on the list starts with a product ID and base price and contains extra options that can be selected.

  2. each option has an option ID, option name, group name, price.

  3. An array must be used for remembering which options has been selected (this can be a data attribute on a DOM element) so that this data can be used to send to the server when clicking on a button for a specific product.

  4. when a option is selected, it must check if the selected option group is in array from step 3. if not then add the object with the values of option ID, option name, group name, price.

  5. everytime a option is selected or deselected the sum for total price for the specific product must be calculated.


Question: In my code (too long to show here) how do I restore inital price without losing the data from other options inside the array.



This is the code that I have done: https://jsfiddle.net/4esqL290/7/



For example I have 3 products or more and I select options for product with ID 1 and I want to have option_id=Z then this how it should look like:



id: 1
price: 10
array:
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]

id: 2
price: 20
array:
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]

id: 3
price: 30
array: [{option_id=Z, price=75, group: cccc}]
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]









share|improve this question

























  • Is there a question in there somewhere?

    – nurdyguy
    Nov 19 '18 at 21:05
















0















I have a list of products where each product has 3 html select menu's that need to follow some rules:




  1. every product on the list starts with a product ID and base price and contains extra options that can be selected.

  2. each option has an option ID, option name, group name, price.

  3. An array must be used for remembering which options has been selected (this can be a data attribute on a DOM element) so that this data can be used to send to the server when clicking on a button for a specific product.

  4. when a option is selected, it must check if the selected option group is in array from step 3. if not then add the object with the values of option ID, option name, group name, price.

  5. everytime a option is selected or deselected the sum for total price for the specific product must be calculated.


Question: In my code (too long to show here) how do I restore inital price without losing the data from other options inside the array.



This is the code that I have done: https://jsfiddle.net/4esqL290/7/



For example I have 3 products or more and I select options for product with ID 1 and I want to have option_id=Z then this how it should look like:



id: 1
price: 10
array:
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]

id: 2
price: 20
array:
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]

id: 3
price: 30
array: [{option_id=Z, price=75, group: cccc}]
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]









share|improve this question

























  • Is there a question in there somewhere?

    – nurdyguy
    Nov 19 '18 at 21:05














0












0








0








I have a list of products where each product has 3 html select menu's that need to follow some rules:




  1. every product on the list starts with a product ID and base price and contains extra options that can be selected.

  2. each option has an option ID, option name, group name, price.

  3. An array must be used for remembering which options has been selected (this can be a data attribute on a DOM element) so that this data can be used to send to the server when clicking on a button for a specific product.

  4. when a option is selected, it must check if the selected option group is in array from step 3. if not then add the object with the values of option ID, option name, group name, price.

  5. everytime a option is selected or deselected the sum for total price for the specific product must be calculated.


Question: In my code (too long to show here) how do I restore inital price without losing the data from other options inside the array.



This is the code that I have done: https://jsfiddle.net/4esqL290/7/



For example I have 3 products or more and I select options for product with ID 1 and I want to have option_id=Z then this how it should look like:



id: 1
price: 10
array:
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]

id: 2
price: 20
array:
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]

id: 3
price: 30
array: [{option_id=Z, price=75, group: cccc}]
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]









share|improve this question
















I have a list of products where each product has 3 html select menu's that need to follow some rules:




  1. every product on the list starts with a product ID and base price and contains extra options that can be selected.

  2. each option has an option ID, option name, group name, price.

  3. An array must be used for remembering which options has been selected (this can be a data attribute on a DOM element) so that this data can be used to send to the server when clicking on a button for a specific product.

  4. when a option is selected, it must check if the selected option group is in array from step 3. if not then add the object with the values of option ID, option name, group name, price.

  5. everytime a option is selected or deselected the sum for total price for the specific product must be calculated.


Question: In my code (too long to show here) how do I restore inital price without losing the data from other options inside the array.



This is the code that I have done: https://jsfiddle.net/4esqL290/7/



For example I have 3 products or more and I select options for product with ID 1 and I want to have option_id=Z then this how it should look like:



id: 1
price: 10
array:
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]

id: 2
price: 20
array:
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]

id: 3
price: 30
array: [{option_id=Z, price=75, group: cccc}]
options: [{option_id=X, price=25, group: aaaa}, {option_id=Y, price=50, group: bbbb}, {option_id=Z, price=75, group: cccc}]






javascript jquery html






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 19 '18 at 21:12







Xenioz

















asked Nov 19 '18 at 21:02









XeniozXenioz

2917




2917













  • Is there a question in there somewhere?

    – nurdyguy
    Nov 19 '18 at 21:05



















  • Is there a question in there somewhere?

    – nurdyguy
    Nov 19 '18 at 21:05

















Is there a question in there somewhere?

– nurdyguy
Nov 19 '18 at 21:05





Is there a question in there somewhere?

– nurdyguy
Nov 19 '18 at 21:05












0






active

oldest

votes











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
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53382571%2fcalculate-product-prices-based-on-options%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























0






active

oldest

votes








0






active

oldest

votes









active

oldest

votes






active

oldest

votes
















draft saved

draft discarded




















































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.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53382571%2fcalculate-product-prices-based-on-options%23new-answer', 'question_page');
}
);

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







Popular posts from this blog

Guess what letter conforming each word

Run scheduled task as local user group (not BUILTIN)

Port of Spain