際際滷

際際滷Share a Scribd company logo
TOOLSTRAP
A front-end framework for Groupon internal tools
99 Problems
 Developers spending time on CSS, not features
 Designers spending time on CSS, not problem-solving
 Inconsistency with brand, designs, etc. within apps
 Inconsistency between apps
 Developers blocked by lack of design/CSS
https://twitter.com/threedaymonk/status/174497507517267968
What is Toolstrap?
http://twitter.github.com/bootstrap/ http://foundation.zurb.com/
Toolstrap
https://styleguide.groupondev.com/
WTF is up with that font?
- Steven Walker, probably
Layouts
Tables
Forms
Buttons & Labels
Navigation & Tabs
Modules
 Modals
 Tooltips
 Alerts
 Accordions
Whos using Toolstrap?
 Coffee
 Perfect Pipeline
 Deal Estate
 Deal Wizard
 AM Workbench
 Sales Workbench
 Quantum Lead
 CS Tools
Coffee
Deal Wizard
Sales Workbench
Mo Toolstrap, Mo Problems
 Dependencies - Rails, JUI, SASS, Compass
 Versioning - constantly in flux
 Specificity - app-specific styles not abstracted out
 Images - backgrounds, logos, icons
 JavaScript - limited
Toolstrap
Toolstrap
Compiled CSS/JS Only
Toolstrap Toolstrap 2
YO DAWG, I HERDYOU LIKE FOLDERS...
http://smacss.com/
SMACCS - Categorizing CSS
 Base - normalize.css; styling elements
 Layout - grid, layouts
 Module - reusable, modular design elements
 State - active/inactive, hidden/visible; JS
 Theme - added layer of design; multiple themes
Toolstrap
Toolstrap
Groupon Icon Font!
http://css-tricks.com/examples/IconFont/
Toolstrap
Toolstrap
Toolstrap
http://icomoon.io/
 Groupon.eot (14k)
Internet Explorer
 Groupon.svg (74k)
Webkit, Opera
 Groupon.ttf (14k)
Firefox 3.5, Webkit
 Groupon.woff (26k)
Firefox 3.6+
 style.css (5k)
 lte-ie7.js (4k)
98 Icons
Category Icons
Form Input Icons
Spinner
Styles for Popular UI Libraries
 jQuery UI
 Select2
 ???
(but CSS aint one)
https://github.groupondev.com/internal-tools-bootstrap/toolstrap
https://github.groupondev.com/maparicio/toolstrap2
https://github.groupondev.com/maparicio/Groupon-Icon-Font
?uestions?
Mike Aparicio
maparicio@groupon.com
http://idol.pe/toolstrap

More Related Content

Viewers also liked (8)

Standard kecergasan fizikal kebangsaan
Standard kecergasan fizikal kebangsaanStandard kecergasan fizikal kebangsaan
Standard kecergasan fizikal kebangsaan
isza76
87199913 prosedur-segak
87199913 prosedur-segak87199913 prosedur-segak
87199913 prosedur-segak
Mohd Izwan Baidawi
Rumusan keseluruhan ujian segak
Rumusan keseluruhan ujian segakRumusan keseluruhan ujian segak
Rumusan keseluruhan ujian segak
Atan Pomen
Borang rekod segak dan bmi
Borang rekod segak dan bmiBorang rekod segak dan bmi
Borang rekod segak dan bmi
Dak Iwan
Keputusan ujian keseluruhan segak
Keputusan ujian keseluruhan segakKeputusan ujian keseluruhan segak
Keputusan ujian keseluruhan segak
Karen Kayny
Pengiraan skor pajsk
Pengiraan skor pajsk Pengiraan skor pajsk
Pengiraan skor pajsk
PAKLONG CIKGU
Basic Principles of Kinesiology
Basic Principles of KinesiologyBasic Principles of Kinesiology
Basic Principles of Kinesiology
joldham5
MBA Internship Report
MBA Internship ReportMBA Internship Report
MBA Internship Report
Ajesh U Bhanu
Standard kecergasan fizikal kebangsaan
Standard kecergasan fizikal kebangsaanStandard kecergasan fizikal kebangsaan
Standard kecergasan fizikal kebangsaan
isza76
Rumusan keseluruhan ujian segak
Rumusan keseluruhan ujian segakRumusan keseluruhan ujian segak
Rumusan keseluruhan ujian segak
Atan Pomen
Borang rekod segak dan bmi
Borang rekod segak dan bmiBorang rekod segak dan bmi
Borang rekod segak dan bmi
Dak Iwan
Keputusan ujian keseluruhan segak
Keputusan ujian keseluruhan segakKeputusan ujian keseluruhan segak
Keputusan ujian keseluruhan segak
Karen Kayny
Pengiraan skor pajsk
Pengiraan skor pajsk Pengiraan skor pajsk
Pengiraan skor pajsk
PAKLONG CIKGU
Basic Principles of Kinesiology
Basic Principles of KinesiologyBasic Principles of Kinesiology
Basic Principles of Kinesiology
joldham5
MBA Internship Report
MBA Internship ReportMBA Internship Report
MBA Internship Report
Ajesh U Bhanu

