Skip to main content
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'jpa/plugins/org.eclipse.jpt.ui/src/org/eclipse/jpt/ui/internal/views/JpaDetailsView.java')
-rw-r--r--jpa/plugins/org.eclipse.jpt.ui/src/org/eclipse/jpt/ui/internal/views/JpaDetailsView.java190
1 files changed, 0 insertions, 190 deletions
diff --git a/jpa/plugins/org.eclipse.jpt.ui/src/org/eclipse/jpt/ui/internal/views/JpaDetailsView.java b/jpa/plugins/org.eclipse.jpt.ui/src/org/eclipse/jpt/ui/internal/views/JpaDetailsView.java
deleted file mode 100644
index 228056d92f..0000000000
--- a/jpa/plugins/org.eclipse.jpt.ui/src/org/eclipse/jpt/ui/internal/views/JpaDetailsView.java
+++ /dev/null
@@ -1,190 +0,0 @@
-/*******************************************************************************
- * Copyright (c) 2006, 2010 Oracle. All rights reserved. This
- * program and the accompanying materials are made available under the terms of
- * the Eclipse Public License v1.0 which accompanies this distribution, and is
- * available at http://www.eclipse.org/legal/epl-v10.html
- *
- * Contributors: Oracle. - initial API and implementation
- *******************************************************************************/
-package org.eclipse.jpt.ui.internal.views;
-
-import java.util.HashMap;
-import java.util.Map;
-import org.eclipse.jpt.core.JpaResourceType;
-import org.eclipse.jpt.core.JpaStructureNode;
-import org.eclipse.jpt.ui.JpaPlatformUi;
-import org.eclipse.jpt.ui.JptUiPlugin;
-import org.eclipse.jpt.ui.details.JpaDetailsPage;
-import org.eclipse.jpt.ui.internal.JptUiMessages;
-import org.eclipse.jpt.ui.internal.platform.JpaPlatformUiRegistry;
-import org.eclipse.jpt.ui.internal.selection.JpaSelection;
-import org.eclipse.swt.SWT;
-import org.eclipse.swt.layout.FillLayout;
-import org.eclipse.swt.widgets.Composite;
-
-/**
- * The JPA view that shows the details of a structure node
- *
- * @version 2.2
- * @since 1.0
- */
-public class JpaDetailsView extends AbstractJpaView
-{
- /**
- * The current <code>JpaDetailsPage</code> that was retrieve based on the
- * current selection.
- */
- private JpaDetailsPage<JpaStructureNode> currentPage;
-
- /**
- * The current selection used to show the right <code>IJpaDetailsPage</code>.
- */
- private JpaSelection currentSelection;
-
- //TODO this is crap, a Map of Maps of Maps. Needs to be done differently, the factory/platform should handle caching instead
- // key1 platform id
- // key2 JpaResourceType
- // key3 structure node type
- // value Composite page
- private Map<String, Map<JpaResourceType, Map<String, JpaDetailsPage<? extends JpaStructureNode>>>> detailsPages;
-
- /**
- * Creates a new <code>JpaDetailsView</code>.
- */
- public JpaDetailsView() {
- super(JptUiMessages.JpaDetailsView_viewNotAvailable);
- }
-
- @Override
- protected void initialize() {
- super.initialize();
-
- this.currentSelection = JpaSelection.NULL_SELECTION;
- this.detailsPages = new HashMap<String, Map<JpaResourceType, Map<String, JpaDetailsPage<? extends JpaStructureNode>>>>();
- }
-
- private JpaPlatformUi getJpaPlatformUi(JpaStructureNode structureNode) {
- String platformId = structureNode.getJpaProject().getJpaPlatform().getId();
- return JpaPlatformUiRegistry.instance().getJpaPlatformUi(platformId);
- }
-
- public JpaSelection getSelection() {
- return this.currentSelection;
- }
-
- private JpaDetailsPage<? extends JpaStructureNode> getDetailsPage(JpaStructureNode structureNode) {
- String platformId = structureNode.getJpaProject().getJpaPlatform().getId();
- if (this.detailsPages.containsKey(platformId)) {
- Map<JpaResourceType, Map<String, JpaDetailsPage<? extends JpaStructureNode>>> platformDetailsPages = this.detailsPages.get(platformId);
- Map<String, JpaDetailsPage<? extends JpaStructureNode>> contentTypeDetailsPages = platformDetailsPages.get(structureNode.getResourceType());
- if (contentTypeDetailsPages != null) {
- JpaDetailsPage<? extends JpaStructureNode> page = contentTypeDetailsPages.get(structureNode.getId());
- if (page != null) {
- if (page.getControl().isDisposed()) {
- platformDetailsPages.remove(structureNode.getId());
- } else {
- return page;
- }
- }
- }
- }
- return buildDetailsPage(structureNode);
- }
-
- private JpaDetailsPage<? extends JpaStructureNode> buildDetailsPage(JpaStructureNode structureNode) {
- JpaPlatformUi jpaPlatformUi = getJpaPlatformUi(structureNode);
-
- Composite container = getWidgetFactory().createComposite(getPageBook());
- container.setLayout(new FillLayout(SWT.HORIZONTAL));
-
- JpaDetailsPage<? extends JpaStructureNode> page = jpaPlatformUi.buildJpaDetailsPage(container, structureNode, getWidgetFactory());
- if (page == null) {
- return null;
- }
-
- String platformId = structureNode.getJpaProject().getJpaPlatform().getId();
- Map<JpaResourceType, Map<String, JpaDetailsPage<? extends JpaStructureNode>>> platformDetailsPages = this.detailsPages.get(platformId);
- if (platformDetailsPages == null) {
- platformDetailsPages = new HashMap<JpaResourceType, Map<String, JpaDetailsPage<? extends JpaStructureNode>>>();
- this.detailsPages.put(platformId, platformDetailsPages);
- }
- JpaResourceType resourceType = structureNode.getResourceType();
- Map<String, JpaDetailsPage<? extends JpaStructureNode>> contentTypeDetailsPages = platformDetailsPages.get(resourceType);
- if (contentTypeDetailsPages == null) {
- contentTypeDetailsPages = new HashMap<String, JpaDetailsPage<? extends JpaStructureNode>>();
- platformDetailsPages.put(resourceType, contentTypeDetailsPages);
- }
- contentTypeDetailsPages.put(structureNode.getId(), page);
-
- return page;
- }
-
- @Override
- @SuppressWarnings("unchecked")
- public void select(JpaSelection jpaSelection) {
- if (jpaSelection.equals(this.currentSelection)) {
- return;
- }
-
- this.currentSelection = jpaSelection;
- if (jpaSelection == JpaSelection.NULL_SELECTION) {
- if (this.currentPage != null) {
- this.currentPage.setSubject(null);
- this.setCurrentPage(null);
- }
- return;
- }
- JpaStructureNode newNode = jpaSelection.getSelectedNode();
- JpaDetailsPage<JpaStructureNode> newPage = (JpaDetailsPage<JpaStructureNode>) getDetailsPage(newNode);
- if (this.currentPage != null && this.currentPage != newPage){
- try {
- this.currentPage.setSubject(null);
- } catch (Exception e) {
- JptUiPlugin.log(e);
- }
- }
- if (newPage != null) {
- try {
- newPage.setSubject(newNode);
- } catch (Exception e) {
- newPage = null;// Show error page
- JptUiPlugin.log(e);
- }
- }
- setCurrentPage(newPage);
- }
-
- /**
- * Changes the current page and shows the given page.
- *
- * @param newPage The new page to display
- */
- private void setCurrentPage(JpaDetailsPage<JpaStructureNode> newPage) {
- this.currentPage = newPage;
-
- // Show new page
- if (newPage == null) {
- showDefaultPage();
- }
- else {
- showPage(newPage.getControl());
- }
- }
-
- @Override
- public void dispose() {
- for (Map<JpaResourceType, Map<String, JpaDetailsPage<? extends JpaStructureNode>>> resourceTypeMap : this.detailsPages.values()) {
- for (Map<String, JpaDetailsPage<? extends JpaStructureNode>> detailsPageMap : resourceTypeMap.values()) {
- for (JpaDetailsPage<? extends JpaStructureNode> detailsPage : detailsPageMap.values()) {
- detailsPage.dispose();
- }
- }
- }
- this.detailsPages.clear();
-
- this.currentSelection = JpaSelection.NULL_SELECTION;
- this.currentPage = null;
-
- super.dispose();
- }
-} \ No newline at end of file

Back to the top