Update to Thymeleaf 3.0.2 and remove tiles

Spring 5 removed support for Tiles 2 and Thymeleaf does not support
Tiles 3 yet. This commit updates to Thymeleaf 3.0.2 and uses
Thymeleaf's build in layout support.

Issue gh-4080
This commit is contained in:
Rob Winch 2016-10-17 09:12:24 -05:00
parent c1e9140940
commit 5e35e37a2b
24 changed files with 180 additions and 362 deletions

View File

@ -162,12 +162,12 @@ Our existing configuration means that all we need to do is create a *login.html*
.src/main/resources/views/login.html .src/main/resources/views/login.html
[source,xml] [source,xml]
---- ----
<html xmlns:th="http://www.thymeleaf.org" xmlns:tiles="http://www.thymeleaf.org"> <html xmlns:th="http://www.thymeleaf.org">
<head> <head th:include="layout :: head(title=~{::title},links=~{})">
<title tiles:fragment="title">Messages : Create</title> <title>Please Login</title>
</head> </head>
<body> <body th:include="layout :: body" th:with="content=~{::content}">
<div tiles:fragment="content"> <div th:fragment="content">
<form name="f" th:action="@{/login}" method="post"> <1> <form name="f" th:action="@{/login}" method="post"> <1>
<fieldset> <fieldset>
<legend>Please Login</legend> <legend>Please Login</legend>

View File

@ -37,7 +37,7 @@ ext.springDataJpaVersion = '1.10.2.RELEASE'
ext.springDataRedisVersion = '1.7.2.RELEASE' ext.springDataRedisVersion = '1.7.2.RELEASE'
ext.springSessionVersion = '1.2.1.RELEASE' ext.springSessionVersion = '1.2.1.RELEASE'
ext.springBootVersion = '1.4.0.RELEASE' ext.springBootVersion = '1.4.0.RELEASE'
ext.thymeleafVersion = '2.1.5.RELEASE' ext.thymeleafVersion = '3.0.2.RELEASE'
ext.jsonassertVersion = '1.3.0' ext.jsonassertVersion = '1.3.0'
ext.validationApiVersion = '1.1.0.Final' ext.validationApiVersion = '1.1.0.Final'

View File

