SlideShare uma empresa Scribd logo
1 de 13
Baixar para ler offline
João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro
Whateverweb.com
João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro
João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro
João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro
?
João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro
João Ribeiro (Jay)
CSS Optimization
& Media Query
Extension
Image
Optimization
jr@whateverweb.com | @joaofribeiro
Device Detection
(Client Features + WURFL)
IMAGE OPTIMIZER
Auto Image Scaling according to maximum device width
Custom Scaling (url parameters)
* Metadata Stripping
* Image transformations (e.g. rotation, cropping)
João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro
<img src="http://img.demo.wew.io/http://yourdomain/your_image.jpg" alt="An image" />
<img src="http://img.demo.wew.io/px_240/http://yourdomain/your_image.jpg" alt="An image" />
CSS OPTIMIZER WITH EXTENDED MEDIA QUERIES SUPPORT
Runs extended media queries (e.g. brand name, pointing method)
Strips “unreachable” CSS code in media queries
Strips irrelevant vendor prefixes
Inlines/combines CSS fragments using @import
Minifies (YUI) / Compresses (YUI)
João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro
<link rel="stylesheet" type="text/css“ href="http://css.demo.wew.io/http://yourdomain/styles.css" />
João Ribeiro (Jay)
@import "bootstrap.css";
/* Standard Media Queries */
@media (min-width: 768px) {
.hidden-desktop {
display: inherit !important;
}
}
/* Extended media queries - Touch*/
@media (-wew-pointing-method:
touchscreen) {
.button{
display:block;
margin-bottom: 1em;
}
}
/*Extended media queries - Brand*/
@media (-wew-brand-name: Google) {
.ads .googleDevices{
display:block;
}
}
styles.css
jr@whateverweb.com | @joaofribeiro
João Ribeiro (Jay)
.clearfix {*zoom: 1;}
.clearfix:before,
.clearfix:after {
display: table;
…
.button{
display:block;
margin-bottom: 1em;
}
optimized
styles.css
@import "bootstrap.css";
/* Standard Media Queries */
@media (min-width: 768px) {
.hidden-desktop {
display: inherit !important;
}
}
/* Extended media queries - Touch*/
@media (-wew-pointing-method:
touchscreen) {
.button{
display:block;
margin-bottom: 1em;
}
}
/*Extended media queries - Brand*/
@media (-wew-brand-name: Google) {
.ads .googleDevices{
display:block;
}
}
styles.css
X
X
jr@whateverweb.com | @joaofribeiro
João Ribeiro (Jay)
@import "bootstrap.css";
/* Standard Media Queries */
@media (min-width: 768px) {
.hidden-desktop {
display: inherit !important;
}
}
/* Extended media queries - Touch*/
@media (-wew-pointing-method:
touchscreen) {
.button{
display:block;
margin-bottom: 1em;
}
}
/*Extended media queries - Brand*/
@media (-wew-brand-name: Google) {
.ads .googleDevices{
display:block;
}
}
styles.css
jr@whateverweb.com | @joaofribeiro
João Ribeiro (Jay)
.clearfix {*zoom: 1;}
.clearfix:before,
.clearfix:after {
display: table;
…
hidden-desktop {
display: inherit !important;
}
.button {
display:block;
margin-bottom: 1em;
}
.ads .googleDevices {
display:block;
}
optimized
styles.css
@import "bootstrap.css";
/* Standard Media Queries */
@media (min-width: 768px) {
.hidden-desktop {
display: inherit !important;
}
}
/* Extended media queries - Touch*/
@media (-wew-pointing-method:
touchscreen) {
.button{
display:block;
margin-bottom: 1em;
}
}
/*Extended media queries - Brand*/
@media (-wew-brand-name: Google) {
.ads .googleDevices{
display:block;
}
}
styles.css
jr@whateverweb.com | @joaofribeiro
João Ribeiro (Jay)
Sign up for free at whateverweb.com
jr@whateverweb.com | @joaofribeiro

Mais conteúdo relacionado

Semelhante a Whateverweb.com

Responsive websites. Toolbox
Responsive websites. ToolboxResponsive websites. Toolbox
Responsive websites. ToolboxWojtek Zając
 
Broadstreet quickstart-mar11-1
Broadstreet quickstart-mar11-1Broadstreet quickstart-mar11-1
Broadstreet quickstart-mar11-1Mary Barr Mann
 
Diseño de Sistemas de Diseño con Atomic Design y Pattern Lab
Diseño de Sistemas de Diseño con Atomic Design y Pattern LabDiseño de Sistemas de Diseño con Atomic Design y Pattern Lab
Diseño de Sistemas de Diseño con Atomic Design y Pattern LabMauricio Angulo Sillas
 
Responsive Web Design tips and tricks.
Responsive Web Design tips and tricks.Responsive Web Design tips and tricks.
Responsive Web Design tips and tricks.GaziAhsan
 
Printing photos-html-using-android
Printing photos-html-using-androidPrinting photos-html-using-android
Printing photos-html-using-androidKetan Raval
 
Module 4 Minuteman Lexington Web Design Daniel Downs
Module 4 Minuteman Lexington Web Design Daniel DownsModule 4 Minuteman Lexington Web Design Daniel Downs
Module 4 Minuteman Lexington Web Design Daniel DownsDaniel Downs
 
Pinkoi Mobile Web
Pinkoi Mobile WebPinkoi Mobile Web
Pinkoi Mobile Webmikeleeme
 
The specs behind the sex, mobile-friendly layout beyond the desktop
The specs behind the sex, mobile-friendly layout beyond the desktopThe specs behind the sex, mobile-friendly layout beyond the desktop
The specs behind the sex, mobile-friendly layout beyond the desktopbetabeers
 
Responsive Images and Video
Responsive Images and VideoResponsive Images and Video
Responsive Images and VideoJason Grigsby
 
Mobile Your Joomla Site
Mobile Your Joomla SiteMobile Your Joomla Site
Mobile Your Joomla SiteKyle Ledbetter
 
Developing web applications in 2010
Developing web applications in 2010Developing web applications in 2010
Developing web applications in 2010Ignacio Coloma
 
Create Responsive Website Design with Bootstrap 3
Create Responsive Website Design with Bootstrap 3Create Responsive Website Design with Bootstrap 3
Create Responsive Website Design with Bootstrap 3Wahyu Putra
 
Using Google For Online Learning
Using Google For Online LearningUsing Google For Online Learning
Using Google For Online LearningJanet Clarey
 
Presentation of bootstrap
Presentation of bootstrapPresentation of bootstrap
Presentation of bootstrap1amitgupta
 
Responsive Web Design: Clever Tips and Techniques
Responsive Web Design: Clever Tips and TechniquesResponsive Web Design: Clever Tips and Techniques
Responsive Web Design: Clever Tips and TechniquesVitaly Friedman
 

Semelhante a Whateverweb.com (20)

Responsive websites. Toolbox
Responsive websites. ToolboxResponsive websites. Toolbox
Responsive websites. Toolbox
 
Mobilize Joomla
Mobilize JoomlaMobilize Joomla
Mobilize Joomla
 
Technical Introduction to YDN
Technical Introduction to YDNTechnical Introduction to YDN
Technical Introduction to YDN
 
Broadstreet quickstart-mar11-1
Broadstreet quickstart-mar11-1Broadstreet quickstart-mar11-1
Broadstreet quickstart-mar11-1
 
Diseño de Sistemas de Diseño con Atomic Design y Pattern Lab
Diseño de Sistemas de Diseño con Atomic Design y Pattern LabDiseño de Sistemas de Diseño con Atomic Design y Pattern Lab
Diseño de Sistemas de Diseño con Atomic Design y Pattern Lab
 
Responsive Web Design tips and tricks.
Responsive Web Design tips and tricks.Responsive Web Design tips and tricks.
Responsive Web Design tips and tricks.
 
Rwd slidedeck
Rwd slidedeckRwd slidedeck
Rwd slidedeck
 
Printing photos-html-using-android
Printing photos-html-using-androidPrinting photos-html-using-android
Printing photos-html-using-android
 
Module 4 Minuteman Lexington Web Design Daniel Downs
Module 4 Minuteman Lexington Web Design Daniel DownsModule 4 Minuteman Lexington Web Design Daniel Downs
Module 4 Minuteman Lexington Web Design Daniel Downs
 
Pinkoi Mobile Web
Pinkoi Mobile WebPinkoi Mobile Web
Pinkoi Mobile Web
 
The specs behind the sex, mobile-friendly layout beyond the desktop
The specs behind the sex, mobile-friendly layout beyond the desktopThe specs behind the sex, mobile-friendly layout beyond the desktop
The specs behind the sex, mobile-friendly layout beyond the desktop
 
Responsive Images and Video
Responsive Images and VideoResponsive Images and Video
Responsive Images and Video
 
Windows phone 8
Windows phone 8Windows phone 8
Windows phone 8
 
Mobile Your Joomla Site
Mobile Your Joomla SiteMobile Your Joomla Site
Mobile Your Joomla Site
 
Developing web applications in 2010
Developing web applications in 2010Developing web applications in 2010
Developing web applications in 2010
 
Create Responsive Website Design with Bootstrap 3
Create Responsive Website Design with Bootstrap 3Create Responsive Website Design with Bootstrap 3
Create Responsive Website Design with Bootstrap 3
 
Using Google For Online Learning
Using Google For Online LearningUsing Google For Online Learning
Using Google For Online Learning
 
Presentation of bootstrap
Presentation of bootstrapPresentation of bootstrap
Presentation of bootstrap
 
Responsive Web Design: Clever Tips and Techniques
Responsive Web Design: Clever Tips and TechniquesResponsive Web Design: Clever Tips and Techniques
Responsive Web Design: Clever Tips and Techniques
 
Adobe & HTML5
Adobe & HTML5Adobe & HTML5
Adobe & HTML5
 

Último

How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonetsnaman860154
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsMaria Levchenko
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxMalak Abu Hammad
 
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j
 
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxFactors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxKatpro Technologies
 
My Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationMy Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationRidwan Fadjar
 
Key Features Of Token Development (1).pptx
Key  Features Of Token  Development (1).pptxKey  Features Of Token  Development (1).pptx
Key Features Of Token Development (1).pptxLBM Solutions
 
SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024Scott Keck-Warren
 
Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Paola De la Torre
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitecturePixlogix Infotech
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptxHampshireHUG
 
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmaticsKotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmaticscarlostorres15106
 
Azure Monitor & Application Insight to monitor Infrastructure & Application
Azure Monitor & Application Insight to monitor Infrastructure & ApplicationAzure Monitor & Application Insight to monitor Infrastructure & Application
Azure Monitor & Application Insight to monitor Infrastructure & ApplicationAndikSusilo4
 
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Patryk Bandurski
 
GenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationGenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationMichael W. Hawkins
 
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024BookNet Canada
 
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure servicePooja Nehwal
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...HostedbyConfluent
 
Pigging Solutions in Pet Food Manufacturing
Pigging Solutions in Pet Food ManufacturingPigging Solutions in Pet Food Manufacturing
Pigging Solutions in Pet Food ManufacturingPigging Solutions
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking MenDelhi Call girls
 

Último (20)

How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonets
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed texts
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptx
 
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
Neo4j - How KGs are shaping the future of Generative AI at AWS Summit London ...
 
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptxFactors to Consider When Choosing Accounts Payable Services Providers.pptx
Factors to Consider When Choosing Accounts Payable Services Providers.pptx
 
My Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 PresentationMy Hashitalk Indonesia April 2024 Presentation
My Hashitalk Indonesia April 2024 Presentation
 
Key Features Of Token Development (1).pptx
Key  Features Of Token  Development (1).pptxKey  Features Of Token  Development (1).pptx
Key Features Of Token Development (1).pptx
 
SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024SQL Database Design For Developers at php[tek] 2024
SQL Database Design For Developers at php[tek] 2024
 
Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101Salesforce Community Group Quito, Salesforce 101
Salesforce Community Group Quito, Salesforce 101
 
Understanding the Laravel MVC Architecture
Understanding the Laravel MVC ArchitectureUnderstanding the Laravel MVC Architecture
Understanding the Laravel MVC Architecture
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
 
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmaticsKotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
Kotlin Multiplatform & Compose Multiplatform - Starter kit for pragmatics
 
Azure Monitor & Application Insight to monitor Infrastructure & Application
Azure Monitor & Application Insight to monitor Infrastructure & ApplicationAzure Monitor & Application Insight to monitor Infrastructure & Application
Azure Monitor & Application Insight to monitor Infrastructure & Application
 
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
Integration and Automation in Practice: CI/CD in Mule Integration and Automat...
 
GenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day PresentationGenCyber Cyber Security Day Presentation
GenCyber Cyber Security Day Presentation
 
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
#StandardsGoals for 2024: What’s new for BISAC - Tech Forum 2024
 
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure serviceWhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
WhatsApp 9892124323 ✓Call Girls In Kalyan ( Mumbai ) secure service
 
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
Transforming Data Streams with Kafka Connect: An Introduction to Single Messa...
 
Pigging Solutions in Pet Food Manufacturing
Pigging Solutions in Pet Food ManufacturingPigging Solutions in Pet Food Manufacturing
Pigging Solutions in Pet Food Manufacturing
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
 

Whateverweb.com

  • 1. João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro Whateverweb.com
  • 2. João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro
  • 3. João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro
  • 4. João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro ?
  • 5. João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro
  • 6. João Ribeiro (Jay) CSS Optimization & Media Query Extension Image Optimization jr@whateverweb.com | @joaofribeiro Device Detection (Client Features + WURFL)
  • 7. IMAGE OPTIMIZER Auto Image Scaling according to maximum device width Custom Scaling (url parameters) * Metadata Stripping * Image transformations (e.g. rotation, cropping) João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro <img src="http://img.demo.wew.io/http://yourdomain/your_image.jpg" alt="An image" /> <img src="http://img.demo.wew.io/px_240/http://yourdomain/your_image.jpg" alt="An image" />
  • 8. CSS OPTIMIZER WITH EXTENDED MEDIA QUERIES SUPPORT Runs extended media queries (e.g. brand name, pointing method) Strips “unreachable” CSS code in media queries Strips irrelevant vendor prefixes Inlines/combines CSS fragments using @import Minifies (YUI) / Compresses (YUI) João Ribeiro (Jay) jr@whateverweb.com | @joaofribeiro <link rel="stylesheet" type="text/css“ href="http://css.demo.wew.io/http://yourdomain/styles.css" />
  • 9. João Ribeiro (Jay) @import "bootstrap.css"; /* Standard Media Queries */ @media (min-width: 768px) { .hidden-desktop { display: inherit !important; } } /* Extended media queries - Touch*/ @media (-wew-pointing-method: touchscreen) { .button{ display:block; margin-bottom: 1em; } } /*Extended media queries - Brand*/ @media (-wew-brand-name: Google) { .ads .googleDevices{ display:block; } } styles.css jr@whateverweb.com | @joaofribeiro
  • 10. João Ribeiro (Jay) .clearfix {*zoom: 1;} .clearfix:before, .clearfix:after { display: table; … .button{ display:block; margin-bottom: 1em; } optimized styles.css @import "bootstrap.css"; /* Standard Media Queries */ @media (min-width: 768px) { .hidden-desktop { display: inherit !important; } } /* Extended media queries - Touch*/ @media (-wew-pointing-method: touchscreen) { .button{ display:block; margin-bottom: 1em; } } /*Extended media queries - Brand*/ @media (-wew-brand-name: Google) { .ads .googleDevices{ display:block; } } styles.css X X jr@whateverweb.com | @joaofribeiro
  • 11. João Ribeiro (Jay) @import "bootstrap.css"; /* Standard Media Queries */ @media (min-width: 768px) { .hidden-desktop { display: inherit !important; } } /* Extended media queries - Touch*/ @media (-wew-pointing-method: touchscreen) { .button{ display:block; margin-bottom: 1em; } } /*Extended media queries - Brand*/ @media (-wew-brand-name: Google) { .ads .googleDevices{ display:block; } } styles.css jr@whateverweb.com | @joaofribeiro
  • 12. João Ribeiro (Jay) .clearfix {*zoom: 1;} .clearfix:before, .clearfix:after { display: table; … hidden-desktop { display: inherit !important; } .button { display:block; margin-bottom: 1em; } .ads .googleDevices { display:block; } optimized styles.css @import "bootstrap.css"; /* Standard Media Queries */ @media (min-width: 768px) { .hidden-desktop { display: inherit !important; } } /* Extended media queries - Touch*/ @media (-wew-pointing-method: touchscreen) { .button{ display:block; margin-bottom: 1em; } } /*Extended media queries - Brand*/ @media (-wew-brand-name: Google) { .ads .googleDevices{ display:block; } } styles.css jr@whateverweb.com | @joaofribeiro
  • 13. João Ribeiro (Jay) Sign up for free at whateverweb.com jr@whateverweb.com | @joaofribeiro