use of com.amalto.workbench.dialogs.NewGroupDialog in project tmdm-studio-se by Talend.
the class XSDNewGroupFromParticleAction method doAction.
public IStatus doAction() {
try {
IStructuredSelection selection = (IStructuredSelection) page.getTreeViewer().getSelection();
selParticle = (XSDParticle) selection.getFirstElement();
if (!(selParticle.getContainer() instanceof XSDModelGroup))
return Status.CANCEL_STATUS;
XSDModelGroup group = (XSDModelGroup) selParticle.getContainer();
// get position of the selected particle in the container
int index = 0;
int i = 0;
for (Iterator iter = group.getContents().iterator(); iter.hasNext(); ) {
XSDParticle p = (XSDParticle) iter.next();
if (p.equals(selParticle)) {
index = i;
break;
}
i++;
}
dialog = new NewGroupDialog(this, page.getSite().getShell());
dialog.setBlockOnOpen(true);
int ret = dialog.open();
if (ret == Dialog.CANCEL) {
return Status.CANCEL_STATUS;
}
XSDFactory factory = XSDSchemaBuildingTools.getXSDFactory();
// add an element declaration
XSDElementDeclaration subElement = factory.createXSDElementDeclaration();
// $NON-NLS-1$
subElement.setName("subelement");
// $NON-NLS-1$
subElement.setTypeDefinition(schema.resolveSimpleTypeDefinition(schema.getSchemaForSchemaNamespace(), "string"));
XSDParticle subParticle = factory.createXSDParticle();
subParticle.setMinOccurs(1);
subParticle.setMaxOccurs(1);
subParticle.setContent(subElement);
subParticle.updateElement();
XSDModelGroup newGroup = factory.createXSDModelGroup();
if (isChoice)
newGroup.setCompositor(XSDCompositor.CHOICE_LITERAL);
else if (isAll)
newGroup.setCompositor(XSDCompositor.ALL_LITERAL);
else
newGroup.setCompositor(XSDCompositor.SEQUENCE_LITERAL);
newGroup.getContents().add(0, subParticle);
newGroup.updateElement();
XSDParticle particle = factory.createXSDParticle();
particle.setContent(newGroup);
particle.setMinOccurs(this.minOccurs);
particle.setMaxOccurs(this.maxOccurs);
group.getContents().add(index + 1, particle);
group.updateElement();
page.refresh();
page.getTreeViewer().setSelection(new StructuredSelection(particle), true);
page.markDirty();
} catch (Exception e) {
log.error(e.getMessage(), e);
MessageDialog.openError(page.getSite().getShell(), Messages._Error, Messages.bind(Messages.XSDNewGroupFromParticleAction_ErrorMsg, e.getLocalizedMessage()));
return Status.CANCEL_STATUS;
}
return Status.CANCEL_STATUS;
}
use of com.amalto.workbench.dialogs.NewGroupDialog in project tmdm-studio-se by Talend.
the class XSDNewGroupFromTypeAction method doAction.
public IStatus doAction() {
try {
IStructuredSelection selection = (IStructuredSelection) page.getTreeViewer().getSelection();
if (selection.getFirstElement() instanceof XSDComplexTypeDefinition) {
XSDComplexTypeDefinition ctd = (XSDComplexTypeDefinition) selection.getFirstElement();
if (!(ctd.getContent() instanceof XSDParticle))
return Status.CANCEL_STATUS;
if (!(((XSDParticle) ctd.getContent()).getTerm() instanceof XSDModelGroup))
return Status.CANCEL_STATUS;
group = (XSDModelGroup) ((XSDParticle) ctd.getContent()).getTerm();
} else if (selection.getFirstElement() instanceof XSDParticle) {
group = (XSDModelGroup) ((XSDParticle) selection.getFirstElement()).getTerm();
} else {
return Status.CANCEL_STATUS;
}
dialog = new NewGroupDialog(this, page.getSite().getShell());
dialog.setBlockOnOpen(true);
int ret = dialog.open();
if (ret == Window.CANCEL) {
return Status.CANCEL_STATUS;
}
XSDFactory factory = XSDSchemaBuildingTools.getXSDFactory();
// add an element declaration
XSDElementDeclaration subElement = factory.createXSDElementDeclaration();
// $NON-NLS-1$
subElement.setName("subelement");
// $NON-NLS-1$
subElement.setTypeDefinition(schema.resolveSimpleTypeDefinition(schema.getSchemaForSchemaNamespace(), "string"));
XSDParticle subParticle = factory.createXSDParticle();
subParticle.setMinOccurs(1);
subParticle.setMaxOccurs(1);
subParticle.setContent(subElement);
subParticle.updateElement();
XSDModelGroup newGroup = factory.createXSDModelGroup();
if (isChoice)
newGroup.setCompositor(XSDCompositor.CHOICE_LITERAL);
else if (isAll)
newGroup.setCompositor(XSDCompositor.ALL_LITERAL);
else
newGroup.setCompositor(XSDCompositor.SEQUENCE_LITERAL);
newGroup.getContents().add(0, subParticle);
newGroup.updateElement();
XSDParticle particle = factory.createXSDParticle();
particle.setContent(newGroup);
particle.setMinOccurs(this.minOccurs);
particle.setMaxOccurs(this.maxOccurs);
group.getContents().add(0, particle);
group.updateElement();
page.refresh();
page.getTreeViewer().setSelection(new StructuredSelection(particle), true);
page.markDirty();
} catch (Exception e) {
log.error(e.getMessage(), e);
MessageDialog.openError(page.getSite().getShell(), Messages._Error, Messages.bind(Messages.XSDNewGroupFromTypeAction_ErrorMsg, e.getLocalizedMessage()));
return Status.CANCEL_STATUS;
}
return Status.OK_STATUS;
}
Aggregations