Site du proximo, utilisé pour gérer le stock.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

stock.js 5.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207
  1. let defaultTypes = [
  2. 'Nouveau',
  3. 'Alimentaire',
  4. 'Boissons',
  5. 'Utilitaires'
  6. ];
  7. let defaultStock = [
  8. {
  9. name: 'Granola',
  10. quantity: '2',
  11. price: '1.3',
  12. code: '7622210601988',
  13. image : 'https://cookieandkate.com/images/2015/10/granola-mixed-in-bowl.jpg',
  14. type: [
  15. 'Alimentaire',
  16. ]
  17. }
  18. ];
  19. let currentDataset = [];
  20. let currentTypes = [];
  21. function initValuesFromPHPDump() {
  22. currentDataset = json_dump.articles; // json_dump is set using PHP
  23. currentTypes = json_dump.types;
  24. console.log(currentDataset);
  25. console.log(currentTypes);
  26. generateTable(currentDataset);
  27. }
  28. $(document).ready(function () {
  29. initValuesFromPHPDump();
  30. generateTypeCheckboxes();
  31. });
  32. function generateTable(dataset) {
  33. for (let i = 0; i < dataset.length; i++) {
  34. generateLine(dataset[i]);
  35. }
  36. }
  37. function generateLine(item) {
  38. $.selector_cache('#stockTable').append(
  39. '<tr id="row_' + item.code + '">' +
  40. '<td>' + item.name + '</td>' +
  41. '<td>' + item.quantity + '</td>' +
  42. '<td>' + item.price + '</td>' +
  43. '<td>' + item.code + '</td>' +
  44. '<td><ul id="typeList_' + item.code + '"></ul></td>' +
  45. '<td><a href="' + item.image + '" target="_blank">LINK</a></td>' +
  46. '<td>' +
  47. '<button class="btn btn-danger" id="delete_' + item.code + '" onclick="deleteItem(this)"><i class="fas fa-times"></i></button>' +
  48. '<button class="btn btn-primary" id="edit_' + item.code + '" onclick="editItem(this)"><i class="fas fa-edit"></i></button>' +
  49. '</td>' +
  50. '</tr>'
  51. );
  52. // Fill in the type cell
  53. for (let i = 0; i < item.type.length; i++) {
  54. $('#typeList_' + item.code).append(
  55. '<li>' + item.type[i] + '</li>'
  56. );
  57. }
  58. }
  59. function generateTypeCheckboxes() {
  60. for (let i = 0; i < currentTypes.length; i++) {
  61. let id = 'typeCheck_' + currentTypes[i];
  62. $('#typeCheckboxesCell').append(
  63. '<div class="form-check">' +
  64. '<input type="checkbox" class="form-check-input" id="' + id + '">' +
  65. '<label class="form-check-label" for="' + id + '">' + currentTypes[i] + '</label>' +
  66. '</div>'
  67. );
  68. }
  69. }
  70. function getItemOfCode(code) {
  71. let item = {};
  72. for (let i = 0; i < currentDataset.length; i++) {
  73. if (currentDataset[i].code === code) {
  74. item = currentDataset[i];
  75. break;
  76. }
  77. }
  78. return item;
  79. }
  80. function addNewItem() {
  81. if (isItemInputFilled()) {
  82. let item = {
  83. name: $.selector_cache('#nameInput').val(),
  84. quantity: $.selector_cache('#quantityInput').val(),
  85. price: $.selector_cache('#priceInput').val(),
  86. code: $.selector_cache('#codeInput').val(),
  87. type: getTypesChecked(),
  88. image: $.selector_cache('#imageInput').val(),
  89. };
  90. if (isCodeAvailable(item.code)) {
  91. setEditFieldValues('', '', '', '', [], '');
  92. currentDataset.push(item);
  93. generateLine(item);
  94. }
  95. }
  96. }
  97. function editItem(elem) {
  98. if (isItemInputEmpty()) {
  99. let code = elem.id.replace('edit_', '');
  100. let item = getItemOfCode(code);
  101. setEditFieldValues(item.name, item.quantity, item.price, item.code, item.type, item.image);
  102. removeItemFromList(item); // Move the item in the edit fields
  103. }
  104. }
  105. function deleteItem(elem) {
  106. let code = elem.id.replace('delete_', '');
  107. let item = getItemOfCode(code);
  108. removeItemFromList(item);
  109. }
  110. function removeItemFromList(item) {
  111. currentDataset.splice(currentDataset.indexOf(item), 1);
  112. $('#row_' + item.code).remove();
  113. }
  114. function getTypesChecked() {
  115. let types = [];
  116. for (let i = 0; i < currentTypes.length; i++) {
  117. let id = 'typeCheck_' + currentTypes[i];
  118. if ($('#' + id).is(':checked')) {
  119. types.push(currentTypes[i]);
  120. }
  121. }
  122. return types;
  123. }
  124. function setTypesChecked(types) {
  125. for (let i = 0; i < currentTypes.length; i++) {
  126. let id = 'typeCheck_' + currentTypes[i];
  127. $('#' + id).prop('checked', types.indexOf(currentTypes[i]) !== -1);
  128. }
  129. return types;
  130. }
  131. function setEditFieldValues(name, quantity, price, code, type, image) {
  132. $.selector_cache('#nameInput').val(name);
  133. $.selector_cache('#quantityInput').val(quantity);
  134. $.selector_cache('#priceInput').val(price);
  135. $.selector_cache('#codeInput').val(code);
  136. $.selector_cache('#codeInput').val(code);
  137. setTypesChecked(type);
  138. $.selector_cache('#imageInput').val(image);
  139. }
  140. function isCodeAvailable (code) {
  141. let isAvailable = true;
  142. for (let i = 0; i < currentDataset.length; i++) {
  143. if (currentDataset[i].code === code) {
  144. isAvailable = false;
  145. break;
  146. }
  147. }
  148. return isAvailable;
  149. }
  150. function isItemInputEmpty() {
  151. return $.selector_cache('#nameInput').val() === '' &&
  152. $.selector_cache('#quantityInput').val() === '' &&
  153. $.selector_cache('#priceInput').val() === '' &&
  154. $.selector_cache('#codeInput').val() === '' &&
  155. $.selector_cache('#imageInput').val() === '' &&
  156. getTypesChecked().length === 0;
  157. }
  158. function isItemInputFilled() {
  159. return $.selector_cache('#nameInput').val() !== '' &&
  160. $.selector_cache('#quantityInput').val() !== '' &&
  161. $.selector_cache('#priceInput').val() !== '' &&
  162. $.selector_cache('#codeInput').val() !== '' &&
  163. $.selector_cache('#imageInput').val() !== '' &&
  164. getTypesChecked().length > 0;
  165. }
  166. function saveDataset() {
  167. let finalDataset = {
  168. types: currentTypes,
  169. articles: currentDataset
  170. };
  171. console.log(finalDataset);
  172. $.ajax({
  173. type: "POST",
  174. url: "write_json.php",
  175. data: JSON.stringify(finalDataset),
  176. dataType: "json",
  177. contentType: "application/json; charset=utf-8",
  178. complete: function (data) {
  179. alert(data.responseText);
  180. console.log(data);
  181. },
  182. });
  183. }