styling with css - eclipseglobal styling globally change application colors, fonts, … simple and...

43
@EclipseScout The Future Proof Java Web-framework OOP ‘16 – Matthias Zimmermann

Upload: others

Post on 13-Jun-2020

11 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

@EclipseScout The Future Proof Java Web-framework

OOP ‘16 – Matthias Zimmermann

Page 2: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Agenda

Why you need «future-proof»

16 Years of Scout

Eclipse Scout Neon: Java and HTML5

− Model: Java

− Building: Maven

− Theming and Styling: CSS3

Wrap up

Page 3: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout 2015

Why you need «Future Proof»

Page 4: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Enterprise Applications

The Good

Represents Core Process Knowledge

Make business more efficient

The Bad

Large initial Costs

Large running Costs

Page 5: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Enterprise Applications

The Ugly

Include Legacy Technologies

Risk and Cost increasing

Look old

«Now, let’s look at a typical example»

Page 6: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Copy Paste

Copy Paste

«New» Technology

Copy Paste

New Feature

Old Technology

New Feature

Old Technology

New Feature

Page 7: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

What did go wrong?

Focus on latest technology

Keep adding new technologies

Fail to remove legacy technologies

Page 8: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Can we do better?

Think long term

Choose boring* technology

Keep technology stack minimal

Keep business logic separate from technology

«And, what do we get in return?»

*http://mcfunley.com/choose-boring-technology-slides (oscon ‘15)

Page 9: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Focus on Business Logic

«Boring» Technology

Modular Architecture

Minimal Stack

Page 10: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Protect investment in business logic

Keep technology healthy

Keep developers happy

Avoid rewrites

Want this?

Eclipse Scout can help

How? Let’s look at the Scout story …

Benefits of «Future Proof» Applications

Page 11: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout 2015

16 Years of Scout

Page 12: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Let’s go back to …

Page 13: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

… 1999

Page 14: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

… 1999

Page 15: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

… 1999

Page 16: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

… 2002

Page 17: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

… 2005

Page 18: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

… 2007

Page 19: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout 2011

Page 20: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout 2012

Page 21: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout 2016

Page 22: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Zero rewrites

Many Scout Upgrades

UI technologies come and go

Eclipse Scout helps to «future proof»

Our learnings from last 16 years

Page 23: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout 2015

Eclipse Scout

Page 24: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout

Framework

Built for Enterprise Applications

Based on Java and HTML5

Multi Device support

Goals

Support Long Term strategy (enterprise apps live > 10 years)

Boost productivity (salaries in Switzerland …)

Easy to learn (get productive in 1-2 weeks)

Page 25: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Page 26: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Page 27: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout 2015

Eclipse Scout – The Model

Page 28: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout Model

What to model?

User Interface

Services

Security

Level of Detail?

Tradeoff flexibility and efficiency

DON’T depend on any UI technology

DO allow for UI rendering

Page 29: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

String Fields – The last 20 years

AS400

SAP R3

JSP

Eclipse Scout

Page 30: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

StringField in Scout

Page 31: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout 2015

Eclipse Scout – Java and Building /w Maven

Page 32: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: 2. Zeile als Untertitel nicht Fett

Until Eclipse Mars …

MANIFEST.MF

plugin.xml

<bundle>

myapp-server.product

myapp.target

P2 Update Site

<bundle>.test

MAVEN TYCHO

Page 33: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: 2. Zeile als Untertitel nicht Fett

MAVEN

… With Neon

Page 34: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: 2. Zeile als Untertitel nicht Fett

{project name}

{project name}.server

{project name}.shared

{project name}.client

{project name}.ui.html

{project name}.server.app.dev

{project name}.ui.html.app.dev

{project name}.server.app.war

{project name}.ui.html.app.war

Maven Standard Multi Module Projects

Page 35: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: 2. Zeile als Untertitel nicht Fett

Maven Build m2e for Eclipse IDE

Page 36: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: 2. Zeile als Untertitel nicht Fett

Maven Build Command Line

Page 37: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout 2015

Eclipse Scout – Themes and Styling

Page 38: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Technology

CSS3 + Less

CSS Organisation

Global Less files (colors, fonts, sizes, …)

Component specific Less files (Form, Field, Button…)

Optional: Project specific Less files

Theme: Named set of Less files

From Less to final CSS

1. Project specific files override Scout defaults

2. Single big CSS is assembled, processed and minified

Themes and Styling with Scout

Page 39: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Scout Theming

Page 40: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Global Styling

Globally change application colors, fonts, …

Simple and low effort

Example: Color of data fields

Styling of Components

Change individual elements

Powerful but more CSS knowledge requried

Example: Appearance of dialogs

Scout Styling

Page 41: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Eclipse Scout 2015

Wrap up

Page 42: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

Enterprise Apps: Long Life (> 10 years)

UIs Technologies: Short Life (<5 years)

Think Longterm

Eclipse Scout

Helps «future proofing» your enterprise apps

Based on Java and HTML5

Styling with CSS3 is simple

Wrap up

Page 43: Styling with CSS - EclipseGlobal Styling Globally change application colors, fonts, … Simple and low effort Example: Color of data fields Styling of Components Change individual

Farben:

254/153/21

0/130/161

127/127/127

Schrift: Titel: Calibri, Fett, 32

Text: Calibri, 22 (mind. 18)

Special: Automatischer Einzug

@EclipseScout

OOP ‘16 – Matthias Zimmermann

Thanks

Follow us

on