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:
parent
c1e9140940
commit
5e35e37a2b
|
@ -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>
|
||||||
|
|
|
@ -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'
|
||||||
|
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
|
@ -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>
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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() }
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -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() }
|
||||||
|
|
|
@ -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() }
|
||||||
|
|
|
@ -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") {
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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>
|
|
|
@ -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>
|
||||||
|
|
|
@ -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"
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
||||||
|
|
Loading…
Reference in New Issue