Technology Blogs by Members
Explore a vibrant mix of technical expertise, industry insights, and tech buzz in member blogs covering SAP products, technology, and events. Get in the mix!
cancel
Showing results for 
Search instead for 
Did you mean: 
former_member184578
Active Contributor

Introduction

This document helps how to make selected row of table editable in Web Dynpro ABAP.

Step by Step Process

Step 1: Create a Web Dynpro Component.

Go to the SE80 transaction and create a Web Dynpro Component.

Enter Description and click on OK.

Step 2: Data Binding

Go to the Context tab of Main View and create a node FLIGHT..

Enter dictionary structure SFLIGHT, cardinality 0..n and click on Add attributes from structure.

Select the required fields and click on OK.

Step 3: Layout Design.

   Now Go to Layout tab, and click on Web Dynpro Code Wizard( magic symbol button).


Double click on Table to create and bind Table UI.

Click on context and select the Flight Node.

Change the Standard cell editor to 'Input Filed' .and click on OK.

Now we can see the Table UI in the layout.

  Now select the carrid input field, under properties click on bind button for readOnly property.

Select the required attribute( by default it will be selected, here carrid ), And slect the radio button 'Bind to the property of selected Attribute' and select 'Read Only' property. click on OK.

Now click on table UI, under properties, click on create button for onLeadSelect Event to create an action for Lead Selection.

Enter Action Name, description and click on OK.

Now goto Methods tab, and enter below code in WDDOINIT method.

WDDOINIT

method WDDOINIT .

   DATA lo_nd_flight TYPE REF TO if_wd_context_node.

   DATA lt_flight TYPE wd_this->Elements_flight.

   DATA ls_flight TYPE wd_this->Element_flight.

   DATA lo_el_flight TYPE REF TO if_wd_context_element.

*   navigate from <CONTEXT> to <FLIGHT> via lead selection

   lo_nd_flight = wd_context->get_child_node( name = wd_this->wdctx_flight ).

   SELECT * FROM sflight into TABLE lt_flight UP TO 10 rows.

   lo_nd_flight->bind_table( new_items = lt_flight set_initial_elements = abap_true ).

* To disable all rows initially

   LOOP AT lt_flight INTO ls_flight.

     lo_el_flight = lo_nd_flight->get_element( index = sy-tabix ).

*  set single attribute

     lo_el_flight->set_attribute_property(

       attribute_name `CARRID`

       property = 3  " Property 3 - Read Only

       value = 'X' ). " Disable the rows for carrid

   ENDLOOP.

endmethod.

Enter below code in ONACTIONMODIFY_ROW method.

ONACTIONMODIFY_ROW

method ONACTIONMODIFY_ROW .

   DATA lo_nd_flight TYPE REF TO if_wd_context_node.

   DATA lo_el_flight TYPE REF TO if_wd_context_element.

   DATA lt_flight TYPE wd_this->Elements_flight.

   DATA ls_flight TYPE wd_this->Element_flight.

   DATA lv_index TYPE i.

*   navigate from <CONTEXT> to <FLIGHT> via lead selection

   lo_nd_flight = wd_context->get_child_node( name = wd_this->wdctx_flight ).

   lv_index = lo_nd_flight->get_lead_selection_index).

   lo_nd_flight->get_static_attributes_table( importing table = lt_flight ).

*  Enable selected row

   LOOP AT lt_flight INTO ls_flight.

     IF sy-tabix = lv_index.

       lo_el_flight = lo_nd_flight->get_element( index = sy-tabix ).

       lo_el_flight->set_attribute_property(

        attribute_name `CARRID`

        property = 3    " Property 3 - Read Only

        value = '' ).  " Enable

     ELSE.

       lo_el_flight = lo_nd_flight->get_element( index = sy-tabix ).

       lo_el_flight->set_attribute_property(

        attribute_name `CARRID`

        property = 3   " Property 3 - Read Only

        value = 'X' ).       " Disable

     ENDIF.

   ENDLOOP.

endmethod.

Now Save and Activate the Web Dynpro Component.

Create Application.

Create Web Dynpro Application and save it.


Now right click on web dynpro application and click on Test.

Result:

Now you can see, initially all the rows are disable.

Now select any row and the corresponding row will be enabled.

Conclusion

Here I demonstrated only for one column, we can disable all columns initially and make the entire row enable onLead Selection of the row.

Reference

I saw this thread http://scn.sap.com/thread/3163682 and tried for the solution, the above doc is one such experiment .

6 Comments
Labels in this area