Skip to content

Commit

Permalink
DROOLS-3843: [DMN Editor] Decision Navigator differentiate icons for …
Browse files Browse the repository at this point in the history
…DRGElement (#3257)

DROOLS-3843: [DMN Editor] Decision Navigator differentiate icons for DRGElement (#3257)
  • Loading branch information
Valentino Pellegrino committed Apr 3, 2020
1 parent fc47a9b commit cb5c65e
Show file tree
Hide file tree
Showing 5 changed files with 136 additions and 20 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,8 @@

package org.kie.workbench.common.dmn.client.docks.navigator;

import java.util.HashMap;
import java.util.Map;
import java.util.Objects;
import java.util.TreeSet;

Expand Down Expand Up @@ -134,14 +136,38 @@ String getOrderingName() {
}

public enum Type {
ROOT,
ITEM,
CONTEXT,
DECISION_TABLE,
FUNCTION_DEFINITION,
INVOCATION,
LIST,
LITERAL_EXPRESSION,
RELATION
ROOT("Root"),
ITEM("Item"),
CONTEXT("Context"),
DECISION_TABLE("DecisionTable"),
FUNCTION_DEFINITION("FunctionDefinition"),
INVOCATION("Invocation"),
LIST("List"),
LITERAL_EXPRESSION("LiteralExpression"),
RELATION("Relation"),
TEXT_ANNOTATION("TextAnnotation"),
BUSINESS_KNOWLEDGE_MODEL("BusinessKnowledgeModel"),
INPUT_DATA("InputData"),
DECISION_SERVICE("DecisionService"),
KNOWLEDGE_SOURCE("KnowledgeSource"),
DECISION("Decision");

private static final Map<String, Type> BY_CLASS_NAME = new HashMap<>();

static {
for (final Type type : values()) {
BY_CLASS_NAME.put(type.navigatorItemClassName, type);
}
}

private final String navigatorItemClassName;

Type(final String navigatorItemClassName) {
this.navigatorItemClassName = navigatorItemClassName;
}

public static Type ofExpressionNodeClassName(final String nodeClassName) {
return BY_CLASS_NAME.getOrDefault(nodeClassName, ITEM);
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -16,15 +16,18 @@

package org.kie.workbench.common.dmn.client.docks.navigator.factories;

import java.util.Optional;

import javax.enterprise.context.Dependent;
import javax.inject.Inject;

import org.kie.workbench.common.dmn.client.docks.navigator.DecisionNavigatorItem;
import org.kie.workbench.common.dmn.client.docks.navigator.DecisionNavigatorItem.Type;
import org.kie.workbench.common.stunner.core.graph.Edge;
import org.kie.workbench.common.stunner.core.graph.Node;
import org.kie.workbench.common.stunner.core.graph.content.view.View;
import org.kie.workbench.common.stunner.core.util.DefinitionUtils;

import static org.kie.workbench.common.dmn.client.docks.navigator.DecisionNavigatorItem.Type.ITEM;
import static org.kie.workbench.common.dmn.client.docks.navigator.DecisionNavigatorItem.Type.ROOT;

@Dependent
Expand All @@ -42,6 +45,10 @@ public DecisionNavigatorItem makeRoot(final Node<View, Edge> node) {
}

public DecisionNavigatorItem makeItem(final Node<View, Edge> node) {
return baseItemFactory.makeItem(node, ITEM);
final String nodeClassName = Optional.ofNullable(DefinitionUtils.getElementDefinition(node))
.map(elementDefinition -> elementDefinition.getClass().getSimpleName())
.orElse(Node.class.getSimpleName());

return baseItemFactory.makeItem(node, Type.ofExpressionNodeClassName(nodeClassName));
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -92,31 +92,31 @@
content: "\f0da";
}

li.kie-root div > span:before {
li.kie-root > div > span:before {
content: "\f1e0";
}

li.kie-item div > span:before {
li.kie-item > div > span:before {
content: "\f111";
}

li.kie-context div > span:before {
li.kie-context > div > span:before {
content: "\f192";
}

li.kie-decision-table div > span:before {
li.kie-decision-table > div > span:before {
content: "\f0ce";
}

li.kie-invocation div > span:before {
li.kie-invocation > div > span:before {
content: "\f0a1";
}

li.kie-list div > span:before {
li.kie-list > div > span:before {
content: "\f0ca";
}

li.kie-function-definition div > span:before {
li.kie-function-definition > div > span:before {
content: "f ( )";
font-family: serif;
font-style: italic;
Expand All @@ -125,19 +125,55 @@
margin: -0.1em 0 0 -1.8em;
}

li.kie-literal-expression div > span:before {
li.kie-literal-expression > div > span:before {
content: "Σ";
font-family: sans-serif;
font-weight: bold;
font-size: 1.2em;
margin: 0 0 0 -1.15em;
}

li.kie-relation div > span:before {
li.kie-relation > div > span:before {
content: "\f0c1";
font-size: 1.2em;
transform: rotate(-45deg);
margin: -0.15em 0 0 -1.45em;
}

li.kie-text-annotation > div > span:before {
width: 1.8em;
height: 1.8em;
content: url("");
}

li.kie-business-knowledge-model > div > span:before {
width: 1.8em;
height: 1.8em;
content: url("");
}

li.kie-input-data > div > span:before {
width: 1.8em;
height: 1.8em;
content: url("");
}

li.kie-decision-service > div > span:before {
width: 1.8em;
height: 1.8em;
content: url("");
}

li.kie-knowledge-source > div > span:before {
width: 1.8em;
height: 1.8em;
content: url("");
}

li.kie-decision > div > span:before {
width: 1.8em;
height: 1.8em;
content: url("");
}
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,10 @@
import java.util.TreeSet;

import org.junit.Test;
import org.kie.workbench.common.dmn.client.docks.navigator.DecisionNavigatorItem.Type;
import org.uberfire.mvp.Command;

import static org.assertj.core.api.Assertions.assertThat;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotEquals;
import static org.junit.Assert.assertTrue;
Expand Down Expand Up @@ -158,4 +160,24 @@ public void testCompareToWhenItemOrderingNameIsLessThanObjectOrderingName() {

assertTrue(result > 0);
}

@Test
public void testTypeEnumWhenRetrievingByExistingItemClassName() {
assertThat(Type.ofExpressionNodeClassName("InputData")).isEqualTo(Type.INPUT_DATA);
}

@Test
public void testTypeEnumWhenRetrievingByNotExistingItemClassName() {
assertThat(Type.ofExpressionNodeClassName("NOT_EXISTING")).isEqualTo(ITEM);
}

@Test
public void testTypeEnumWhenRetrievingByEmptyClassName() {
assertThat(Type.ofExpressionNodeClassName("")).isEqualTo(ITEM);
}

@Test
public void testTypeEnumWhenRetrievingByNullClassName() {
assertThat(Type.ofExpressionNodeClassName(null)).isEqualTo(ITEM);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -20,13 +20,15 @@
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.kie.workbench.common.dmn.api.definition.model.DecisionService;
import org.kie.workbench.common.dmn.client.docks.navigator.DecisionNavigatorItem;
import org.kie.workbench.common.stunner.core.graph.Edge;
import org.kie.workbench.common.stunner.core.graph.Node;
import org.kie.workbench.common.stunner.core.graph.content.view.View;
import org.mockito.Mock;

import static org.junit.Assert.assertEquals;
import static org.kie.workbench.common.dmn.client.docks.navigator.DecisionNavigatorItem.Type.DECISION_SERVICE;
import static org.kie.workbench.common.dmn.client.docks.navigator.DecisionNavigatorItem.Type.ITEM;
import static org.kie.workbench.common.dmn.client.docks.navigator.DecisionNavigatorItem.Type.ROOT;
import static org.mockito.Mockito.spy;
Expand All @@ -41,6 +43,9 @@ public class DecisionNavigatorItemFactoryTest {
@Mock
private Node<View, Edge> node;

@Mock
private View content;

@Mock
private DecisionNavigatorItem item;

Expand All @@ -66,4 +71,24 @@ public void testMakeItem() {

assertEquals(item, factory.makeItem(node));
}

@Test
public void testMakeItemWhenTypeIsDecisionService() {

when(baseItemFactory.makeItem(node, DECISION_SERVICE)).thenReturn(item);
when(node.getContent()).thenReturn(content);
when(content.getDefinition()).thenReturn(new DecisionService());

assertEquals(item, factory.makeItem(node));
}

@Test
public void testMakeItemWhenTypeIsNotMapped() {

when(baseItemFactory.makeItem(node, ITEM)).thenReturn(item);
when(node.getContent()).thenReturn(content);
when(content.getDefinition()).thenReturn(new Object());

assertEquals(item, factory.makeItem(node));
}
}

0 comments on commit cb5c65e

Please sign in to comment.