4

问题是删除的 ContactDocumentseditor.getList().remove(index)仍然通过验证,因此无法保存已编辑的联系人。例如requestContext.save(),如果我添加新的 ContactDocument 并editor.getList().add()由于某些字段上的 @NotNull 违规而立即将其删除,则会因 onConstraintViolation 失败。

我有简单的关系:联系人有很多 ContactDocuments。我正在尝试使用请求工厂和编辑器框架编辑联系人。ContactDocuments 使用 JSR-303 进行注释以进行基本验证。

我的 ContactDocuments 集合的 ListEditor:

public class ContactDocumentListEditor extends Composite implements IsEditor<ListEditor<ContactDocumentProxy, ContactDocumentEditor>>, HasRequestContext<List<ContactDocumentProxy>> {
private RequestContext requestContext;

interface ViewUiBinder extends UiBinder<Widget, ContactDocumentListEditor> {}
private final static ViewUiBinder uiBinder = GWT.create(ViewUiBinder.class);

private final ListEditor<ContactDocumentProxy, ContactDocumentEditor> editor = ListEditor.of(new DocumentEditorSource());

@UiField
VerticalPanel container;
@UiField
Button addContactDocumentButton;


@UiHandler("addContactDocumentButton")
void addContactDocumentButtonClick(ClickEvent event) {
    addNewContactDocument();
}


public ContactDocumentListEditor() {
    initWidget(uiBinder.createAndBindUi(this));
}

private class DocumentEditorSource extends EditorSource<ContactDocumentEditor> {
    @Override
    public ContactDocumentEditor create(final int index) {
        final ContactDocumentEditor documentEditor = new ContactDocumentEditor();
        documentEditor.addClickHandler(new ClickHandler() {
            @Override
            public void onClick(ClickEvent event) {
                removeDocumentEditor(index);
            }
        });
        container.insert(documentEditor, index);
        return documentEditor;
    }

    @Override
    public void dispose(ContactDocumentEditor subEditor) {
        container.remove(subEditor);
    }

    @Override
    public void setIndex(ContactDocumentEditor subEditor, int index) {
        container.insert(subEditor, index);
    }
}

@Override
public ListEditor<ContactDocumentProxy, ContactDocumentEditor> asEditor() {
    return editor;
}

@Override
public void setRequestContext(RequestContext ctx) {
    requestContext = ctx;
}

private void addNewContactDocument() {
    ContactDocumentProxy newDocument = requestContext.create(ContactDocumentProxy.class);
    editor.getList().add(newDocument);
}

private void removeDocumentEditor(int index) {
    editor.getList().remove(index);
}
}

我的演示者来驱动它:

    final ContactRequestContext contactRequestContext =  contactRequestContextProvider.get();
    contactRequestContext.save(contact);
    driver.edit(contact, contactRequestContext);
    driver.flush().fire(new Receiver<Void>() {
        @Override
        public void onSuccess(Void response) {
            // success 
        }

        @Override
        public void onConstraintViolation(Set<ConstraintViolation<?>> violations) {
            for (ConstraintViolation violation : violations) {
                logger.info("Contact constraint violation: " + violation.getPropertyPath() + " = " + violation.getMessage());
            }
            driver.setConstraintViolations(violations);
        }
    });

我该如何解决?

4

1 回答 1

1

要么使用双重延迟创建真正的代理(创建一个实现代理接口的类,创建该类的实例而不是 RF 代理,并在刷新时或之后创建真正的代理来替换的代理;那方式你永远不会创建一个不会发送到服务器的代理)。

或者,如果可能,仅将您的对象作为其他对象的一部分进行验证,而不是单独验证(不要单独验证 a ContactDocument,仅作为验证 a 的一部分,在包含 s 的属性上Contact使用):这可以使用覆盖方法来完成,可能与一个或两个类上的a 以及使用除.@ValidContactDocumentServiceLayerDecoratorvalidate@GroupSequenceServiceLayerDecoratorDefault

相关问题:无法从 RequestContext 编辑上下文中删除代理

于 2012-11-22T13:27:33.870 回答