Similar to Toolstrap (20)

Rapid prototyping front end libraries
Rapid prototyping front end librariesRapid prototyping front end libraries
Rapid prototyping front end libraries
Michal Taberski
Bootstrap UI Library Introduction
Bootstrap UI Library IntroductionBootstrap UI Library Introduction
Bootstrap UI Library Introduction
Vardot
Bootstrap Crash Course 20180717
Bootstrap Crash Course 20180717Bootstrap Crash Course 20180717
Bootstrap Crash Course 20180717
Haim Michael
Ready? Bootstrap! Go! (SOTR 2013) copy
Ready? Bootstrap! Go! (SOTR 2013) copyReady? Bootstrap! Go! (SOTR 2013) copy
Ready? Bootstrap! Go! (SOTR 2013) copy
Guust Nieuwenhuis
Web technologies-course 06.pptx
Web technologies-course 06.pptxWeb technologies-course 06.pptx
Web technologies-course 06.pptx
Stefan Oprea
Bootstrap Workout 2015
Bootstrap Workout 2015Bootstrap Workout 2015
Bootstrap Workout 2015
Rob Davarnia
bootstrap_slidesfor bootstrapthingyise.pdf
bootstrap_slidesfor bootstrapthingyise.pdfbootstrap_slidesfor bootstrapthingyise.pdf
bootstrap_slidesfor bootstrapthingyise.pdf
mohamedalisadek27102
Scalable front-end architecture with Bootstrap 3 + Atomic CSS
Scalable front-end architecture with Bootstrap 3 + Atomic CSSScalable front-end architecture with Bootstrap 3 + Atomic CSS
Scalable front-end architecture with Bootstrap 3 + Atomic CSS
Hayden Bleasel
Bootstrap training basics tutorial | Bootstrap Essentials
Bootstrap training basics tutorial | Bootstrap EssentialsBootstrap training basics tutorial | Bootstrap Essentials
Bootstrap training basics tutorial | Bootstrap Essentials
QA TrainingHub
Twitter Bootstrap, or why being a PHP Developer is a bad idea
Twitter Bootstrap, or why being a PHP Developer is a bad ideaTwitter Bootstrap, or why being a PHP Developer is a bad idea
Twitter Bootstrap, or why being a PHP Developer is a bad idea
Jason Lotito
Bootstrap Jump Start
Bootstrap Jump StartBootstrap Jump Start
Bootstrap Jump Start
Haim Michael
RWD - Bootstrap
RWD - BootstrapRWD - Bootstrap
RWD - Bootstrap
Jasvinder Singh
Bootstrap Framework and Drupal
Bootstrap Framework and DrupalBootstrap Framework and Drupal
Bootstrap Framework and Drupal
Jim Birch
Treeshaking your CSS
Treeshaking your CSSTreeshaking your CSS
Treeshaking your CSS
James Stone
Ready? bootstrap. go! (cf objective 14 05-2014)
Ready? bootstrap. go! (cf objective 14 05-2014)Ready? bootstrap. go! (cf objective 14 05-2014)
Ready? bootstrap. go! (cf objective 14 05-2014)
ColdFusionConference
Bootstrap 3.0
Bootstrap 3.0Bootstrap 3.0
Bootstrap 3.0
Youwe Drecomm OOIP
Introduction to Twitter's Bootstrap 2
Introduction to Twitter's Bootstrap 2Introduction to Twitter's Bootstrap 2
Introduction to Twitter's Bootstrap 2
Julien Renaux
Good design is obvious. Great design is transparent. How we use Bootstrap...
Good design is obvious. Great design is transparent.  How we use Bootstrap...Good design is obvious. Great design is transparent.  How we use Bootstrap...
Good design is obvious. Great design is transparent. How we use Bootstrap...
Roni Banerjee
Sexy HTML with Twitter Bootstrap
Sexy HTML with Twitter BootstrapSexy HTML with Twitter Bootstrap
Sexy HTML with Twitter Bootstrap
Karthik Gaekwad
Bootstrap Bootcamp
Bootstrap BootcampBootstrap Bootcamp
Bootstrap Bootcamp
William Simms
Rapid prototyping front end libraries
Rapid prototyping front end librariesRapid prototyping front end libraries
Rapid prototyping front end libraries
Michal Taberski
Bootstrap UI Library Introduction
Bootstrap UI Library IntroductionBootstrap UI Library Introduction
Bootstrap UI Library Introduction
Vardot
Bootstrap Crash Course 20180717
Bootstrap Crash Course 20180717Bootstrap Crash Course 20180717
Bootstrap Crash Course 20180717
Haim Michael
Ready? Bootstrap! Go! (SOTR 2013) copy
Ready? Bootstrap! Go! (SOTR 2013) copyReady? Bootstrap! Go! (SOTR 2013) copy
Ready? Bootstrap! Go! (SOTR 2013) copy
Guust Nieuwenhuis
Web technologies-course 06.pptx
Web technologies-course 06.pptxWeb technologies-course 06.pptx
Web technologies-course 06.pptx
Stefan Oprea
Bootstrap Workout 2015
Bootstrap Workout 2015Bootstrap Workout 2015
Bootstrap Workout 2015
Rob Davarnia
bootstrap_slidesfor bootstrapthingyise.pdf
bootstrap_slidesfor bootstrapthingyise.pdfbootstrap_slidesfor bootstrapthingyise.pdf
bootstrap_slidesfor bootstrapthingyise.pdf
mohamedalisadek27102
Scalable front-end architecture with Bootstrap 3 + Atomic CSS
Scalable front-end architecture with Bootstrap 3 + Atomic CSSScalable front-end architecture with Bootstrap 3 + Atomic CSS
Scalable front-end architecture with Bootstrap 3 + Atomic CSS
Hayden Bleasel
Bootstrap training basics tutorial | Bootstrap Essentials
Bootstrap training basics tutorial | Bootstrap EssentialsBootstrap training basics tutorial | Bootstrap Essentials
Bootstrap training basics tutorial | Bootstrap Essentials
QA TrainingHub
Twitter Bootstrap, or why being a PHP Developer is a bad idea
Twitter Bootstrap, or why being a PHP Developer is a bad ideaTwitter Bootstrap, or why being a PHP Developer is a bad idea
Twitter Bootstrap, or why being a PHP Developer is a bad idea
Jason Lotito
Bootstrap Jump Start
Bootstrap Jump StartBootstrap Jump Start
Bootstrap Jump Start
Haim Michael
Bootstrap Framework and Drupal
Bootstrap Framework and DrupalBootstrap Framework and Drupal
Bootstrap Framework and Drupal
Jim Birch
Treeshaking your CSS
Treeshaking your CSSTreeshaking your CSS
Treeshaking your CSS
James Stone
Ready? bootstrap. go! (cf objective 14 05-2014)
Ready? bootstrap. go! (cf objective 14 05-2014)Ready? bootstrap. go! (cf objective 14 05-2014)
Ready? bootstrap. go! (cf objective 14 05-2014)
ColdFusionConference
Introduction to Twitter's Bootstrap 2
Introduction to Twitter's Bootstrap 2Introduction to Twitter's Bootstrap 2
Introduction to Twitter's Bootstrap 2
Julien Renaux
Good design is obvious. Great design is transparent. How we use Bootstrap...
Good design is obvious. Great design is transparent.  How we use Bootstrap...Good design is obvious. Great design is transparent.  How we use Bootstrap...
Good design is obvious. Great design is transparent. How we use Bootstrap...
Roni Banerjee
Sexy HTML with Twitter Bootstrap
Sexy HTML with Twitter BootstrapSexy HTML with Twitter Bootstrap
Sexy HTML with Twitter Bootstrap
Karthik Gaekwad
Bootstrap Bootcamp
Bootstrap BootcampBootstrap Bootcamp
Bootstrap Bootcamp
William Simms
Ad

