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

bold font after \n in relationships text #62

Open
dgutson opened this issue Nov 3, 2022 · 5 comments
Open

bold font after \n in relationships text #62

dgutson opened this issue Nov 3, 2022 · 5 comments

Comments

@dgutson
Copy link

dgutson commented Nov 3, 2022

Given

@startuml
title SS - Container1 - Components

top to bottom direction

skinparam {
  shadowing false
  arrowFontSize 10
  defaultTextAlignment center
  wrapWidth 200
  maxMessageSize 100
}

hide stereotype

skinparam rectangle<<SS.Container1.Component11>> {
  BackgroundColor #85bbf0
  FontColor #000000
  BorderColor #5d82a8
  roundCorner 20
}
skinparam rectangle<<SS.Container1.Component12>> {
  BackgroundColor #85bbf0
  FontColor #000000
  BorderColor #5d82a8
  roundCorner 20
}
skinparam rectangle<<SS.Container2>> {
  BackgroundColor #438dd5
  FontColor #ffffff
  BorderColor #2e6295
  roundCorner 20
}

rectangle "==Container2\n<size:10>[Container]</size>" <<SS.Container2>> as SS.Container2

package "Container1\n[Container]" <<SS.Container1>> {
  skinparam PackageBorderColor<<SS.Container1>> #444444
  skinparam PackageFontColor<<SS.Container1>> #444444

  rectangle "==Component11\n<size:10>[Component]</size>" <<SS.Container1.Component11>> as SS.Container1.Component11
  rectangle "==Component12\n<size:10>[Component]</size>" <<SS.Container1.Component12>> as SS.Container1.Component12
}

SS.Container1.Component12 .[#707070,thickness=2].> SS.Container2 : "<color:#707070>Relation2"
SS.Container1.Component11 .[#707070,thickness=2].> SS.Container1.Component12 : "<color:#707070>one\ntwo"
SS.Container1.Component11 .[#707070,thickness=2].> SS.Container2 : "<color:#707070>Relation1"
@enduml

Output is:
image

Note that two is darker than one.

@dgutson
Copy link
Author

dgutson commented Nov 3, 2022

Not sure if related to #61

@Potherca
Copy link
Contributor

Potherca commented Nov 4, 2022

When the given example is reduced to a Short, Self Contained, Correct example:

@startuml
(A) -> (B): "one\ntwo"
(C) -> (D): "<b>one\ntwo"
(E) -> (F) : "<color:#707070>one\ntwo"
@enduml

One can see that the difference is not the font weight (i.e. "bold") but the font color (i.e. "black").

As far as I am aware, the font style reverting to default after a newline/linebreak is expected behaviour.

(I could be wrong, that is for @arnaudroques to decide).

The solution for the second line also being colored #707070 is to declare the color again for that line:

@startuml
(A) -> (B) : "<color:#707070>one\n<color:#707070>two"
@enduml

Or using a stereotype:

@startuml
skinparam arrowFontColor<<gray>> #707070

(A) -> (B)<<gray>> : "one\ntwo"
@enduml

Regarding

Not sure if related to #61

Although the source of the issue is the same, the behavior described in #61 is a bug in the downstream project.

I have created an issue to address the problem in C4-PlantUML in that repo: plantuml-stdlib/C4-PlantUML#255

@arnaudroques
Copy link
Contributor

As far as I am aware, the font style reverting to default after a newline/linebreak is expected behaviour.

(I could be wrong, that is for @arnaudroques to decide).

You are right, that's the point. The font style is reverting to default after a newline.
I realize that is not a standard behaviour. The initial intention (10 years ago?) was to keep syntax as short as possible so that people that actually type diagrams on keyboard do not have to close tags.
The implementation was also simpler.

Now changing this would have too many impacts so I'm afraid we have to live with it.
I hope this is not a major issue, since the workaround is, as you said, to repeat color definition.

@dgutson
Copy link
Author

dgutson commented Nov 4, 2022

Thanks folks for the explanation, the workaround, (and the link for self contained.. :) ).
I must admit that this is completely unexpected for the terrestrial user, which unless comes here and reports this and have nice maintainers to explain, it would have been never solved.

May I propose a function call to disable this behavior? Like HIDE_LEGEND() but for this one, and have this documented somewhere?
Maybe something like KEEP_STYLE_ON_BREAKS()
That would preserve compatibility, avoid the verbosity of repeating the tag after each \n (or \l or \r, all things I tried).

@dgutson
Copy link
Author

dgutson commented Nov 4, 2022

BTW CC @simonbrowndotje because I think the workaround should be implemented in the exporter of structurizr.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants