Refrescar ALV
Buenas, tengo un programa saca una alv, y al pinchar en el documento de compra, me va a la transaccion ME23N y modifico lo que sea.
El caso esque le doy al boton refrescar y no me hace nada de nada, y ya no se como hacerlo. He probado a poner: rs_selfield-refresh = 'X'. lo e puesto en mil sitios para probar y nada de nada, no me refresca , aber si alguien me echa una mano. Dejo el perfom q uso: *---------------------------------------------------------------------* * FORM user_command * *---------------------------------------------------------------------* FORM callback_ucomm USING r_ucomm LIKE sy-ucomm rs_selfield TYPE slis_selfield. DATA answer. CONSTANTS ansy VALUE 'J'. DATA noborra. DATA: usuario TYPE r_usuario. DATA: usuario_altern TYPE r_usuario. CASE r_ucomm. WHEN '&REF'. rs_selfield-refresh = 'X'. w_res-refresh = 'X'. WHEN '&IC1'. * Mostramos el pedido o el listado secundario SELECT SINGLE * FROM ekko WHERE ebeln = rs_selfield-value. IF sy-subrc = 0. rs_selfield-refresh = 'X'. SET PARAMETER ID 'BES' FIELD rs_selfield-value. = 'X'. CALL TRANSACTION 'ME23N'. ELSE. READ TABLE i_data INDEX rs_selfield-tabindex. PERFORM pantalla_historial. ENDIF. *- Ini Ins SIS5F 13/10/05 WHEN '&DEL'. LOOP AT i_data WHERE mark = 'X'. PERFORM borrado_pos USING i_data noborra. * La desmarco en el ALV IF noborra = 'X'. i_data-mark = ' '. CLEAR noborra. MODIFY i_data. ELSE. ENDIF. ENDLOOP. PERFORM mostrar_posibles_mod. IF NOT tab_borrado IS INITIAL. CALL FUNCTION 'POPUP_TO_CONFIRM_WITH_MESSAGE' EXPORTING defaultoption = 'N' diagnosetext1 = text-006 diagnosetext2 = text-007 diagnosetext3 = text-008 textline1 = text-010 titel = text-009 IMPORTING answer = answer. CASE answer. WHEN ansy. PERFORM ejecutar_borrado. MOVE 'X' TO rs_selfield-refresh. WHEN OTHERS. *** Cancelada por usuario MESSAGE s000(zmm) WITH text-014. ENDCASE. ENDIF. ********Tratamiento Usuario Alternativo.************* WHEN '&USU'. CLEAR: i_data_altern, usuario, usuario_altern. REFRESH i_data_altern[]. LOOP AT i_data WHERE mark = 'X'. MOVE-CORRESPONDING i_data TO i_data_altern. APPEND i_data_altern. ENDLOOP. IF sy-subrc <> 0. MESSAGE e000(zmm) WITH 'Seleccione al menos un registro'. ENDIF. PERFORM usuario_alternativo USING usuario usuario_altern. *6º Vuelvo. al alv (1º refrescar) MOVE 'X' TO rs_selfield-refresh. *- FIn Ins SIS5F 5/02/06 WHEN OTHERS. ENDCASE. ENDFORM. |
Que cosas cambias?'
O a que te refieres de que no cambia los datos?' Si pones un ejemplo estaria mejor |
Que tipo de cambio quieres?
Por lo que he entendido, lo que quieres es ver reflejados los cambios en el ALV que has hecho por la transaccion, si es asi, el problema que veo a primera vista es que en ningun momento le dices a la transaccion que devuleva los datos, cosa que veo dificil o al menos yo no tengo idea de como hacerlo si no es a traves de una consulta a tablas. De cualquier manera si aclaras un poco mas el problema para mas o menos entenderte mejor, saludos...
|
Buenas que tal. No te esta refrescando el ALV porque la tabla interna no es alterada cuando ejecutas la trx ME23N. Se me ocurren una par de cosas que te lo actualizarian pero no son buenas practicas. Hasta me da verguenza escribirlas :D
Saludos. PD: Field symbol a la tabla del programa y modificarla desde ahi :D . Con un refresh deberia funcionar. |
Bien, lo que digo, esque llamo a la transaccion me23n, y cambio el importe por ejemplo, entonces al grabar, me vuelve a la alv, pero, en la columna importe, sigue siendo la misma, no me a cambiado el importe, y yo kiero eso, o que cuando regrese de la transacion, cambial el contedo de la fila que e cambiado o que le de al boton refrescar y me lo cambie.
Como uso Field symbol , y el refres?? por probarlo.......... |
Lo que he visto es que no vuelves a llamar a los datos guardados en la transaccion ME23N, por lo que veo es que te falta primero volver a consultar los datos de las tablas.
|
Bueno el ejemplo, seria q pincho en el doc. de compra, me va a la me23n, cambio el importe, le doy a grabar, me volveria a la alv, y una de dos, o bien le doy a un boton y q me la actualize, pero e probado con :
CASE r_ucomm. WHEN '&REFRESH'. rs_selfield-refresh = 'X'. pero no refresca ni nada, o sino, que al grabar, cambiara los datos de la alv |
Buenas, hmmm, si no he entendido mal, lo que deberias hacer es refrescar la tabla interna, osease volver a seleccionar todos los datos ya que tienes una incoherencia, actualizas el diccionario mediante la transaccion y pretendes actualizar el alv con los datos que hay en la tabla interna.
Create un perform de seleccion, lo llamas en el start of selecction, muestras el alv, controlas de alguna manera si los datos cambian, por ejemplo cuando haces el call transaction, marcas un flag, si el flag esta marcado refresh de la tabla interna, llamas el perform de seleccion de datos y luego refresh del alv. Yo haria esto, antes de liarme con field symbols :D Saludos, LouieBoy |
1 Adjunto(s)
Bueno os adjunto el programa por si alguien me le puede echar un vistazo y decirme.
|
Buenas, ¿te has leido mi post? Si es asi, explicame que parte no entiendes y tel a vuelvo a explicar.
Saludos, LouieBoy |
Husos Horarios son GMT. La hora en este momento es 05:58:27. |
www.mundosap.com 2006 - Spain
software crm, crm on demand, software call center, crm act, crm solutions, crm gratis, crm web