projects/genea/out/phpui/edit_source.php
1.
<?php
2.
 
3.
/*
4.
 
5.
        Formulaire d'édition pour la table : source.
6.
 
7.
        07/03/2021 10:45
8.
 
9.
        lvardon@laposte.net - 2021
10.
         
11.
        Licence libre
12.
 
13.
*/
14.
 
15.
include_once "dbconnect.php";
16.
include_once "phpdb/class_source.php";
17.
include_once "phpdb/class_source_ext.php";
18.
 
19.
if (isset($_REQUEST['a_id_value']))    $id=$_REQUEST['a_id_value'];
20.
else 
21.
    if (isset($_REQUEST['id']))    $id=$_REQUEST['id'];
22.
    else die("Erreur : _REQUEST['id'] est manquant.");  
23.
                
24.
if (isset($_REQUEST['offset']))
25.
    $offset=$_REQUEST['offset'];
26.
else 
27.
    $offset '';
28.
 
29.
$userUiMessage="";
30.
  
31.
// Class instance
32.
$mysource = new source$db );
33.
 
34.
  
35.
// Traitement des fichiers télédéposés
36.
 
37.
if ( isset($_REQUEST['a_icon_deletebefore']) && file_exists($_REQUEST["a_icon"])) {    
38.
    unlink($_REQUEST['a_icon']);
39.
    $_REQUEST['a_icon'] = '';
40.
}
41.
if(isset($_FILES['a_icon']) && $_FILES['a_icon']['name'] != '' ){
42.
 
43.
      $errors= array();
44.
      $file_name $_FILES['a_icon']['name'];
45.
      $file_size $_FILES['a_icon']['size'];
46.
      $file_tmp $_FILES['a_icon']['tmp_name'];
47.
      $file_type $_FILES['a_icon']['type'];
48.
      $file_ext=strtolower(end(explode('.',$_FILES['a_icon']['name'])));
49.
           
50.
      $extensions= array( 'jpeg''jpg''png' );
51.
      
52.
      if(in_array($file_ext,$extensions)=== false){
53.
         $errors[]="Extensions autorisées : 'jpeg', 'jpg', 'png'.";
54.
      }
55.
      
56.
      if($file_size 2097152 ) {
57.
         $errors[]='Taille maximum fichier : 2097152 octets.';
58.
      }
59.
      
60.
      if(empty($errors)==true) {
61.
        $dest_dir="documents/icons/";
62.
                    
63.
        if ( file_exists($_REQUEST['a_icon'] ) ) {
64.
            $userUiMessage='<div class="editmessageError">Le fichier existe déjà : '.$_REQUEST["a_icon"].'</div>';
65.
        }
66.
        else {
67.
            move_uploaded_file($file_tmp,$dest_dir.$file_name);
68.
            $_REQUEST['a_icon']= $dest_dir.$file_name// Database url doc update        
69.
            $userUiMessage .= '<div class="editmessageInfo">Fichier déposé : '.$dest_dir.$file_name.'</div>';        
70.
        }
71.
      }else{
72.
        $userUiMessage .= '<div class="editmessageError">';    
73.
        $userUiMessage .= 'Erreur upload :';
74.
        foreach ($errors as $verr) {
75.
            $userUiMessage .= $verr.'<br>';
76.
        }        
77.
        $userUiMessage .= '</div>';                  
78.
      }
79.
}   
80.
 
81.
 
82.
$sqlError false;
83.
 
84.
// Sauvegarde 
85.
if(isset($_POST['submitSave'])) 
86.
87.
    if ($id 0) {
88.
        $results $mysource->update
89.
$_REQUEST["a_id"], 
90.
$_REQUEST["a_name"], 
91.
$_REQUEST["a_description"], 
92.
$_REQUEST["a_private"], 
93.
$_REQUEST["a_category"], 
94.
$_REQUEST["a_icon"], 
95.
$_REQUEST["a_sourcetext"], 
96.
$_REQUEST["a_sourceurl"], 
97.
$_REQUEST["a_quality"], 
98.
$_REQUEST["a_page"], 
99.
$_REQUEST["a_citation"], 
100.
$_REQUEST["a_textdraduction"], 
101.
$_REQUEST["a_notesearch"], 
102.
$_REQUEST["a_datecreated"] ); 
103.
 