@ -64,13 +64,6 @@ public class WebMvcConfiguration extends WebMvcConfigurerAdapter {
return result; return result;
} }
@Bean
public ThymeleafTilesConfigurer tilesConfigurer() {
ThymeleafTilesConfigurer tilesConfigurer = new ThymeleafTilesConfigurer();
tilesConfigurer.setDefinitions(new String[] { "classpath:tiles/tiles-def.xml" });
return tilesConfigurer;
}
@Bean @Bean
public SpringTemplateEngine templateEngine( public SpringTemplateEngine templateEngine(
ClassLoaderTemplateResolver templateResolver) { ClassLoaderTemplateResolver templateResolver) {

View File

@ -1,57 +0,0 @@
<?xml version="1.0" encoding="ISO-8859-1" ?>
<!DOCTYPE tiles-definitions PUBLIC
"-//Apache Software Foundation//DTD Tiles Configuration 2.1//EN"
"http://tiles.apache.org/dtds/tiles-config_2_1.dtd">
<tiles-definitions>
<definition name="messages/*"
template="layout">
<put-attribute name="content"
value="content/messages/{1}"/>
<put-attribute name="title"
value="title/messages/{1}"/>
<put-attribute name="head"
value="head/messages/{1}"/>
</definition>
<definition name="content/messages/*"
template="messages/{1} :: content"/>
<definition name="title/messages/*"
template="messages/{1} :: title"/>
<definition name="head/messages/*"
template="messages/{1} :: /html/head/link"/>
<definition name="user/*"
template="layout">
<put-attribute name="content"
value="content/user/{1}"/>
<put-attribute name="title"
value="title/user/{1}"/>
<put-attribute name="head"
value="head/user/{1}"/>
</definition>
<definition name="content/user/*"
template="user/{1} :: content"/>
<definition name="title/user/*"
template="user/{1} :: title"/>
<definition name="head/user/*"
template="user/{1} :: /html/head/link"/>
<definition name="*"
template="layout">
<put-attribute name="content"
value="content/{1}"/>
<put-attribute name="title"
value="title/{1}"/>
<put-attribute name="head"
value="head/{1}"/>
</definition>
<definition name="content/*"
template="{1} :: content"/>
<definition name="title/*"
template="{1} :: title"/>
<definition name="head/*"
template="{1} :: /html/head/link"/>
</tiles-definitions>

View File

@ -1,9 +1,8 @@
<html xmlns:th="http://www.thymeleaf.org" xmlns:tiles="http://www.thymeleaf.org"> <html xmlns:th="http://www.thymeleaf.org">
<head> <head th:include="layout :: head(title=~{::title},links=~{})">
<title tiles:fragment="title">Chat</title> <title>Chat</title>
</head> </head>
<body> <body th:include="layout :: body" th:with="content=~{::content}">
<div tiles:fragment="content">
<div class="container"> <div class="container">
<div id="heading" class="masthead"> <div id="heading" class="masthead">
<h3 class="muted">Chat Application</h3> <h3 class="muted">Chat Application</h3>

View File

@ -1,9 +1,8 @@
<!DOCTYPE html SYSTEM "http://www.thymeleaf.org/dtd/xhtml1-strict-thymeleaf-spring4-3.dtd"> <!DOCTYPE html SYSTEM "http://www.thymeleaf.org/dtd/xhtml1-strict-thymeleaf-spring4-3.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" <html xmlns="http://www.w3.org/1999/xhtml"
xmlns:th="http://www.thymeleaf.org" xmlns:th="http://www.thymeleaf.org">
xmlns:tiles="http://www.thymeleaf.org"> <head th:fragment="head(title,links)">
<head> <title>SecureMail: <th:block th:include="${title}"></th:block></title>
<title tiles:include="title">SecureMail:</title>
<link rel="icon" type="image/x-icon" th:href="@{/resources/img/favicon.ico}" href="../resources/img/favicon.ico"/> <link rel="icon" type="image/x-icon" th:href="@{/resources/img/favicon.ico}" href="../resources/img/favicon.ico"/>
<link th:href="@{/resources/css/bootstrap.css}" href="../resources/css/bootstrap.css" rel="stylesheet"></link> <link th:href="@{/resources/css/bootstrap.css}" href="../resources/css/bootstrap.css" rel="stylesheet"></link>
<style type="text/css"> <style type="text/css">
@ -77,7 +76,7 @@
<!--[if lt IE 9]> <!--[if lt IE 9]>
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script> <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
<![endif]--> <![endif]-->
<script tiles:replace="head"></script> <th:block th:replace="${links}"/>
</head> </head>
@ -111,7 +110,7 @@
th:text="${globalMessage}"> th:text="${globalMessage}">
Some Success message Some Success message
</div> </div>
<div tiles:substituteby="content"> <div th:replace="${content}">
Fake content Fake content
</div> </div>
</div> </div>

View File

@ -1,22 +1,19 @@
<html xmlns:th="http://www.thymeleaf.org" xmlns:tiles="http://www.thymeleaf.org"> <html xmlns:th="http://www.thymeleaf.org">
<head> <head th:include="layout :: head(title=~{::title},links=~{})">
<title tiles:fragment="title">Log In</title> <title>Please Login</title>
</head> </head>
<body> <body th:include="layout :: body" th:with="content=~{::content}">
<div tiles:fragment="content"> <div th:fragment="content">
<form name="f" th:action="@{/login}" method="post"> <form name="f" th:action="@{/login}" method="post">
<fieldset> <fieldset>
<legend>Please Login</legend> <legend>Please Login</legend>
<div th:if="${param.error}" class="alert alert-error"> <div th:if="${param.error}" class="alert alert-error">Invalid
Invalid username and password. username and password.</div>
</div> <div th:if="${param.logout}" class="alert alert-success">You
<div th:if="${param.logout}" class="alert alert-success"> have been logged out.</div>
You have been logged out. <label for="username">Username</label> <input type="text"
</div> id="username" name="username" /> <label for="password">Password</label>
<label for="username">Username</label> <input type="password" id="password" name="password" />
<input type="text" id="username" name="username"/>
<label for="password">Password</label>
<input type="password" id="password" name="password"/>
<div class="form-actions"> <div class="form-actions">
<button type="submit" class="btn">Log in</button> <button type="submit" class="btn">Log in</button>
</div> </div>

View File

@ -24,7 +24,7 @@ import geb.*
*/ */
class HomePage extends Page { class HomePage extends Page {
static url = '' static url = ''
static at = { assert driver.title == 'Messages : View All'; true} static at = { assert driver.title == 'SecureMail: View All'; true}
static content = { static content = {
user { $('p.navbar-text').text() } user { $('p.navbar-text').text() }
logout { $('input', type: 'submit').click() } logout { $('input', type: 'submit').click() }

View File

@ -24,7 +24,7 @@ import geb.*
*/ */
class LoginPage extends Page { class LoginPage extends Page {
static url = 'login' static url = 'login'
static at = { assert driver.title == 'Please Login'; true} static at = { assert driver.title == 'SecureMail: Please Login'; true}
static content = { static content = {
login(required:false) { user='user', password='password' -> login(required:false) { user='user', password='password' ->
loginForm.username = user loginForm.username = user

View File

@ -1,22 +1,19 @@
<html xmlns:th="http://www.thymeleaf.org" xmlns:tiles="http://www.thymeleaf.org"> <html xmlns:th="http://www.thymeleaf.org">
<head> <head th:include="layout :: head(title=~{::title},links=~{})">
<title tiles:fragment="title">Please Login</title> <title>Please Login</title>
</head> </head>
<body> <body th:include="layout :: body" th:with="content=~{::content}">
<div tiles:fragment="content"> <div th:fragment="content">
<form name="f" th:action="@{/login}" method="post"> <form name="f" th:action="@{/login}" method="post">
<fieldset> <fieldset>
<legend>Please Login</legend> <legend>Please Login</legend>
<div th:if="${param.error}" class="alert alert-error"> <div th:if="${param.error}" class="alert alert-error">Invalid
Invalid username and password. username and password.</div>
</div> <div th:if="${param.logout}" class="alert alert-success">You
<div th:if="${param.logout}" class="alert alert-success"> have been logged out.</div>
You have been logged out. <label for="username">Username</label> <input type="text"
</div> id="username" name="username" /> <label for="password">Password</label>
<label for="username">Username</label> <input type="password" id="password" name="password" />
<input type="text" id="username" name="username"/>
<label for="password">Password</label>
<input type="password" id="password" name="password"/>
<div class="form-actions"> <div class="form-actions">
<button type="submit" class="btn">Log in</button> <button type="submit" class="btn">Log in</button>
</div> </div>

View File

@ -1,41 +0,0 @@
/*
* Copyright 2002-2013 the original author or authors.
*
* 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.springframework.security.samples.mvc.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.core.Ordered;
import org.thymeleaf.spring4.SpringTemplateEngine;
import org.thymeleaf.spring4.view.ThymeleafViewResolver;
/**
* Disable tiles so that we can provide our custom view without being decorated.
*
* @author Rob Winch
*
*/
@Configuration
public class CustomMvcConfig {
@Bean
public ThymeleafViewResolver thymeleafViewResolver(SpringTemplateEngine templateEngine) {
ThymeleafViewResolver viewResolver = new ThymeleafViewResolver();
viewResolver.setOrder(Ordered.HIGHEST_PRECEDENCE - 10);
viewResolver.setTemplateEngine(templateEngine);
return viewResolver;
}
}

View File

@ -24,7 +24,7 @@ import geb.*
*/ */
class HomePage extends Page { class HomePage extends Page {
static url = '' static url = ''
static at = { assert driver.title == 'Messages : View All'; true} static at = { assert driver.title.endsWith('View All') == true; true}
static content = { static content = {
user { $('p.navbar-text').text() } user { $('p.navbar-text').text() }
logout { $('input', type: 'submit').click() } logout { $('input', type: 'submit').click() }

View File

@ -24,7 +24,7 @@ import geb.*
*/ */
class HomePage extends Page { class HomePage extends Page {
static url = '' static url = ''
static at = { assert driver.title == 'Messages : View All'; true} static at = { assert driver.title == 'SecureMail: View All'; true}
static content = { static content = {
user { $('p.navbar-text').text() } user { $('p.navbar-text').text() }
logout { $('input', type: 'submit').click() } logout { $('input', type: 'submit').click() }

View File

@ -1,12 +1,10 @@
sonarqube.skipProject = true sonarqube.skipProject = true
dependencies { dependencies {
provided "javax.servlet:javax.servlet-api:3.0.1" provided "javax.servlet:javax.servlet-api:$servletApiVersion"
compile project(":spring-security-web"), compile project(":spring-security-web"),
project(":spring-security-config"), project(":spring-security-config"),
"org.hibernate.javax.persistence:hibernate-jpa-2.0-api:1.0.0.Final",
"org.hsqldb:hsqldb:$hsqlVersion", "org.hsqldb:hsqldb:$hsqlVersion",
"javax.validation:validation-api:$validationApiVersion", "javax.validation:validation-api:$validationApiVersion",
"org.hibernate:hibernate-validator:$hibernateValidatorVersion", "org.hibernate:hibernate-validator:$hibernateValidatorVersion",
@ -20,8 +18,9 @@ dependencies {
"org.springframework:spring-core:$springVersion", "org.springframework:spring-core:$springVersion",
"org.springframework:spring-aspects:$springVersion", "org.springframework:spring-aspects:$springVersion",
"org.thymeleaf:thymeleaf-spring4:$thymeleafVersion", "org.thymeleaf:thymeleaf-spring4:$thymeleafVersion",
"org.thymeleaf.extras:thymeleaf-extras-tiles2-spring4:2.1.1.RELEASE" "nz.net.ultraq.thymeleaf:thymeleaf-layout-dialect:2.0.4",
compile('org.hibernate:hibernate-entitymanager:3.6.10.Final') { "org.eclipse.persistence:javax.persistence:$javaPersistenceVersion"
compile("org.hibernate:hibernate-entitymanager:$hibernateVersion") {
exclude group:'javassist', module: 'javassist' exclude group:'javassist', module: 'javassist'
} }
compile("org.springframework.data:spring-data-jpa:$springDataJpaVersion") { compile("org.springframework.data:spring-data-jpa:$springDataJpaVersion") {

View File

@ -16,26 +16,30 @@
package org.springframework.security.samples.mvc.config; package org.springframework.security.samples.mvc.config;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.ComponentScan;
import org.springframework.core.Ordered; import org.springframework.core.Ordered;
import org.springframework.data.repository.support.DomainClassConverter; import org.springframework.data.repository.support.DomainClassConverter;
import org.springframework.format.support.FormattingConversionService; import org.springframework.format.support.FormattingConversionService;
import org.springframework.web.servlet.ViewResolver;
import org.springframework.web.servlet.config.annotation.EnableWebMvc; import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry; import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.ViewControllerRegistry; import org.springframework.web.servlet.config.annotation.ViewControllerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter; import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
import org.thymeleaf.extras.tiles2.dialect.TilesDialect; import org.thymeleaf.TemplateEngine;
import org.thymeleaf.extras.tiles2.spring4.web.configurer.ThymeleafTilesConfigurer;
import org.thymeleaf.extras.tiles2.spring4.web.view.ThymeleafTilesView;
import org.thymeleaf.spring4.SpringTemplateEngine; import org.thymeleaf.spring4.SpringTemplateEngine;
import org.thymeleaf.spring4.templateresolver.SpringResourceTemplateResolver;
import org.thymeleaf.spring4.view.ThymeleafViewResolver; import org.thymeleaf.spring4.view.ThymeleafViewResolver;
import org.thymeleaf.templateresolver.ClassLoaderTemplateResolver; import org.thymeleaf.templatemode.TemplateMode;
@EnableWebMvc @EnableWebMvc
@ComponentScan("org.springframework.security.samples.mvc") @ComponentScan("org.springframework.security.samples.mvc")
public class WebMvcConfiguration extends WebMvcConfigurerAdapter { public class WebMvcConfiguration extends WebMvcConfigurerAdapter {
@Autowired
private ApplicationContext applicationContext;
@Autowired @Autowired
private FormattingConversionService mvcConversionService; private FormattingConversionService mvcConversionService;
@ -47,42 +51,34 @@ public class WebMvcConfiguration extends WebMvcConfigurerAdapter {
@Override @Override
public void addResourceHandlers(ResourceHandlerRegistry registry) { public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/resources/**") registry.addResourceHandler("/resources/**").addResourceLocations("classpath:/resources/")
.addResourceLocations("classpath:/resources/").setCachePeriod(31556926); .setCachePeriod(31556926);
registry.setOrder(Ordered.HIGHEST_PRECEDENCE); registry.setOrder(Ordered.HIGHEST_PRECEDENCE);
} }
@Bean @Bean
public ClassLoaderTemplateResolver templateResolver() { public ViewResolver viewResolver() {
ClassLoaderTemplateResolver result = new ClassLoaderTemplateResolver(); ThymeleafViewResolver resolver = new ThymeleafViewResolver();
result.setPrefix("views/"); resolver.setTemplateEngine(templateEngine());
result.setSuffix(".html"); resolver.setCharacterEncoding("UTF-8");
result.setTemplateMode("HTML5"); return resolver;
return result;
} }
@Bean @Bean
public ThymeleafTilesConfigurer tilesConfigurer() { public TemplateEngine templateEngine() {
ThymeleafTilesConfigurer tilesConfigurer = new ThymeleafTilesConfigurer(); SpringTemplateEngine engine = new SpringTemplateEngine();
tilesConfigurer.setDefinitions(new String[] { "classpath:tiles/tiles-def.xml" }); engine.setEnableSpringELCompiler(true);
return tilesConfigurer; engine.setTemplateResolver(templateResolver());
return engine;
} }
@Bean private SpringResourceTemplateResolver templateResolver() {
public SpringTemplateEngine templateEngine( SpringResourceTemplateResolver resolver = new SpringResourceTemplateResolver();
ClassLoaderTemplateResolver templateResolver) { resolver.setPrefix("classpath:/views/");
SpringTemplateEngine templateEngine = new SpringTemplateEngine(); resolver.setSuffix(".html");
templateEngine.setTemplateResolver(templateResolver); resolver.setTemplateMode(TemplateMode.HTML);
templateEngine.addDialect(new TilesDialect()); resolver.setApplicationContext(applicationContext);
return templateEngine; return resolver;
}
@Bean
public ThymeleafViewResolver viewResolver(SpringTemplateEngine templateEngine) {
ThymeleafViewResolver viewResolver = new ThymeleafViewResolver();
viewResolver.setTemplateEngine(templateEngine);
viewResolver.setViewClass(ThymeleafTilesView.class);
return viewResolver;
} }
@Bean @Bean

View File

@ -1,57 +0,0 @@
<?xml version="1.0" encoding="ISO-8859-1" ?>
<!DOCTYPE tiles-definitions PUBLIC
"-//Apache Software Foundation//DTD Tiles Configuration 2.1//EN"
"http://tiles.apache.org/dtds/tiles-config_2_1.dtd">
<tiles-definitions>
<definition name="messages/*"
template="layout">
<put-attribute name="content"
value="content/messages/{1}"/>
<put-attribute name="title"
value="title/messages/{1}"/>
<put-attribute name="head"
value="head/messages/{1}"/>
</definition>
<definition name="content/messages/*"
template="messages/{1} :: content"/>
<definition name="title/messages/*"
template="messages/{1} :: title"/>
<definition name="head/messages/*"
template="messages/{1} :: /html/head/link"/>
<definition name="user/*"
template="layout">
<put-attribute name="content"
value="content/user/{1}"/>
<put-attribute name="title"
value="title/user/{1}"/>
<put-attribute name="head"
value="head/user/{1}"/>
</definition>
<definition name="content/user/*"
template="user/{1} :: content"/>
<definition name="title/user/*"
template="user/{1} :: title"/>
<definition name="head/user/*"
template="user/{1} :: /html/head/link"/>
<definition name="*"
template="layout">
<put-attribute name="content"
value="content/{1}"/>
<put-attribute name="title"
value="title/{1}"/>
<put-attribute name="head"
value="head/{1}"/>
</definition>
<definition name="content/*"
template="{1} :: content"/>
<definition name="title/*"
template="{1} :: title"/>
<definition name="head/*"
template="{1} :: /html/head/link"/>
</tiles-definitions>

View File

@ -1,9 +1,8 @@
<!DOCTYPE html SYSTEM "http://www.thymeleaf.org/dtd/xhtml1-strict-thymeleaf-spring4-3.dtd"> <!DOCTYPE html SYSTEM "http://www.thymeleaf.org/dtd/xhtml1-strict-thymeleaf-spring4-3.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" <html xmlns="http://www.w3.org/1999/xhtml"
xmlns:th="http://www.thymeleaf.org" xmlns:th="http://www.thymeleaf.org">
xmlns:tiles="http://www.thymeleaf.org"> <head th:fragment="head(title,links)">
<head> <title>SecureMail: <th:block th:include="${title}"></th:block></title>
<title tiles:include="title">SecureMail:</title>
<link rel="icon" type="image/x-icon" th:href="@{/resources/img/favicon.ico}" href="../resources/img/favicon.ico"/> <link rel="icon" type="image/x-icon" th:href="@{/resources/img/favicon.ico}" href="../resources/img/favicon.ico"/>
<link th:href="@{/resources/css/bootstrap.css}" href="../resources/css/bootstrap.css" rel="stylesheet"></link> <link th:href="@{/resources/css/bootstrap.css}" href="../resources/css/bootstrap.css" rel="stylesheet"></link>
<style type="text/css"> <style type="text/css">
@ -71,11 +70,11 @@
<!--[if lt IE 9]> <!--[if lt IE 9]>
<script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script> <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
<![endif]--> <![endif]-->
<script tiles:replace="head"></script> <th:block th:replace="${links}"/>
</head> </head>
<body> <body th:fragment="body">
<div id="wrap"> <div id="wrap">
<div class="navbar navbar-inverse navbar-static-top"> <div class="navbar navbar-inverse navbar-static-top">
<div class="navbar-inner"> <div class="navbar-inner">
@ -105,7 +104,7 @@
th:text="${globalMessage}"> th:text="${globalMessage}">
Some Success message Some Success message
</div> </div>
<div tiles:substituteby="content"> <div th:replace="${content}">
Fake content Fake content
</div> </div>
</div> </div>

View File

@ -1,9 +1,9 @@
<html xmlns:th="http://www.thymeleaf.org" xmlns:tiles="http://www.thymeleaf.org"> <html xmlns:th="http://www.thymeleaf.org">
<head> <head th:include="layout :: head(title=~{::title},links=~{})">
<title tiles:fragment="title">Messages : Create</title> <title>Create</title>
</head> </head>
<body> <body th:include="layout :: body" th:with="content=~{::content}">
<div tiles:fragment="content"> <div th:fragment="content">
<div class="container"> <div class="container">
<h1>Messages : Create</h1> <h1>Messages : Create</h1>
<form id="messageForm" <form id="messageForm"

View File

@ -1,9 +1,9 @@
<html xmlns:th="http://www.thymeleaf.org" xmlns:tiles="http://www.thymeleaf.org"> <html xmlns:th="http://www.thymeleaf.org">
<head> <head th:include="layout :: head(title=~{::title},links=~{})">
<title tiles:fragment="title">Messages : View All</title> <title>View All</title>
</head> </head>
<body> <body th:include="layout :: body" th:with="content=~{::content}">
<div tiles:fragment="content"> <div th:fragment="content">
<h1>Inbox</h1> <h1>Inbox</h1>
<table class="table table-bordered table-striped"> <table class="table table-bordered table-striped">
<thead> <thead>

View File

@ -1,9 +1,9 @@
<html xmlns:th="http://www.thymeleaf.org" xmlns:tiles="http://www.thymeleaf.org"> <html xmlns:th="http://www.thymeleaf.org">
<head> <head th:include="layout :: head(title=~{::title},links=~{})">
<title tiles:fragment="title">Messages : Create</title> <title>Create</title>
</head> </head>
<body> <body th:include="layout :: body" th:with="content=~{::content}">
<div tiles:fragment="content"> <div th:fragment="content">
<div class="container"> <div class="container">
<h1>Message : <span th:text="${message.summary}">A short summary...</span></h1> <h1>Message : <span th:text="${message.summary}">A short summary...</span></h1>
<dl> <dl>

View File

@ -1,11 +1,11 @@
<html xmlns:th="http://www.thymeleaf.org" xmlns:tiles="http://www.thymeleaf.org"> <html xmlns:th="http://www.thymeleaf.org">
<head> <head th:include="layout :: head(title=~{::title},links=~{::link})">
<title tiles:fragment="title">Messages : Login</title> <title>Messages : Login</title>
<!-- /Simple OpenID Selector --> <!-- /Simple OpenID Selector -->
<link rel="stylesheet" th:href="@{/resources/css/openid.css}" /> <link rel="stylesheet" th:href="@{/resources/css/openid.css}" />
</head> </head>
<body> <body th:include="layout :: body" th:with="content=~{::content}">
<div tiles:fragment="content"> <div th:fragment="content">
<form name="f" th:action="@{/login/openid}" method="post" id="openid_form"> <form name="f" th:action="@{/login/openid}" method="post" id="openid_form">
<input type="hidden" name="action" value="verify" /> <input type="hidden" name="action" value="verify" />
<fieldset> <fieldset>

View File

@ -1,11 +1,11 @@
<html xmlns:th="http://www.thymeleaf.org" xmlns:tiles="http://www.thymeleaf.org"> <html xmlns:th="http://www.thymeleaf.org">
<head> <head th:include="layout :: head(title=~{::title},links=~{})">
<title tiles:fragment="title">Messages : Login</title> <title>Messages : Login</title>
<!-- /Simple OpenID Selector --> <!-- /Simple OpenID Selector -->
<link rel="stylesheet" th:href="@{/resources/css/openid.css}" /> <link rel="stylesheet" th:href="@{/resources/css/openid.css}" />
</head> </head>
<body> <body th:include="layout :: body" th:with="content=~{::content}">
<div tiles:fragment="content"> <div th:fragment="content">
<h1>User Attributes</h1> <h1>User Attributes</h1>
<table class="table table-border"> <table class="table table-border">
<thead> <thead>

View File

@ -1,22 +1,19 @@
<html xmlns:th="http://www.thymeleaf.org" xmlns:tiles="http://www.thymeleaf.org"> <html xmlns:th="http://www.thymeleaf.org">
<head> <head th:include="layout :: head(title=~{::title},links=~{})">
<title tiles:fragment="title">Messages : Create</title> <title>Please Login</title>
</head> </head>
<body> <body th:include="layout :: body" th:with="content=~{::content}">
<div tiles:fragment="content"> <div th:fragment="content">
<form name="f" th:action="@{/j_security_check}" method="post"> <form name="f" th:action="@{/j_security_check}" method="post">
<fieldset> <fieldset>
<legend>Please Login</legend> <legend>Please Login</legend>
<div th:if="${param.error}" class="alert alert-error"> <div th:if="${param.error}" class="alert alert-error">Invalid
Invalid username and password. username and password.</div>
</div> <div th:if="${param.logout}" class="alert alert-success">You
<div th:if="${param.logout}" class="alert alert-success"> have been logged out.</div>
You have been logged out. <label for="username">Username</label> <input type="text"
</div> id="username" name="username" /> <label for="password">Password</label>
<label for="username">Username</label> <input type="password" id="password" name="password" />
<input type="text" id="username" name="username"/>
<label for="password">Password</label>
<input type="password" id="password" name="password"/>
<div class="form-actions"> <div class="form-actions">
<button type="submit" class="btn">Log in</button> <button type="submit" class="btn">Log in</button>
</div> </div>

View File

@ -1,24 +1,21 @@
<html xmlns:th="http://www.thymeleaf.org" xmlns:tiles="http://www.thymeleaf.org"> <html xmlns:th="http://www.thymeleaf.org">
<head> <head th:include="layout :: head(title=~{::title},links=~{})">
<title tiles:fragment="title">Messages : Create</title> <title>Please Login</title>
</head> </head>
<body> <body th:include="layout :: body" th:with="content=~{::content}">
<div tiles:fragment="content"> <div th:fragment="content">
<form name="f" th:action="@{/login}" method="post"> <form name="f" th:action="@{/login}" method="post">
<fieldset> <fieldset>
<legend>Please Login</legend> <legend>Please Login</legend>
<div th:if="${param.error}" class="alert alert-error"> <div th:if="${param.error}" class="alert alert-error">Invalid
Invalid username and password. username and password.</div>
</div> <div th:if="${param.logout}" class="alert alert-success">You
<div th:if="${param.logout}" class="alert alert-success"> have been logged out.</div>
You have been logged out. <label for="username">Username</label> <input type="text"
</div> id="username" name="username" /> <label for="password">Password</label>
<label for="username">Username</label> <input type="password" id="password" name="password" /> <label
<input type="text" id="username" name="username"/> for="remember-me">Remember Me?</label> <input type="checkbox"
<label for="password">Password</label> id="remember-me" name="remember-me" />
<input type="password" id="password" name="password"/>
<label for="remember-me">Remember Me?</label>
<input type="checkbox" id="remember-me" name="remember-me"/>
<div class="form-actions"> <div class="form-actions">
<button type="submit" class="btn">Log in</button> <button type="submit" class="btn">Log in</button>
</div> </div>