Estoy haciendo un pequeño sistema de ticketing y, en su página inicial, quiero incluir un select que permita ver una tabla de los tickets:
-Asignados al grupo del usuario
-Creados por el usuario
-Creados por cualquier usuario del grupo del usuario
Es algo como lo que ya tienen otras herramientas profesionales. Hasta ahora estaba usando JavaScript y Ajax para que, onchange en mano, no fuera necesario pinchar en ningún "submit" y tampoco fuera necesario recargar la página. Lo de tener que recargarla o no me da igual para el proyecto. El problema viene en que, al recargar la página, sea cual sea el objeto de la página que quiera enviar al servidor no consigo actualizar la página (todo o parte) bien.
Me explico algo mejor, con unos <div> tengo separada la pantalla en:
-Barra de título (arriba)
-Bloque Opciones/Enlaces (a la izquierda)
-Resto de la pantalla
Con el código que tengo (el que está mal y quiero corregir sin saber aún cómo), cuando salta el onChange se recarga toda la pantalla (título, bloque y resto) en el espacio que hay para el resto. Este es el código:
Código PHP:
Ver original
<form name="ticketViews" id="ticketViews" action=""> <select name="optionsUnfold" id="optionsUnfold" onchange="handleTicketViews(this.form)"> <option value="1">Asignados a mi grupo</option> <option value="2">Creados por mi</option> <option value="3">Creados por mi grupo</option> </select> </form>
Código Javascript:
Ver original
function handleTicketViews(){ userList = document.getElementById("optionsUnfold"); userValue = userList.options[userList.selectedIndex].value; url = "Tickets.php?handle="+userValue; view.open("GET", url, true); view.onreadystatechange = viewResponse; view.send(null); } function viewResponse(){ if(view.readyState == 4){ if(view.status == 200){ document.getElementById("ticketViews").innerHTML = view.responseText; } else{ alert('Ha ocurrido un error: '+view.statusText); } } }
Igual me he empeñado en hacerlo en JavaScript sin tener por qué, cuando lo que realmente quiero es (lo explico en modo bruto):
1.Detectar que el usuario ha seleccionado/cambiado una opción sin tener que apretar botón alguno (ni de hacer nada más)
2.Capturar el valor/texto (mejor el valor) de la selección
3.En base a la selección volver a mostrar la misma página, pero con el contenido de la tabla arriba indicada actualizado
Claro está, en base a la selección hecha por el usuario voy a hacer una query MySQL u otra para extraer dichos datos.
¿Veis donde estoy metiendo la pata? ¿Lo haríais de otra manera?
Gracias por anticipado.