org.icefaces.ace.component.tableconfigpanel.TableConfigPanelMeta Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of icefaces-ace Show documentation
Show all versions of icefaces-ace Show documentation
${icefaces.product.name} ACE Component Library
/*
* Copyright 2004-2014 ICEsoft Technologies Canada Corp.
*
* 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.icefaces.ace.component.tableconfigpanel;
import org.icefaces.ace.meta.annotation.*;
import org.icefaces.ace.meta.baseMeta.UIComponentBaseMeta;
import org.icefaces.ace.resources.ACEResourceNames;
import org.icefaces.resources.ICEResourceDependencies;
import org.icefaces.resources.ICEResourceDependency;
import org.icefaces.resources.ICEResourceLibrary;
@Component(
tagName = "tableConfigPanel",
extendsClass = "javax.faces.component.UIComponentBase",
rendererClass = "org.icefaces.ace.component.tableconfigpanel.TableConfigPanelRenderer",
rendererType = "org.icefaces.ace.component.TableConfigPanelRenderer",
generatedClass = "org.icefaces.ace.component.tableconfigpanel.TableConfigPanelBase",
componentType = "org.icefaces.ace.component.TableConfigPanel",
componentClass = "org.icefaces.ace.component.tableconfigpanel.TableConfigPanel",
componentFamily = "org.icefaces.ace.TableConfigPanel",
tlddoc = "Renders a hidden panel with controls to configure column features. The table whose columns are to be configured is targeted with the 'for' attribute. The location of the button to reveal this panel is configured via the 'type' attribute.
" +
"The table config panel renders three buttons, a checkmark which submits changes, a crossout that closes without submitting changes, and a trashcan, that closes and resets the column properties configurable via the table config panel to an unconfigured state.
" +
"For more information, see the TableConfigPanel Wiki Documentation.
")
@ICEResourceLibrary(ACEResourceNames.ACE_LIBRARY)
@ICEResourceDependencies({
@ICEResourceDependency(name = "util/ace-core.js"),
@ICEResourceDependency(name = "jquery/jquery.js"),
@ICEResourceDependency(name = "util/ace-datatable.js")
})
@ClientBehaviorHolder(events = {
@ClientEvent(name="open", javadoc="Fired when the TableConfigPanel is shown.",
tlddoc="Fired when the TableConfigPanel is shown.", defaultRender="@all", defaultExecute="@this"),
@ClientEvent(name="submit", javadoc="Fired when the TableConfigPanel submits its changes and closes.",
tlddoc="Fired when the TableConfigPanel submits its changes and closes.", defaultRender="@all", defaultExecute="@this"),
@ClientEvent(name="cancel", javadoc="Fired when the TableConfigPanel cancel its changes and closes.",
tlddoc="Fired when the TableConfigPanel cancel its changes and closes.", defaultRender="@all", defaultExecute="@this"),
@ClientEvent(name="trash", javadoc="Fired when the TableConfigPanel clears out the current state and closes.",
tlddoc="Fired when the TableConfigPanel clears out it's changes and closes.", defaultRender="@all", defaultExecute="@this")},
defaultEvent = "submit"
)
public class TableConfigPanelMeta extends UIComponentBaseMeta {
@Property(tlddoc = "Enable the configuration of column order." )
boolean columnOrderingConfigurable;
// @Property(tlddoc = "Allow the configuration of column size.")
// boolean columnSizingConfigurable;
@Property(tlddoc = "Enable the configuration of column visibility.")
boolean columnVisibilityConfigurable;
@Property(tlddoc = "Enable the configuration of column headerText properties.")
boolean columnNameConfigurable;
@Property(tlddoc = "Enable the configuration of column sorting priority and directions.")
boolean columnSortingConfigurable;
@Property(name = "for", tlddoc="Defines the component ID of the DataTable this ConfigPanel manipulates.")
String forTarget;
@Property(tlddoc = "When set to true, the disabled rows in the panel (corresponding to ace:column's that have their 'configurable' attribute set to false) will not be rendered, instead of rendering them with a disabled styling.",
defaultValue = "false",
defaultValueType = DefaultValueType.EXPRESSION)
boolean hideDisabledRows;
@Property(tlddoc = "Defines the display mode for the 'open' control panel button. Available options: first-col, last-col, in-col-right, in-col-left",
defaultValue = "first-col")
String type;
@Property(tlddoc = "Defines the column to render the 'launch' panel button in when using the 'in-col-left' or 'in-col-right' type options.")
String inColumnId;
@Property(tlddoc = "Defines a CSS selector of a TableConfigPanel subregion used as the handle when dragging the panel.")
String dragHandle;
@Property(tlddoc = "Define the distance in pixels from left boundary of the CSS positioning bounding parent. If undefined, the panel is positioned offset slightly from the target DataTable.")
Integer offsetLeft;
@Property(tlddoc = "Define the distance in pixels from top boundary of the CSS positioning bounding parent. If undefined, the panel is positioned offset slightly from the target DataTable.")
Integer offsetTop;
@Property(tlddoc = "Specify whether viewing this panel disables the rest of the application from input.",
defaultValue = "false", defaultValueType = DefaultValueType.EXPRESSION)
Boolean modal;
@Property(tlddoc = "Access key that, when pressed, transfers focus to this component.")
String accesskey;
@Field(defaultValue = "0")
Integer forcedRenderCount;
}