Grails formRemote - как избежать перенаправления на мульти-форму? - PullRequest
0 голосов
/ 06 апреля 2011

У меня есть главный контроллер с именем Screening. У меня есть рабочий процесс представления представления для этого контроллера (например: создать, редактировать, список, показать).

В моем представлении редактирования я использую Jquery TABS (каждая вкладка получает содержимое из шаблона, связанного с доменом). Итак, подведем итог:

Controller (Screening) -> Edit View -> tabs -> Eligibility Inclusion(tab - template/domain)
                                               Eligibility Exclusion(tab - template/domain)
                                               Demographics(tab - template/domain)

Итак, в моем представлении редактирования скрининга я использую formRemote для добавления части шаблона, например:

<div id="tabs">
<ul>
   <li><a href="#demographics"><span>Demographics</span></a></li>
</ul>

<div id="demographics">
<g:formRemote url="[controller:'demographics', action:'update']" update="ajaxMessage" name="demographicsForm">
<span class="onvButton"><g:actionSubmit value="Save" action="update" /></span>
<g:render template="/demographics/editDemographics" model="[demographicsInstance:demographicsInstance]" />
</g:formRemote>
</div> 

Я хотел бы сохранить проверки / сохранение в режиме скрининга, как я могу справиться с этим?
Фактически, если пользователи пытаются сохранить (или если проверка не удалась), они перенаправляются в демографический контроллер / представление; как этого избежать? Я не хочу, чтобы пользователи перенаправлялись.
Есть ли лучший способ обработки мультиформ (с ассоциацией шаблон / домен) в одном контроллере / домене?

1 Ответ

0 голосов
/ 11 апреля 2011

Это звучит так:

Контроллер:

def saveRemote = {

    def remoteT1Instance = new RemoteT1(params)
    if (remoteT1Instance.save(flush: true)) {
        flash.message = "${message(code: 'default.created.message', args: [message(code: 'remoteT1.label', default: 'RemoteT1'), remoteT1Instance.id])}"
    }
    else {
        flash.message = null
    }
    render(template: "remote", model: [remoteT1Instance: remoteT1Instance])
}

index.gsp:

<div id="updateArea">
  <g:render template="/remoteT1/remote"/>
</div>

_remote.gsp (шаблон):

<g:if test="${flash.message}">
            <div class="message">${flash.message}</div>
            </g:if>
            <g:hasErrors bean="${remoteT1Instance}">
            <div class="errors">
                <g:renderErrors bean="${remoteT1Instance}" as="list" />
            </div>
            </g:hasErrors>

            <g:formRemote
              name="editForm"
              url="[controller:'remoteT1', action:'saveRemote']"
              update="updateArea">
                    <table>
                        <tbody>

                            <tr class="prop">
                                <td valign="top" class="name">
                                    <label for="nom"><g:message code="remoteT1.nom.label" default="Nom" /></label>
                                </td>
                                <td valign="top" class="value ${hasErrors(bean: remoteT1Instance, field: 'nom', 'errors')}">
                                    <g:textField name="nom" value="${remoteT1Instance?.nom}" />
                                </td>
                            </tr>

                            <tr class="prop">
                                <td valign="top" class="name">
                                    <label for="prenom"><g:message code="remoteT1.prenom.label" default="Prenom" /></label>
                                </td>
                                <td valign="top" class="value ${hasErrors(bean: remoteT1Instance, field: 'prenom', 'errors')}">
                                    <g:textField name="prenom" value="${remoteT1Instance?.prenom}" />
                                </td>
                            </tr>

                            <tr class="prop">
                                <td valign="top" class="name">
                                    <label for="password"><g:message code="remoteT1.password.label" default="Password" /></label>
                                </td>
                                <td valign="top" class="value ${hasErrors(bean: remoteT1Instance, field: 'password', 'errors')}">
                                    <g:textField name="password" value="${remoteT1Instance?.password}" />
                                </td>
                            </tr>

                            <div id='reply2'></div>

                        </tbody>
                    </table>

                <div class="buttons">
                    <span class="button"><input type="submit" value="Register"/></span>
                </div>
            </g:formRemote>

Если я попытаюсь использовать: update = "[success: 'reply2', fail: 'updateArea']" в моем g: formRemote, звук не работает, я получаю 2 div (старый и новый) Я думаю, что это проблема JavaScript.

Кто-нибудь получил что-то лучше?

...