Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feat custom diagram #159

Merged
merged 26 commits into from
Jan 15, 2025
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
26 commits
Select commit Hold shift + click to select a range
a584e6f
feat: Implement custom_diagram
huyenngn Nov 9, 2024
c65647a
fix: Diagram target dictates unified edge direction
huyenngn Nov 9, 2024
cf6fdca
feat(custom_diagram): Add recursion option
huyenngn Nov 10, 2024
40c009c
fix: Move edges to owners
huyenngn Nov 11, 2024
bfa43bc
docs: Add docs for custom diagram
huyenngn Nov 11, 2024
be8a5b8
feat(custom_diagram): Add nested recursion and recursion depth
huyenngn Nov 12, 2024
810ca66
docs: Add expamles for custom_diagram
huyenngn Nov 12, 2024
8e6baea
fix: Fix recursion depth
huyenngn Nov 18, 2024
d7e94b9
fix: Straighten target edge
huyenngn Nov 18, 2024
d6592a0
feat(context-diagram): Add support for PhysicalPorts
huyenngn Nov 19, 2024
261ea06
docs: Add PhysicalPort to docs
huyenngn Nov 19, 2024
2a5f966
fix: Apply code review suggestions
huyenngn Nov 25, 2024
6305008
fix: Apply suggestions from code review
huyenngn Nov 25, 2024
e4dfd0d
fix: Fix minimum size calculation of boxes
huyenngn Nov 26, 2024
f091a65
refactor: Implement generic make_owner_boxes function
huyenngn Nov 26, 2024
bed6a30
fix: Fix mutability bug
huyenngn Nov 27, 2024
c744a6b
feat: Add support for python lambda filter
huyenngn Nov 27, 2024
3f99c27
fix: Add custom_diagram attribute to Class elements
huyenngn Dec 2, 2024
5398b91
refactor: Add generic make_owner_box method
huyenngn Dec 9, 2024
ad39f99
refactor(custom_diagram): Take iterable as collection
huyenngn Dec 9, 2024
d2162d4
docs(custom_diagram): Add example to docs
huyenngn Dec 9, 2024
51772a8
docs: Update custom_diagram docs
huyenngn Dec 16, 2024
fd3b4b1
fix: Remove duplicates from port context
ewuerger Jan 6, 2025
e492ffe
fix: Change custom diagram names
huyenngn Jan 8, 2025
7ace887
merge: Merge 'main'
ewuerger Jan 15, 2025
60d743b
docs: Fix cross-reference
ewuerger Jan 15, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
47 changes: 47 additions & 0 deletions docs/custom_diagram.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
<!--
~ SPDX-FileCopyrightText: 2022 Copyright DB InfraGO AG and the capellambse-context-diagrams contributors
~ SPDX-License-Identifier: Apache-2.0
-->

# Custom Diagram

`Custom diagram`s let you create custom diagrams based on the data in the model. You define the data collection using an iterable, and `Custom diagram` takes care of the rest.

You can access `.custom_diagram` on any supported model element.

??? example "Custom Diagram of `PP 1 `"

``` py
import capellambse

def _collector(
target: m.ModelElement,
) -> cabc.Iterator[m.ModelElement]:
visited = set()
def collector(
target: m.ModelElement,
) -> cabc.Iterator[m.ModelElement]:
if target.uuid in visited:
return
visited.add(target.uuid)
for link in target.links:
yield link
yield from collector(link.source)
yield from collector(link.target)
yield from collector(target)

model = capellambse.MelodyModel("tests/data/ContextDiagram.aird")
obj = model.by_uuid("c403d4f4-9633-42a2-a5d6-9e1df2655146")
diag = obj.context_diagram
diag.render("svgdiagram", collect=_collector(obj)).save(pretty=True)
```
<figure markdown>
<img src="assets/images/Context of PP 1.svg" width="1000000">
<figcaption>Context of PP 1 [PAB]</figcaption>
</figure>

## Check out the code

