All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.wicket.devutils.debugbar.DebugBar Maven / Gradle / Ivy

Go to download

Wicket development utilities provide helpful features that are typically used during development only, but may be turned on for additional production debugging.

There is a newer version: 10.2.0
Show newest version
/*
 * 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.wicket.devutils.debugbar;

import java.util.ArrayList;
import java.util.List;

import org.apache.wicket.Application;
import org.apache.wicket.AttributeModifier;
import org.apache.wicket.Component;
import org.apache.wicket.MetaDataKey;
import org.apache.wicket.devutils.DevUtilsPanel;
import org.apache.wicket.markup.head.CssHeaderItem;
import org.apache.wicket.markup.head.IHeaderResponse;
import org.apache.wicket.markup.head.JavaScriptHeaderItem;
import org.apache.wicket.markup.head.OnDomReadyHeaderItem;
import org.apache.wicket.markup.html.WebMarkupContainer;
import org.apache.wicket.markup.html.image.Image;
import org.apache.wicket.markup.html.list.ListItem;
import org.apache.wicket.markup.html.list.ListView;
import org.apache.wicket.model.AbstractReadOnlyModel;
import org.apache.wicket.request.resource.CssResourceReference;
import org.apache.wicket.request.resource.JavaScriptResourceReference;
import org.apache.wicket.request.resource.PackageResourceReference;
import org.apache.wicket.util.lang.Args;

/**
 * The debug bar is for use during development. It allows contributors to add useful functions or
 * data, making them readily accessible to the developer.
*
* To use it, simply add it to your base page so that all of your pages automatically have it.
* *
* * Java: * add(new DebugBar("debug")); * * HTML: * <div wicket:id="debug"></div> * * *
* You can also add your own information to the bar by creating a {@link IDebugBarContributor} and * registering it with the debug bar. * *

The debug bar uses CSS absolute positioning to appear in the top-right corner of the page. * Important: if there is an element with a z-index in this part of your page, the DebugBar will need a higher * "z-index" style value to show up. Or you can use different position for it. See wicket-debugbar.css.

* * @author Jeremy Thomerson * @see IDebugBarContributor */ public class DebugBar extends DevUtilsPanel { private static final long serialVersionUID = 1L; private static final MetaDataKey> CONTRIBS_META_KEY = new MetaDataKey>() { private static final long serialVersionUID = 1L; }; /** * Construct. *

* Create debug bar (initially expanded) * * @param id * component id * * @see #DebugBar(String, boolean) */ public DebugBar(final String id) { this(id, true); } /** * Construct. * * @param id * component id * @param initiallyExpanded * {@code true} to show debug bar initially expanded * * @see #DebugBar(String) */ public DebugBar(final String id, boolean initiallyExpanded) { super(id); setMarkupId("wicketDebugBar"); setOutputMarkupId(true); add(AttributeModifier.replace("class", new AbstractReadOnlyModel() { private static final long serialVersionUID = 1L; @Override public String getObject() { return "wicketDebugBar" + (DebugBar.this.hasErrorMessage() ? "Error" : ""); } })); add(new Image("logo", new PackageResourceReference(DebugBar.class, "wicket.png"))); add(contentSection("content", initiallyExpanded)); } /** * Positions the DebugBar at the bottom of the page * @return */ public DebugBar positionBottom() { add(AttributeModifier.append("class", "bottom")); return this; } private Component contentSection(final String id, boolean initiallyExpanded) { WebMarkupContainer section = new WebMarkupContainer(id); if (!initiallyExpanded) { section.add(AttributeModifier.append("style", "display:none").setSeparator(";")); } List contributors = getContributors(getApplication()); section.add(new ListView("contributors", contributors) { private static final long serialVersionUID = 1L; @Override protected void populateItem(final ListItem item) { IDebugBarContributor contrib = item.getModelObject(); Component comp = contrib.createComponent("contrib", DebugBar.this); if (comp == null) { // some contributors only add information to the debug bar // and don't actually create a contributed component item.setVisibilityAllowed(false); } else { item.add(comp); } } }); section.add(new Image("removeImg", new PackageResourceReference(DebugBar.class, "remove.png"))); return section; } @Override public boolean isVisible() { return getApplication().getDebugSettings().isDevelopmentUtilitiesEnabled(); } @Override public void renderHead(final IHeaderResponse response) { response.render(CssHeaderItem.forReference(new CssResourceReference(DebugBar.class, "wicket-debugbar.css"))); response.render(JavaScriptHeaderItem.forReference(new JavaScriptResourceReference( DebugBar.class, "wicket-debugbar.js"))); response.render(OnDomReadyHeaderItem.forScript("wicketDebugBarCheckState()")); } /** * Register your own custom contributor that will be part of the debug bar. You must have the * context of an application for this thread at the time of calling this method. * * @param contrib * custom contributor - can not be null */ public static void registerContributor(final IDebugBarContributor contrib) { registerContributor(contrib, Application.get()); } /** * Register your own custom contributor that will be part of the debug bar. You must have the * context of an application for this thread at the time of calling this method. * * @param application * @param contrib * custom contributor - can not be null */ public static void registerContributor(final IDebugBarContributor contrib, final Application application) { Args.notNull(contrib, "contrib"); List contributors = getContributors(application); contributors.add(contrib); setContributors(contributors, application); } public static List getContributors(final Application application) { List list = application.getMetaData(CONTRIBS_META_KEY); return list == null ? new ArrayList() : list; } public static void setContributors(List contributors, Application application) { Args.notNull(application, "application"); application.setMetaData(CONTRIBS_META_KEY, contributors); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy