Estou finalizando o curso da Academia Web na V.Office. Neste, tivemos a oportunidade em integrar o tema SB Admin2 com JSF.
Em paralelo a isso, tive um desafio no trabalho de criar uma aplicação de consulta e autenticação responsiva. Unindo o útil ao agradável, utilizei este tema do bootstrap para me auxiliar. Vejamos como é simples realizar essa integração.
1 – Faça o download do tema;
2 – No eclipse, crie um projeto maven (utilizei o archetype maven-archetype-webapp);
3 – Adicione as dependências necessárias no pom.xml e atualize o projeto.
<dependencies> <dependency> <groupId>javax</groupId> <artifactId>javaee-web-api</artifactId> <version>7.0</version> <scope>provided</scope> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> <version>1.2</version> <scope>provided</scope> </dependency> </dependencies>
4 – Atualize o web.xml;
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0"> <display-name>Archetype Created Web Application</display-name> <servlet> <servlet-name>Faces Servlet</servlet-name> <servlet-class>javax.faces.webapp.FacesServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>Faces Servlet</servlet-name> <url-pattern>*.xhtml</url-pattern> </servlet-mapping> <welcome-file-list> <welcome-file>index.xhtml</welcome-file> </welcome-file-list> </web-app>
5 – Descompacte o projeto sb-admin 2. Dentro de webapp crie a pasta resources e copie as pastas data, dist e vendor do arquivo descompactado;
6 – Crie o arquivo index.xhtml dentro da pasta webapp e copie o conteúdo do arquivo index.html da pasta extraída para ele. Obs: Mantenha os xmlns do jsf.
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml" xmlns:ui="http://java.sun.com/jsf/facelets" xmlns:f="http://java.sun.com/jsf/core" xmlns:h="http://java.sun.com/jsf/html"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <meta name="description" content=""> <meta name="author" content="">
7 – Corrija o href dos links, exemplo:
<!-- Bootstrap Core CSS --> <link href="/integrando-sb-jsf/resources/vendor/bootstrap/css/bootstrap.min.css" rel="stylesheet">
8 – Como está sendo utilizado o XHTML, é necessário fechar algumas tags para evitar erros. Ex:
<meta charset="utf-8"/> <link href="/integrando-sb-jsf/resources/vendor/bootstrap/css/bootstrap.min.css" rel="stylesheet"/> <hr/>
9 – Agora vamos criar um controller simples para testar o JSF.
package br.com.karanalpe.integrando.sb.jsf.controller; import javax.enterprise.context.RequestScoped; import javax.inject.Named; @Named @RequestScoped public class IndexMB { public String imprimirMensagem() { return "Olá JSF"; } }
10 – Testando no xhtml.
<h1 class="page-header">#{indexMB.imprimirMensagem()}</h1>
Resultado:
Conclusão
O template SB Admin é muito útil para quem deseja desenvolver um sistema com uma interface limpa e responsiva. Além disso, o mesmo oferece uma série de componentes customizáveis que facilita muito a vida do desenvolvedor. Para conhecer um pouco melhor o template clique aqui. Caso queira baixar o código fonte desse post, clique aqui.