public code v1
This commit is contained in:
@@ -0,0 +1,7 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<classpath>
|
||||
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.8"/>
|
||||
<classpathentry kind="con" path="org.eclipse.pde.core.requiredPlugins"/>
|
||||
<classpathentry kind="src" path="src"/>
|
||||
<classpathentry kind="output" path="bin"/>
|
||||
</classpath>
|
||||
@@ -0,0 +1,14 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
|
||||
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
<parent>
|
||||
<groupId>flintstones.group</groupId>
|
||||
<artifactId>flintstones.bundles</artifactId>
|
||||
<version>1.0.0-SNAPSHOT</version>
|
||||
</parent>
|
||||
<artifactId>flintstones.method.todim.phase.gathering.ui</artifactId>
|
||||
<version>1.0.0-SNAPSHOT</version>
|
||||
<packaging>eclipse-plugin</packaging>
|
||||
<name>[bundle] Ui</name>
|
||||
</project>
|
||||
@@ -0,0 +1,45 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<projectDescription>
|
||||
<name>flintstones.method.todim.phase.gathering.ui</name>
|
||||
<comment></comment>
|
||||
<projects>
|
||||
</projects>
|
||||
<buildSpec>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.jdt.core.javabuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.pde.ManifestBuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.pde.SchemaBuilder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
<buildCommand>
|
||||
<name>org.eclipse.m2e.core.maven2Builder</name>
|
||||
<arguments>
|
||||
</arguments>
|
||||
</buildCommand>
|
||||
</buildSpec>
|
||||
<natures>
|
||||
<nature>org.eclipse.m2e.core.maven2Nature</nature>
|
||||
<nature>org.eclipse.pde.PluginNature</nature>
|
||||
<nature>org.eclipse.jdt.core.javanature</nature>
|
||||
</natures>
|
||||
<filteredResources>
|
||||
<filter>
|
||||
<id>1779484362700</id>
|
||||
<name></name>
|
||||
<type>30</type>
|
||||
<matcher>
|
||||
<id>org.eclipse.core.resources.regexFilterMatcher</id>
|
||||
<arguments>node_modules|\.git|__CREATED_BY_JAVA_LANGUAGE_SERVER__</arguments>
|
||||
</matcher>
|
||||
</filter>
|
||||
</filteredResources>
|
||||
</projectDescription>
|
||||
+2
@@ -0,0 +1,2 @@
|
||||
eclipse.preferences.version=1
|
||||
encoding/<project>=UTF-8
|
||||
+7
@@ -0,0 +1,7 @@
|
||||
eclipse.preferences.version=1
|
||||
org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
|
||||
org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8
|
||||
org.eclipse.jdt.core.compiler.compliance=1.8
|
||||
org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
|
||||
org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
|
||||
org.eclipse.jdt.core.compiler.source=1.8
|
||||
+4
@@ -0,0 +1,4 @@
|
||||
activeProfiles=
|
||||
eclipse.preferences.version=1
|
||||
resolveWorkspaceProjects=true
|
||||
version=1
|
||||
@@ -0,0 +1,21 @@
|
||||
Manifest-Version: 1.0
|
||||
Bundle-ManifestVersion: 2
|
||||
Bundle-Name: Ui
|
||||
Bundle-SymbolicName: flintstones.method.todim.phase.gathering.ui;singleton:=true
|
||||
Bundle-Version: 1.0.0.qualifier
|
||||
Automatic-Module-Name: flintstones.method.todim.phase.gathering.ui
|
||||
Bundle-RequiredExecutionEnvironment: JavaSE-11
|
||||
Require-Bundle: org.eclipse.swt,
|
||||
flintstones.model.ui.service,
|
||||
flintstones.helper.html,
|
||||
org.eclipse.jface,
|
||||
javax.inject,
|
||||
org.eclipse.e4.core.contexts,
|
||||
org.eclipse.e4.core.services,
|
||||
flintstones.entity.method.phase.ui,
|
||||
flintstones.model.problemelement.service,
|
||||
flintstones.application.perspective.framework.ui,
|
||||
flintstones.method.todim.phase.gathering,
|
||||
flintstones.entity.method.phase,
|
||||
flintstones.entity.problemelement,
|
||||
flintstones.model.method.phase.service
|
||||
@@ -0,0 +1,5 @@
|
||||
source.. = src/
|
||||
output.. = bin/
|
||||
bin.includes = META-INF/,\
|
||||
.,\
|
||||
plugin.xml
|
||||
@@ -0,0 +1,13 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<?eclipse version="3.4"?>
|
||||
<plugin>
|
||||
<extension
|
||||
point="flintstones.phasemethod.ui">
|
||||
<phasemethod_ui
|
||||
uid="flintstones.method.todim.phase.gathering.ui"
|
||||
implementation="flintstones.method.todim.phase.gathering.ui.TODIMPhaseUI"
|
||||
phasemethod="flintstones.method.todim.phase.gathering">
|
||||
</phasemethod_ui>
|
||||
</extension>
|
||||
|
||||
</plugin>
|
||||
+77
@@ -0,0 +1,77 @@
|
||||
package flintstones.method.todim.phase.gathering.provider;
|
||||
|
||||
import javax.inject.Inject;
|
||||
|
||||
import org.eclipse.jface.resource.ImageDescriptor;
|
||||
import org.eclipse.jface.viewers.DelegatingStyledCellLabelProvider.IStyledLabelProvider;
|
||||
import org.eclipse.jface.viewers.LabelProvider;
|
||||
import org.eclipse.jface.viewers.StyledString;
|
||||
import org.eclipse.swt.graphics.Color;
|
||||
import org.eclipse.swt.graphics.Image;
|
||||
|
||||
import flintstones.entity.problemelement.entities.ProblemElement;
|
||||
import flintstones.model.method.phase.IPhaseMethodService;
|
||||
import flintstones.model.ui.service.UiService;
|
||||
import flintstones.model.ui.service.style.ForegroundStyler;
|
||||
|
||||
public class ProblemElementLabelProvider extends LabelProvider implements IStyledLabelProvider {
|
||||
|
||||
@Inject
|
||||
IPhaseMethodService phaseService;
|
||||
|
||||
/** The group image. */
|
||||
private final ImageDescriptor groupImage;
|
||||
|
||||
/** The individual image. */
|
||||
private final ImageDescriptor individualImage;
|
||||
|
||||
|
||||
/**
|
||||
* Instantiates a new problem element name label provider.
|
||||
*
|
||||
* @param individualImage the individual image
|
||||
* @param groupImage the group image
|
||||
*/
|
||||
public ProblemElementLabelProvider(ImageDescriptor individualImage, ImageDescriptor groupImage) {
|
||||
this.groupImage = groupImage;
|
||||
this.individualImage = individualImage;
|
||||
}
|
||||
|
||||
@Override
|
||||
public StyledString getStyledText(Object element) {
|
||||
if (element instanceof ProblemElement) {
|
||||
ProblemElement pe = (ProblemElement) element;
|
||||
StyledString styledString;
|
||||
styledString = paint(pe.getName(), "");
|
||||
|
||||
return styledString;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
/* (non-Javadoc)
|
||||
*
|
||||
* @see org.eclipse.jface.viewers.LabelProvider#getImage(java.lang.Object) */
|
||||
@Override
|
||||
public Image getImage(Object element) {
|
||||
if (element instanceof ProblemElement) {
|
||||
if (((ProblemElement) element).hasChildren())
|
||||
return this.groupImage.createImage();
|
||||
|
||||
return this.individualImage.createImage();
|
||||
}
|
||||
|
||||
return super.getImage(element);
|
||||
}
|
||||
|
||||
private StyledString paint(String leftText, String rightText) {
|
||||
|
||||
Color foregroundColorLeft = UiService.COLOR_FG_NORMAL;
|
||||
Color foregroundColorRight = UiService.COLOR_FG_SECONDARY;
|
||||
|
||||
StyledString leftT = new StyledString(leftText, new ForegroundStyler(foregroundColorLeft));
|
||||
StyledString rightT = new StyledString(rightText, new ForegroundStyler(foregroundColorRight));
|
||||
return leftT.append(" ")
|
||||
.append(rightT);
|
||||
}
|
||||
}
|
||||
+250
@@ -0,0 +1,250 @@
|
||||
package flintstones.method.todim.phase.gathering.ui;
|
||||
|
||||
import flintstones.application.perspective.framework.ui.interfaces.IProblemElementViewerOnSingleClick;
|
||||
import flintstones.application.perspective.framework.ui.viewer.ProblemElementViewer;
|
||||
import flintstones.entity.method.phase.ui.PhaseMethodUI;
|
||||
import flintstones.entity.problemelement.entities.Criterion;
|
||||
import flintstones.entity.problemelement.entities.Expert;
|
||||
import flintstones.entity.problemelement.entities.FakeProblemElement;
|
||||
import flintstones.entity.problemelement.entities.ProblemElement;
|
||||
import flintstones.helper.DoubleHelper;
|
||||
import flintstones.helper.html.table.HtmlTextTable;
|
||||
import flintstones.method.todim.phase.gathering.phaseTodim;
|
||||
import flintstones.method.todim.phase.gathering.ui.messages.Messages;
|
||||
import flintstones.method.todim.phase.gathering.viewer.ProblemElementViewerLabel;
|
||||
import flintstones.model.problemelement.service.IProblemElementService;
|
||||
import flintstones.model.ui.service.UiService;
|
||||
import javax.inject.Inject;
|
||||
|
||||
import org.eclipse.e4.core.contexts.ContextInjectionFactory;
|
||||
import org.eclipse.e4.core.contexts.IEclipseContext;
|
||||
import org.eclipse.e4.core.services.nls.Translation;
|
||||
import org.eclipse.jface.viewers.CheckStateChangedEvent;
|
||||
import org.eclipse.jface.viewers.ICheckStateListener;
|
||||
import org.eclipse.swt.SWT;
|
||||
import org.eclipse.swt.events.ModifyEvent;
|
||||
import org.eclipse.swt.events.ModifyListener;
|
||||
import org.eclipse.swt.layout.GridData;
|
||||
import org.eclipse.swt.widgets.Composite;
|
||||
import org.eclipse.swt.widgets.Label;
|
||||
import org.eclipse.swt.widgets.Spinner;
|
||||
|
||||
|
||||
public class TODIMPhaseUI extends PhaseMethodUI implements IProblemElementViewerOnSingleClick, ICheckStateListener{
|
||||
|
||||
@Inject
|
||||
IEclipseContext context;
|
||||
|
||||
@Inject
|
||||
IProblemElementService problemService;
|
||||
|
||||
@Inject
|
||||
@Translation
|
||||
Messages messages;
|
||||
|
||||
phaseTodim todim;
|
||||
|
||||
ProblemElementViewer criterionViewer;
|
||||
String selectedCriterion;
|
||||
|
||||
Label titleLabelParametersCriterion;
|
||||
Spinner spinnerScale;
|
||||
|
||||
double[] scale;
|
||||
int selectedIndex;
|
||||
|
||||
@Override
|
||||
public void init() {
|
||||
todim = (phaseTodim) this.getModel();
|
||||
todim.initialize();
|
||||
|
||||
scale = new double[todim.getCriteria().length];
|
||||
for(int i = 0; i < scale.length; i++)
|
||||
scale[i] = 1.0f;
|
||||
|
||||
selectedIndex = 0;
|
||||
|
||||
selectedCriterion = problemService.getAll(Criterion.Type)[0].getCanonicalName();
|
||||
|
||||
Composite base = this.getBaseComposite();
|
||||
UiService.setGridData(base, 9, 9, true, true);
|
||||
UiService.setGridLayout(base, 1);
|
||||
|
||||
Composite row1 = new Composite(base, 0);
|
||||
UiService.setGridData(row1, 9, 0, true, false);
|
||||
UiService.setGridLayout(row1, 1);
|
||||
|
||||
Label titleLabel = new Label(row1, SWT.NONE);
|
||||
titleLabel.setText(messages.TODIM_phase);
|
||||
UiService.setGridData(titleLabel, 9 ,9, true, false);
|
||||
UiService.setFont(titleLabel, UiService.FONT_SECTION_TITLE);
|
||||
|
||||
Composite row2 = new Composite(base, 0);
|
||||
UiService.setGridData(row2, 9, 9, true, true);
|
||||
UiService.setGridLayout(row2, 1);
|
||||
|
||||
initBody(row2);
|
||||
|
||||
titleLabelParametersCriterion.setText(messages.Thresholds_of + selectedCriterion);
|
||||
|
||||
todim.executeMethod((Expert) problemService.getAll(Expert.Type)[0], scale);
|
||||
}
|
||||
|
||||
public void initBody(Composite base) {
|
||||
//Primera mitad
|
||||
Composite rowMitadArriba = new Composite(base, SWT.BORDER);
|
||||
GridData gd = UiService.setGridData(rowMitadArriba, 9, 9, true, true);
|
||||
gd.heightHint = 350;
|
||||
UiService.setGridLayout(rowMitadArriba, 1);
|
||||
|
||||
Expert expert = (Expert) problemService.getAll(Expert.Type)[0];
|
||||
tableInitialProblem(rowMitadArriba,
|
||||
todim.getValuations(expert),
|
||||
todim.getAlternativesNames(),
|
||||
todim.getCriterionNames());
|
||||
|
||||
//La otra mitad
|
||||
Composite rowMitadAbajo = new Composite(base, 0);
|
||||
UiService.setGridData(rowMitadAbajo, 9, 9, true, true);
|
||||
UiService.setGridLayout(rowMitadAbajo, 2);
|
||||
|
||||
//Criterions y datos.
|
||||
createColTreeView(rowMitadAbajo);
|
||||
|
||||
createColParametersTodim(rowMitadAbajo);
|
||||
|
||||
}
|
||||
|
||||
public void tableInitialProblem(Composite base, double[][] values, String[] itemRow, String[] itemCol) {
|
||||
String[][] matrix = new String[itemRow.length][itemCol.length];
|
||||
|
||||
for(int i = 0; i < values.length; i++) {
|
||||
for (int j = 0; j < values[i].length; j++) {
|
||||
matrix [i][j] = String.format("%.2f", values[i][j]); //$NON-NLS-1$
|
||||
}
|
||||
}
|
||||
|
||||
HtmlTextTable tableDelta = new HtmlTextTable(base, matrix, itemCol, itemRow);
|
||||
tableDelta.render();
|
||||
}
|
||||
|
||||
//Crea los botones y spinner para poder introducir los datos del problema
|
||||
private void createColParametersTodim(Composite base) {
|
||||
Composite row = new Composite(base, 0);
|
||||
UiService.setGridData(row, 9, 9, true, true);
|
||||
UiService.setGridLayout(row, 1);
|
||||
|
||||
titleLabelParametersCriterion = new Label(row, SWT.NONE);
|
||||
UiService.setGridData(titleLabelParametersCriterion, 9 ,9, true, false);
|
||||
UiService.setFont(titleLabelParametersCriterion, UiService.FONT_SECTION_TITLE);
|
||||
|
||||
Composite row1 = new Composite(row, SWT.BORDER);
|
||||
UiService.setGridData(row1, 9, 9, true, true);
|
||||
UiService.setGridLayout(row1, 1);
|
||||
|
||||
//Scale
|
||||
Composite rowLabelScale = new Composite(row1, 0);
|
||||
UiService.setGridData(rowLabelScale, 9, 9, true, false);
|
||||
UiService.setGridLayout(rowLabelScale, 1, true);
|
||||
spinnerScale = new Spinner (rowLabelScale, SWT.BORDER);
|
||||
spinnerScale.setDigits(3);
|
||||
spinnerScale.setMinimum(1);
|
||||
spinnerScale.setMaximum(Integer.MAX_VALUE);
|
||||
spinnerScale.setSelection((int) (scale[0] * Math.pow(10, spinnerScale.getDigits())));
|
||||
spinnerScale.addModifyListener(new ModifyListener() {
|
||||
@Override
|
||||
public void modifyText(ModifyEvent e) {
|
||||
saveParameters();
|
||||
todim.executeMethod((Expert) problemService.getSubElements(Expert.Type)[0], scale);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
//Métodos para el Tree View
|
||||
private void createColTreeView(Composite base) {
|
||||
|
||||
Composite row = new Composite(base, 0);
|
||||
UiService.setGridData(row, 9, 9, true, true);
|
||||
UiService.setGridLayout(row, 1);
|
||||
|
||||
Label titleLabel = new Label(row, SWT.NONE);
|
||||
titleLabel.setText(messages.Criteria);
|
||||
UiService.setGridData(titleLabel, 9 ,9, true, false);
|
||||
UiService.setFont(titleLabel, UiService.FONT_SECTION_TITLE);
|
||||
|
||||
//Criterion tree
|
||||
criterionViewer = getViewer(row, Criterion.Type, true);
|
||||
}
|
||||
|
||||
//Funión que nos devuelve el Viewer con los criterios
|
||||
private ProblemElementViewer getViewer(Composite parent, String type, boolean addParent) {
|
||||
|
||||
ProblemElementViewerLabel viewer = ContextInjectionFactory.make(ProblemElementViewerLabel.class, this.context);
|
||||
|
||||
if (addParent) {
|
||||
FakeProblemElement fakePE = new FakeProblemElement(""); //$NON-NLS-1$
|
||||
fakePE.as(type);
|
||||
viewer.useGlobalParent(fakePE);
|
||||
}
|
||||
|
||||
viewer.createControls(type, parent);
|
||||
viewer.addListener(this);
|
||||
viewer.loadListeners();
|
||||
|
||||
UiService.setGridLayout(viewer.getTree().getTree(), 1);
|
||||
UiService.setGridData(viewer.getTree().getTree(), 9, 9, true, true);
|
||||
|
||||
return viewer;
|
||||
}
|
||||
|
||||
public void problemElementViewerOnSingleClick(ProblemElement item) {
|
||||
|
||||
if(item.getCanonicalName().equals("")) //$NON-NLS-1$
|
||||
return;
|
||||
|
||||
saveParameters();
|
||||
|
||||
selectedCriterion = item.getCanonicalName();
|
||||
titleLabelParametersCriterion.setText(messages.Thresholds_of + selectedCriterion);
|
||||
|
||||
for(int i = 0; i < todim.getCriteria().length; i++) {
|
||||
if( todim.getCriteria()[i].getCanonicalName().equals(selectedCriterion) ){
|
||||
selectedIndex = i;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
setParametersSelected();
|
||||
|
||||
criterionViewer.updateViewer(Criterion.Type);
|
||||
}
|
||||
|
||||
private void setParametersSelected() {
|
||||
double oldNumber = scale[selectedIndex];
|
||||
oldNumber *= Math.pow(10, spinnerScale.getDigits());
|
||||
int newNumberWithDecimal = (int) oldNumber;
|
||||
spinnerScale.setSelection(newNumberWithDecimal);
|
||||
}
|
||||
|
||||
public void saveParameters() {
|
||||
double scal = DoubleHelper.ParseDouble(spinnerScale.getText());
|
||||
scale[selectedIndex] = (float) scal;
|
||||
}
|
||||
|
||||
public void checkStateChanged(CheckStateChangedEvent event) {
|
||||
refreshUI();
|
||||
}
|
||||
|
||||
public void refreshUI() {
|
||||
this.sendRefresh();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void refresh() {
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean isForwardEnabled() {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
+10
@@ -0,0 +1,10 @@
|
||||
package flintstones.method.todim.phase.gathering.ui.messages;
|
||||
|
||||
public class Messages {
|
||||
|
||||
public String Criteria;
|
||||
public String Scale;
|
||||
public String Thresholds_of;
|
||||
public String TODIM_phase;
|
||||
|
||||
}
|
||||
+4
@@ -0,0 +1,4 @@
|
||||
Criteria=Criteria
|
||||
Scale=Scale:
|
||||
Thresholds_of=Scale of
|
||||
TODIM_phase=TODIM PHASE
|
||||
+4
@@ -0,0 +1,4 @@
|
||||
Criteria=Criterios
|
||||
phaseTodimUI_Scale=Escala:
|
||||
phaseTodimUI_Thresholds_of=Escala de
|
||||
phaseTodimUI_TODIM_phase=Fase TODIM
|
||||
+35
@@ -0,0 +1,35 @@
|
||||
package flintstones.method.todim.phase.gathering.viewer;
|
||||
|
||||
import javax.inject.Inject;
|
||||
|
||||
import org.eclipse.e4.core.contexts.ContextInjectionFactory;
|
||||
import org.eclipse.e4.core.contexts.IEclipseContext;
|
||||
import org.eclipse.jface.resource.ImageDescriptor;
|
||||
import org.eclipse.jface.viewers.DelegatingStyledCellLabelProvider.IStyledLabelProvider;
|
||||
|
||||
import flintstones.application.perspective.framework.ui.viewer.ProblemElementViewer;
|
||||
import flintstones.entity.problemelement.entities.ProblemElementHelper;
|
||||
import flintstones.method.todim.phase.gathering.provider.ProblemElementLabelProvider;
|
||||
import flintstones.model.problemelement.service.IProblemElementService;
|
||||
import flintstones.model.ui.service.UiService;
|
||||
|
||||
public class ProblemElementViewerLabel extends ProblemElementViewer {
|
||||
|
||||
@Inject
|
||||
IEclipseContext context;
|
||||
|
||||
@Inject
|
||||
IProblemElementService problemService;
|
||||
|
||||
@Override
|
||||
protected IStyledLabelProvider getLabelProvider(String type) {
|
||||
|
||||
ImageDescriptor individualImage = UiService.getIcon(ProblemElementHelper.getImage(type, false));
|
||||
ImageDescriptor groupImage = UiService.getIcon(ProblemElementHelper.getImage(type, true));
|
||||
|
||||
ProblemElementLabelProvider provider = new ProblemElementLabelProvider(individualImage, groupImage);
|
||||
ContextInjectionFactory.inject(provider, context);
|
||||
return provider;
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user