问题是,使用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);
}
});
我该如何解决?
答案 0 :(得分:1)
使用 double 推迟创建 real 代理(创建一个实现代理接口的类,创建该类的实例而不是一个RF代理,在 flush 之后或之后创建真正的代理来替换假的那些;这样你永远不会创建一个不会被发送到服务器)。德尔>
或者,如果可能,只会将您的对象作为其他人的一部分进行验证,而不是单独验证{不要单独验证ContactDocument
,而只是作为验证Contact
的一部分,使用@Valid
在包含ContactDocument
s)的属性上:这可以使用覆盖ServiceLayerDecorator
方法的validate
来完成,可能在一个或两个类上与@GroupSequence
结合使用{ {1}}使用ServiceLayerDecorator
以外的特定群组进行验证。
相关问题:Cannot remove proxy from RequestContext editing context