com.structurizr.view.RelationshipView Maven / Gradle / Ivy
package com.structurizr.view;
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonInclude;
import com.structurizr.model.Relationship;
import java.util.Collection;
import java.util.LinkedList;
/**
* This class represents an instance of a Relationship on a View.
*/
public final class RelationshipView {
private static final int START_OF_LINE = 0;
private static final int END_OF_LINE = 100;
private Relationship relationship;
private String id;
private String description;
private String order;
private Collection vertices = new LinkedList<>();
@JsonInclude(value = JsonInclude.Include.NON_NULL)
private Routing routing;
@JsonInclude(value = JsonInclude.Include.NON_NULL)
private Integer position;
RelationshipView() {
}
RelationshipView(Relationship relationship) {
this.relationship = relationship;
}
/**
* Gets the ID of the relationship this RelationshipView represents.
*
* @return the ID, as a String
*/
public String getId() {
if (relationship != null) {
return relationship.getId();
} else {
return this.id;
}
}
void setId(String id) {
this.id = id;
}
/**
* Gets the relationship that this RelationshipView represents.
*
* @return a Relationship instance
*/
@JsonIgnore
public Relationship getRelationship() {
return relationship;
}
void setRelationship(Relationship relationship) {
this.relationship = relationship;
}
/**
* Gets the description of this relationship (used in dynamic views only).
*
* @return the description, as a String
* or an empty string if a description has not been set
*/
public String getDescription() {
return description != null ? description : "";
}
/**
* Sets the description of this relationship (used in dynamic views only).
*
* @param description the description, as a String
*/
public void setDescription(String description) {
this.description = description;
}
/**
* Gets the order of this relationship (used in dynamic views only; e.g. 1.0, 1.1, 2.0, etc).
*
* @return the order, as a String
*/
public String getOrder() {
return order;
}
/**
* Sets the order of this relationship (used in dynamic views only; e.g. 1.0, 1.1, 2.0, etc).
*
* @param order the order, as a String
*/
public void setOrder(String order) {
this.order = order;
}
/**
* Gets the set of vertices used to render the relationship.
*
* @return a collection of Vertex objects
*/
public Collection getVertices() {
return new LinkedList<>(vertices);
}
/**
* Sets the collection of vertices used when rendering this relationship.
*
* @param vertices a Collection of Vertex instances
*/
public void setVertices(Collection vertices) {
if (vertices != null) {
this.vertices = new LinkedList<>(vertices);
}
}
/**
* Gets the routing algorithm used when rendering this relationship.
*
* @return a Routing instance, or null if not explicitly set
*/
public Routing getRouting() {
return routing;
}
/**
* Sets the routing algorithm used when rendering this relationship.
*
* @param routing a Routing instance, or null to not explicitly set this property
*/
public void setRouting(Routing routing) {
this.routing = routing;
}
/**
* Gets the position of the annotation along the line.
*
* @return an integer between 0 (start of the line) to 100 (end of the line) inclusive
*/
public Integer getPosition() {
return position;
}
/**
* Sets the position of the annotation along the line.
*
* @param position the position, as an integer between 0 (start of the line) to 100 (end of the line) inclusive
*/
public void setPosition(Integer position) {
if (position == null) {
this.position = null;
} else if (position < START_OF_LINE) {
this.position = START_OF_LINE;
} else if (position > END_OF_LINE) {
this.position = END_OF_LINE;
} else {
this.position = position;
}
}
void copyLayoutInformationFrom(RelationshipView source) {
if (source != null) {
setVertices(source.getVertices());
setPosition(source.getPosition());
setRouting(source.getRouting());
}
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
RelationshipView that = (RelationshipView) o;
if (description != null ? !description.equals(that.description) : that.description != null) return false;
if (!getId().equals(that.getId())) return false;
if (order != null ? !order.equals(that.order) : that.order != null) return false;
return true;
}
@Override
public int hashCode() {
int result = getId().hashCode();
result = 31 * result + (description != null ? description.hashCode() : 0);
result = 31 * result + (order != null ? order.hashCode() : 0);
return result;
}
@Override
public String toString() {
if (relationship != null) {
return (order != null ? order + ": " : "") + (description != null ? description + " " : "") + relationship.toString();
}
return "";
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy