Preparing assets
							parent
							
								
									eca2464430
								
							
						
					
					
						commit
						8fef71ef6c
					
				| @ -1,12 +1,18 @@ | |||||||
| //region CSS
 | //region CSS
 | ||||||
| import './styles/app.scss'; | import './styles/app.scss'; | ||||||
| //endregion
 | //endregion
 | ||||||
| //region Bootstrap
 |  | ||||||
| import 'bootstrap'; |  | ||||||
| //endregion
 |  | ||||||
| //region jQuery
 | //region jQuery
 | ||||||
| import 'jqueryLocal'; // Declare $ as a global variable, accessible in all files
 | import 'jqueryLocal'; // Declare $ as a global variable, accessible in all files
 | ||||||
| //endregion
 | //endregion
 | ||||||
|  | //region Bootstrap
 | ||||||
|  | import '@popperjs/core'; | ||||||
|  | import {Tooltip} from 'bootstrap'; | ||||||
|  | //region Tooltips
 | ||||||
|  | const tooltipTriggerList = document.querySelectorAll('[data-bs-toggle="tooltip"]'); | ||||||
|  | [...tooltipTriggerList].map(tooltipTriggerEl => new Tooltip(tooltipTriggerEl)); | ||||||
|  | //endregion
 | ||||||
|  | //endregion
 | ||||||
| //region FontAwesome
 | //region FontAwesome
 | ||||||
| import 'fontawesome'; | import 'fontawesome'; | ||||||
| //endregion
 | //endregion
 | ||||||
