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

com.github.gwtbootstrap.client.ui.config.Configurator Maven / Gradle / Ivy

/*
 *  Copyright 2012 GWT-Bootstrap
 *
 *  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 com.github.gwtbootstrap.client.ui.config;

import com.github.gwtbootstrap.client.ui.base.IsResponsive;
import com.github.gwtbootstrap.client.ui.resources.Resources;

/**
 * 

Using custom CSS/JS resources.

* *

* GWT-Bootstrap uses embedded copies of bootstrap.css and bootstrap.js by default. If you need to use your own copies * or include other resources, you'll need to create a custom {@link Configurator} and a custom {@link Resources}. *

*

* A suggested layout is below. First, create your resource package at the same level as client/server/shared. Next, create * css and js directories beneath the resources directory, and add your custom css and js files into those. Next, create your custom * {@link Configurator} and a custom {@link Resources}. Finally, add * a replace-with tag and a public tag to your module xml. *

*

* Full example below: *

* *

* 1. Create your resources package directory and add css and js directories beneath that. Add your custom css and js files to the css and js * directories, respectively. *

 * src/main/java/com/example
 * |-- client
 * |-- resources
 * |   |-- css
 * |   |   `-- bootstrap.min.css < your custom css
 * |   |   `-- bootstrap-responsive.min.css < your custom css
 * |   |-- js
 * |   |   `-- bootstrap.min.js < your custom js
 * |   |-- ExampleConfigurator.java < your custom Configurator class
 * |   `-- ExampleResources.java < your custom Resources interface
 * |-- server
 * |-- shared
 * `-- Example.gwt.xml < your module xml file
 * 
* * * 2. Create a Resources interface (extending {@link Resources}) that overrides the * getters of the files you want to replace. * *
 * 	public interface MyResources extends Resources {
 * 		{@literal @Source("css/bootstrap.min.css")}
 * 		TextResource bootstrapCss();
 *
 * 		{@literal @Source("css/bootstrap-responsive.min.css")}
 * 		TextResource bootstrapResponsiveCss();
 * 	}
 * 
* *

* *

* 3. Create a Configurator that returns your new {@link Resources}. * *

 * 	public MyConfigurator implements Configurator {
 * 		public Resources getResources() {
 * 			return GWT.create(MyResources.class);
 * 		}
 * 	}
 * 
* *

* *

* 4. Add a replace-with tag, a source tag, and a public tag to your module xml * (*.gwt.xml): * *

 * {@literal
 * 
 * 
 *     
 * 
 * 
 *     
 *     
 * 
 *
 * }
 * 
* *

* *

A more detailed tutorial and a full working example can be found here.

* @since 2.0.4.0 * * @author Dominik Mayer * @author ohashi keisuke * @author Carlos A Becker * * @see Resources * @see DefaultConfigurator */ public interface Configurator { /** * Get the Bootstrap Resources that should be used for this project. * * @return the Bootstrap Resources */ Resources getResources(); //@formatter:off /** * Determines whether the project uses a responsive design. * *

* If the responsive * design is enabled, the interface can adapt to the screen size and show * different content on smartphones, tablets and desktop computers. *

* * @return true if the responsive features should be enabled. * Default: false * * @see IsResponsive * * @see Bootstrap documentation */ boolean hasResponsiveDesign(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy