-
Notifications
You must be signed in to change notification settings - Fork 58
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[1139] Add support for a new tree widget in forms
Bug: #1139 Signed-off-by: Pierre-Charles David <[email protected]>
- Loading branch information
1 parent
4608d99
commit 8b678e0
Showing
23 changed files
with
3,284 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
136 changes: 136 additions & 0 deletions
136
...d/sirius-components-forms/src/main/java/org/eclipse/sirius/components/forms/TreeNode.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,136 @@ | ||
/******************************************************************************* | ||
* Copyright (c) 2022 Obeo. | ||
* This program and the accompanying materials | ||
* are made available under the terms of the Eclipse Public License v2.0 | ||
* which accompanies this distribution, and is available at | ||
* https://www.eclipse.org/legal/epl-2.0/ | ||
* | ||
* SPDX-License-Identifier: EPL-2.0 | ||
* | ||
* Contributors: | ||
* Obeo - initial API and implementation | ||
*******************************************************************************/ | ||
package org.eclipse.sirius.components.forms; | ||
|
||
import java.text.MessageFormat; | ||
import java.util.Objects; | ||
|
||
import org.eclipse.sirius.components.annotations.Immutable; | ||
|
||
/** | ||
* Represents a node (and its sub-nodes if it has any) inside a {@link TreeWidget}. | ||
* | ||
* @author pcdavid | ||
*/ | ||
@Immutable | ||
public final class TreeNode { | ||
private String id; | ||
|
||
private String parentId; | ||
|
||
private String label; | ||
|
||
private String kind; | ||
|
||
private String imageURL; | ||
|
||
private boolean selectable; | ||
|
||
private TreeNode() { | ||
// Prevent instantiation | ||
} | ||
|
||
public String getId() { | ||
return this.id; | ||
} | ||
|
||
public String getParentId() { | ||
return this.parentId; | ||
} | ||
|
||
public String getLabel() { | ||
return this.label; | ||
} | ||
|
||
public String getKind() { | ||
return this.kind; | ||
} | ||
|
||
public String getImageURL() { | ||
return this.imageURL; | ||
} | ||
|
||
public boolean isSelectable() { | ||
return this.selectable; | ||
} | ||
|
||
public static Builder newTreeNode(String id) { | ||
return new Builder(id); | ||
} | ||
|
||
@Override | ||
public String toString() { | ||
String pattern = "{0} '{'id: {1}, label: {2}, kind: {3}, selectable: {4}, imageURL: {5}, parentId: {6}'}'"; //$NON-NLS-1$ | ||
return MessageFormat.format(pattern, this.getClass().getSimpleName(), this.id, this.label, this.kind, this.selectable, this.imageURL, this.parentId); | ||
} | ||
|
||
/** | ||
* The builder used to create the tree node. | ||
* | ||
* @author pcdavid | ||
*/ | ||
@SuppressWarnings("checkstyle:HiddenField") | ||
public static final class Builder { | ||
private String id; | ||
|
||
private String parentId; | ||
|
||
private String label; | ||
|
||
private String kind; | ||
|
||
private String imageURL; | ||
|
||
private boolean selectable; | ||
|
||
private Builder(String id) { | ||
this.id = Objects.requireNonNull(id); | ||
} | ||
|
||
public Builder parentId(String parentId) { | ||
this.parentId = parentId; | ||
return this; | ||
} | ||
|
||
public Builder label(String label) { | ||
this.label = Objects.requireNonNull(label); | ||
return this; | ||
} | ||
|
||
public Builder kind(String kind) { | ||
this.kind = Objects.requireNonNull(kind); | ||
return this; | ||
} | ||
|
||
public Builder imageURL(String imageURL) { | ||
this.imageURL = Objects.requireNonNull(imageURL); | ||
return this; | ||
} | ||
|
||
public Builder selectable(boolean selectable) { | ||
this.selectable = Objects.requireNonNull(selectable); | ||
return this; | ||
} | ||
|
||
public TreeNode build() { | ||
TreeNode treeNode = new TreeNode(); | ||
treeNode.id = Objects.requireNonNull(this.id); | ||
treeNode.parentId = this.parentId; | ||
treeNode.label = Objects.requireNonNull(this.label); | ||
treeNode.kind = Objects.requireNonNull(this.kind); | ||
treeNode.selectable = Objects.requireNonNull(this.selectable); | ||
treeNode.imageURL = Objects.requireNonNull(this.imageURL); | ||
return treeNode; | ||
} | ||
} | ||
} |
Oops, something went wrong.