/*
* Copyright 2015 Red Hat, Inc. and/or its affiliates.
*
* 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.kie.workbench.common.screens.datamodeller.client.widgets.advanceddomain.valuepaireditor.enums;
import java.util.ArrayList;
import java.util.List;
import com.google.gwt.core.client.GWT;
import com.google.gwt.user.client.ui.Widget;
import org.kie.workbench.common.screens.datamodeller.client.util.UIUtil;
import org.kie.workbench.common.screens.datamodeller.client.widgets.advanceddomain.valuepaireditor.ValuePairEditor;
import org.kie.workbench.common.screens.datamodeller.client.widgets.advanceddomain.valuepaireditor.ValuePairEditorHandler;
import org.kie.workbench.common.screens.datamodeller.client.widgets.advanceddomain.valuepaireditor.util.ValuePairEditorUtil;
import org.kie.workbench.common.services.datamodeller.core.AnnotationValuePairDefinition;
import org.uberfire.commons.data.Pair;
public class EnumValuePairEditor
implements EnumValuePairEditorView.Presenter,
ValuePairEditor<String> {
private EnumValuePairEditorView view;
private String currentValue;
private AnnotationValuePairDefinition valuePairDefinition;
private ValuePairEditorHandler editorHandler;
public EnumValuePairEditor() {
this( ( EnumValuePairEditorView ) GWT.create( EnumValuePairEditorViewImpl.class ) );
}
public EnumValuePairEditor( EnumValuePairEditorView view ) {
this.view = view;
view.init( this );
}
@Override
public Widget asWidget() {
return view.asWidget();
}
@Override
public void init( AnnotationValuePairDefinition valuePairDefinition ) {
this.valuePairDefinition = valuePairDefinition;
view.initOptions( createOptionsList( valuePairDefinition.enumValues() ) );
view.setValuePairLabel( ValuePairEditorUtil.buildValuePairLabel( valuePairDefinition ) );
view.showValuePairRequiredIndicator( !valuePairDefinition.hasDefaultValue() );
}
private List<Pair<String, String>> createOptionsList( String[] enumValues ) {
List<Pair<String, String>> items = new ArrayList<Pair<String, String>>( );
for ( int i = 0; i < enumValues.length; i++ ) {
items.add( new Pair( enumValues[i], enumValues[i] ) );
}
return items;
}
@Override
public void setValue( String value ) {
view.setSelectedValue( value != null ? value : UIUtil.NOT_SELECTED );
this.currentValue = value;
}
public String getValue( ) {
return currentValue;
}
@Override
public boolean isValid() {
return true;
}
@Override
public void clear() {
view.setSelectedValue( UIUtil.NOT_SELECTED );
}
@Override
public void addEditorHandler( ValuePairEditorHandler editorHandler ) {
this.editorHandler = editorHandler;
}
@Override
public AnnotationValuePairDefinition getValuePairDefinition() {
return valuePairDefinition;
}
@Override
public void setErrorMessage( String errorMessage ) {
view.setErrorMessage( errorMessage );
}
@Override
public void clearErrorMessage() {
view.clearErrorMessage();
}
@Override
public void showValidateButton( boolean show ) {
//This editor doesn't need the validate button.
}
@Override
public void showValuePairName( boolean show ) {
//this editor doesn't need to hide the label
}
@Override
public void refresh() {
//This editor doesn't need the refresh method.
}
@Override
public void onValueChange() {
String value = view.getSelectedValue();
currentValue = !UIUtil.NOT_SELECTED.equals( value ) ? value : null;
if ( editorHandler != null ) {
editorHandler.onValueChange();
}
}
}