blob: 589fe751177b8364faf3e51a3f0493758c91f53e [file] [log] [blame]
/*
* Copyright 2015-present Open Networking Laboratory
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.onosproject.ui;
import com.google.common.base.MoreObjects;
import java.util.Objects;
/**
* Represents user interface view addition.
*/
public class UiView {
/**
* Designates navigation menu category.
*/
public enum Category {
/**
* Represents platform related views.
*/
PLATFORM("Platform"),
/**
* Represents network-control related views.
*/
NETWORK("Network"),
/**
* Represents miscellaneous views.
*/
OTHER("Other"),
/**
* Represents views that do not show in the navigation menu.
* This category should not be specified directly; rather, use
* the {@link UiViewHidden} constructor instead of {@link UiView}.
*/
HIDDEN("(hidden)");
private final String label;
Category(String label) {
this.label = label;
}
/**
* Returns display label for the category.
*
* @return display label
*/
public String label() {
return label;
}
}
private final Category category;
private final String id;
private final String label;
private final String iconId;
/**
* Creates a new user interface view descriptor. The navigation item
* will appear in the navigation menu under the specified category.
*
* @param category view category
* @param id view identifier
* @param label view label
*/
public UiView(Category category, String id, String label) {
this(category, id, label, null);
}
/**
* Creates a new user interface view descriptor. The navigation item
* will appear in the navigation menu under the specified category,
* with the specified icon adornment.
*
* @param category view category
* @param id view identifier
* @param label view label
* @param iconId icon id
*/
public UiView(Category category, String id, String label, String iconId) {
this.category = category;
this.id = id;
this.label = label;
this.iconId = iconId;
}
/**
* Returns the navigation category.
*
* @return navigation category
*/
public Category category() {
return category;
}
/**
* Returns the view identifier.
*
* @return view id
*/
public String id() {
return id;
}
/**
* Returns the view label.
*
* @return view label
*/
public String label() {
return label;
}
/**
* Returns the icon ID.
*
* @return icon ID
*/
public String iconId() {
return iconId;
}
@Override
public int hashCode() {
return id.hashCode();
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null || getClass() != obj.getClass()) {
return false;
}
final UiView other = (UiView) obj;
return Objects.equals(this.id, other.id);
}
@Override
public String toString() {
return MoreObjects.toStringHelper(this)
.add("category", category)
.add("id", id)
.add("label", label)
.add("iconId", iconId)
.toString();
}
}