addCollectionWidget.js 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. (function ($) {
  2. $.fn.addCollection = function() {
  3. function requete(chemin, handleData) {
  4. $.ajax({
  5. url: chemin,
  6. type: 'POST',
  7. dataType: 'json',
  8. success: function (reponse) {
  9. let reponseArray = parseJson(reponse);
  10. handleData(reponseArray);
  11. }
  12. })
  13. }
  14. function parseJson(data) {
  15. let tableau = [];
  16. for (let i = 0; i < data.length; i++) {
  17. let UnObjetJson = data[i];
  18. let obj = JSON.parse(UnObjetJson);
  19. sortie = Object.values(obj)
  20. tableau.push(sortie[0]);
  21. }
  22. return tableau;
  23. }
  24. function addDeleteLink($prototype) {
  25. // Création du lien
  26. let $deleteLink = $('<button type="button" class="btn btn-outline-secondary"><i class="fa fa-trash fa-lg text-danger"></i></button>');
  27. // Ajout du lien
  28. $prototype.find(":input").after($deleteLink);
  29. // Ajout du listener sur le clic du lien pour effectivement supprimer la catégorie
  30. $deleteLink.on("click", function(e) {
  31. $prototype.remove();
  32. e.preventDefault(); // évite qu'un # apparaisse dans l'URL
  33. return false;
  34. });
  35. }
  36. this.each(function() {
  37. // Chemin pour la requête
  38. var chemin = $(this).data('path');
  39. // On récupère le fieldset pour ajouter les delete-link aux éléments existants
  40. var $container = $($(this).attr("data-list-selector"));
  41. $li = $container.find('li');
  42. $li.each(function() {
  43. $(this).find(':input').prop("readonly", true);
  44. addDeleteLink($(this));
  45. })
  46. $(this).on("click", function(e) {
  47. e.preventDefault();
  48. var list = jQuery(jQuery(this).attr('data-list-selector'));
  49. // Try to find the counter of the list or use the length of the list
  50. var counter = list.data('widget-counter') | list.children().length;
  51. // grab the prototype template
  52. var newWidget = list.attr('data-prototype');
  53. // replace the "__name__" used in the id and name of the prototype
  54. // with a number that's unique to your emails
  55. // end name attribute looks like name="contact[emails][2]"
  56. newWidget = newWidget.replace(/__name__/g, counter);
  57. // Increase the counter
  58. counter++;
  59. // And store it, the length cannot be used if deleting widgets is allowed
  60. list.data('widget-counter', counter);
  61. // create a new list element and add it to the list
  62. var newElem = jQuery(list.attr('data-widget-tags')).html(newWidget);
  63. requete (chemin, function(output) {
  64. newElem.find(':input').autocomplete({
  65. source: output
  66. });
  67. })
  68. addDeleteLink(newElem);
  69. newElem.appendTo(list);
  70. })
  71. })
  72. }
  73. })(jQuery);