104.
        if ($results === false) {           
105.
            $userUiMessage .= '<div class="editmessageError">Erreur sauvegarde (id='.$id.') :'.$mysource->lasterror.'</div>';        
106.
            $sqlError true;
107.
        }
108.
        else 
109.
            $userUiMessage .= '<div class="editmessageInfo">Sauvegarde effectuée (id='.$id.')</div>';        
110.
    }
111.
    else 
112.
    {
113.
        $results $mysource->insert
114.
$_REQUEST["a_name"], 
115.
$_REQUEST["a_description"], 
116.
$_REQUEST["a_private"], 
117.
$_REQUEST["a_category"], 
118.
$_REQUEST["a_icon"], 
119.
$_REQUEST["a_sourcetext"], 
120.
$_REQUEST["a_sourceurl"], 
121.
$_REQUEST["a_quality"], 
122.
$_REQUEST["a_page"], 
123.
$_REQUEST["a_citation"], 
124.
$_REQUEST["a_textdraduction"], 
125.
$_REQUEST["a_notesearch"], 
126.
$_REQUEST["a_datecreated"]  ); 
127.
        echo '<div class="editmessage">';
128.
        if ($results === false) {
129.
            $userUiMessage .= '<div class="editmessageError">Erreur de création :'.$mysource->lasterror.'</div>';        
130.
            $sqlError true;
131.
        }
132.
        else {
133.
            $id=$mysource->lastInsertId;
134.
            $userUiMessage .= '<div class="editmessageInfo">Création effectuée (id='.$id.')</div>';
135.
        }        
136.
    }
137.
}
138.
 
139.
// Suppression
140.
if(isset($_POST['submitDelete'])) 
141.
142.
    if ($id 0) {
143.
        $results $mysource->delete$id ); 
144.
 
145.
        if ($results === false) {
146.
            $userUiMessage .= '<div class="editmessageError">Erreur Suppression (id='.$id.') :'.$mysource->lasterror.'</div>';
147.
            $sqlError true;
148.
        }
149.
        else {
150.
            $userUiMessage .= '<div class="editmessageInfo">Suppression effectuée (id='.$id.')</div>';
151.
            $id = -1;
152.
        }
153.
        
154.
    }
155.
}
156.
 
157.
// Select reccord by id :
158.
if ($sqlError === false ) {
159.
    
160.
    if ( isset($_POST['submitSave']) || isset($_POST['submitDelete']) ) 
161.
        $results $mysource->select$id );
162.
    else {
163.
        switch ($offset) {
164.
            case '_PREV':
165.
                $results $mysource->selectPrev$id );
166.
                $id $results[0]['a.id'];
167.
                break;
168.
            case '_NEXT':
169.
                $results $mysource->selectNext$id );
170.
                $id $results[0]['a.id'];
171.
                break;
172.
            default:
173.
                $results $mysource->select$id );
174.
                break;
175.
        }                
176.
    }
177.
        
178.
    if ($results === false) {           
179.
        $userUiMessage .= '<div class="editmessageError">Erreur Sql : '.$mysource->lasterror.'</div>';        
180.
        $sqlError true;
181.
    }
182.
    /*if ( empty($results) ) {           
183.
        $userUiMessage .= '<div class="editmessageInfo">Cet enregistrement n\'existe plus. id = '.$id.'  </div>';        
184.
        $sqlError = true;
185.
    }
186.
    */    
187.
}
188.
else {     
189.
        $results[0]["a.id"] = $_REQUEST['a_id'];    
190.
        $results[0]["a.quality"] = $_REQUEST['a_quality'];
191.
        $results[0]["a.page"] = $_REQUEST['a_page'];
192.
        $results[0]["a.name"] = $_REQUEST['a_name'];
193.
        $results[0]["a.description"] = $_REQUEST['a_description'];
194.
        $results[0]["a.private"] = $_REQUEST['a_private'];
195.
        $results[0]["a.icon"] = $_REQUEST['a_icon'];
196.
        $results[0]["a.notesearch"] = $_REQUEST['a_notesearch'];
197.
        $results[0]["a.datecreated"] = $_REQUEST['a_datecreated'];
198.
        $results[0]["a.category"] = $_REQUEST['a_category'];
199.
        $results[0]["a.sourcetext"] = $_REQUEST['a_sourcetext'];
200.
        $results[0]["a.sourceurl"] = $_REQUEST['a_sourceurl'];
201.
        $results[0]["a.citation"] = $_REQUEST['a_citation'];
202.
        $results[0]["a.textdraduction"] = $_REQUEST['a_textdraduction'];
203.
        
204.
    }
