fen1ksss
fen1ksss

Reputation: 1120

Wicket add method after the button click

I have the question, how to "reload" add method after the button click? for example:

ArrayList list = new ArrayList();
DataView dataView = new DataView("listview", new ListDataProvider(list)) {
    public void populateItem(final Item item) {
            final DBUser user = (DBUser) item.getModelObject();
            item.add(new Label("id", String.valueOf(user.getid())));
     }
};
final Load load = new Load(dataView);
    Form<?> form2 = new Form<Void>("form2") {
        @Override
        protected void onSubmit() {

            load.tick();
        }
};
add(dataView);

Now the load class:

public class Load {
private DataView dataView;

public Load(DataView dataView)
{
    this.dataView = dataView;
}

public DataView tick()
{
    Session session = HibernateUtil.getSessionFactory().openSession();//getCurrentSession();
    session.beginTransaction();
    Query query = session.createQuery(
            "from DBUser");
    ArrayList list = new ArrayList();
    for (Iterator it=query.iterate();it.hasNext();) {
        DBUser row = (DBUser) it.next();
        DBUser dbuser = new DBUser(row.getid());
        list.add(dbuser);
    }

    dataView = new DataView("listview", new ListDataProvider(list)) {
        public void populateItem(final Item item) {
            final DBUser user = (DBUser) item.getModelObject();
            item.add(new Label("id", String.valueOf(user.getid())));
        }
    };
    session.close();
    return dataView;
}

}

Right now add(line) method was called just once, how to call it after every button click?

here is my .html

<table frame="below" border=1>
    <tr wicket:id="listview">
         <td align="center" width="40"><span wicket:id="id"></span></td>
     </tr>
 </table>

Upvotes: 0

Views: 1299

Answers (1)

Artem Shafranov
Artem Shafranov

Reputation: 2673

I think, you could reload your DataView in such a way:

Form<?> form2 = new Form<Void>("form2") {

    @Override
    protected void onSubmit() {
        StartPage.this.replace( load.tick() );
        // or you can use 
        // StartPage.this.addOrReplace( load.tick() ) 
        // instead
    }
};

But your code also needs serious refactoring! As for me I would write it like so to improve readability:

final Load load = new Load();

Form<?> form2 = new Form<Void>("form2") {
    @Override
    protected void onSubmit() {
        StartPage.this.replace( createDataView( load.tick() ) );
    }
};
add(form2);

add( createDataView( new ArrayList() ) );

Implementation of the createDataView(list) method:

private DataView createDataView(List list) {
    return new DataView("listview", new ListDataProvider(list)) {
        public void populateItem(final Item item) {
            final DBUser user = (DBUser) item.getModelObject();
            item.add(new Label("id", String.valueOf(user.getid())));
        }
    };
}

Implementation of the Load class:

public class Load {

    public List tick() {
        List result = new ArrayList();
        // ...
        // populate list from database
        // ...
        return result;
    }
}

Hope this helps.

Upvotes: 2

Related Questions