Package de.xima.fc.form.common.items
Class XSelect
- java.lang.Object
-
- de.xima.fc.form.common.items.XSelect
-
- All Implemented Interfaces:
IXDataSourceOptions
,IXItem
,IXItemBasic
,IXValuableItem
public class XSelect extends Object implements IXItem, IXValuableItem, IXDataSourceOptions
-
-
Field Summary
Fields Modifier and Type Field Description protected static org.slf4j.Logger
LOG
-
Constructor Summary
Constructors Constructor Description XSelect()
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description Map<String,List<org.apache.commons.lang3.Range<Integer>>>
getAllowedDataSourceParameterCount()
Use this method to indicate how many parameters each data source type must have in order to be selectable.ArrayList<XItemPropertyDesc>
getAvailableProperties(Locale locale)
String
getIcon()
String
getPrefix()
Finds the prefix for form items of this type, such ascb
for checkboxes ortf
for input fields.boolean
isShouldRenderForAttributeOnLabel(XItemRenderData renderData)
Whether thefor
should be added to the label of this element, if this element does have a label.boolean
isShouldRenderUnit(XItemRenderData renderData)
Whether theXPropertyEnum.unit
should be rendered.protected boolean
isShowDefaultOption(XItemRenderData renderData)
boolean
isSubmitsValues()
Checks whether form items of this type can send values to the server when the form is submitted.void
renderItem(com.hp.gagawa.java.elements.Div container, XItemRenderData renderData, XItemRenderCtx renderCtx, IXFormRenderContext formRenderCtx)
Creates the HTML for this form item that is included in the final rendered form.void
renderItemPreview(com.hp.gagawa.java.elements.Div container, XItemRenderData renderData, XItemRenderCtx renderCtx, IXFormRenderContext formRenderCtx)
Similar to theIXItemBasic.renderItem(Div, XItemRenderData, XItemRenderCtx, IXFormRenderContext)
method, but this is called when the form is viewed in the designer.-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface de.xima.fc.form.common.models.IXItemBasic
getAutoReRender, isShowInDrawerPanel, isShowInElementSelect, processUpload, validate, validate, validateGlobal
-
-
-
-
Method Detail
-
getAvailableProperties
public ArrayList<XItemPropertyDesc> getAvailableProperties(Locale locale)
- Specified by:
getAvailableProperties
in interfaceIXItemBasic
- Parameters:
locale
- The current locale that can be used for locale dependent properties.- Returns:
- A list of all properties
-
isShowDefaultOption
protected boolean isShowDefaultOption(XItemRenderData renderData)
-
isShouldRenderUnit
public boolean isShouldRenderUnit(XItemRenderData renderData)
Description copied from interface:IXItemBasic
Whether theXPropertyEnum.unit
should be rendered. Note that the unit is rendered only when the item contains the propertyXPropertyEnum.unit
and its value is not empty. However, some elements may sometimes not support a unit. For example,XSelect
only support a unit when the it is rendered as a combo box, but not when rendered as a list of checkboxes. In these cases, you can override this method with an appropriate implementation. The default implementation simply returnstrue
.- Specified by:
isShouldRenderUnit
in interfaceIXItemBasic
- Parameters:
renderData
- The current render data with the properties and options of the item.- Returns:
true
when theXPropertyEnum.unit
should be rendered, orfalse
otherwise.
-
isShouldRenderForAttributeOnLabel
public boolean isShouldRenderForAttributeOnLabel(XItemRenderData renderData)
Description copied from interface:IXItemBasic
Whether thefor
should be added to the label of this element, if this element does have a label. The W3C spec requires that thefor
points to a non-hidden form control element (e.g. aninput
ortextarea
). Defaults totrue
.- Specified by:
isShouldRenderForAttributeOnLabel
in interfaceIXItemBasic
- Parameters:
renderData
- The current render data with the properties and options of the item.- Returns:
- Whether to include the
for
in the label.
-
getIcon
public String getIcon()
- Specified by:
getIcon
in interfaceIXItemBasic
- Returns:
- The CSS class for the icon of this form item, such as for example
ico-fc-XCheckbox
.
-
getPrefix
public String getPrefix()
Description copied from interface:IXItemBasic
Finds the prefix for form items of this type, such ascb
for checkboxes ortf
for input fields. This prefix is used, for example, in the designer to generate a default name for newly added form items (tf-1
,cb-2
).- Specified by:
getPrefix
in interfaceIXItemBasic
- Returns:
- The prefix for form items of this type.
-
isSubmitsValues
public boolean isSubmitsValues()
Description copied from interface:IXItemBasic
Checks whether form items of this type can send values to the server when the form is submitted. Form items that do not submit values are, for example, not validated and no values are ever stored in the database. Form items such as pictures or charts do no submit values, while classical form elements such as input fields and checkboxes are a prime example of form items that do submit values.- Specified by:
isSubmitsValues
in interfaceIXItemBasic
- Returns:
- Whether form element of this type can send values to the server when the form is submitted.
-
renderItem
public void renderItem(com.hp.gagawa.java.elements.Div container, XItemRenderData renderData, XItemRenderCtx renderCtx, IXFormRenderContext formRenderCtx)
Description copied from interface:IXItemBasic
Creates the HTML for this form item that is included in the final rendered form. You should append one or more HTML elements to the container that is passed to this method.- Specified by:
renderItem
in interfaceIXItemBasic
- Parameters:
container
- The container that will contain this form item in the final form. You should append children to this container.renderData
- The current render data with the properties and options of the item.renderCtx
- The current render context giving you access to the global configuration.formRenderCtx
- The form render context giving you access to the global form configuration.- See Also:
IXItemBasic.renderItemPreview(Div, XItemRenderData, XItemRenderCtx, IXFormRenderContext)
-
renderItemPreview
public void renderItemPreview(com.hp.gagawa.java.elements.Div container, XItemRenderData renderData, XItemRenderCtx renderCtx, IXFormRenderContext formRenderCtx)
Description copied from interface:IXItemBasic
Similar to theIXItemBasic.renderItem(Div, XItemRenderData, XItemRenderCtx, IXFormRenderContext)
method, but this is called when the form is viewed in the designer. You can, if necessary, render the form slightly differently in the desigern. This is useful, for example, when when you do not want users to be able to interact with the form element directly in the designer preview area.- Specified by:
renderItemPreview
in interfaceIXItemBasic
- Parameters:
container
- The container that will contain this form item in the final form. You should append children to this container.renderData
- The current render data with the properties and options of the item.renderCtx
- The current render context giving you access to the global configuration.formRenderCtx
- The form render context giving you access to the global form configuration.- See Also:
IXItemBasic.renderItem(Div, XItemRenderData, XItemRenderCtx, IXFormRenderContext)
-
getAllowedDataSourceParameterCount
public Map<String,List<org.apache.commons.lang3.Range<Integer>>> getAllowedDataSourceParameterCount()
Description copied from interface:IXDataSourceOptions
Use this method to indicate how many parameters each data source type must have in order to be selectable. For example, the default XSelect form element lets the user select CSV, DB and PLUGIN data sources with no parameters:@Override public Map<String, List<Range<Integer>>> getAllowedDataSourceParameterCount() { final Map<String, List<Range<Integer>>> ranges = new HashMap<>(); ranges.put(EDatasource.CSV.name(), Arrays.asList(Range.is(0))); ranges.put(EDatasource.DB.name(), Arrays.asList(Range.is(0))); ranges.put(EDatasource.PLUGIN.name(), Arrays.asList(Range.is(0))); return ranges; }
- Specified by:
getAllowedDataSourceParameterCount
in interfaceIXDataSourceOptions
- Returns:
- A map between each data source type as the key and a list of allowed parameter counts (inclusive range) as
the value. When
null
is returned, the defaults (which may change) are used. When a key for a data source type is missing or is mapped tonull
, no data sources of that type are selectable.
-
-