Recently uploaded (20)

MCP vs A2A vs ACP: Choosing the Right Protocol | Bluebash
MCP vs A2A vs ACP: Choosing the Right Protocol | BluebashMCP vs A2A vs ACP: Choosing the Right Protocol | Bluebash
MCP vs A2A vs ACP: Choosing the Right Protocol | Bluebash
Bluebash
Creating an Accessible Future-How AI-powered Accessibility Testing is Shaping...
Creating an Accessible Future-How AI-powered Accessibility Testing is Shaping...Creating an Accessible Future-How AI-powered Accessibility Testing is Shaping...
Creating an Accessible Future-How AI-powered Accessibility Testing is Shaping...
Impelsys Inc.
Soulmaite review - Find Real AI soulmate review
Soulmaite review - Find Real AI soulmate reviewSoulmaite review - Find Real AI soulmate review
Soulmaite review - Find Real AI soulmate review
Soulmaite
ISOIEC 42005 Revolutionalises AI Impact Assessment.pptx
ISOIEC 42005 Revolutionalises AI Impact Assessment.pptxISOIEC 42005 Revolutionalises AI Impact Assessment.pptx
ISOIEC 42005 Revolutionalises AI Impact Assessment.pptx
AyilurRamnath1
How to Detect Outliers in IBM SPSS Statistics.pptx
How to Detect Outliers in IBM SPSS Statistics.pptxHow to Detect Outliers in IBM SPSS Statistics.pptx
How to Detect Outliers in IBM SPSS Statistics.pptx
Version 1 Analytics
How Qualcomm Is Powering AI-driven Multimedia at the Edge, a Presentation f...
How Qualcomm Is Powering AI-driven Multimedia at the Edge, a Presentation f...How Qualcomm Is Powering AI-driven Multimedia at the Edge, a Presentation f...
How Qualcomm Is Powering AI-driven Multimedia at the Edge, a Presentation f...
Edge AI and Vision Alliance
DevOps in the Modern Era - Thoughtfully Critical Podcast
DevOps in the Modern Era - Thoughtfully Critical PodcastDevOps in the Modern Era - Thoughtfully Critical Podcast
DevOps in the Modern Era - Thoughtfully Critical Podcast
Chris Wahl
7 Salesforce Data Cloud Best Practices.pdf
7 Salesforce Data Cloud Best Practices.pdf7 Salesforce Data Cloud Best Practices.pdf
7 Salesforce Data Cloud Best Practices.pdf
Minuscule Technologies
Bridging the divide: A conversation on tariffs today in the book industry - T...
Bridging the divide: A conversation on tariffs today in the book industry - T...Bridging the divide: A conversation on tariffs today in the book industry - T...
Bridging the divide: A conversation on tariffs today in the book industry - T...
BookNet Canada
Scaling GenAI Inference From Prototype to Production: Real-World Lessons in S...
Scaling GenAI Inference From Prototype to Production: Real-World Lessons in S...Scaling GenAI Inference From Prototype to Production: Real-World Lessons in S...
Scaling GenAI Inference From Prototype to Production: Real-World Lessons in S...
Anish Kumar
Dancing with AI - A Developer's Journey.pptx
Dancing with AI - A Developer's Journey.pptxDancing with AI - A Developer's Journey.pptx
Dancing with AI - A Developer's Journey.pptx
Elliott Richmond
cnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdf
cnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdfcnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdf
cnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdf
AmirStern2
Improving Developer Productivity With DORA, SPACE, and DevEx
Improving Developer Productivity With DORA, SPACE, and DevExImproving Developer Productivity With DORA, SPACE, and DevEx
Improving Developer Productivity With DORA, SPACE, and DevEx
Justin Reock
AI Agents in Logistics and Supply Chain Applications Benefits and Implementation
AI Agents in Logistics and Supply Chain Applications Benefits and ImplementationAI Agents in Logistics and Supply Chain Applications Benefits and Implementation
AI Agents in Logistics and Supply Chain Applications Benefits and Implementation
Christine Shepherd
vertical-cnc-processing-centers-drillteq-v-200-en.pdf
vertical-cnc-processing-centers-drillteq-v-200-en.pdfvertical-cnc-processing-centers-drillteq-v-200-en.pdf
vertical-cnc-processing-centers-drillteq-v-200-en.pdf
AmirStern2
Establish Visibility and Manage Risk in the Supply Chain with Anchore SBOM
Establish Visibility and Manage Risk in the Supply Chain with Anchore SBOMEstablish Visibility and Manage Risk in the Supply Chain with Anchore SBOM
Establish Visibility and Manage Risk in the Supply Chain with Anchore SBOM
Anchore
FME Beyond Data Processing Creating A Dartboard Accuracy App
FME Beyond Data Processing Creating A Dartboard Accuracy AppFME Beyond Data Processing Creating A Dartboard Accuracy App
FME Beyond Data Processing Creating A Dartboard Accuracy App
Safe Software
State-space Models vs. Transformers for Ultra-low-power Edge AI, a Presenta...
State-space Models vs. Transformers for Ultra-low-power Edge AI, a Presenta...State-space Models vs. Transformers for Ultra-low-power Edge AI, a Presenta...
State-space Models vs. Transformers for Ultra-low-power Edge AI, a Presenta...
Edge AI and Vision Alliance
Oracle Cloud Infrastructure Generative AI Professional
Oracle Cloud Infrastructure Generative AI ProfessionalOracle Cloud Infrastructure Generative AI Professional
Oracle Cloud Infrastructure Generative AI Professional
VICTOR MAESTRE RAMIREZ
ELNL2025 - Unlocking the Power of Sensitivity Labels - A Comprehensive Guide....
ELNL2025 - Unlocking the Power of Sensitivity Labels - A Comprehensive Guide....ELNL2025 - Unlocking the Power of Sensitivity Labels - A Comprehensive Guide....
ELNL2025 - Unlocking the Power of Sensitivity Labels - A Comprehensive Guide....
Jasper Oosterveld
MCP vs A2A vs ACP: Choosing the Right Protocol | Bluebash
MCP vs A2A vs ACP: Choosing the Right Protocol | BluebashMCP vs A2A vs ACP: Choosing the Right Protocol | Bluebash
MCP vs A2A vs ACP: Choosing the Right Protocol | Bluebash
Bluebash
Creating an Accessible Future-How AI-powered Accessibility Testing is Shaping...
Creating an Accessible Future-How AI-powered Accessibility Testing is Shaping...Creating an Accessible Future-How AI-powered Accessibility Testing is Shaping...
Creating an Accessible Future-How AI-powered Accessibility Testing is Shaping...
Impelsys Inc.
Soulmaite review - Find Real AI soulmate review
Soulmaite review - Find Real AI soulmate reviewSoulmaite review - Find Real AI soulmate review
Soulmaite review - Find Real AI soulmate review
Soulmaite
ISOIEC 42005 Revolutionalises AI Impact Assessment.pptx
ISOIEC 42005 Revolutionalises AI Impact Assessment.pptxISOIEC 42005 Revolutionalises AI Impact Assessment.pptx
ISOIEC 42005 Revolutionalises AI Impact Assessment.pptx
AyilurRamnath1
How to Detect Outliers in IBM SPSS Statistics.pptx
How to Detect Outliers in IBM SPSS Statistics.pptxHow to Detect Outliers in IBM SPSS Statistics.pptx
How to Detect Outliers in IBM SPSS Statistics.pptx
Version 1 Analytics
How Qualcomm Is Powering AI-driven Multimedia at the Edge, a Presentation f...
How Qualcomm Is Powering AI-driven Multimedia at the Edge, a Presentation f...How Qualcomm Is Powering AI-driven Multimedia at the Edge, a Presentation f...
How Qualcomm Is Powering AI-driven Multimedia at the Edge, a Presentation f...
Edge AI and Vision Alliance
DevOps in the Modern Era - Thoughtfully Critical Podcast
DevOps in the Modern Era - Thoughtfully Critical PodcastDevOps in the Modern Era - Thoughtfully Critical Podcast
DevOps in the Modern Era - Thoughtfully Critical Podcast
Chris Wahl
7 Salesforce Data Cloud Best Practices.pdf
7 Salesforce Data Cloud Best Practices.pdf7 Salesforce Data Cloud Best Practices.pdf
7 Salesforce Data Cloud Best Practices.pdf
Minuscule Technologies
Bridging the divide: A conversation on tariffs today in the book industry - T...
Bridging the divide: A conversation on tariffs today in the book industry - T...Bridging the divide: A conversation on tariffs today in the book industry - T...
Bridging the divide: A conversation on tariffs today in the book industry - T...
BookNet Canada
Scaling GenAI Inference From Prototype to Production: Real-World Lessons in S...
Scaling GenAI Inference From Prototype to Production: Real-World Lessons in S...Scaling GenAI Inference From Prototype to Production: Real-World Lessons in S...
Scaling GenAI Inference From Prototype to Production: Real-World Lessons in S...
Anish Kumar
Dancing with AI - A Developer's Journey.pptx
Dancing with AI - A Developer's Journey.pptxDancing with AI - A Developer's Journey.pptx
Dancing with AI - A Developer's Journey.pptx
Elliott Richmond
cnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdf
cnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdfcnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdf
cnc-drilling-dowel-inserting-machine-drillteq-d-510-english.pdf
AmirStern2
Improving Developer Productivity With DORA, SPACE, and DevEx
Improving Developer Productivity With DORA, SPACE, and DevExImproving Developer Productivity With DORA, SPACE, and DevEx
Improving Developer Productivity With DORA, SPACE, and DevEx
Justin Reock
AI Agents in Logistics and Supply Chain Applications Benefits and Implementation
AI Agents in Logistics and Supply Chain Applications Benefits and ImplementationAI Agents in Logistics and Supply Chain Applications Benefits and Implementation
AI Agents in Logistics and Supply Chain Applications Benefits and Implementation
Christine Shepherd
vertical-cnc-processing-centers-drillteq-v-200-en.pdf
vertical-cnc-processing-centers-drillteq-v-200-en.pdfvertical-cnc-processing-centers-drillteq-v-200-en.pdf
vertical-cnc-processing-centers-drillteq-v-200-en.pdf
AmirStern2
Establish Visibility and Manage Risk in the Supply Chain with Anchore SBOM
Establish Visibility and Manage Risk in the Supply Chain with Anchore SBOMEstablish Visibility and Manage Risk in the Supply Chain with Anchore SBOM
Establish Visibility and Manage Risk in the Supply Chain with Anchore SBOM
Anchore
FME Beyond Data Processing Creating A Dartboard Accuracy App
FME Beyond Data Processing Creating A Dartboard Accuracy AppFME Beyond Data Processing Creating A Dartboard Accuracy App
FME Beyond Data Processing Creating A Dartboard Accuracy App
Safe Software
State-space Models vs. Transformers for Ultra-low-power Edge AI, a Presenta...
State-space Models vs. Transformers for Ultra-low-power Edge AI, a Presenta...State-space Models vs. Transformers for Ultra-low-power Edge AI, a Presenta...
State-space Models vs. Transformers for Ultra-low-power Edge AI, a Presenta...
Edge AI and Vision Alliance
Oracle Cloud Infrastructure Generative AI Professional
Oracle Cloud Infrastructure Generative AI ProfessionalOracle Cloud Infrastructure Generative AI Professional
Oracle Cloud Infrastructure Generative AI Professional
VICTOR MAESTRE RAMIREZ
ELNL2025 - Unlocking the Power of Sensitivity Labels - A Comprehensive Guide....
ELNL2025 - Unlocking the Power of Sensitivity Labels - A Comprehensive Guide....ELNL2025 - Unlocking the Power of Sensitivity Labels - A Comprehensive Guide....
ELNL2025 - Unlocking the Power of Sensitivity Labels - A Comprehensive Guide....
Jasper Oosterveld
Ad

Toolstrap