Class InputMatrixInputBuilder
InputType.INPUTMATRIX- 
Nested Class SummaryNested classes/interfaces inherited from class AbstractInputBuilderAbstractInputBuilder.InputWidth
- 
Field SummaryFields inherited from class AbstractInputBuilderbuilderContext, cp
- 
Constructor SummaryConstructorsConstructorDescriptionInputMatrixInputBuilder(InputBuilderContext builderContext, String paramName) 
- 
Method SummaryModifier and TypeMethodDescriptionprotected ObjectsetCanModifyRows(boolean value) When set tofalsea user will not be able to add or remove rows in the input matrix table.setColumns(List<?> columns) setColumnValueOptions(Map value) Sets column value options.setDefaultHeight(int value) Sets the maximum input matrix table height.setDisableRowSelection(boolean disableRowSelection) Manage the row selection visibilitysetEnableAdvancedFilter(boolean enableAdvancedFilter) Enabling the advanced filter functionality.setEnableClientFilter(boolean enableClientFilter) Allows a user to filter the table by row values.
 Default =true(the filtering is enabled).setFitFieldWidths(boolean value) Sets whether fields (table cells) should autofit widths to title texts or the content.setFixTableHeight(boolean value) Set totrueto limit the input matrix table height by the DefaultHeight.setHiddenColumns(List<String> columnsToHide) Allow for particular columns to be hidden in the input matrix table.setHideAddButton(boolean value) Hides the "Add" button.setHideDeleteButton(boolean value) Deprecated.setHideRemoveButton(boolean value) Hides the "Remove" button.setNoCellRefresh(boolean value) Set totrueto display the Apply button within the input matrix.setReadOnlyColumns(List<String> readOnlyColumns) Marks specified columns as read-only.setRequiredColumns(List<String> requiredColumns) Sets columns as required.withEnableAdvancedFilter(boolean enableAdvancedFilter) Enabling the advanced filter functionality.withEnableClientFilter(boolean enableClientFilter) Allows a user to filter the table by row values.
 Default =true(the filtering is enabled).withPreferenceName(String preferenceName) Defines the preference name (whitespace and non-alphanumeric will be dropped).Methods inherited from class AbstractInputBuilderaddOrUpdateInput, addToConfiguratorEntry, addToConfiguratorEntry, buildContextParameter, buildMap, getInput, self, setAccessCode, setAlign, setAllValueTypesTracking, setAlwaysEditable, setAppearance, setAutoComplete, setAutoFocus, setCaption, setConfigValues, setCustomAttributeName, setCustomAttributeValue, setDefaultValueTracking, setDefaultWidth, setDisabled, setDisplayMode, setErrorMessage, setExportable, setFirstRunTracking, setFlex, setHelpLink, setHelpText, setIcon, setIconPosition, setImportable, setLabel, setLabelPlacement, setLabelStyle, setLabelTranslations, setLayoutGridName, setLogActivity, setNoRefresh, setParameterGroup, setPlaceholderText, setPreviousValueTracking, setReadOnly, setRequired, setShowInline, setSize, setStoreAuditTrail, setSuccessMessage, setTab, setTheme, setTitle, setTrackedValue, setUserGroupEdit, setUserGroupEdit, setUserGroupView, setUserGroupView, setValue, setValueChangeTracking, setValueHint, setWarningMessage, setWidth
- 
Constructor Details- 
InputMatrixInputBuilder
 
- 
- 
Method Details- 
setColumnsMethod can be used to set column's name byListor byListofMaps.ListofMapargument allow to add columns with name, label and type.The column's Mapstructure is predefined:Keys allowed: 'columnName' (mandatory), 'columnLabel' (optional) and 'columnType' (optional). There is no additional validation for 'columnType'. Keys are case-sensitive (ie. 'columnName' is not the same as 'columnNAME' and the second one will not be qualified). Values allowed: no limitations, nulls and empty also allowed. If 'columnName' is massing in the Map, theInputBuilderExceptions.MissingMandatoryColumnExceptionis thrownIf other than 'columnLabel' or 'columnType' key is passed in the Map, theInputBuilderExceptions.ColumnStructureExceptionis thrown.If null or empty collection is passed as the method's argument, the InputBuilderExceptions.NullOrEmptyColumnsExceptionis thrownExample: 
 Whendef inputMatrix = api.inputBuilderFactory() .createInputMatrix('The Matrix') .setColumns([[columnName: 'Desc', columnLabel: 'Description', columnType: 'Text'], [columnName: 'Value', columnLabel: 'Numeric Value', columnType: 'Numeric']]) .buildMap() quoteProcessor.addOrUpdateInput(inputMatrix) return inputMatrixListofStrings is passed as the argument only columns names are set.Example: def im = api.inputBuilderFactory() .createInputMatrix("The Matrix") .setColumns(["column1", "column2"]) .buildMap() quoteProcessor.addOrUpdateInput(im) return im
