Skip to content

Commit

Permalink
Merge branch 'finos:master' into feature-6681
Browse files Browse the repository at this point in the history
  • Loading branch information
Ralph Mensah authored Sep 6, 2023
2 parents 1c0036a + 77d5b0d commit 20c71ea
Show file tree
Hide file tree
Showing 186 changed files with 6,915 additions and 1,094 deletions.
6 changes: 3 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -69,9 +69,9 @@ progress and done issues.

| Release | Date | Summary |
|---------|----------------|---------------------------------------------------|
| 1.52 | Mid Aug 2023 | Primary ratings (cont), navigation aid generators |
| 1.53 | tbd | tbd |
| 1.54 | tbd | tbd |
| 1.53 | Sept 5th 2023 | Diagrams (builder + markdown), Cost Allocations |
| 1.54 | Sept 26th 2023 | tbd |
| 1.55 | tbc | tbd |

See the [releases](https://github.com/finos/waltz/releases) page for historic versions.

Expand Down
2 changes: 1 addition & 1 deletion docs/features/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ Feature | Overview
[Roadmaps and Scenarios](roadmaps/README.md) | Used to describe how applications may change over time
[Report Grids](report-grids/README.md) | Used to quickly aggregate data into a report
[Server / Database Information](servers_and_databases/README.md) | Servers and databases associated with apps and flows
[Surveys](surveys/README.md) | Questionnaires that can be sent to a subset of Waltz users using criteria native to Waltz
[Surveys](surveys/README.adoc) | Questionnaires that can be sent to a subset of Waltz users using criteria native to Waltz


## Administrative Features
Expand Down
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Original file line number Diff line number Diff line change
@@ -0,0 +1,92 @@
# Overlay Diagrams

## Overview

Overlay diagrams can be used in a number of ways. Depending on the `diagram_kind` specified, the `layout_data` will be rendered differently.
This document will describe overlay diagrams of the kind `WALTZ_ENTITY_OVERLAY` which can be constructed using the diagram builder by system admin and rendered on group pages in the diagram section.

Entity Overlay Diagrams are constructed of 'group cells' which may or may not be backed by an entity e.g. a measurable, person or data type.
The cell contents can show aggregated waltz data relating to the backing entity of the cell by selecting one of the overlays.


## Model

We make use of `aggregate_overlay_diagrams` for storing entity overlay diagram data.

- `aggregate_overlay_diagram` - captured the diagram info and layout data
- `aggregate_overlay_diagram_Cell_data` - stores the backing entities for the diagram cells. The `cell_external_id` maps to the `id` field in the `layout data` on the diagram.

### Visual Concepts

![img.png](entity-overlay-diagram-section-view.png)

| Name | Description |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Group Cell | A unit drawn on the diagram as a box (1). Constructed of two parts: a title (can be hidden), and a content box. Optionally can be backed by data (2), the backing entities can be a 'PERSON', 'MEASURABLE' or 'DATA_TYPE'. |
| Content Box | Area used to display the contents of the group cell (3). If this group contains children, these child groups will be displayed in the content box (4), otherwise the cell contents will be shown. Child groups can be a mixture of groups backed by different entity kinds and groups without a backing entity |
| Cell Contents | Data relating to the cell is shown in the cell contents. If there is no data associated to the cell then the group will appear empty (1). Otherwise the selected overlay will be shown (5), by defualt the backing entities are displayed. |
| Overlay | Visual produced by aggregating information related to the backing entity of the cell at the given vantage point (5). Overlays exist for all cells backed with data (although all may not be visible as child groups are shown). |

### Layout Data

A diagram is constructed of nested groups, stored as JSON in the `layout_data` field, with associated data linked to each group. Each group has the following attributes:

| Name | Description |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| id | A GUID to uniquely identify the group |
| parent_id | A reference to the parent group |
| title | Text to be displayed in the title bar. When adding groups with data the title is defaulted to the name of the entity added |
| properties | Information to style the group cell. e.g. cell width, cell height, show title, show border, title color, background color etc. Defaults if not explicitly set. |
| data (optional) | An object containing the entity reference to the backing entity for this cell. Formally captured in the `aggregate_overlay_diagram_cell_data` but retained in the layout information in case of reconstruction from this object | |

Example:
```
[
{
"title":"Demo Diagram",
"id":"08e5ffb6-ee04-4809-8357-49191b0ede14",
"parentId":null,
"props": {
"minHeight":5,
"minWidth":10,
"flexDirection":"row",
"showTitle":true,
"showBorder":true,
"bucketSize":3,
"proportion":1,
"titleColor":"#1F7FE0",
"contentColor":"#eef5fb",
"contentFontSize":0.7,
"titleFontSize":0.8,
"position":1
}
}
]
```

## Features

### Builder

Available via the 'System Admin' page. Users with admin privileges can create / edit diagrams.

![img.png](entity-overlay-diagram-builder.png)

The diagram builder shows the selected diagram information at the top of the page (1). You can construct diagrams without them being saved to the database, in which case this is hidden.
The diagrams controls are at the bottom of the header (2); here you can update the lifecycle status of the diagram, rename it or save any changes to the layout below.

The main section of the diagram editor is split into the rendered diagram (3) and the context panel (4). The rendered diagram gives you a preview of the structure and can be used to interact with the groups and reorder sections.
The context panel displays the overall structure of the diagram (useful for navigation), and once a group is selected, the edit options for the layout relating to that group.

### Section

A list of active diagrams can be viewed and selected from the 'Entity Diagrams' tab (1) in the diagrams section.

![img.png](entity-overlay-diagram-overlay-picker.png)

The default overlay shows the backing entities for the group cells. In the context panel you can pick from the list of available overlays to populate data on the diagram relative to the vantage point you are using e.g. the current `ORG_UNIT` or `APP_GROUP`.

![img.png](entity-overlay-diagram-selected-overlay.png)

Once an overlay has been picked the cell contents show the overlay (where one exists). Group cells that are not backed by data will not show an overlay. Cells with no relevant data for that overlay will also appear blank. There is the option to toggle whether to show or hide cells with empty cell contents in the context panel (2).
By selecting a group cell on the diagram you can get an enhanced view of the overlay in the context panel (4).
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,7 @@ public static String readAsString(InputStream stream) {
checkNotNull(stream, "stream must not be null");

return streamLines(stream)
.collect(Collectors.joining());
.collect(Collectors.joining("\n"));
}


Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,15 +11,15 @@
public class IOUtilities_readAsStringTest {
@Test
public void canReadLinesAsString() throws IOException {
String lines = IOUtilities.readAsString(getStream("lines.txt"));
assertEquals(138, lines.length());
String str = IOUtilities.readAsString(getStream("lines.txt"));
assertEquals(141, str.length());
}


@Test
public void emptyGivesEmptyList() throws IOException {
String lines = IOUtilities.readAsString(getStream("empty.txt"));
assertEquals(0, lines.length());
String str = IOUtilities.readAsString(getStream("empty.txt"));
assertEquals(0, str.length());
}


Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,12 @@
import java.util.Collections;
import java.util.Set;

import static org.finos.waltz.common.SetUtilities.*;
import static org.junit.jupiter.api.Assertions.*;
import static org.finos.waltz.common.SetUtilities.asSet;
import static org.finos.waltz.common.SetUtilities.complement;
import static org.finos.waltz.common.SetUtilities.union;
import static org.junit.jupiter.api.Assertions.assertEquals;
import static org.junit.jupiter.api.Assertions.assertThrows;
import static org.junit.jupiter.api.Assertions.assertTrue;

public class SetUtilities_complementTest {

Expand Down
14 changes: 0 additions & 14 deletions waltz-data/src/main/java/org/finos/waltz/data/actor/ActorDao.java
Original file line number Diff line number Diff line change
Expand Up @@ -67,20 +67,6 @@ public class ActorDao {
};


public static final Function<Actor, ActorRecord> TO_RECORD_MAPPER = actor -> {

ActorRecord record = new ActorRecord();
record.setName(actor.name());
record.setDescription(actor.description());
record.setLastUpdatedAt(Timestamp.valueOf(actor.lastUpdatedAt()));
record.setLastUpdatedBy(actor.lastUpdatedBy());
record.setIsExternal(actor.isExternal());
record.setProvenance(actor.provenance());
actor.id().ifPresent(record::setId);
actor.externalId().ifPresent(record::setExternalId);

return record;
};

private static final String PROVENANCE = "waltz";

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,14 @@
import org.finos.waltz.data.JooqUtilities;
import org.finos.waltz.model.EntityKind;
import org.finos.waltz.model.EntityReference;
import org.finos.waltz.model.ReleaseLifecycleStatusChangeCommand;
import org.finos.waltz.model.aggregate_overlay_diagram.AggregateOverlayDiagram;
import org.finos.waltz.model.aggregate_overlay_diagram.BackingEntity;
import org.finos.waltz.model.aggregate_overlay_diagram.ImmutableBackingEntity;
import org.finos.waltz.model.aggregate_overlay_diagram.OverlayDiagramSaveCommand;
import org.finos.waltz.model.aggregate_overlay_diagram.OverlayDiagramKind;
import org.finos.waltz.schema.tables.records.AggregateOverlayDiagramCellDataRecord;
import org.finos.waltz.schema.tables.records.AggregateOverlayDiagramRecord;
import org.jooq.DSLContext;
import org.jooq.Field;
import org.springframework.beans.factory.annotation.Autowired;
Expand All @@ -15,6 +20,8 @@
import java.util.Set;

import static org.finos.waltz.common.ListUtilities.newArrayList;
import static org.finos.waltz.common.SetUtilities.map;
import static org.finos.waltz.data.JooqUtilities.summarizeResults;
import static org.finos.waltz.data.aggregate_overlay_diagram.AggregateOverlayDiagramUtilities.TO_DOMAIN_MAPPER;
import static org.finos.waltz.schema.Tables.AGGREGATE_OVERLAY_DIAGRAM;
import static org.finos.waltz.schema.Tables.AGGREGATE_OVERLAY_DIAGRAM_CELL_DATA;
Expand All @@ -28,6 +35,7 @@ public class AggregateOverlayDiagramDao {
newArrayList(
EntityKind.MEASURABLE,
EntityKind.APP_GROUP,
EntityKind.DATA_TYPE,
EntityKind.PERSON
))
.as("entity_name");
Expand Down Expand Up @@ -56,6 +64,15 @@ public Set<AggregateOverlayDiagram> findAll() {
}


public Set<AggregateOverlayDiagram> findByKind(OverlayDiagramKind kind) {
return dsl
.select(AGGREGATE_OVERLAY_DIAGRAM.fields())
.from(AGGREGATE_OVERLAY_DIAGRAM)
.where(AGGREGATE_OVERLAY_DIAGRAM.DIAGRAM_KIND.eq(kind.name()))
.fetchSet(TO_DOMAIN_MAPPER::map);
}


public Set<BackingEntity> findBackingEntities(Long diagramId) {

return dsl
Expand All @@ -80,4 +97,59 @@ public Set<BackingEntity> findBackingEntities(Long diagramId) {
.build();
});
}


public void updateBackingEntities(Long diagramId,
Set<BackingEntity> backingEntities) {

dsl.transaction(ctx -> {

DSLContext tx = ctx.dsl();

int removedEntities = tx
.deleteFrom(AGGREGATE_OVERLAY_DIAGRAM_CELL_DATA)
.where(AGGREGATE_OVERLAY_DIAGRAM_CELL_DATA.DIAGRAM_ID.eq(diagramId))
.execute();

Set<AggregateOverlayDiagramCellDataRecord> toInsert = map(backingEntities, d -> mkCellDataRecord(tx, diagramId, d));

int insertedEntities = summarizeResults(tx
.batchInsert(toInsert)
.execute());
});
}


private AggregateOverlayDiagramCellDataRecord mkCellDataRecord(DSLContext tx, Long diagramId, BackingEntity backingEntity) {
AggregateOverlayDiagramCellDataRecord record = tx.newRecord(AGGREGATE_OVERLAY_DIAGRAM_CELL_DATA);
record.setDiagramId(diagramId);
record.setCellExternalId(backingEntity.cellId());
record.setRelatedEntityId(backingEntity.entityReference().id());
record.setRelatedEntityKind(backingEntity.entityReference().kind().name());
return record;
}


public Long save(OverlayDiagramSaveCommand saveCmd, String username) {
AggregateOverlayDiagramRecord record = dsl.newRecord(AGGREGATE_OVERLAY_DIAGRAM);
record.setName(saveCmd.name());
record.setDescription(saveCmd.description());
record.setDiagramKind(saveCmd.diagramKind().name());
record.setAggregatedEntityKind(saveCmd.aggregatedEntityKind().name());
record.setLayoutData(saveCmd.layoutData());
record.setLastUpdatedBy(username);
saveCmd.id().ifPresent(record::setId);
record.changed(AGGREGATE_OVERLAY_DIAGRAM.ID, false);
record.store();
return record.getId();
}


public Boolean updateStatus(long diagramId, ReleaseLifecycleStatusChangeCommand changeStatusCmd) {
return dsl
.update(AGGREGATE_OVERLAY_DIAGRAM)
.set(AGGREGATE_OVERLAY_DIAGRAM.STATUS, changeStatusCmd.newStatus().name())
.where(AGGREGATE_OVERLAY_DIAGRAM.ID.eq(diagramId))
.execute() == 1;
}
}
Loading

0 comments on commit 20c71ea

Please sign in to comment.