diff options
author | piernov <piernov@piernov.org> | 2016-04-24 22:27:33 +0200 |
---|---|---|
committer | piernov <piernov@piernov.org> | 2016-04-24 22:27:33 +0200 |
commit | 5ff6c7051867ed14ecbbc391709f25106c1bef1f (patch) | |
tree | a259394a3ff4620b4e34d80faa4fd1fd511eba7a /js | |
parent | f2d53d539ee55e1b41cc74368ad5457da6e05cf3 (diff) | |
download | candybox-5ff6c7051867ed14ecbbc391709f25106c1bef1f.tar.gz candybox-5ff6c7051867ed14ecbbc391709f25106c1bef1f.tar.bz2 candybox-5ff6c7051867ed14ecbbc391709f25106c1bef1f.tar.xz candybox-5ff6c7051867ed14ecbbc391709f25106c1bef1f.zip |
Add client side JS shop functions
Diffstat (limited to 'js')
-rw-r--r-- | js/craftmine.js | 7 | ||||
-rw-r--r-- | js/shop.js | 57 |
2 files changed, 61 insertions, 3 deletions
diff --git a/js/craftmine.js b/js/craftmine.js index 912d10c..dc4ee9a 100644 --- a/js/craftmine.js +++ b/js/craftmine.js @@ -44,9 +44,10 @@ function withdrawMine() { } function initCraftMine() { - sendRequest("craftmine.php", "op=getCraftMine", function(xhr) { - var ret = xhr; - data.gold = parseInt(ret); // Server's response is a string + sendRequest("craftmine.php", "op=getCraftMine", function(ret) { + data.gold = parseInt(ret.gold); // Server's response is a string + if(ret.shop) displayShop(ret.shop); + displayInventory(ret.inventory); updateData("gold"); }) } diff --git a/js/shop.js b/js/shop.js new file mode 100644 index 0000000..00636e1 --- /dev/null +++ b/js/shop.js @@ -0,0 +1,57 @@ +function displayShop(ret) { + var tmphtml = "<h4> Select an item to buy it:</h4>"; + tmphtml += "<ul class=\"list-inline\">"; + for(var i=0; i < ret.items.length; i++) { + tmphtml += "<li>"; + tmphtml += "<button type=\"submit\" class=\"btn btn-primary\" onclick=\"buyItem('" + ret.items[i].name + "')\"><span class=\"item-icon\">" + ret.items[i].icon + "</span><br />" + ret.items[i].name + "</button>"; + tmphtml += "</li>"; + } + tmphtml += "</ul>" + document.getElementById("tab2").innerHTML = tmphtml; +} + +function displayInventory(items) { + for(var i=0; i < items.length; i++) { + addItem(items[i]); + } +} + +function buildShop() { + sendRequest("craftmine.php", "op=buildShop", function(ret) { + displayShop(ret); + debitAccount(ret.cost); + }); +} + +function addItem(ret) { + var itemhtml = "<li>"; + itemhtml += "<button type=\"submit\" class=\"btn btn-primary\" onclick=\"useItem('" + ret.name + "')\"><span class=\"item-icon\">" + ret.icon + "</span><br />" + ret.name + "</button>"; + itemhtml += "</li>"; + + var invcontent = document.getElementById("tab3"); + + if(invcontent.children.length <= 1) + { + var tmphtml = "<h4>Your bag contains the following items:</h4>"; + tmphtml += "<ul class=\"list-inline\">"; + tmphtml += itemhtml; + tmphtml += "</ul>" + invcontent.innerHTML = tmphtml; + } else + invcontent.getElementsByTagName('ul')[0].innerHTML += itemhtml; + + showInfo(ret.desc); +} + +function buyItem(name) { + sendRequest("craftmine.php", "op=buyItem&item="+name, function(ret) { + addItem(ret); + debitAccount(ret.cost); + }); +} + +function useItem(name) { + sendRequest("craftmine.php", "op=useItem&item="+name, function(ret) { + }); +} + |