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 6.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219
  1. let currentDataset = [];
  2. let currentTypes = [];
  3. function initValuesFromPHPDump() {
  4. currentDataset = json_dump.articles; // json_dump is set using PHP
  5. currentTypes = json_dump.types;
  6. console.log(currentDataset);
  7. console.log(currentTypes);
  8. generateTable(currentDataset);
  9. }
  10. $(document).ready(function () {
  11. if (json_dump !== undefined) {
  12. initValuesFromPHPDump();
  13. generateTypeCheckboxes();
  14. }
  15. setEditFieldValues('', '', '', '', '', '', '');
  16. });
  17. function generateTable(dataset) {
  18. for (let i = 0; i < dataset.length; i++) {
  19. generateLine(dataset[i]);
  20. }
  21. }
  22. function generateLine(item) {
  23. $.selector_cache('#stockTable').append(
  24. '<tr id="row_' + item.code + '">' +
  25. '<td>' + item.name + '</td>' +
  26. '<td>' + item.description + '</td>' +
  27. '<td>' + item.quantity + '</td>' +
  28. '<td>' + item.price + '</td>' +
  29. '<td>' + item.code + '</td>' +
  30. '<td><span id="typeList_' + item.code + '"></span></td>' +
  31. '<td><a href="' + item.image + '" target="_blank"><img class="row-img" src="' + item.image + '"/></a></td>' +
  32. '<td>' +
  33. '<button class="btn btn-danger" id="delete_' + item.code + '" onclick="deleteItem(this)"><i class="fas fa-times"></i></button>' +
  34. '<button class="btn btn-primary" id="edit_' + item.code + '" onclick="editItem(this)"><i class="fas fa-edit"></i></button>' +
  35. '</td>' +
  36. '</tr>'
  37. );
  38. // Fill in the type cell
  39. for (let i = 0; i < item.type.length; i++) {
  40. let type = getTypeOfId(item.type[i]);
  41. $('#typeList_' + item.code).append(
  42. '<span class="mdi mdi-' + type.icon + '"></span>'
  43. );
  44. }
  45. }
  46. function generateTypeCheckboxes() {
  47. for (let i = 0; i < currentTypes.length; i++) {
  48. let id = 'typeCheck_' + currentTypes[i].id;
  49. $('#typeCheckboxesCell').append(
  50. '<div class="form-check">' +
  51. '<input type="checkbox" class="form-check-input" id="' + id + '">' +
  52. '<label class="form-check-label" for="' + id + '">' +
  53. '<span class="mdi mdi-' + currentTypes[i].icon + '"></span>' + currentTypes[i].name + '</label>' +
  54. '</div>'
  55. );
  56. }
  57. }
  58. function getTypeOfId(id) {
  59. let item = {};
  60. for (let i = 0; i < currentTypes.length; i++) {
  61. if (currentTypes[i].id === id) {
  62. item = currentTypes[i];
  63. break;
  64. }
  65. }
  66. return item;
  67. }
  68. function getItemOfCode(code) {
  69. let item = {};
  70. for (let i = 0; i < currentDataset.length; i++) {
  71. if (currentDataset[i].code === code) {
  72. item = currentDataset[i];
  73. break;
  74. }
  75. }
  76. return item;
  77. }
  78. function addNewItem() {
  79. if (isItemInputFilled()) {
  80. let item = {
  81. name: sanitizeString($.selector_cache('#nameInput').val()),
  82. description: sanitizeString($.selector_cache('#descriptionInput').val()),
  83. quantity: sanitizeNumber($.selector_cache('#quantityInput').val()),
  84. price: sanitizeNumber($.selector_cache('#priceInput').val()),
  85. code: $.selector_cache('#codeInput').val(),
  86. type: getTypesChecked(),
  87. image: $.selector_cache('#imageInput').val(),
  88. };
  89. if (isCodeAvailable(item.code)) {
  90. setEditFieldValues('', '', '', '', [], '', '');
  91. currentDataset.push(item);
  92. generateLine(item);
  93. }
  94. }
  95. }
  96. function editItem(elem) {
  97. if (isItemInputEmpty()) {
  98. let code = elem.id.replace('edit_', '');
  99. let item = getItemOfCode(code);
  100. setEditFieldValues(item.name, item.description, item.quantity, item.price, item.code, item.type, item.image);
  101. removeItemFromList(item); // Move the item in the edit fields
  102. }
  103. }
  104. function deleteItem(elem) {
  105. let code = elem.id.replace('delete_', '');
  106. let item = getItemOfCode(code);
  107. removeItemFromList(item);
  108. }
  109. function removeItemFromList(item) {
  110. currentDataset.splice(currentDataset.indexOf(item), 1);
  111. $('#row_' + item.code).remove();
  112. }
  113. function getTypesChecked() {
  114. let types = [];
  115. for (let i = 0; i < currentTypes.length; i++) {
  116. let id = 'typeCheck_' + currentTypes[i].id;
  117. if ($('#' + id).is(':checked')) {
  118. types.push(currentTypes[i].id);
  119. }
  120. }
  121. return types;
  122. }
  123. function setTypesChecked(types) {
  124. for (let i = 0; i < currentTypes.length; i++) {
  125. let id = 'typeCheck_' + currentTypes[i].id;
  126. $('#' + id).prop('checked', types.indexOf(currentTypes[i].id) !== -1);
  127. }
  128. return types;
  129. }
  130. function setEditFieldValues(name, description, quantity, price, code, type, image) {
  131. $.selector_cache('#nameInput').val(name);
  132. $.selector_cache('#descriptionInput').val(description);
  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('#descriptionInput').val() === '' &&
  153. $.selector_cache('#quantityInput').val() === '' &&
  154. $.selector_cache('#priceInput').val() === '' &&
  155. $.selector_cache('#codeInput').val() === '' &&
  156. $.selector_cache('#imageInput').val() === '' &&
  157. getTypesChecked().length === 0;
  158. }
  159. function isItemInputFilled() {
  160. return $.selector_cache('#nameInput').val() !== '' &&
  161. $.selector_cache('#descriptionInput').val() !== '' &&
  162. $.selector_cache('#quantityInput').val() !== '' &&
  163. $.selector_cache('#priceInput').val() !== '' &&
  164. $.selector_cache('#codeInput').val() !== '' &&
  165. $.selector_cache('#imageInput').val() !== '' &&
  166. getTypesChecked().length > 0;
  167. }
  168. function saveDataset() {
  169. SaveManager.saveData(currentTypes, currentDataset);
  170. }
  171. function sanitizeString(str) {
  172. return str.trim();
  173. }
  174. function sanitizeNumber(nbrStr) {
  175. return nbrStr.replace(/\s/g,'');
  176. }
  177. function scanArticle(code) {
  178. let data = {
  179. password: 'coucou',
  180. code : code,
  181. };
  182. $.ajax({
  183. type: "POST",
  184. url: "../ajax/scan_article.php",
  185. data: JSON.stringify(data),
  186. dataType: "json",
  187. contentType: "application/json; charset=utf-8",
  188. complete: function (data) {
  189. // alert(data.responseText);
  190. console.log(data.responseText);
  191. },
  192. });
  193. }