[Solucionado] Jquery visualizar un calendario en un input clonado

Iniciado por Slikp, 1 Diciembre 2014, 17:34 PM

0 Miembros y 1 Visitante están viendo este tema.

Slikp

- Buenas a todos espero puedan ayudarme ya tengo un par de varias horas con esto y nada que encuentro la solucion, veran a raiz de que el atributo Date de html5 no me sirve en Mozilla Firefox busque otra alternativa en Google y me encontre con el Calendario Datepicker lo probe por separado de mi proyecto y de una vez me funciono lo cambie a español y todo fino todo bello, bien lo quise integrar a mi proyecto y hasta cierto punto pense que estaba bien hasta que me di cuenta que si añadia otro campo en mi documento el calendario en el segundo elemento clonado no funciona, para ser mas claro yo tengo el siguiente formulario.

Código (html4strict) [Seleccionar]

<form method="post" name="up_form" class="formulario">
<input type="hidden" name="insertar">
 <table id="up_form"><br>
  <thead>
           <tr>
               <th>Clasificación</th>
               <th>Descripción Documento</th>
               <th>Fecha del Documento</th>
               <th>Fecha de Expiración</th>
               <th>Adjuntar Archivo</th>
           </tr>        
       </thead>
       <tbody>
          <tr class="lire">
<td>
<select id="taxonomia" name="cod_clasificacion">
<option value="">SELECCIONE UNA OPCION VALIDA</option>
<option value="0">EXPEDIENTE MEDICO</option>
<option value="1">EXPEDIENTE LABORAL</option>
<option value="2">EXPEDIENTE SEGURIDAD INDUSTRIAL</option>
</select>
</td>
<td>
<textarea id="describe" name="descripcion" required /></textarea>
</td>
<td>
<input type="text" class="datepicke" name="fecha_doc" required />
</td>
<td>
<input type="text" class="datepicker" name="fecha_exp" required />
</td>
<td>
<div class='input-file'>
         <input type="file" name="archivo[]">
         <input type="hidden" name="codigo" value="<?php echo $fila["cod_emp"]; ?>">
          Seleccionar archivo
         <div class="files">...</div>
         </div>
</td>
</tr>
</tbody>
 </table>
<td>
<a href="#" id="btn-up" class="anex-up"> Anexar Otro Archivo </a>
<input id="btn-up" class="sub" type="submit" value="Cargar Documentos">
</td><br><br>
</form>



- Eso me da la siguiente interfaz.


- Si hago un click en cualquier de los dos input de Fecha del Documento y Fecha de Expiracion me sale el siguiente calendario.

.

- Ahora bien si yo hago un click en Añadir otro Archivo la fila de arriba se clona y se anexa de bajo, hice 2 click por lo tanto obtuve lo siguiente.

.

- Ok ahora el problema si yo doy click en los inputs CLONADOS de Fecha del Documento y Fecha de Expiracion no "Hace nada" no se muestran los calendario.

- Con este codigo hago la clonacion de filas.
Código (javascript) [Seleccionar]

$(document).ready(function() {
   $(document).on('change', 'input:file', function(){  // NUEVA LINEA
      if($(this).val())
      {
        // Si tiene valor, se muestra en el class .files
        $(this).parent().find(".files").html($(this).val().replace("C:\\fakepath\\", ""));
       }else{
        // Si no tiene valor, se muestran los puntos ...
        $(this).parent().find(".files").html("...");
       }
   });


$(document).on("click",".anex-up",function() {
  $("#up_form tbody tr:eq(0)").clone().appendTo("#up_form tbody").append('<td class="eliminar"><div id="eliminar">x</div></td>');
   // (Se selecciona la ultima fila agregada, y se modifica el valor html del elemento con la clase 'files')
   $("#up_form tbody tr:eq(-1)").find(".files").html("..."); // NUEVA LINEA

});

$(document).on("click",".eliminar",function(){
   var parent = $(this).parents().get(0);
   $(parent).remove();
});
});




- Y para usar el Datepicker uso lo siguiente, tal cual como vi en su documentacion esto lo tengo en el html donde tengo el formulario.
Código (html4strict) [Seleccionar]

<script src="script/jquery-2.1.1.min.js"></script>
<script src="script/jquery-ui.js"></script>
     <script>
 $(document).ready(function() {
   $( ".datepicker" ).datepicker();
   $( ".datepicke" ).datepicker();
 });
   </script>


- Alguna idea? espero puedan ayudarme un Saludo.

Slikp

#1
- Buenas aun no he podido resolver este problema. Sin embargo en intentado unas cosas con los siguientes resultados.

-Aplicar el widget datepicker al elemnto que clono para que dicho clon también tenga el comportamiento deseado, lo inserte en este fragmento del codigo.


Código (javascript) [Seleccionar]
$(document).on("click",".anex-up",function() {
      $("#up_form tbody tr:eq(0)").clone().appendTo("#up_form tbody").append('<td class="eliminar"><div id="eliminar">x</div></td>');
       
       $("#up_form tbody tr:eq(-1)").find(".files").html("...");
       $("#up_form tbody tr:eq(-1)").find(".datepicker").datepicker(); // NUEVA LINEA
$("#up_form tbody tr:eq(-1)").find(".datepicke").datepicker(); // NUEVA LINEA  
   
   });



- Y la verdad no entiendo porque no funciono entonces sin darme cuenta elimine esto.


Código (javascript) [Seleccionar]
<script>
         $(document).ready(function() {
           $( ".datepicker" ).datepicker();
           $( ".datepicke" ).datepicker();
         });
     </script>


