diff -r 000000000000 -r 522a326673b6 sysmodelmgr/com.symbian.smt.gui/src/com/symbian/smt/gui/preferences/AdvancedOptionsPreferences.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/sysmodelmgr/com.symbian.smt.gui/src/com/symbian/smt/gui/preferences/AdvancedOptionsPreferences.java Thu Mar 11 19:08:43 2010 +0200 @@ -0,0 +1,116 @@ +// Copyright (c) 2008-2009 Nokia Corporation and/or its subsidiary(-ies). +// All rights reserved. +// This component and the accompanying materials are made available +// under the terms of "Eclipse Public License v1.0" +// which accompanies this distribution, and is available +// at the URL "http://www.eclipse.org/legal/epl-v10.html". +// +// Initial Contributors: +// Nokia Corporation - initial contribution. +// +// Contributors: +// +// Description: +// + + + +package com.symbian.smt.gui.preferences; + +import org.eclipse.core.runtime.preferences.DefaultScope; +import org.eclipse.core.runtime.preferences.IEclipsePreferences; +import org.eclipse.core.runtime.preferences.IScopeContext; +import org.eclipse.core.runtime.preferences.InstanceScope; +import org.eclipse.jface.preference.PreferencePage; +import org.eclipse.jface.resource.ImageDescriptor; +import org.eclipse.swt.SWT; +import org.eclipse.swt.layout.FillLayout; +import org.eclipse.swt.widgets.Composite; +import org.eclipse.swt.widgets.Control; +import org.eclipse.ui.IWorkbench; +import org.eclipse.ui.IWorkbenchPreferencePage; + +import com.symbian.smt.gui.AbstractPersistentDataStore; +import com.symbian.smt.gui.Activator; +import com.symbian.smt.gui.PersistentDataStore; +import com.symbian.smt.gui.smtwidgets.AdvancedOptionsWidget; + +/** + * This is the Preference page for the Advanced Options. It utilises the + * AdvancedOptionsWidget. + *

+ * By default, there are no advanced options defined. + *

+ * + * @author barbararosi-schwartz + */ +public class AdvancedOptionsPreferences extends PreferencePage implements + IWorkbenchPreferencePage { + + private AdvancedOptionsWidget advancedOptionsWidget; + private AbstractPersistentDataStore instanceStore; + private AbstractPersistentDataStore defaultStore; + + public AdvancedOptionsPreferences() { + } + + public AdvancedOptionsPreferences(String title) { + super(title); + } + + public AdvancedOptionsPreferences(String title, ImageDescriptor image) { + super(title, image); + } + + @Override + protected Control createContents(Composite parent) { + Composite composite = new Composite(parent, SWT.NONE); + composite.setLayout(new FillLayout(SWT.VERTICAL)); + + advancedOptionsWidget = new AdvancedOptionsWidget(composite, SWT.NONE); + + IScopeContext defaultScope = new DefaultScope(); + IEclipsePreferences defaultNode = defaultScope + .getNode(Activator.PLUGIN_ID); + defaultStore = new PersistentDataStore(defaultNode); + + IScopeContext instanceScope = new InstanceScope(); + IEclipsePreferences instanceNode = instanceScope + .getNode(Activator.PLUGIN_ID); + instanceStore = new PersistentDataStore(instanceNode, defaultNode); + + advancedOptionsWidget.setAdvancedOptions(instanceStore + .getAdvancedOptions()); + + composite.pack(); + parent.pack(); + + return composite; + } + + public void init(IWorkbench workbench) { + setPreferenceStore(Activator.getDefault().getPreferenceStore()); + setDescription("System Model Diagram advanced options.\n" + + "These must be defined in their entirety. " + + "Their order is also user defined."); + } + + public void performDefaults() { + restoreDefaults(); + } + + public boolean performOk() { + storeValues(); + return super.performOk(); + } + + private void restoreDefaults() { + advancedOptionsWidget.setAdvancedOptions(defaultStore + .getAdvancedOptions()); + } + + private void storeValues() { + instanceStore.setAdvancedOptions(advancedOptionsWidget + .getAdvancedOptions()); + } +}