GET:列表编辑器错误地尝试验证从列表中删除的实体

时间:2012-11-22 11:44:04

标签: java gwt bean-validation requestfactory gwt-editors

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

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

我的ContactDocuitor集合的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);
        }
    });

我该如何解决?

1 个答案:

答案 0 :(得分:1)

使用 double 推迟创建 real 代理(创建一个实现代理接口的类,创建该类的实例而不是一个RF代理,在 flush 之后或之后创建真正的代理来替换假的那些;这样你永远不会创建一个不会被发送到服务器)。

或者,如果可能,只会将您的对象作为其他人的一部分进行验证,而不是单独验证{不要单独验证ContactDocument,而只是作为验证Contact的一部分,使用@Valid在包含ContactDocument s)的属性上:这可以使用覆盖ServiceLayerDecorator方法的validate来完成,可能在一个或两个类上与@GroupSequence结合使用{ {1}}使用ServiceLayerDecorator以外的特定群组进行验证。

相关问题:Cannot remove proxy from RequestContext editing context