- 
setRequiredColumnsSets columns as required. Example:def inputMatrix = api.inputBuilderFactory() .createInputMatrix('The Matrix') .setColumnsWithNameLabelType([[columnName: 'Desc', columnType: 'Text'], [columnName: 'Value', columnType: 'Numeric']]) .setRequiredColumns(['Value']) .buildMap() quoteProcessor.addOrUpdateInput(inputMatrix) return inputMatrix- Parameters:
- requiredColumns- column's names collection, which need to be a part of the columns collection
- Returns:
- The same instance of this class.
- Since:
- 12.1 - Clover Club
 
- 
setDisableRowSelectionManage the row selection visibilityExample: def inputMatrix = api.inputBuilderFactory() .createInputMatrix("The Matrix") .setColumns(["column1", "column2"]) .setDisableRowSelection(false) .buildMap() quoteProcessor.addOrUpdateInput(inputMatrix) return inputMatrix- Parameters:
- disableRowSelection- true for disabling the row selection (hide the check-box).
- Returns:
- The same instance of this class.
- Since:
- 12.0 - Clover Club
 
- 
setReadOnlyColumnsMarks specified columns as read-only. A user will not be able to change values in these columns. Example – sets "column2" as read only:def im = api.inputBuilderFactory() .createInputMatrix("The Matrix") .setColumns(["column1", "column2"]) .setReadOnlyColumns(["column2"]) .buildMap() quoteProcessor.addOrUpdateInput(im) return im- Parameters:
- readOnlyColumns- A list of strings that specifies columns to be marked as read-only.
- Returns:
- self
 
- 
setFitFieldWidthsSets whether fields (table cells) should autofit widths to title texts or the content. Example:def im = api.inputBuilderFactory() .createInputMatrix("The Matrix") .setColumns(["column1", "column2"]) .setFitFieldWidths(true) .buildMap() quoteProcessor.addOrUpdateInput(im) return im- Parameters:
- value-- trueto enable,- falseto disable fit field width
- Returns:
- self
- Since:
- 12.0 - Clover Club
 
- 
setDefaultHeightSets the maximum input matrix table height. If there are more entries than the defined default height the scroll bar appears. Example:def im = api.inputBuilderFactory() .createInputMatrix("The Matrix") .setColumns(["column1", "column2"]) .setDefaultHeight(300) .setFixTableHeight(true) .buildMap() quoteProcessor.addOrUpdateInput(im) return im- Parameters:
- value- The maximum default height of the input matrix table.
- Returns:
- self
- See Also:
 
- 
setColumnValueOptionsSets column value options. Allows a user to select one of the specified value only. Example – defines "option1" and "option2" as the only available values the user can select from:def im = api.inputBuilderFactory() .createInputMatrix("The Matrix") .setColumns(["column1", "column2"]) .setColumnValueOptions([column1: ["option1", "option2"], column2: ["option1", "option2"]]) .buildMap() quoteProcessor.addOrUpdateInput(im) return im- Parameters:
- value- The list of options for each column (a map of columnName:list of options).
- Returns:
- self
 
- 
setCanModifyRowsWhen set to Example:falsea user will not be able to add or remove rows in the input matrix table.def im = api.inputBuilderFactory() .createInputMatrix("The Matrix") .setColumns(["column1", "column2"]) .setCanModifyRows(false) .buildMap() quoteProcessor.addOrUpdateInput(im) return im- Parameters:
- value- true to enable, false to disable rows modification. Default = true.
- Returns:
- self
 
- 
setNoCellRefreshSet totrueto display the Apply button within the input matrix. A user can manually apply changes performed in the input matrix by clicking this button.Example: def im = api.inputBuilderFactory() .createInputMatrix("The Matrix") .setColumns(["column1", "column2"]) .setNoCellRefresh(true) .buildMap() quoteProcessor.addOrUpdateInput(im) return im- Parameters:
- value-- trueto disable,- falseto enable refreshing cells automatically. Default =- false.
- Returns:
- self
 
- 
setFixTableHeightSet to Example:trueto limit the input matrix table height by the DefaultHeight. The scroll bar appears within the input matrix when DefaultHeight is exceeded.def im = api.inputBuilderFactory() .createInputMatrix("The Matrix") .setColumns(["column1", "column2"]) .setDefaultHeight(150) .setFixTableHeight(false) .buildMap() quoteProcessor.addOrUpdateInput(im) return im- Parameters:
- value-- trueto enable,- falseto disable fix table height. Default =- true.
- Returns:
- self
- See Also:
 
