Playframework: Looping over a list

Gaurav Sharma picture Gaurav Sharma · Jun 3, 2013 · Viewed 12.1k times · Source

I have a list that I'm passing back to the view.

public static Result index() {

        List<String> list = new ArrayList<String>();
        list.add("idea 1");
        list.add("idea 2");
        list.add("idea 3");
        list.add("idea 4");
        list.add("idea 5");
        list.add("idea 6");
        list.add("idea 7");

        return ok(index.render(list));
}

I'd like to iterate over it 3 at a time so that it's displayed like so:

<ul>
    <li>idea 1</li>
    <li>idea 2</li>
    <li>idea 3</li>
</ul>
<ul>
    <li>idea 4</li>
    <li>idea 5</li>
    <li>idea 6</li>
</ul>
<ul>
    <li>idea 7</li>
</ul>

I'm unable to figure out how to do this using the for loop.

I have the Java code for this, just unable to translate this to the Play framework template code:

        int size = list.size();
        int loopSize = (int) Math.ceil(size / 3.0);
        int counter = 0;

        for(int j = 0 ; j < loopSize; j++) {

            System.out.println("---------------------");            

            for (int i = 0; i < 3; i++) {
                if(counter < size) {
                    System.out.println(list.get(counter));
                    counter++;
                } else {
                    break;
                }
            }

            System.out.println("---------------------");
        }

Answer

Aerus picture Aerus · Jun 4, 2013

This should work:

@(list: List[String])

@for(index <- 0 until list.size){
    @if(index % 3 == 0){
        <ul>
    }

    <li>@list(index)</li>

    @if(index % 3 == 2 || index == (list.size - 1)){
        </ul>
    }
}