205.
 
206.
$recordcount $mysource->getCount();
207.
 
208.
echo '<div class="formtable">';
209.
 
210.
$protocol strpos(strtolower($_SERVER['SERVER_PROTOCOL']),'https'
211.
                === FALSE 'http' 'https';
212.
$host     $_SERVER['HTTP_HOST'];
213.
$script   $_SERVER['SCRIPT_NAME'];
214.
$params   $_SERVER['QUERY_STRING'];
215.
 
216.
$currentUrl $protocol '://' $host $script '?' $params;
217.
 
218.
// xxx  fix enctype
219.
echo '<form id="editform" class="formedit pure-form pure-form-aligned" method="post" action="'.$currentUrl.'"  enctype="multipart/form-data" >';
220.
 
221.
echo '<fieldset>';
222.
 
223.
echo '<legend style="display:inline-block" class="titleedit"><span title="Liste des sources" class="titleedit">Source</span> #'.($id==-1?'?':$id).'/'.$recordcount['count'];
224.
 
225.
echo '<div style="font-size:80%; float:right; display:inline-block;">'.$userUiMessage.'</div>';
226.
 
227.
echo '</legend>';
228.
?>
229.
230.
<input type="hidden" readonly name="a.id.value" value="<?php echo $results[0]["a.id"]; ?>" >
231.
 
232.
<div class="pure-control-group"><label for="aligned-name">a_id</label>
233.
        <input type="{{edithidden}}" readonly name="a.id" value="<?php echo $results[0]["a.id"]; ?>"         
234.
        style="width:12em;" ><span class="pure-form-message-inline"></span>
235.
</div>
236.
        
237.
        <div class="pure-control-group"><label title="" for="aligned-name">quality</label>
238.
    
239.
            
240.
        
241.
            
242.
                <select  name="a.quality" >
243.
                    <option  value="" <?php if ($results[0]["a.quality"]=="") echo "selected"?>  >Non déterminée</option>
244.
<option  value="0" <?php if ($results[0]["a.quality"]=="0") echo "selected"?>  >source non fiable ou estimation</option>
245.
<option  value="1" <?php if ($results[0]["a.quality"]=="1") echo "selected"?>  >fiabilité douteuse </option>
246.
<option  value="2" <?php if ($results[0]["a.quality"]=="2") echo "selected"?>  >source indirecte</option>
247.
<option  value="3" <?php if ($results[0]["a.quality"]=="3") echo "selected"?>  >preuve indiscutable</option>
248.
                    
249.
                </select>
250.
                <div style="display:inline-block; color:red">&nbsp;</div>
251.
            
252.
                        
253.
            <span class="pure-form-message-inline"></span>    
254.
                                
255.
        </div>
256.
        
257.
        <div class="pure-control-group"><label title="Page dans le document" for="aligned-name">Page</label>
258.
    
259.
            
260.
            
261.
            
262.
                <input type="text"  class="" name="a.page" id="a_page" 
263.
                value="<?php if ( $results[0]["a.page"] !='') echo $results[0]["a.page"]; else echo ''?>"
264.
                style="width:12em;" 
265.
                >            
266.
                <div style="display:inline-block; color:red">&nbsp;</div>
267.
                
268.
            
269.
                        
270.
            <span class="pure-form-message-inline"></span>    
271.
                                
272.
        </div>
273.
        
274.
        <div class="pure-control-group"><label title="Nom de la source" for="aligned-name">Nom</label>
275.
    
276.
            
277.
            
278.
            
279.
                <input type="text"  class="" name="a.name" id="a_name" 
280.
                value="<?php if ( $results[0]["a.name"] !='') echo $results[0]["a.name"]; else echo ''?>"
281.
                style="width:30em;" 
282.
                >            
283.
                <div style="display:inline-block; color:red">*</div>
284.
                
285.
            
286.
                        
287.
            <span class="pure-form-message-inline"></span>    
288.
                                
289.
        </div>
290.
        
291.
        <div class="pure-control-group"><label title="description" for="aligned-name">a_description</label>
292.
    
293.
            
294.
                        
295.
            
296.
                <textarea  text rows="4" cols="40" name="a.description" rows="4" cols="30" ><?php if ( $results[0]["a.description"] !='') echo $results[0]["a.description"]; else echo ''?></textarea>
297.
            
298.
                        
299.
            <span class="pure-form-message-inline"></span>    
300.
                                
301.
        </div>
302.
        
303.
        <div class="pure-control-group"><label title="private" for="aligned-name">a_private</label>
304.
    
305.
            
306.
            
307.
            
308.
                <input type="checkbox"  name="a.private" 
309.
                value="1" 
310.
                <?php echo ($results[0]["a.private"]==1?"checked='checked'":""?>
311.
                >
312.
                <div style="display:inline-block; color:red">&nbsp;</div>
313.
            
314.
                        
315.
            <span class="pure-form-message-inline"></span>    
316.
                                
317.
        </div>
318.
        
319.
        <div class="pure-control-group"><label title="icon" for="aligned-name">icon</label>
320.
    
321.
                
322.
            
323.
            
324.
                <input style="display:inline-block" type="file" class="" name="a.icon" id="a_icon" 
325.
                style="width:12em;" 
326.
                >    
327.
                
328.
                <input type="checkbox" name="a_icon_deletebefore" id="a_icon_deletebefore" title="Supprimer le fichier.">
329.
                                                
330.
                <input type="hidden" class="" name="a_icon" id="a_icon" 
331.
                value="<?php echo $results[0]["a.icon"]; ?>"
332.
                >    
333.
                <div style="display:inline-block; vertical-align:middle" >
334.
                    
335.
                    <?php
336.
                    
337.
                    if (file_exists($results[0]["a.icon"])) {
338.
                        
339.
                        echo '<img width="50" height="50" style="width: 50px; height: 50px;" alt="'.$results[0]["a.icon"].'" title="'.$results[0]["a.icon"].'" src="'.$results[0]["a.icon"].' ">';
340.
                    } else {
341.
                        
342.
                        echo '<img width="50" height="50" style="width: 50px; height: 50px;" alt="Image inexistante" title="Image inexistante" src="img/missing.png">';            
343.
                    }            
344.
                        
345.
                    ?>                    
346.
                    
347.
                </div>
348.
            
349.
                        
350.
            <span class="pure-form-message-inline"></span>    
351.
                                
352.
        </div>
353.
        
354.
        <div class="pure-control-group"><label title="Notes de recherche" for="aligned-name">Notes de recherche</label>
355.
    
356.
            
357.
                        
358.
            
359.
                <textarea  text rows="4" cols="40" name="a.notesearch" rows="4" cols="12" ><?php if ( $results[0]["a.notesearch"] !='') echo $results[0]["a.notesearch"]; else echo ''?></textarea>
360.
            
361.
                        
362.
            <span class="pure-form-message-inline"></span>    
363.
                                
364.
        </div>
365.
        
366.
        <div class="pure-control-group"><label title="datecreated" for="aligned-name">a_datecreated</label>
367.
    
368.
            
369.
                        
370.
            <span class="pure-form-message-inline"></span>    
371.
                                
372.
        </div>
373.
        
374.
        <div class="pure-control-group"><label title="" for="aligned-name">category</label>
375.
    
376.
            
377.
        
378.
            
379.
                <select  name="a.category" >
380.
                    <option  value="url" <?php if ($results[0]["a.category"]=="url") echo "selected"?>  >Url</option>
381.
<option  value="text" <?php if ($results[0]["a.category"]=="text") echo "selected"?>  >Texte</option>
382.
<option  value="file" <?php if ($results[0]["a.category"]=="file") echo "selected"?>  >Fichier local</option>
383.
                    
384.
                </select>
385.
                <div style="display:inline-block; color:red">*</div>
386.
            
387.
                        
388.
            <span class="pure-form-message-inline"></span>    
389.
                                
390.
        </div>
391.
        
392.
        <div class="pure-control-group"><label title="" for="aligned-name">sourcetext</label>
393.
    
394.
            
395.
                        
396.
            
397.
                <textarea  text rows="4" cols="40" name="a.sourcetext" rows="4" cols="30" ><?php if ( $results[0]["a.sourcetext"] !='') echo $results[0]["a.sourcetext"]; else echo ''?></textarea>
398.
            
399.
                        
400.
            <span class="pure-form-message-inline"></span>    
401.
                                
402.
        </div>
403.
        
404.
        <div class="pure-control-group"><label title="" for="aligned-name">sourceurl</label>
405.
    
406.
            
407.
            
408.
            
409.
                <input type="text"  class="" name="a.sourceurl" id="a_sourceurl" 
410.
                value="<?php if ( $results[0]["a.sourceurl"] !='') echo $results[0]["a.sourceurl"]; else echo ''?>"
411.
                style="width:30em;" 
412.
                >            
413.
                <div style="display:inline-block; color:red">&nbsp;</div>
414.
                
415.
            
416.
                        
417.
            <span class="pure-form-message-inline"></span>    
418.
                                
419.
        </div>
420.
        
421.
        <div class="pure-control-group"><label title="" for="aligned-name">citation</label>
422.
    
423.
            
424.
            
425.
            
426.
                <input type="text"  class="" name="a.citation" id="a_citation" 
427.
                value="<?php if ( $results[0]["a.citation"] !='') echo $results[0]["a.citation"]; else echo ''?>"
428.
                style="width:30em;" 
429.
                >            
430.
                <div style="display:inline-block; color:red">&nbsp;</div>
431.
                
432.
            
433.
                        
434.
            <span class="pure-form-message-inline"></span>    
435.
                                
436.
        </div>
437.
        
438.
        <div class="pure-control-group"><label title="" for="aligned-name">textdraduction</label>
439.
    
440.
            
441.
                        
442.
            
443.
                <textarea  text rows="4" cols="40" name="a.textdraduction" rows="4" cols="30" ><?php if ( $results[0]["a.textdraduction"] !='') echo $results[0]["a.textdraduction"]; else echo ''?></textarea>
444.
            
445.
                        
446.
            <span class="pure-form-message-inline"></span>    
447.
                                
448.
        </div>
449.
 
450.
<?
451.
 
452.
echo ' <div class="pure-controls">'."\n";
453.
echo '<button type="submit" name = "submitSave" class="formbutton xpure-button xpure-button-primary">Enregistrer</button>'."\n";
454.
$confirmBox "onclick=\"return confirm('Etes vous sûr de vouloir supprimer cet article ?')\"";
455.
if ($id 0)
456.
    echo '<button type="submit" name = "submitDelete" class="formbutton xpure-button xpure-button-primary" '.$confirmBox.'  >Supprimer</button>'."\n";
457.
 
458.
 
459.
parse_str($_SERVER['QUERY_STRING'], $query_string);
460.
 
461.
if ($id != -and $id $recordcount['minid'] ) {     
462.
    $urlPrev='';
463.
    $query_string['id'] = $id;
464.
    $query_string['offset'] = '_PREV';
465.
    $paramPrev http_build_query($query_string);
466.
    $urlPrev $protocol '://' $host $script '?' $paramPrev;
467.
    echo "<a class='formbutton' href='$urlPrev'>Précédent</a>\n";
468.
}
469.
else echo "<a class='formbutton' style='color:gray; pointer-events: none' href=''>Précédent</a>\n";
470.
 
471.
if ($id != -and $id $recordcount['maxid']  ) { 
472.
    $urlNext='';
473.
    $query_string['id'] = $id;
474.
    $query_string['offset'] = '_NEXT';
475.
    $paramNext http_build_query($query_string);
476.
    $urlNext $protocol '://' $host $script '?' $paramNext;
477.
    echo "<a class='formbutton' href='$urlNext'>Suivant</a>\n";
478.
}
479.
else echo "<a class='formbutton' style='color:gray; pointer-events: none' href=''>Suivant</a>\n";
480.
 
481.
    
482.
echo '</div>'."\n";
483.
echo '</fieldset>'."\n";
484.
echo '</form>'."\n";
485.
 
486.
echo '</div>';
487.
 
488.
?>
489.
490.
 
491.
<script type="text/javascript">
492.
    
493.
    $(document).ready(function(){
494.
        
495.
        $(".selectlist").on("click", function() {            
496.
            startModal('selectplaceholder');                                    
497.
            //alert("Id du champ à remplir au retour : [" + $(this).attr('valuebackval')  + "]");
498.
            var url = "phpui/select_" + $(this).attr('valuetable') + ".php?valuebackfield=" + $(this).attr('valuebackfield') + '&valuebackval=' + $(this).attr('valuebackval');
499.
            
500.
            $('#selectplaceholder').load(url, function() {
501.
                $('#selectplaceholder').css("background-color", "white");
502.
                $('#selectplaceholder').css("border", "1px solid #034668");
503.
                //box-shadow: 5px 10px 12px -4px rgba(0,0,0,0.75);
504.
                //-webkit-box-shadow: 5px 10px 12px -4px rgba(0,0,0,0.75);
505.
                //-moz-box-shadow: 5px 10px 12px -4px rgba(0,0,0,0.75);
506.
                $('#selectplaceholder').css("box-shadow", "5px 10px 12px -4px rgba(0,0,0,0.75)");                
507.
                $('#selectplaceholder').css("border-radius", "7px");
508.
            });            
509.
            
510.
        });
511.
    });
512.
 
513.
    function startModal(id) {
514.
        $("body").prepend(
515.
            "<div id='PopupMask' style='position:fixed;width:100%;height:100%;z-index:10;background-color:gray;'></div>"+
516.
            "<div style='position: fixed;top: 50%;left: 50%; transform: translate(-50%, -50%);' "+
517.
                "id='selectplaceholder'><img  width='180' height='60' src='img/loading.gif'></div>");
518.
        $("#PopupMask").css('opacity', 0.5);  
519.
        $("#"+id).data('saveZindex', $("#"+id).css( "z-index"));
520.
        $("#"+id).data('savePosition', $("#"+id).css( "position"));
521.
        $("#"+id).css( "z-index" , 11 );
522.
        $("#"+id).css( "position" , "fixed" );
523.
    }
524.
 
525.
</script>
526.
 
527.
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>
528.
<link rel="stylesheet" href="https://code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
529.
 
530.
<script>
531.
 
532.
    // Disable autofill
533.
    $(".datepicker").prop("autocomplete", "off");
534.
 
535.
    $( function() {
536.
        
537.
        $.datepicker.regional['fr'] = {
538.
                yearRange: '1:2099',
539.
                changeMonth: true,
540.
                changeYear: true,
541.
                closeText: 'Fermer',
542.
                prevText: '&#x3c;Préc',
543.
                nextText: 'Suiv&#x3e;',
544.
                currentText: 'Aujourd\'hui',
545.
                monthNames: ['Janvier','Fevrier','Mars','Avril','Mai','Juin',
546.
                'Juillet','Aout','Septembre','Octobre','Novembre','Decembre'],
547.
                monthNamesShort: ['Jan','Fev','Mar','Avr','Mai','Jun',
548.
                'Jul','Aou','Sep','Oct','Nov','Dec'],
549.
                dayNames: ['Dimanche','Lundi','Mardi','Mercredi','Jeudi','Vendredi','Samedi'],
550.
                dayNamesShort: ['Dim','Lun','Mar','Mer','Jeu','Ven','Sam'],
551.
                dayNamesMin: ['Di','Lu','Ma','Me','Je','Ve','Sa'],
552.
                weekHeader: 'Sm',
553.
                dateFormat: 'dd/mm/yy',
554.
                firstDay: 1,
555.
                /*isRTL: false,*/
556.
                /*showMonthAfterYear: false,*/
557.
                /*yearSuffix: '',*/
558.
                /*minDate: 0,*/
559.
                /*maxDate: '+12M +0D',*/
560.
                numberOfMonths: 1,
561.
                showButtonPanel: true
562.
            };
563.
                        
564.
        $.datepicker.setDefaults($.datepicker.regional['fr']);
565.
                
566.
        $(".datepicker" ).datepicker().on("show", function() {
567.
                            var formDate = $(this).val()                            
568.
                            $(this).val(formDate).datepicker('update');
569.
                        });
570.
                                
571.
    } );
572.
 
573.
    $("#over").remove();
574.
    
575.
    // Page quit confirmation
576.
    var form = $('#editform'),
577.
      original = form.serialize()
578.
 
579.
    form.submit(function(){
580.
        $('body').append('<div id="over" style="background:rgba(0,0,0, 0.05); position:fixed; top:0; left:0; width:100%; height:100%;"> <img style="position:absolute; top:0; left:0; right:0; bottom:0; margin:auto;"  width="180" height="60" src="img/loading.gif"> </div> ');
581.
        window.onbeforeunload = null
582.
    })
583.
 
584.
    window.onbeforeunload = function(){
585.
      if (form.serialize() != original)
586.
        return "Confirmez-vous l'abandon de vos modifications ?"
587.
    }
588.
 
589.
</script>
590.
  
591.