- 
setHiddenColumnsAllow for particular columns to be hidden in the input matrix table.If columns-to-be-hidden are not valid InputMatrix-config-options-column's name then nothing is set Example: if (api.isInputGenerationExecution()) return def inputMatrix1 = api.inputBuilderFactory() .createInputMatrix('Input matrix') .setColumns(['Key_1', 'Key_2', 'Key_3']) .setHiddenColumns(['Key_2']) .buildContextParameter() // Column with name 'Key_2' will be hidden in the InputMatrix table def inputMatrix2 = api.inputBuilderFactory() .createInputMatrix('Input matrix') .setColumns(['Key_1', 'Key_2', 'Key_3']) .setHiddenColumns(['Key_4']) .buildContextParameter() // Column with name 'Key_4' does not exist in the InputMatrix table, thus nothing be hidden or set- Parameters:
- columnsToHide- List of columns' name to be hidden
- Returns:
- self
- Since:
- 12.0 - Clover Club
 
- 
setHideAddButtonHides the "Add" button.Set to Example – adds the input matrix and hides its "Add" button:trueto hide the "Add" button.return api.inputBuilderFactory() .createInputMatrix("InputMatrix") .setColumns(columns) .setColumnValueOptions(columnsValueOption) .setHideAddButton(true) .getInput()- Parameters:
- value-- trueto hide,- falseto show the button.
- Returns:
- self
- Since:
- 11.2.0 - Paper Plane
 
- 
setHideDeleteButtonDeprecated.UsesetHideRemoveButton(boolean)instead.Set to Example – adds the input matrix:trueto hide the "Delete" button.return api.inputBuilderFactory() .createInputMatrix("InputMatrix") .setColumns(columns) .setColumnValueOptions(columnsValueOption) .setHideAddButton(true) .setHideDeleteButton(true) .getInput()- Returns:
- self
 
- 
setHideRemoveButtonHides the "Remove" button.Set to Example – adds the input matrix and hides its "Remove" button:trueto hide the "Remove" button.return api.inputBuilderFactory() .createInputMatrix("InputMatrix") .setColumns(columns) .setColumnValueOptions(columnsValueOption) .setHideRemoveButton(true) .getInput()- Parameters:
- value-- trueto hide,- falseto show the button.
- Returns:
- self
- Since:
- 11.2.0 - Paper Plane
 
- 
withEnableClientFilterAllows a user to filter the table by row values.
 Default =true(the filtering is enabled).Example: return api.inputBuilderFactory() .createInputMatrix('InputMatrix') .setColumns(columns) .withEnableClientFilter(false) .buildContextParameter()- Parameters:
- enableClientFilter- Set to- falseto disable filtering.
- Returns:
- the current instance of InputMatrixInputBuilder
- Since:
- 13.0 - Rampur
- See Also:
 
- 
setEnableClientFilterAllows a user to filter the table by row values.
 Default =true(the filtering is enabled).Example: return api.inputBuilderFactory() .createInputMatrix('InputMatrix') .setColumns(columns) .setColumnValueOptions(columnsValueOption) .setEnableClientFilter(false) .buildContextParameter()- Parameters:
- enableClientFilter- Set to- falseto disable filtering.
- Returns:
- the current instance of InputMatrixInputBuilder
- Since:
- 13.0 - Rampur
- See Also:
 
- 
withEnableAdvancedFilterEnabling the advanced filter functionality. Default =true(the filtering is enabled).Example: return api.inputBuilderFactory() .createInputMatrix("InputMatrix") .setColumns(columns) .withEnableAdvancedFilter(false) .buildContextParameter()- Parameters:
- enableAdvancedFilter- Set to- falseto disable filtering.
- Returns:
- the current instance of InputMatrixInputBuilder
- Since:
- 13.0 - Rampur
- See Also:
 
- 
setEnableAdvancedFilterEnabling the advanced filter functionality. Default =true(the filtering is enabled).Example: return api.inputBuilderFactory() .createInputMatrix('InputMatrix') .setColumns(columns) .setColumnValueOptions(columnsValueOption) .setEnableAdvancedFilter(false) .buildContextParameter()- Parameters:
- enableAdvancedFilter- Set to- falseto disable filtering.
- Returns:
- the current instance of InputMatrixInputBuilder
- Since:
- 13.0 - Rampur
- See Also:
 
- 
withPreferenceNameDefines the preference name (whitespace and non-alphanumeric will be dropped).Example: def contextParameter = api.inputBuilderFactory() .createInputMatrix('matrix') .withPreferenceName('someName') .buildContextParameter() contextParameter.getPreferenceName == 'someName'- Parameters:
- preferenceName- name of the preference, cannot be whitespace or non-alphanumeric.
- Returns:
- the current instance of InputMatrixInputBuilder
- Since:
- 13.0 - Rampur
- See Also:
 
- 
_getInput- Specified by:
- _getInputin class- AbstractInputBuilder<InputMatrixInputBuilder,- Object> 
 
 
- 
setHideRemoveButton(boolean)instead.