/* Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to you 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.apache.wiki.forms; import org.apache.wiki.WikiContext; import org.apache.wiki.api.plugin.WikiPlugin; /** */ public abstract class FormElement implements WikiPlugin { /** * In order to make the form-to-handler parameter transfer easier, * we prefix all user-specified FORM element names with HANDLERPARAM_PREFIX * the HTML output. This lets us differentiate user-defined FormHandler * parameters from Form parameters. * The submit handler must then use MapUtil.requestToMap() to * strip them before executing the handler itself. */ public static final String HANDLERPARAM_PREFIX = "nbf_"; /** * The submit servlet may decide to store a FormInfo with user-entered * form values in the Session. It should use this name, and this class * checks for it to pre-fill fields from a previous form submit. */ public static final String FORM_VALUES_CARRIER = "nbpf_values"; /** * Show values. Value is <tt>{@value}</tt>. */ public static final String HIDE_SUCCESS = "onsuccess"; // Parameter names: /** Plugin parameter, optional, indicates servlet to post to. */ public static final String PARAM_SUBMITHANDLER = "submit"; /** Plugin parameter, mandatory, indicates what form element to insert. */ public static final String PARAM_ELEMENT = "element"; /** * Plugin parameter, mandatory in output element, indicates * WikiPlugin to use to handle form submitted data. */ public static final String PARAM_HANDLER = "handler"; /** Plugin parameter, mandatory in open/output: name of the form. */ public static final String PARAM_FORM = "form"; /** Plugin parameter, mandatory in input elements: name of an element. */ public static final String PARAM_INPUTNAME = "name"; /** Plugin parameter, optional: default value for an input. */ public static final String PARAM_VALUE = "value"; /** Experimental: hide the form if it was submitted successfully. */ public static final String PARAM_HIDEFORM = "hide"; /** If set to 'handler' in output element, the handler plugin is * called even on first invocation (no submit). The plugin can * then place values into its parameter map, and these are seen by * subsequent Form elements. (Store a value in the plugin with the * same key as an input element, and the value will be visible in * the initial form.) */ public static final String PARAM_POPULATE = "populate"; /** HTTP parameter, inserted as hidden variable into the generated form. */ public static final String PARAM_FORMNAMEHIDDEN = "formname"; // Key to store the form info container in the context by: //public static final String CONTEXT_FORMINFO = "FormPluginInfo"; /** * Utility method stores a FormInfo object into the WikiContext. * * @param ctx The Context to store it in * @param info The FormInfo to store. */ protected void storeFormInfo( WikiContext ctx, FormInfo info ) { ctx.setVariable( FORM_VALUES_CARRIER, info ); } /** * Attempts to retrieve information on the currently handled * form from the WikiContext. * * @param ctx The Context * @return The FormInfo from the context */ protected FormInfo getFormInfo( WikiContext ctx ) { return ( FormInfo )ctx.getVariable( FORM_VALUES_CARRIER ); } }