/**
*
* Copyright (c) 2006-2017, Speedment, Inc. All Rights Reserved.
*
* 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 com.speedment.tool.propertyeditor;
import javafx.collections.ObservableList;
import javafx.geometry.HPos;
import javafx.geometry.VPos;
import javafx.scene.Node;
import javafx.scene.layout.ColumnConstraints;
import javafx.scene.layout.GridPane;
import javafx.scene.layout.Priority;
import java.util.HashSet;
import java.util.Set;
import java.util.concurrent.atomic.AtomicInteger;
/**
* GridPane which takes responsibility for the layout of editor items.
*
* @author Simon Jonasson
* @since 3.0.0
*/
final class PropertyLayout extends GridPane {
private final static int MIN_LABEL_WIDTH = 150;
private final static int MIN_EDITOR_WIDTH = 450;
private final AtomicInteger index;
private final Set<PropertyEditor.Item> items;
/**
* Creates a new GridPane, with proper column layout, and adds the editor items
* in order
*
* @param properties the properties which should be rendered
*/
PropertyLayout(ObservableList<PropertyEditor.Item> properties){
this.index = new AtomicInteger(0);
this.items = new HashSet<>();
getColumnConstraints().add(0, new ColumnConstraints(MIN_LABEL_WIDTH, USE_COMPUTED_SIZE, USE_PREF_SIZE, Priority.NEVER, HPos.LEFT, true));
getColumnConstraints().add(1, new ColumnConstraints(MIN_EDITOR_WIDTH, USE_COMPUTED_SIZE, Double.MAX_VALUE, Priority.ALWAYS, HPos.LEFT, true));
getStyleClass().add("properties-layout");
properties.stream().forEachOrdered( i -> addItem(i) );
}
/**
* Adds a new editor item to the layout. New items are added at the
* bottom.
*
* @param item the item
*/
void addItem(PropertyEditor.Item item){
final Node label = item.createLabel();
label.getStyleClass().add("property-label");
GridPane.setValignment(label, VPos.TOP);
final Node editor = item.createEditor();
editor.getStyleClass().add("property-editor");
GridPane.setValignment(editor, VPos.CENTER);
addRow(index.getAndIncrement(), label, editor);
items.add(item);
}
void remove() {
items.forEach(PropertyEditor.Item::onRemove);
getChildren().clear();
}
}