/* * 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(); } } }