|  | import 'modalDynamic'; | ||||||
| @ -1,4 +1,15 @@ | |||||||
| { | { | ||||||
|     "controllers": {}, |     "controllers": { | ||||||
|  |         "@symfony/ux-turbo": { | ||||||
|  |             "turbo-core": { | ||||||
|  |                 "enabled": true, | ||||||
|  |                 "fetch": "eager" | ||||||
|  |             }, | ||||||
|  |             "mercure-turbo-stream": { | ||||||
|  |                 "enabled": false, | ||||||
|  |                 "fetch": "eager" | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     }, | ||||||
|     "entrypoints": [] |     "entrypoints": [] | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,148 +0,0 @@ | |||||||
| //region Datatables.net
 |  | ||||||
| import 'datatables.net'; |  | ||||||
| import 'datatables.net-dt/css/dataTables.dataTables.min.css'; |  | ||||||
| //endregion
 |  | ||||||
| //region Bootstrap 5 styling for Datatables.net
 |  | ||||||
| import 'datatables.net-bs5'; |  | ||||||
| import 'datatables.net-bs5/css/dataTables.bootstrap5.min.css'; |  | ||||||
| //endregion
 |  | ||||||
| //region Custom style for Datatables.net
 |  | ||||||
| import './styles/datatables.scss'; |  | ||||||
| //endregion
 |  | ||||||
| import 'jqueryLocal'; |  | ||||||
| 
 |  | ||||||
| $(function () { |  | ||||||
|     $('table.table-datatable').each(function () { |  | ||||||
|         const self = $(this); |  | ||||||
| 
 |  | ||||||
|         //region Options du datatable
 |  | ||||||
|         let options = { |  | ||||||
|             paging:     self.data('sortPaging', false), |  | ||||||
|             pageLength: self.data('sortPerPage', 50), |  | ||||||
|             processing: true, |  | ||||||
|             layout:     self.data( |  | ||||||
|                 'sortLayout', |  | ||||||
|                 { |  | ||||||
|                     topStart:    null, |  | ||||||
|                     topEnd:      null, |  | ||||||
|                     bottomStart: null, |  | ||||||
|                     bottomEnd:   'paging', |  | ||||||
|                 }, |  | ||||||
|             ), |  | ||||||
|         }; |  | ||||||
|         //endregion
 |  | ||||||
|         //region Gestion tri initial
 |  | ||||||
|         let initialSort = []; |  | ||||||
|         $('> thead > tr > th[data-sort-onLoad]', this).each(function () { |  | ||||||
|             let self = $(this); |  | ||||||
|             initialSort.push( |  | ||||||
|                 { |  | ||||||
|                     index:     self.index(), |  | ||||||
|                     priority:  self.data('sortOnload'), |  | ||||||
|                     direction: self.data('sortOrder', 'asc').toLowerCase(), |  | ||||||
|                 }, |  | ||||||
|             ); |  | ||||||
|         }); |  | ||||||
|         initialSort.sort(function (sort1, sort2) { |  | ||||||
|             if (sort1.priority === sort2.priority) { |  | ||||||
|                 return sort1.index - sort2.index; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             return sort1.priority - sort2.priority; |  | ||||||
|         }); |  | ||||||
| 
 |  | ||||||
|         if (initialSort.length > 0) { |  | ||||||
|             options.order = []; |  | ||||||
|             initialSort.forEach(function (sortOrder) { |  | ||||||
|                 options.order.push([sortOrder.index, sortOrder.direction]); |  | ||||||
|             }); |  | ||||||
|         } |  | ||||||
|         //endregion
 |  | ||||||
|         //region Gestion sens de tri (1er clic ou initial si concerné)
 |  | ||||||
|         let descSort = []; |  | ||||||
|         $('> thead > tr > th[data-sort-order]', this).each(function () { |  | ||||||
|             const self = $(this); |  | ||||||
|             if (self.data('sortOrder', 'asc').toLowerCase() === 'desc') { |  | ||||||
|                 descSort.push(self.index()); |  | ||||||
|             } |  | ||||||
|         }); |  | ||||||
|         if (descSort.length > 0) { |  | ||||||
|             if (!options.hasOwnProperty('columnDefs')) { |  | ||||||
|                 options.columnDefs = []; |  | ||||||
|             } |  | ||||||
|             options.columnDefs.push( |  | ||||||
|                 { |  | ||||||
|                     targets:       descSort, |  | ||||||
|                     orderSequence: ['desc', 'asc'], |  | ||||||
|                 }, |  | ||||||
|             ); |  | ||||||
|         } |  | ||||||
|         //endregion
 |  | ||||||
|         //region Gestion désactivation tri
 |  | ||||||
|         let disabledSort = []; |  | ||||||
|         $('> thead > tr > th[data-sort]', this).each(function () { |  | ||||||
|             const self = $(this); |  | ||||||
|             if (!self.data('sort', true)) { |  | ||||||
|                 disabledSort.push(self.index()); |  | ||||||
|             } |  | ||||||
|         }); |  | ||||||
|         if (disabledSort.length > 0) { |  | ||||||
|             if (!options.hasOwnProperty('columnDefs')) { |  | ||||||
|                 options.columnDefs = []; |  | ||||||
|             } |  | ||||||
|             options.columnDefs.push( |  | ||||||
|                 { |  | ||||||
|                     targets:   disabledSort, |  | ||||||
|                     orderable: false, |  | ||||||
|                 }, |  | ||||||
|             ); |  | ||||||
|         } |  | ||||||
|         //endregion
 |  | ||||||
|         //region Gestion nom des colonnes
 |  | ||||||
|         const columnsName = $('> thead > tr > th[data-sort-name]', this); |  | ||||||
|         if (columnsName.length > 0) { |  | ||||||
|             if (!options.hasOwnProperty('columnDefs')) { |  | ||||||
|                 options.columnDefs = []; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             columnsName.each(function () { |  | ||||||
|                 const self = $(this); |  | ||||||
|                 const name = self.data('sortName', ''); |  | ||||||
|                 if (name !== '') { |  | ||||||
|                     options.columnDefs.push( |  | ||||||
|                         { |  | ||||||
|                             targets: self.index(), |  | ||||||
|                             name:    name, |  | ||||||
|                         }, |  | ||||||
|                     ); |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
|         } |  | ||||||
|         //endregion
 |  | ||||||
|         //region Gestion de AJAX
 |  | ||||||
|         const ajaxUrl = self.data('sortAjax', false); |  | ||||||
|         if (ajaxUrl !== false) { |  | ||||||
|             options.serverSide = true; |  | ||||||
|             options.ajax = { |  | ||||||
|                 url:  ajaxUrl, |  | ||||||
|                 type: 'POST', |  | ||||||
|                 //createCDATASection: '',
 |  | ||||||
|                 cache: self.data('sortAjaxCache', false), |  | ||||||
|             }; |  | ||||||
| 
 |  | ||||||
|             options.columns = []; |  | ||||||
|             columnsName.each(function () { |  | ||||||
|                 const self = $(this); |  | ||||||
|                 const name = self.data('sortName', ''); |  | ||||||
|                 if (name !== '') { |  | ||||||
|                     options.columns[self.index()] = { |  | ||||||
|                         data: name, |  | ||||||
|                     }; |  | ||||||
|                 } |  | ||||||
|             }); |  | ||||||
|         } |  | ||||||
|         //endregion
 |  | ||||||
| 
 |  | ||||||
|         self.DataTable(options); |  | ||||||
|     }); |  | ||||||
| }); |  | ||||||
| @ -0,0 +1,329 @@ | |||||||
|  | //region Datatables.net
 | ||||||
|  | import 'datatables.net'; | ||||||
|  | import 'datatables.net-dt/css/dataTables.dataTables.min.css'; | ||||||
|  | //endregion
 | ||||||
|  | //region Bootstrap 5 styling for Datatables.net
 | ||||||
|  | import 'datatables.net-bs5'; | ||||||
|  | import 'datatables.net-bs5/css/dataTables.bootstrap5.min.css'; | ||||||
|  | //endregion
 | ||||||
|  | //region Custom style for Datatables.net
 | ||||||
|  | import './styles/datatables2.scss'; | ||||||
|  | //endregion
 | ||||||
|  | import 'jqueryLocal'; | ||||||
|  | import Utils from 'utils'; | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * Chargement automatique des éléments : tableaux, {@link https://datatables.net/ DataTables (v2)}
 | ||||||
|  |  * | ||||||
|  |  * Valide seulement si le JS "DataTable" est bien présent\ | ||||||
|  |  * S'instancie automatiquement sur les <table class="table-datatable2"> | ||||||
|  |  * | ||||||
|  |  * Options : | ||||||
|  |  * * table : | ||||||
|  |  *     * data-sort-paging : boolean\ | ||||||
|  |  *             Pagination gérée ?\ | ||||||
|  |  *             Défaut : faux | ||||||
|  |  *     * data-sort-per-page : integer\ | ||||||
|  |  *             Nombre d'éléments par défaut par page\ | ||||||
|  |  *             Défaut : 50 | ||||||
|  |  *     * data-sort-layout : string (JSON)\ | ||||||
|  |  *             Le JSON du modèle du tableau (https://datatables.net/reference/option/layout)\
 | ||||||
|  |  *             Défaut : pagination (si active) en bas à droite | ||||||
|  |  *     * data-sort-ajax : string|false\ | ||||||
|  |  *             Faux si pas de requête AJAX géré\ | ||||||
|  |  *             Sinon l'URL AJAX appelée\ | ||||||
|  |  *                     Bien penser à définir les "data-sort-name" sur les <th>\ | ||||||
|  |  *             Défaut : false | ||||||
|  |  *     * data-sort-ajax-type : string\ | ||||||
|  |  *             Le type de la requête AJAX (GET, POST, etc.)\ | ||||||
|  |  *             Défaut : POST | ||||||
|  |  *     * data-sort-ajax-cache : boolean\ | ||||||
|  |  *             Mise en cache du résultat des requêtes AJAX ?\ | ||||||
|  |  *             Défaut : faux | ||||||
|  |  *     * data-sort-lang : string (JSON)\ | ||||||
|  |  *             Le JSON des traductions | ||||||
|  |  *     * data-sort-lang-url : string (url)\ | ||||||
|  |  *             L'URL renvoyant le JSON des traductions\ | ||||||
|  |  *             Ignore si "data-sort-lang" renseigné | ||||||
|  |  *     * data-sort-lang-code : string\ | ||||||
|  |  *             Code langue (plugin, voir https://datatables.net/plug-ins/i18n/French.html#Browser-loading-/-CDN)\
 | ||||||
|  |  *                     Exemple avec "fr-FR" : chargera "//cdn.datatables.net/plug-ins/2.2.2/i18n/fr-FR.json"\ | ||||||
|  |  *             Ignoré si "data-sort-lang" ou "data-sort-lang-url" est renseigné | ||||||
|  |  *     * data-sort-child : string (HTML)|false\ | ||||||
|  |  *             Faux si pas de lignes enfants gérées\ | ||||||
|  |  *             Sinon le contenu HTML de la ligne enfant\ | ||||||
|  |  *             Ignoré si supplanté par la version sur les <tr>\ | ||||||
|  |  *             Défaut : false | ||||||
|  |  *     * data-sort-child-ajax : string (url)|false\ | ||||||
|  |  *             Faux si pas de lignes enfants gérées\ | ||||||
|  |  *             L'URL des requêtes AJAX pour les lignes enfants\ | ||||||
|  |  *             Ignoré si "data-sort-child" est renseigné ou supplanté par la version sur les <tr>\ | ||||||
|  |  *             Défaut : false | ||||||
|  |  *     * data-sort-child-ajax-type : string\ | ||||||
|  |  *             Le type de la requête AJAX pour les lignes enfants (GET, POST, etc.)\ | ||||||
|  |  *             Ignoré si supplanté par la version sur les <tr>\ | ||||||
|  |  *             Défaut : POST | ||||||
|  |  *     * data-sort-child-ajax-cache : boolean\ | ||||||
|  |  *             Mise en cache du résultat des requêtes AJAX pour les lignes enfants ?\ | ||||||
|  |  *             Ignoré si supplanté par la version sur les <tr>\ | ||||||
|  |  *             Défaut : faux | ||||||
|  |  * * thead th : | ||||||
|  |  *     * data-sort-onLoad : integer\ | ||||||
|  |  *             Ordre de tri de la colonne pour le tri initial/au chargement | ||||||
|  |  *     * data-sort-order : string ("asc", "desc")\ | ||||||
|  |  *             Sens du tri de la colonne lors du 1er clic (et lors du tri initial/au chargement si "data-sort-onLoad" également renseigné) | ||||||
|  |  *     * data-sort : boolean\ | ||||||
|  |  *             Activer le tri sur la colonne ?\ | ||||||
|  |  *             Défaut : vrai | ||||||
|  |  *     * data-sort-name : string\ | ||||||
|  |  *             Le nom de la colonne dans la source de données (AJAX : cf. data-sort-ajax) | ||||||
|  |  *     * data-sort-name-value : boolean\ | ||||||
|  |  *             La colonne à une valeur de tri différente de son affichage ?\ | ||||||
|  |  *             Si vrai attends une paire display/sort dans le JSON (exemple : https://datatables.net/examples/ajax/orthogonal-data.html)\
 | ||||||
|  |  *                     Cf. SolulogSAS\BaseSite\Web\DataTables2_ColumnWithSortValue\ | ||||||
|  |  *             Défaut : faux | ||||||
|  |  *     * data-sort-child : string (HTML)|false\ | ||||||
|  |  *             Faux si pas de lignes enfants gérées\ | ||||||
|  |  *             Sinon le contenu HTML de la ligne enfant\ | ||||||
|  |  *             Défaut : false | ||||||
|  |  *     * data-sort-child-ajax : string (url)|false\ | ||||||
|  |  *             Faux si pas de lignes enfants gérées\ | ||||||
|  |  *             L'URL des requêtes AJAX pour les lignes enfants\ | ||||||
|  |  *             Ignoré si "data-sort-child" est renseigné\ | ||||||
|  |  *             Défaut : false | ||||||
|  |  *     * data-sort-child-ajax-id : any\ | ||||||
|  |  *             L'ID ajax de la ligne enfant (transmis dans "ajaxId")\ | ||||||
|  |  *             Défaut : {néant} | ||||||
|  |  *     * data-sort-child-ajax-type : string\ | ||||||
|  |  *             Le type de la requête AJAX pour les lignes enfants (GET, POST, etc.)\ | ||||||
|  |  *             Défaut : POST | ||||||
|  |  *     * data-sort-child-ajax-cache : boolean\ | ||||||
|  |  *             Mise en cache du résultat des requêtes AJAX pour les lignes enfants ?\ | ||||||
|  |  *             Défaut : faux | ||||||
|  |  * * tbody td : | ||||||
|  |  *     * data-order : any\ | ||||||
|  |  *             La valeur utilisée pour le tri | ||||||
|  |  *     * data-filter : any\ | ||||||
|  |  *             La valeur utilisée pour le filtrage | ||||||
|  |  * | ||||||
|  |  * @param {Document|jQuery} page | ||||||
|  |  */ | ||||||
|  | function datatables2 (page) { | ||||||
|  |     $('table.table-datatable2', page).each(function () { | ||||||
|  |         const self = $(this); | ||||||
|  | 
 | ||||||
|  |         //region Options du datatable
 | ||||||
|  |         let options = { | ||||||
|  |             paging:     self.dataDefault('sortPaging', false), | ||||||
|  |             pageLength: self.dataDefault('sortPerPage', 50), | ||||||
|  |             processing: true, | ||||||
|  |             layout: | ||||||
|  |                         self.dataDefault('sortLayout', | ||||||
|  |                                          { | ||||||
|  |                                              topStart:    null, | ||||||
|  |                                              topEnd:      null, | ||||||
|  |                                              bottomStart: null, | ||||||
|  |                                              bottomEnd:   'paging', | ||||||
|  |                                          }, | ||||||
|  |                         ), | ||||||
|  |         }; | ||||||
|  |         //endregion
 | ||||||
|  |         //region Gestion traduction
 | ||||||
|  |         let lang = self.dataDefault('sortLang', undefined); | ||||||
|  |         if (Utils.isUndefined(lang)) { | ||||||
|  |             let langUrl = self.dataDefault('sortLangUrl', undefined); | ||||||
|  |             if (Utils.isUndefined(langUrl)) { | ||||||
|  |                 const langCode = self.dataDefault('sortLangCode', undefined); | ||||||
|  |                 if (!Utils.isUndefined(langCode)) { | ||||||
|  |                     langUrl = '//cdn.datatables.net/plug-ins/2.2.2/i18n/' + langCode + '.json'; | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |             if (!Utils.isUndefined(langUrl)) { | ||||||
|  |                 lang = {url: langUrl}; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         if (!Utils.isUndefined(lang)) { | ||||||
|  |             options.language = lang; | ||||||
|  |         } | ||||||
|  |         //endregion
 | ||||||
|  |         //region Gestion tri initial
 | ||||||
|  |         let initialSort = []; | ||||||
|  |         $('> thead > tr > th[data-sort-onLoad]', self).each(function () { | ||||||
|  |             let self = $(this); | ||||||
|  |             initialSort.push( | ||||||
|  |                 { | ||||||
|  |                     index:     self.index(), | ||||||
|  |                     priority:  self.dataDefault('sortOnload', 0), | ||||||
|  |                     direction: self.dataDefault('sortOrder', 'asc').toLowerCase(), | ||||||
|  |                 }, | ||||||
|  |             ); | ||||||
|  |         }); | ||||||
|  |         initialSort.sort(function (sort1, sort2) { | ||||||
|  |             if (sort1.priority === sort2.priority) { | ||||||
|  |                 return sort1.index - sort2.index; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return sort1.priority - sort2.priority; | ||||||
|  |         }); | ||||||
|  | 
 | ||||||
|  |         if (initialSort.length > 0) { | ||||||
|  |             options.order = []; | ||||||
|  |             initialSort.forEach(function (sortOrder) { | ||||||
|  |                 options.order.push([sortOrder.index, sortOrder.direction]); | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |         //endregion
 | ||||||
|  |         //region Gestion sens de tri (1er clic ou initial si concerné)
 | ||||||
|  |         let descSort = []; | ||||||
|  |         $('> thead > tr > th[data-sort-order]', self).each(function () { | ||||||
|  |             const self = $(this); | ||||||
|  |             if (self.dataDefault('sortOrder', 'asc').toLowerCase() === 'desc') { | ||||||
|  |                 descSort.push(self.index()); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |         if (descSort.length > 0) { | ||||||
|  |             if (!options.hasOwnProperty('columnDefs')) { | ||||||
|  |                 options.columnDefs = []; | ||||||
|  |             } | ||||||
|  |             options.columnDefs.push( | ||||||
|  |                 { | ||||||
|  |                     targets:       descSort, | ||||||
|  |                     orderSequence: ['desc', 'asc'], | ||||||
|  |                 }, | ||||||
|  |             ); | ||||||
|  |         } | ||||||
|  |         //endregion
 | ||||||
|  |         //region Gestion désactivation tri
 | ||||||
|  |         let disabledSort = []; | ||||||
|  |         $('> thead > tr > th[data-sort]', self).each(function () { | ||||||
|  |             const self = $(this); | ||||||
|  |             if (!self.dataDefault('sort', true)) { | ||||||
|  |                 disabledSort.push(self.index()); | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |         if (disabledSort.length > 0) { | ||||||
|  |             if (!options.hasOwnProperty('columnDefs')) { | ||||||
|  |                 options.columnDefs = []; | ||||||
|  |             } | ||||||
|  |             options.columnDefs.push( | ||||||
|  |                 { | ||||||
|  |                     targets:   disabledSort, | ||||||
|  |                     orderable: false, | ||||||
|  |                 }, | ||||||
|  |             ); | ||||||
|  |         } | ||||||
|  |         //endregion
 | ||||||
|  |         //region Gestion nom des colonnes
 | ||||||
|  |         const columnsName = $('> thead > tr > th[data-sort-name]', self); | ||||||
|  |         if (columnsName.length > 0) { | ||||||
|  |             if (!options.hasOwnProperty('columnDefs')) { | ||||||
|  |                 options.columnDefs = []; | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             columnsName.each(function () { | ||||||
|  |                 const self = $(this); | ||||||
|  |                 const name = self.dataDefault('sortName', ''); | ||||||
|  |                 if (name !== '') { | ||||||
|  |                     options.columnDefs.push( | ||||||
|  |                         { | ||||||
|  |                             targets: self.index(), | ||||||
|  |                             name:    name, | ||||||
|  |                         }, | ||||||
|  |                     ); | ||||||
|  |                 } | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |         //endregion
 | ||||||
|  |         //region Gestion de AJAX
 | ||||||
|  |         const ajaxUrl = self.dataDefault('sortAjax', false); | ||||||
|  |         if (ajaxUrl !== false) { | ||||||
|  |             options.serverSide = true; | ||||||
|  |             options.ajax = { | ||||||
|  |                 url:   ajaxUrl, | ||||||
|  |                 type: self.dataDefault('sortAjaxType', 'POST'), | ||||||
|  |                 cache: self.dataDefault('sortAjaxCache', false), | ||||||
|  |             }; | ||||||
|  | 
 | ||||||
|  |             options.columns = []; | ||||||
|  |             columnsName.each(function () { | ||||||
|  |                 const self = $(this); | ||||||
|  |                 const name = self.dataDefault('sortName', ''); | ||||||
|  |                 const nameValue = self.dataDefault('sortNameValue', false); | ||||||
|  |                 if (name !== '') { | ||||||
|  |                     options.columns[self.index()] = { | ||||||
|  |                         data: nameValue | ||||||
|  |                                   ? {_: name + '.display', sort: name + '.sort'} | ||||||
|  |                                   : name, | ||||||
|  |                     }; | ||||||
|  |                 } | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |         //endregion
 | ||||||
|  | 
 | ||||||
|  |         const datatable = self.DataTable(options); | ||||||
|  | 
 | ||||||
|  |         //region Gestion lignes enfants
 | ||||||
|  |         const child = self.dataDefault('sortChild', false); | ||||||
|  |         const childAjaxUrl = self.dataDefault('sortChildAjax', false); | ||||||
|  |         const childAjaxType = self.dataDefault('sortChildAjaxType', 'POST'); | ||||||
|  |         const childAjaxCache = self.dataDefault('sortChildAjaxCache', false); | ||||||
|  | 
 | ||||||
|  |         if (child === true || childAjaxUrl !== false) { | ||||||
|  |             const showData = function (dtRow, childData) { | ||||||
|  |                 const parentHtml = '<div></div>'; | ||||||
|  |                 const childJquery = $(parentHtml).append(childData); | ||||||
|  |                 datatables2(childJquery); | ||||||
|  | 
 | ||||||
|  |                 //noinspection JSUnresolvedReference
 | ||||||
|  |                 dtRow.child(childJquery).show(); | ||||||
|  |             }; | ||||||
|  |             self.on('click', '> tbody > tr:not([data-dt-row!=""][data-dt-row]) > td', function () { | ||||||
|  |                 //region Obtention ligne
 | ||||||
|  |                 const row = $(this).parents('tr').first(); | ||||||
|  |                 const dtRow = datatable.row(row); | ||||||
|  |                 //endregion
 | ||||||
|  |                 //region Lignes enfants déjà affichées ? Les masques
 | ||||||
|  |                 //noinspection JSUnresolvedReference
 | ||||||
|  |                 if (dtRow.child.isShown()) { | ||||||
|  |                     //noinspection JSUnresolvedReference
 | ||||||
|  |                     dtRow.child.hide(); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |                 //endregion
 | ||||||
|  | 
 | ||||||
|  |                 //region Données enfants directement spécifiées
 | ||||||
|  |                 const childData = row.dataDefault('sortChild', false); | ||||||
|  |                 if (childData !== false) { | ||||||
|  |                     showData(dtRow, childData); | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  |                 //endregion
 | ||||||
|  |                 //region Données enfants via AJAX
 | ||||||
|  |                 const rowChildAjaxUrl = row.dataDefault('sortChildAjax', childAjaxUrl); | ||||||
|  |                 if (Utils.isUndefined(rowChildAjaxUrl) || rowChildAjaxUrl === false) { | ||||||
|  |                     return; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |                 $.ajax( | ||||||
|  |                     { | ||||||
|  |                         type:  row.dataDefault('sortChildAjaxType', childAjaxType), | ||||||
|  |                         url:   rowChildAjaxUrl, | ||||||
|  |                         data:  { | ||||||
|  |                             ajaxId: row.dataDefault('sortChildAjaxId', undefined), | ||||||
|  |                         }, | ||||||
|  |                         cache: row.dataDefault('sortChildAjaxCache', childAjaxCache), | ||||||
|  |                     }, | ||||||
|  |                 ) | ||||||
|  |                     .done(childData => { | ||||||
|  |                         showData(dtRow, childData); | ||||||
|  |                     }); | ||||||
|  |                 //endregion
 | ||||||
|  |             }); | ||||||
|  |         } | ||||||
|  |         //endregion
 | ||||||
|  |     }); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | $(function () { | ||||||
|  |     datatables2(document); | ||||||
|  | }); | ||||||
| @ -0,0 +1,26 @@ | |||||||
|  | import 'bootstrap'; | ||||||
|  | import 'jqueryLocal'; | ||||||
|  | import Utils from 'utils'; | ||||||
|  | 
 | ||||||
|  | $(function () { | ||||||
|  |     $('.modal-dynamic').on('show.bs.modal', function (event) { | ||||||
|  |         const dialog = $(this); | ||||||
|  |         const sender = $(event.relatedTarget); | ||||||
|  | 
 | ||||||
|  |         const title = sender.dataDefault('modalDynamicTitle'); | ||||||
|  |         const body = sender.dataDefault('modalDynamicBody'); | ||||||
|  |         const linkUrl = sender.dataDefault('modalDynamicLinkUrl', sender.matchTag('a') ? sender.attr('href') : undefined); | ||||||
|  | 
 | ||||||
|  |         if (!Utils.isUndefined(title)) { | ||||||
|  |             $('.modal-title', dialog).html(title); | ||||||
|  |         } | ||||||
|  |         if (!Utils.isUndefined(body)) { | ||||||
|  |             $('.modal-body', dialog).html(body); | ||||||
|  |         } | ||||||
|  |         if (!Utils.isUndefined(linkUrl)) { | ||||||
|  |             $('a.modal-confirm-link', dialog).attr('href', linkUrl); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         return true; | ||||||
|  |     }); | ||||||
|  | }); | ||||||
| @ -1,36 +0,0 @@ | |||||||
| table.dataTable thead > tr > th.dt-orderable-asc span.dt-column-order::after, |  | ||||||
| table.dataTable thead > tr > th.dt-orderable-desc span.dt-column-order::after, |  | ||||||
| table.dataTable thead > tr > th.dt-ordering-asc span.dt-column-order::after, |  | ||||||
| table.dataTable thead > tr > th.dt-ordering-desc span.dt-column-order::after, |  | ||||||
| table.dataTable thead > tr > td.dt-orderable-asc span.dt-column-order::after, |  | ||||||
| table.dataTable thead > tr > td.dt-orderable-desc span.dt-column-order::after, |  | ||||||
| table.dataTable thead > tr > td.dt-ordering-asc span.dt-column-order::after, |  | ||||||
| table.dataTable thead > tr > td.dt-ordering-desc span.dt-column-order::after { |  | ||||||
|     margin-top : 3px; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| table.dataTable thead > tr > th.dt-orderable-asc span.dt-column-order, |  | ||||||
| table.dataTable thead > tr > th.dt-orderable-desc span.dt-column-order, |  | ||||||
| table.dataTable thead > tr > th.dt-ordering-asc span.dt-column-order, |  | ||||||
| table.dataTable thead > tr > th.dt-ordering-desc span.dt-column-order, |  | ||||||
| table.dataTable thead > tr > td.dt-orderable-asc span.dt-column-order, |  | ||||||
| table.dataTable thead > tr > td.dt-orderable-desc span.dt-column-order, |  | ||||||
| table.dataTable thead > tr > td.dt-ordering-asc span.dt-column-order, |  | ||||||
| table.dataTable thead > tr > td.dt-ordering-desc span.dt-column-order { |  | ||||||
|     position : relative; |  | ||||||
|     left     : 10px; |  | ||||||
|     top      : none; |  | ||||||
|     bottom   : none; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| div.dt-container .dt-paging .dt-paging-button { |  | ||||||
|     padding : 0; |  | ||||||
|     margin  : 0; |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| table.dataTable th.dt-type-numeric, |  | ||||||
| table.dataTable th.dt-type-date, |  | ||||||
| table.dataTable td.dt-type-numeric, |  | ||||||
| table.dataTable td.dt-type-date { |  | ||||||
|     text-align : left; |  | ||||||
| } |  | ||||||
| @ -0,0 +1,35 @@ | |||||||
|  | table.table-datatable2 { | ||||||
|  |     & > thead > tr { | ||||||
|  |         & > th.dt-orderable-asc span.dt-column-title { | ||||||
|  |             margin-right : 5px; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         & > th.dt-orderable-asc span.dt-column-order, | ||||||
|  |         & > th.dt-orderable-desc span.dt-column-order { | ||||||
|  |             position : relative; | ||||||
|  |             left     : 0; | ||||||
|  |             top      : 0; | ||||||
|  |             bottom   : 0; | ||||||
|  | 
 | ||||||
|  |             &::after { | ||||||
|  |                 margin-top : 3px; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     & > tbody > tr[data-dt-row]:not([data-dt-row='']) > td { | ||||||
|  |         padding : 0.75rem; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     div.dt-container .dt-paging .dt-paging-button { | ||||||
|  |         padding : 0; | ||||||
|  |         margin  : 0; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     th.dt-type-numeric, | ||||||
|  |     th.dt-type-date, | ||||||
|  |     td.dt-type-numeric, | ||||||
|  |     td.dt-type-date { | ||||||
|  |         text-align : left; | ||||||
|  |     } | ||||||
|  | } | ||||||
| @ -0,0 +1,5 @@ | |||||||
|  | symfonycasts_sass: | ||||||
|  |     # Path to your Sass root file | ||||||
|  |     root_sass: | ||||||
|  |         - '%kernel.project_dir%/assets/styles/app.scss' | ||||||
|  |         - '%kernel.project_dir%/assets/styles/datatables2.scss' | ||||||
					Loading…
					
					
				
		Reference in New Issue
	
	 Julien Rosset
						Julien Rosset