To understand the collection have a look into the
[`custom`][capellambse_context_diagrams.collectors.custom]
module.
1 change: 1 addition & 0 deletions docs/gen_images.py
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
"Physical Node": "fdb34c92-7c49-491d-bf11-dd139930786e",
"Physical Behavior": "313f48f4-fb7e-47a8-b28a-76440932fcb9",
"Maintain": "ee745644-07d7-40b9-ad7a-910dc8cbb805",
"Physical Port": "c403d4f4-9633-42a2-a5d6-9e1df2655146",
}
interface_context_diagram_uuids: dict[str, str] = {
"Left to right": "3ef23099-ce9a-4f7d-812f-935f47e7938d",
Expand Down
14 changes: 14 additions & 0 deletions docs/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -192,6 +192,20 @@ Available via `.context_diagram` on a [`ModelObject`][capellambse.model.ModelObj
<figcaption>Context of Maintain Switch Firmware [PDFB]</figcaption>
</figure>

- ??? example "[`pa.PhysicalPort`][capellambse.metamodel.cs.PhysicalPort] (PAB)"

``` py
import capellambse

model = capellambse.MelodyModel("tests/data/ContextDiagram.aird")
diag = model.by_uuid("c403d4f4-9633-42a2-a5d6-9e1df2655146").context_diagram
diag.render("svgdiagram").save(pretty=True)
```
<figure markdown>
<img src="assets/images/Context of PP 1.svg" width="1000000">
<figcaption>Context of PP 1 [PAB]</figcaption>
</figure>

#### Hierarchy in diagrams

Hierarchical diagrams are diagrams where boxes have child boxes and edges
Expand Down
2 changes: 2 additions & 0 deletions mkdocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,8 @@ nav:
- Overview: data_flow_view.md
- Cable Tree View:
- Overview: cable_tree.md
- Custom Diagram:
- Overview: custom_diagram.md
- Extras:
- Filters: extras/filters.md
- Styling: extras/styling.md
Expand Down
39 changes: 39 additions & 0 deletions src/capellambse_context_diagrams/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -63,10 +63,12 @@ def init() -> None:
"""Initialize the extension."""
register_classes()
register_interface_context()
register_physical_port_context()
register_tree_view()
register_realization_view()
register_data_flow_view()
register_cable_tree_view()
register_custom_diagram()
# register_functional_context() XXX: Future


Expand Down Expand Up @@ -251,6 +253,15 @@ def register_functional_context() -> None:
)


def register_physical_port_context() -> None:
"""Add the `context_diagram` attribute to `PhysicalPort`s."""
m.set_accessor(
cs.PhysicalPort,
ATTR_NAME,
context.PhysicalPortContextAccessor(DiagramType.PAB.value, {}),
)


def register_tree_view() -> None:
"""Add the ``tree_view`` attribute to ``Class``es."""
m.set_accessor(
Expand Down Expand Up @@ -317,3 +328,31 @@ def register_cable_tree_view() -> None:
{},
),
)


def register_custom_diagram() -> None:
"""Add the `custom_diagram` attribute to `ModelObject`s."""
supported_classes: list[tuple[type[m.ModelElement], DiagramType]] = [
(oa.Entity, DiagramType.OAB),
(oa.OperationalActivity, DiagramType.OAB),
(oa.OperationalCapability, DiagramType.OCB),
(oa.CommunicationMean, DiagramType.OAB),
(sa.Mission, DiagramType.MCB),
(sa.Capability, DiagramType.MCB),
(sa.SystemComponent, DiagramType.SAB),
(sa.SystemFunction, DiagramType.SAB),
(la.LogicalComponent, DiagramType.LAB),
(la.LogicalFunction, DiagramType.LAB),
(pa.PhysicalComponent, DiagramType.PAB),
(pa.PhysicalFunction, DiagramType.PAB),
(cs.PhysicalLink, DiagramType.PAB),
(cs.PhysicalPort, DiagramType.PAB),
(fa.ComponentExchange, DiagramType.SAB),
(information.Class, DiagramType.CDB),
]
for class_, dgcls in supported_classes:
m.set_accessor(
class_,
"custom_diagram",
context.CustomContextAccessor(dgcls.value, {}),
)
Loading
Loading