Сортировка таблицы Groovy, когда столбец представляет собой отсортированный набор класса

#grails #groovy

#grails #groovy

Вопрос:

У меня есть представление, в котором перечислены несколько объектов подрядчика. Последний столбец состоит из адресов, которые являются отсортированным набором в объекте contractor. Я пытаюсь отсортировать эти столбцы и получаю исключение, что свойство addresses не определено в class Contractors . Нужно ли мне по-разному обрабатывать отсортированный набор в контроллере?

 <table width="100%">
                <thead>
                <tr>
                    <th></th>
                    <g:sortableColumn property="status" title="${message(code: 'contractor.status.label', default: 'Status')}" params="[statuses:statuses,name:name,nameOperator:nameOperator ?: 'CONTAINS']"/>
                    <g:sortableColumn property="contractorName" title="${message(code: 'contractor.contractorName.label', default: 'Name')}" params="[statuses:statuses,name:name,nameOperator:nameOperator ?: 'CONTAINS']"/>

                    <g:sortableColumn property="addresses.address" title='Address' params="[statuses:statuses,name:name,nameOperator:nameOperator ?: 'CONTAINS']"/>

                </tr>
                </thead>
                <tbody>
                <g:each in="${contractorList}" status="i" var="contractor">
                    <tr class="${(i % 2) == 0 ? 'odd' : 'even'}">

                        <td>
                            <g:link action="show" id="${contractor.id}">show</g:link>
                            amp;nbsp;|amp;nbsp;
                            <g:link action="edit" id="${contractor.id}">edit</g:link>
                        </td>
                        <td>${contractor.status}</td>
                        <td>${contractor.contractorName}</td>
                        <td>${contractor?.addresses?.address}</td>

                    </tr>
                </g:each>
                </tbody>
            </table>
 

Логика в контроллере:

 order(params.sort, params.order)
 

Я очень новичок в groovy / grails, буду признателен за любую помощь, спасибо!

Ответ №1:

Я не уверен, есть ли что-нибудь доступное из коробки для этого, но вот как я решил свою аналогичную проблему. По сути, мне пришлось использовать параметр сортировки и выполнить свою собственную сортировку.:

 if (params.sort amp;amp; params.sort == "state") {
  tasks =  Task.activeOnly.open.unassigned.list() //<--my query
  tasks = sortByState(tasks,params) //<--custom sort
 }
 

— где sortByState это:

 private List sortByState(tasks, params){
        tasks.sort{Task.STATES.indexOf(it.state)} //<-- this is my custom sorter
        if (params.order == "DESC" ) {
            tasks = tasks.reverse()
        }
        def begin = params.int('offset') //<-- next two lines are for paging offsets
        def end = Math.min(begin params.int('max'),tasks.size()-1)
        return tasks[begin..end]
    }
 

Комментарии:

1. Спасибо DmitryB! Я попробую и посмотрю, как это получится.