- Aclaro El primer codigo que coloque aun no lo habia eliminado y cuando fui al programa todos los clones que enexe desplegaban el calendario sin embargo los input Originales no hacian nada.




-Agregue denuevo.

Código (javascript) [Seleccionar]
<script>
         $(document).ready(function() {
           $( ".datepicker" ).datepicker();
           $( ".datepicke" ).datepicker();
         });
     </script>



- Y los inputs Originales despliegan el calendario y los Clonados ahora no hacen absolutamente nada. Y no se que tan mal hice lo siguiente pero intente hacer una condicion de la siguiente manera Sin ningun resultado...


 
Código (javascript) [Seleccionar]
  $(document).ready(function() {
  if($("#up_form tbody tr:eq(-1)").find(".datepicker")){
  $("#up_form tbody tr:eq(-1)").find(".datepicker").datepicker(); // NUEVA LINEA
    $("#up_form tbody tr:eq(-1)").find(".datepicke").datepicker(); // NUEVA LINEA  
  }else {
   $(".datepicker").datepicker();
   $(".datepicke").datepicker();
}
 });



- Seguire intentando de momento espero puedan ayudarme, Saludos.

PD: Intente hacer tambien unas cosas con el Evento LIVE que lei unas cosas sobre el y tampoco puede solucionar y trate de hacer tambien los BIND sobre elementos Existentes y nada :/ .

JorgeEMX

Hay que estar seguros como funciona javascript. Ten en cuenta que cuando se carga el DOM de tu doc HTML ($(document).ready(function(){})) sólo tienes agregado el primer par de inputs y es ahí, dónde, el plugin carga los calendarios sólo en éstos mismos (todos los input que tengan la clase CSS que especificas).

Entonces, yo te recomendaría lanzar el plugin a dichas clases CSS cuando ya tengas dibujado todos los par de inputs que necesitas aplicar el efecto. O en su defecto, tal cómo lo hiciste, que es cada vez que crees unos nuevos.


Slikp

- Buenas JorgeEMX, Gracias por responder la verdad es que soy novato en esto y si he leido mucho sobre el tema y ya he visto ese tipo de sugerencias que me has dado.

Cita de: JorgeEMX en  5 Diciembre 2014, 01:39 AM
Hay que estar seguros como funciona javascript. Ten en cuenta que cuando se carga el DOM de tu doc HTML ($(document).ready(function(){})) sólo tienes agregado el primer par de inputs

- Pero igual a veces por mi falta de experiencia no encuentro la forma de aplicar el plugin u otras cosas que hago cuando los elementos ya existan por completo en el DOM.

- EFEX, compañero tu respuesta me ha sido de mucha ayuda de verdad me solvento el problema, sin embargo en primera instancia cuando intente tuve varios problemas dado que no me funciono, pero insisti un par de veces guiandome del ejemplo que has aportado y a la final creo yo que el problema del porque tu ejemplo no me funcionaba en mi proyecto era la Version de Jquery-UI que yo estaba usando, la volvi a descargar y de la pag oficial y solo el Widget Datepicker sin mas nada reemplaze  la anterior que tenia probe y listo, Muchas gracias a la final quedo asi.

Código (html4strict) [Seleccionar]

<form method="post" name="up_form" class="formulario">
<input type="hidden" name="insertar">
  <table id="up_form"><br>
  <thead>
            <tr>
                <th>Clasificación</th>
                <th>Descripción Documento</th>
                <th>Fecha del Documento</th>
                <th>Fecha de Expiración</th>
                <th>Adjuntar Archivo</th>
            </tr>         
        </thead>
        <tbody>
          <tr class="lire">
<td>
<select id="taxonomia" name="cod_clasificacion">
<option value="">SELECCIONE UNA OPCION VALIDA</option>
<option value="0">EXPEDIENTE MEDICO</option>
<option value="1">EXPEDIENTE LABORAL</option>
<option value="2">EXPEDIENTE SEGURIDAD INDUSTRIAL</option>
</select>
</td>
<td>
<textarea id="describe" name="descripcion" required /></textarea>
</td>
<td>
<input type="text" class="datepicke" name="fecha_doc" required />
</td>
<td>
<input type="text" class="datepicker" name="fecha_exp" required />
</td>
<td>
<div class='input-file'>
          <input type="file" name="archivo[]">
          <input type="hidden" name="codigo" value="<?php echo $fila["cod_emp"]; ?>">
            Seleccionar archivo
          <div class="files">...</div>
          </div>
</td>
</tr>
</tbody>
  </table>
<td>
<a href="#" id="btn-up" class="anex-up"> Anexar Otro Archivo </a>
<input id="btn-up" class="sub" type="submit" value="Cargar Documentos">
</td><br><br>
</form>

<script src="script/jquery-2.1.1.min.js"></script>
<script src="script/ext/external/jquery/jquery.js"></script>
<script src="script/jquery-ui.js"></script>


Código (javascript) [Seleccionar]

$(document).on("click",".anex-up",function() {
   $("#up_form tbody tr:eq(0)").clone().appendTo("#up_form tbody").append('<td class="eliminar"><div id="eliminar">x</div></td>');
    // (Se selecciona la ultima fila agregada, y se modifica el valor html del elemento con la clase 'files')

    $("#up_form tbody tr:eq(-1)").find(".files").html("...");

});

$(document).on("click",".eliminar",function(){
    var parent = $(this).parents().get(0);
    $(parent).remove();
});

$('body').on('focus',".datepicker", function(){
    $(this).datepicker();
});