More changes to enable YUI-Grids CSS layout
[koha_gimpoz] / koha-tmpl / intranet-tmpl / prog / en / modules / cataloguing / addbiblio.tmpl
1 <!-- TMPL_INCLUDE NAME="doc-head-open.inc" -->
2 <title>Koha &rsaquo; Cataloging &rsaquo; <!-- TMPL_IF NAME="biblionumber" -->Edit MARC Record Number <!-- TMPL_VAR name="biblionumber" --><!-- TMPL_ELSE -->Add MARC Record<!-- /TMPL_IF --></title>
3 <!-- TMPL_INCLUDE NAME="doc-head-close.inc" -->
4 <!-- TMPL_INCLUDE NAME="header.inc" -->
5
6 <!--TMPL_UNLESS Name="popup"-->
7     <!-- TMPL_INCLUDE NAME="menu-catalogue.inc" -->
8 <!--/TMPL_UNLESS-->
9
10 <div id="doc3" class="yui-t2">
11    
12    <div id="bd">
13         <div id="yui-main">
14         <div class="yui-b"><div class="yui-g">
15
16 <!--TMPL_IF Name="done"-->
17     <script language="javascript" type="text/javascript">
18         opener.document.forms['f'].biblionumber.value=<!--TMPL_VAR Name="biblionumber"-->;
19         opener.document.forms['f'].title.value='<!--TMPL_VAR Name="title" ESCAPE="HTML"-->';
20         window.close();
21     </script>
22 <!--TMPL_ELSE-->
23     <form method="post" name="f" id="f" action="/cgi-bin/koha/cataloguing/addbiblio.pl" onsubmit="return Check();">
24 <!-- /TMPL_IF -->
25
26 <h1><!-- TMPL_IF NAME="biblionumtagfield" -->Edit MARC Record Number <!-- TMPL_VAR name="biblionumber" --><!-- TMPL_ELSE -->Add MARC Record<!-- /TMPL_IF --></h1>
27
28 <div id="action">
29     <!-- TMPL_IF name="biblionumber" -->
30         <input type="submit" value="Save Bibliographic Record" />
31     <!-- TMPL_ELSE -->
32         <input type="submit" value="Add Bibliographic Record" />
33     <!-- /TMPL_IF -->
34     <input type="button" value="z39.50 Search" onclick="PopupZ3950(); return false;" />
35 </div>
36 <br />
37  Change framework : <!--TMPL_VAR Name="framework" -->
38
39         <input type="hidden" name="op" value="addbiblio" />
40
41 <!--TMPL_IF Name="popup"-->
42         <input type="hidden" name="mode" value="popup" />
43 <!--/TMPL_IF-->
44         <input type="hidden" name="frameworkcode" value="<!-- TMPL_VAR NAME="frameworkcode" -->" />
45         <input type="hidden" name="biblionumber" value="<!-- TMPL_VAR NAME="biblionumber" -->" />
46         <input type="hidden" name="breedingid" value="<!-- TMPL_VAR NAME="breedingid" -->" />
47
48         <div id="tabs">
49         <!-- TMPL_LOOP name="BIG_LOOP" -->
50             <!-- TMPL_IF name="number" -->
51                 <a href="javascript:active(<!-- TMPL_VAR name="number"-->)" class="tab_inactive" id="link<!-- TMPL_VAR name="number"-->"><!-- TMPL_VAR name="number"--></a>
52             <!-- TMPL_ELSE -->
53                 <a href="javascript:active(<!-- TMPL_VAR name="number"-->)" class="tab_active" id="link<!-- TMPL_VAR name="number"-->"><!-- TMPL_VAR name="number"--></a>
54             <!-- /TMPL_IF -->
55         <!--  /TMPL_LOOP -->
56         </div>
57
58 <!-- TMPL_LOOP name="BIG_LOOP" -->
59 <!-- hide every tab except the 1st -->
60 <!-- TMPL_IF name="number" -->
61     <div id="<!-- TMPL_VAR name="number" -->XX" class="content_hidden">
62 <!-- TMPL_ELSE -->
63     <div id="0XX" class="content_visible">
64 <!-- /TMPL_IF -->
65 <!-- TMPL_UNLESS name="number" -->
66     <!-- show duplicate warning on tab 0 only -->
67         <!-- TMPL_IF name="duplicatebiblionumber" -->
68                     <div class="error">
69                         <p class="problem">Is this a duplicate of <a href="/cgi-bin/koha/catalogue/MARCdetail.pl?biblionumber=<!-- TMPL_VAR name="duplicatebiblionumber" -->" onclick="openWindow('../MARCdetail.pl?biblionumber=<!-- TMPL_VAR name="duplicatebiblionumber" -->&amp;popup=1', 'Duplicate biblio'; return false;)"><!-- TMPL_VAR name="duplicatetitle" --></a>?</p>
70                         <p>You must either :</p>
71                         <ul>
72                             <li>If it <em>is</em> a duplicate, <a href="/cgi-bin/koha/cataloguing/additem.pl?biblionumber=<!-- TMPL_VAR name="duplicatebiblionumber" -->">Edit Items</a> of the existing record.</li>
73                             <li>If not, click to <input type="hidden" value="0" id="confirm_not_duplicate" name="confirm_not_duplicate" /> <a href="#" onclick="confirmnotdup(); return false;">Confirm it's not a duplicate</a></li>
74                         </ul>
75                     </div>
76         <!-- /TMPL_IF -->
77     <!-- /TMPL_UNLESS -->
78     
79     <!-- TMPL_LOOP NAME="innerloop" -->
80         <!-- TMPL_IF NAME="tag" -->
81         <div class="tag" id="tag_<!-- TMPL_VAR name="tag"-->_<!-- TMPL_VAR NAME='index'-->">
82         <div class="tag_title" name="div_indicator">
83             <!-- TMPL_UNLESS name="hide_marc" -->
84                 <span title="<!-- TMPL_VAR NAME="tag_lib" -->"><!-- TMPL_VAR NAME="tag" --></span>
85                 <!-- TMPL_IF NAME="fixedfield" -->
86                         <input tabindex="1" class="indicator flat" type="text" style="display:none;" name="tag_<!-- TMPL_VAR NAME="tag" -->_indicator_<!-- TMPL_VAR NAME='index'-->" size="2" maxlength="2" value="<!-- TMPL_VAR NAME="indicator" -->" />
87                 <!-- TMPL_ELSE -->
88                         <input tabindex="1" class="indicator flat" type="text" name="tag_<!-- TMPL_VAR NAME="tag" -->_indicator_<!-- TMPL_VAR NAME='index'-->" size="2" maxlength="2" value="<!-- TMPL_VAR NAME="indicator" -->" />
89                 <!-- /TMPL_IF --> -
90             <!-- TMPL_ELSE -->
91                 <!-- TMPL_IF NAME="fixedfield" -->
92                     <input tabindex="1" type="hidden" name="tag_<!-- TMPL_VAR NAME="tag" -->_indicator_<!-- TMPL_VAR NAME='index'-->" value="<!-- TMPL_VAR NAME="indicator" -->" />
93                 <!-- TMPL_ELSE -->
94                     <input tabindex="1" type="hidden" name="tag_<!-- TMPL_VAR NAME="tag" -->_indicator_<!-- TMPL_VAR NAME='index'-->" value="<!-- TMPL_VAR NAME="indicator" -->" />
95                 <!-- /TMPL_IF -->
96             <!-- /TMPL_UNLESS -->
97
98             <!-- TMPL_UNLESS NAME="advancedMARCEditor" -->
99                     <a onclick="ExpandField('tag_<!-- TMPL_VAR name="tag"-->_<!-- TMPL_VAR NAME='index'-->')"><!-- TMPL_VAR NAME="tag_lib" --></a>
100             <!-- /TMPL_UNLESS -->
101             <!-- TMPL_IF name="repeatable" -->
102                 <span class="buttonPlus" onclick="CloneField('tag_<!-- TMPL_VAR name="tag"-->_<!-- TMPL_VAR NAME='index'-->')">+</span>
103             <!-- /TMPL_IF -->
104             
105         </div>
106         
107         <!-- TMPL_LOOP NAME="subfield_loop" -->
108             <!--  One line on the marc editor -->
109             <div name="line" class="subfield_line" style="<!-- TMPL_VAR NAME='visibility' -->;" id="subfield<!-- TMPL_VAR NAME='tag' --><!-- TMPL_VAR NAME='subfield' -->">
110             
111                 <!--TMPL_UNLESS NAME="advancedMARCEditor" -->
112                 <label for="tag_<!-- TMPL_VAR NAME='tag'-->_subfield_<!--  TMPL_VAR NAME='subfield'-->_<!-- TMPL_VAR NAME='index'-->_<!-- TMPL_VAR NAME='index_subfield'-->" <!-- TMPL_IF NAME="fixedfield" --> style="display:none;" <!-- /TMPL_IF --> class="labelsubfield" >
113                 <!-- /TMPL_UNLESS --> 
114                 
115                 <!-- TMPL_UNLESS name="hide_marc" -->
116                     <img class="buttonUp" <!-- TMPL_IF NAME="fixedfield" --> style="display:none;" <!-- /TMPL_IF --> src="<!-- TMPL_VAR NAME="themelang" -->/images/up.png" onclick="upSubfield('subfield<!-- TMPL_VAR NAME='tag' --><!-- TMPL_VAR NAME='subfield' -->')" alt="" />
117                         <input title="<!-- TMPL_VAR NAME='marc_lib_plain' -->" style=" <!-- TMPL_IF NAME="fixedfield" -->display:none; <!-- /TMPL_IF -->border:0;" type="text" name="tag_<!-- TMPL_VAR NAME='tag'-->_code_<!--  TMPL_VAR NAME='subfield'-->_<!-- TMPL_VAR NAME='index'-->_<!-- TMPL_VAR NAME='index_subfield'-->" value="<!-- TMPL_VAR NAME="subfield" -->" size="1" maxlength="1" class="flat" tabindex="-1" />
118                 <!-- TMPL_ELSE -->
119                     <input type="hidden" name="tag_<!-- TMPL_VAR NAME='tag'-->_code_<!--  TMPL_VAR NAME='subfield'-->_<!-- TMPL_VAR NAME='index'-->_<!-- TMPL_VAR NAME='index_subfield'-->" value="<!-- TMPL_VAR NAME="subfield" -->" />
120                 <!-- /TMPL_UNLESS -->
121             
122                 <!-- TMPL_UNLESS NAME="advancedMARCEditor" -->
123                     <!-- TMPL_IF name="mandatory" --><span class="subfield_mandatory"><!-- /TMPL_IF -->
124                         <!-- TMPL_VAR NAME="marc_lib" -->
125                     <!-- TMPL_IF name="mandatory" --></span><!-- /TMPL_IF -->
126                     </label>
127                 <!-- /TMPL_UNLESS -->
128                 
129                 <!-- TMPL_VAR NAME="marc_value" -->
130                 
131                 <!-- TMPL_IF NAME="repeatable" -->
132                     <span class="buttonPlus" onclick="CloneSubfield('subfield<!-- TMPL_VAR NAME='tag' --><!-- TMPL_VAR NAME='subfield' -->')">+</span>
133                 <!-- /TMPL_IF -->
134                 
135             </div>
136             <!-- End of the line -->
137             
138         <!-- /TMPL_LOOP -->
139         </div>
140         <!-- /TMPL_IF --><!-- tag -->
141     <!-- /TMPL_LOOP -->
142     </div>
143 <!-- /TMPL_LOOP -->
144
145 </form>
146
147 <script language="javascript" type="text/javascript">
148
149 function _(s) { return s } // dummy function for gettext
150
151 function confirmnotdup(){
152         document.getElementById("confirm_not_duplicate").value = 1;
153         var checkform = document.getElementById("f");
154         Check(checkform);
155 }
156
157 function active(numlayer){
158     for (i=0; i <= 10 ; i++ ) {
159         var tab;
160         try{
161                 tab = document.getElementById(i+'XX');
162                 tab.getAttribute('id'); // do not remove this line. It throws an execption.
163         }
164         catch(e){
165                 continue;
166         }
167         if (numlayer==i) {
168             tab.setAttribute("class","content_visible");
169             var tabactive=document.getElementById('link'+i);
170             tabactive.removeAttribute("class");
171             tabactive.setAttribute("class","tab_active");
172         } else {
173             tab.setAttribute("class","content_hidden");
174             try {
175                 var tabactive=document.getElementById('link'+i);
176                 tabactive.removeAttribute("class");
177                 tabactive.setAttribute("class","tab_inactive");
178             }
179             catch(e){};
180         }
181     }
182 }
183
184 /**
185  * 
186  * 
187  */
188 function Check(){
189     var StrAlert = AreMandatoriesNotOk();
190     if( ! StrAlert ){
191         document.f.submit;
192         return true;
193     } else {
194         alert(StrAlert);
195         return false;
196     }
197 }
198
199 function Dopop(link,i) {
200     defaultvalue = document.getElementById(i).value;
201     window.open(link+"&result="+defaultvalue,"value builder",'width=700,height=550,toolbar=false,scrollbars=yes');
202 }
203
204 /**
205  * this function open a popup to search on z3950 server.
206  */
207 function PopupZ3950() {
208     var strQuery = AreZ3950MandoriesOk();
209     if(strQuery){
210         window.open("/cgi-bin/koha/cataloguing/z3950_search.pl?biblionumber=<!-- TMPL_VAR NAME="biblionumber" -->&frameworkcode=<!-- TMPL_VAR NAME="frameworkcode" -->"+strQuery,"z3950search",'width=640,height=400,location=yes,toolbar=no,scrollbars=yes');
211     } else {
212         var strAlert = _("To perform a z39.50 search, you must enter at least one of the following: \n\n ISBN\n ISSN\n Title\n Author\n");    
213         alert(strAlert);
214     }
215 }
216
217 /**
218  * check if mandatory subfields are writed
219  */
220 function AreMandatoriesNotOk(){
221     var mandatories = new Array();
222     var tab = new Array();
223     var label = new Array();
224     var flag=0;
225     <!-- TMPL_LOOP NAME='BIG_LOOP' --><!-- TMPL_LOOP NAME='innerloop' --><!-- TMPL_LOOP NAME='subfield_loop'--><!-- TMPL_IF NAME='mandatory'-->mandatories.push("<!-- TMPL_VAR NAME='id' -->");
226                         tab.push("<!-- TMPL_VAR NAME='number' -->");
227                         label.push("<!-- TMPL_VAR NAME='marc_lib' -->");
228                 <!-- /TMPL_IF --><!-- /TMPL_LOOP --><!-- /TMPL_LOOP --><!-- /TMPL_LOOP -->
229     var StrAlert = "Can't save this record because the following field aren't filled :\n\n";
230     for(var i=0,len=mandatories.length; i<len ; i++){
231         if( ! document.getElementById(mandatories[i]).value){
232             flag = 1;
233             document.getElementById(mandatories[i]).setAttribute('class','subfield_not_filled');
234             document.getElementById(mandatories[i]).focus();
235             StrAlert += "\t* "+label[i]+" in tab "+tab[i]+"\n";
236         }
237     }
238     if(flag){
239             return StrAlert;
240         } else {
241                 return flag;
242         }
243 }
244
245 /** 
246  * check if z3950 mandatories are set or not
247  */
248 function AreZ3950MandoriesOk(){
249     var mandatories = new Array();
250     var mandatories_label = new Array();
251         <!-- TMPL_LOOP NAME='BIG_LOOP' --><!-- TMPL_LOOP NAME='innerloop' --><!-- TMPL_LOOP NAME='subfield_loop'--><!-- TMPL_IF NAME='z3950_mandatory'-->mandatories.push("<!-- TMPL_VAR NAME='id' -->");
252         mandatories_label.push("<!-- TMPL_VAR NAME='z3950_mandatory' -->");<!-- /TMPL_IF --><!-- /TMPL_LOOP --><!-- /TMPL_LOOP --><!-- /TMPL_LOOP -->
253     
254     var error = 0;
255     var strQuery="";
256     for(var i=0,len=mandatories.length; i<len ; i++){
257         var field_value = document.getElementById(mandatories[i]).value;
258         if( ! field_value ){
259             error++;
260         } else {
261             strQuery += "&"+mandatories_label[i]+"="+field_value;
262         }
263     }
264     if(error < 4){
265         return strQuery;
266     } else {
267         return false;
268     }
269 }
270
271 function Changefwk(FwkList) {
272         var fwk = FwkList.options[FwkList.selectedIndex].value;
273         window.location = "/cgi-bin/koha/cataloguing/addbiblio.pl?biblionumber=<!--TMPL_VAR Name="oldbiblionumber"-->&breedingid=<!-- TMPL_VAR name="breedingid" -->&frameworkcode="+fwk;
274
275 }
276
277 function openAuth(tagid,authtype,X) {
278 //      defaultid=document.getElementById(subfieldid);
279 //     alert("X"+X);
280     Y=X.parentNode.getAttribute("id");
281 //     alert("tagid"+Y);
282         newin=window.open("../authorities/auth_finder.pl?authtypecode="+  authtype+ "&tagid="+Y, "value builder",'width=700,height=550,toolbar=false,scrollbars=yes');
283 }
284
285
286 function ExpandField(index) {
287     var original = document.getElementById(index); //original <div>
288     var divs = original.getElementsByTagName('div');
289     for(var i=0,divslen = divs.length ; i<divslen ; i++){      // foreach div
290         if(divs[i].getAttribute("name") == 'line'){  // if it s a subfield
291             if (divs[i].style.display == 'block') {
292                 divs[i].style.display = 'none';
293             } else {
294                 divs[i].style.display = 'block';
295             }
296         }
297     }
298 }
299
300 /**
301  * To clone a field or a subfield by clickink on '+' button
302  */ 
303 function CloneField(index) {
304     var original = document.getElementById(index); //original <div>
305     var clone = original.cloneNode(true);
306     var new_key = CreateKey();
307     var new_id  = original.getAttribute('id')+new_key;
308     
309     clone.setAttribute('id',new_id); // setting a new id for the parent div
310     
311     var divs = clone.getElementsByTagName('div');
312     
313     <!-- TMPL_UNLESS NAME='hide_marc'--> // No indicator if hide_marc
314         // setting a new name for the new indicator
315         var indicator = clone.getElementsByTagName('input')[0];
316         indicator.setAttribute('name',indicator.getAttribute('name')+new_key);
317     <!-- /TMPL_UNLESS -->
318         
319     // settings all subfields
320     for(var i=0,divslen = divs.length ; i<divslen ; i++){      // foreach div
321         if(divs[i].getAttribute("name") == 'line'){  // if it s a subfield
322             
323             // set the attribute for the new 'div' subfields
324             divs[i].setAttribute('id',divs[i].getAttribute('id')+new_key);
325             
326             var inputs   = divs[i].getElementsByTagName('input');
327             var id_input = "";
328             
329             inputs[0].setAttribute('id',inputs[0].getAttribute('id')+new_key);
330             inputs[0].setAttribute('name',inputs[0].getAttribute('name')+new_key);
331             var id_input;
332             try {
333                 id_input = inputs[1].getAttribute('id')+new_key;
334                 inputs[1].setAttribute('id',id_input);
335                 inputs[1].setAttribute('name',inputs[1].getAttribute('name')+new_key);
336             } catch(e) {
337                 try{ // it s a select if it is not an input
338                     var selects = divs[i].getElementsByTagName('select');
339                     id_input = selects[0].getAttribute('id')+new_key;
340                     selects[0].setAttribute('id',id_input);
341                     selects[0].setAttribute('name',selects[0].getAttribute('name')+new_key);
342                 }catch(e2){ // it is a textarea if it s not a select or an input
343                         var textaeras = divs[i].getElementsByTagName('textarea');
344                         id_input = textaeras[0].getAttribute('id')+new_key;
345                         textaeras[0].setAttribute('id',id_input);
346                     textaeras[0].setAttribute('name',textaeras[0].getAttribute('name')+new_key);
347                 }
348             }
349             
350             <!-- TMPL_UNLESS NAME='advancedMARCEditor'-->
351             // when cloning a subfield, re set its label too.
352             var labels = divs[i].getElementsByTagName('label');
353             labels[0].setAttribute('for',id_input);
354             <!-- /TMPL_UNLESS -->
355             
356             <!-- TMPL_UNLESS NAME='hide_marc'-->
357                 // updating javascript parameters on button up
358                 var imgs = divs[i].getElementsByTagName('img');
359                 imgs[0].setAttribute('onclick',"upSubfield(\'"+divs[i].getAttribute('id')+"\');");
360             <!-- /TMPL_UNLESS -->
361             
362             // setting its '+' button
363             var CloneButtonPlus=0;
364             try {
365                 CloneButtonPlus = divs[i].getElementsByTagName('span')[0];
366                 if(CloneButtonPlus.getAttribute('class') == 'buttonPlus'){
367                     CloneButtonPlus.setAttribute('onclick',"CloneSubfield('" + divs[i].getAttribute('id') + "')");
368                 } else {
369                     CloneButtonPlus = 0;
370                 }
371             }
372             catch(e){
373                 // do nothig if ButtonPlus & CloneButtonPlus don t exist.
374             }
375             
376             // button ...
377             var spans=0;
378             try {
379                 spans = divs[i].getElementsByTagName('span');
380             } catch(e) {
381                 // no spans
382             }
383             if(spans){
384                 var buttonDot;
385                 if(!CloneButtonPlus){ // it s impossible to have  + ... (buttonDot AND buttonPlus)
386                     buttonDot = spans[0];
387                     if(buttonDot){
388                         // 2 possibilities :
389                         try{
390                             var buttonDotOnClick = buttonDot.getAttribute('onclick');
391                             if(buttonDotOnClick.match('Clictag')){   // -1- It s a plugin
392                                 var re = /\('.*'\)/i;
393                                 buttonDotOnClick = buttonDotOnClick.replace(re,"('"+inputs[1].getAttribute('id')+"')");
394                                 if(buttonDotOnClick){
395                                     buttonDot.setAttribute('onclick',buttonDotOnClick);
396                                 }
397                             } else {
398                                 if(buttonDotOnClick.match('Dopop')) {  // -2- It's a auth value
399                                     
400                                     var re1 = /&index=.*',/;
401                                     var re2 = /,.*\)/;
402
403                                     buttonDotOnClick = buttonDotOnClick.replace(re1,"&index="+inputs[1].getAttribute('id')+"',");
404                                     buttonDotOnClick = buttonDotOnClick.replace(re2,",'"+inputs[1].getAttribute('id')+"')");
405                                     
406                                     if(buttonDotOnClick){
407                                             buttonDot.setAttribute('onclick',buttonDotOnClick);
408                                     }
409                                 }
410                             }
411                             try {
412                                 // do not copy the script section.
413                                 var script = spans[0].getElementsByTagName('script')[0];
414                                 spans[0].removeChild(script);
415                             } catch(e) {
416                                 // do nothing if there is no script
417                             }
418                         }catch(e){}
419                         }
420                 }
421             }
422             <!-- TMPL_UNLESS NAME='hide_marc'-->
423                 var buttonUp = divs[i].getElementsByTagName('img')[0];
424                 buttonUp.setAttribute('onclick',"upSubfield('" + divs[i].getAttribute('id') + "')");
425             <!-- /TMPL_UNLESS -->
426             
427         } else { // it's a indicator div
428             if(divs[i].getAttribute('name') == 'div_indicator'){
429                 var inputs = divs[i].getElementsByTagName('input');
430                 inputs[0].setAttribute('id',inputs[0].getAttribute('id')+new_key);
431                 
432                 var CloneButtonPlus;
433                 try {
434                     CloneButtonPlus = divs[i].getElementsByTagName('span')[1]; // 0 is the title
435                     CloneButtonPlus.setAttribute('onclick',"CloneField('" + divs[i].parentNode.getAttribute('id') + "')");
436                 }
437                 catch(e){
438                     // do nothig CloneButtonPlus doesn't exist.
439                 }
440             }
441         }
442     }
443     
444     // insert this line on the page
445     original.parentNode.insertBefore(clone,original.nextSibling);
446 }
447
448 function CloneSubfield(index){
449     var original = document.getElementById(index); //original <div>
450     var clone = original.cloneNode(true);
451     var new_key = CreateKey();
452     var new_id  = original.getAttribute('id')+new_key;
453     
454     // set the attribute for the new 'div' subfields
455     var inputs     = clone.getElementsByTagName('input');
456     var selects    = clone.getElementsByTagName('select');
457     var textareas  = clone.getElementsByTagName('textarea');
458         
459     // input
460     var id_input = "";
461     for(var i=0,len=inputs.length; i<len ; i++ ){
462         id_input = inputs[i].getAttribute('id')+new_key;
463         inputs[i].setAttribute('id',id_input);
464         inputs[i].setAttribute('name',inputs[i].getAttribute('name')+new_key);
465     }
466     
467     // select 
468     for(var i=0,len=selects.length; i<len ; i++ ){
469         id_input = selects[i].getAttribute('id')+new_key;
470         selects[i].setAttribute('id',selects[i].getAttribute('id')+new_key);
471         selects[i].setAttribute('name',selects[i].getAttribute('name')+new_key);
472     }
473     
474     // textarea
475     for(var i=0,len=textareas.length; i<len ; i++ ){
476         id_input = textareas[i].getAttribute('id')+new_key;
477         textareas[i].setAttribute('id',textareas[i].getAttribute('id')+new_key);
478         textareas[i].setAttribute('name',textareas[i].getAttribute('name')+new_key);
479     }
480     
481     <!-- TMPL_UNLESS NAME='advancedMARCEditor' -->
482     // when cloning a subfield, reset its label too.
483     var label = clone.getElementsByTagName('label')[0];
484     label.setAttribute('for',id_input);
485     <!-- /TMPL_UNLESS -->
486     
487     // setting a new if for the parent div
488     clone.setAttribute('id',new_id);
489     
490     var CloneButtonPlus;
491     try {
492         var spans = clone.getElementsByTagName('span');
493         if(spans.length){
494                 for(var i = 0 ,lenspans = spans.length ; i < lenspans ; i++){
495                         if(spans[i].getAttribute('class') == 'buttonPlus'){
496                     CloneButtonPlus = spans[i];
497                     CloneButtonPlus.setAttribute('onclick',"CloneSubfield('" + new_id + "')");
498                     var buttonUp = clone.getElementsByTagName('img')[0];
499                     buttonUp.setAttribute('onclick',"upSubfield('" + new_id + "')");
500                 }
501             }
502         }
503     }
504     catch(e){
505         // do nothig if ButtonPlus & CloneButtonPlus don't exist.
506     }
507     // insert this line on the page
508     original.parentNode.insertBefore(clone,original.nextSibling);
509 }
510
511 /**
512  * This function create a random number
513  */
514 function CreateKey(){
515     return parseInt(Math.random() * 100000);
516 }
517
518 /**
519  * This function allows to move a subfield up by clickink on the 'up' button .
520  */
521 function upSubfield(index) {
522     try{
523         var line = document.getElementById(index); // get the line where the user has clicked.
524     } catch(e) {
525         return; // this line doesn't exist...
526     }
527     var tag = line.parentNode; // get the dad of this line. (should be "<div id='tag_...'>")
528     
529     // getting all subfields for this tag
530     var subfields = tag.getElementsByTagName('div');
531     var subfieldsLength = subfields.length;
532     
533     if(subfieldsLength<=1) return; // nothing to do if there is just one subfield.
534     
535     // among all subfields 
536     for(var i=0;i<subfieldsLength;i++){ 
537         if(subfields[i].getAttribute('id') == index){ //looking for the subfield which is clicked :
538             if(i==1){ // if the clicked subfield is on the top
539                 tag.appendChild(subfields[1]);
540                 return;
541             } else {
542                 var lineAbove = subfields[i-1];
543                 tag.insertBefore(line,lineAbove);
544                 return;
545             }
546         }
547     }
548 }
549
550 function unHideSubfield(index,labelindex) { // FIXME :: is it used ?
551     subfield = document.getElementById(index);
552     subfield.style.display = 'block';
553     label = document.getElementById(labelindex);
554     label.style.display='none'; 
555 }
556
557 </script>
558 </div>
559 </div>
560 </div>
561
562 <!-- TMPL_INCLUDE NAME="mainmenu.inc" -->
563 <!-- TMPL_INCLUDE NAME="intranet-bottom.inc" -->