Fundamentos

de UX/UI
para developers

NO diseñador

Mario González

Lead Instructor @ The Refactor Project

Objetivos del taller

no eres diseñador/a

no has estudiado a tus usuarios/as

a nadie le importa que a ti te encante tu diseño

¿UI?

¿UX/UI?

¿UX?

UX

User eXperience

tú no

UX

no te flipes

UX

Users Research

UX

Information Architecture

UX

Flow Diagrams

UX

User Journey

UX

Prototypes

UI

User Interface

UI

Visual Hierarchy

UX/UI

UX/UI

UX/UI

UX/UI

La importancia del UX Research

UX/UI

UX/UI

UX/UI

UX/UI

UX/UI

Colaboración entre diseño y desarrollo

🧑‍🎨

🥷

Diseñadores/as

Developers

Historia

🤦‍♀️

😓

🤌

Colaboración entre diseño y desarrollo

🤌

👨‍🦲

🤶

🤩

Colaboración entre diseño y desarrollo

Colaboración entre diseño y desarrollo

Wireframes

Mockups

Prototypes

?

?

?

Wireframes

Wireframes

low fidelity

high fidelity

Mockups

wireframe

mockup

Mockups

Prototypes

Prototypes

UI Kits & Design Systems

UI kit

Design System

Design System

Design System

Design System

Atomic Design

Design Tokens

Design Tokens

Design

Tokens

Design Tokens

{
  "color": {
    "font": {
      "base": "#111111",
      "secondary": "#333333",
      "tertiary": "#666666",
      "inverse": {
        "base": "#ffffff"        
      }
    }
  },  
  "size": {
    "font": {
      "base":  16,
      "large": 20 
    }
  }
}

Design Tokens

const theme = extendTheme({
  colorSchemes: {
    dark: {
      palette: {
        primary: {
          50: '#c0ccd9',
          100: '#a5b8cf',
          200: '#6a96ca',
          300: '#4886d0',
          400: '#2178dd',
          500: '#096bde',
          600: '#1b62b5',
          700: '#265995',
          800: '#2f4968',
          900: '#2f3c4c',
        },
      },
    },
  },
});

Design Tokens

import Typography from '@mui/joy/Typography';

<Typography
  sx={theme => ({
    color: `rgba(${theme.vars.palette.primary.mainChannel} / 0.72)`,
  })}
>

Design Tokens

Design Tokens

Design Tokens

¿Cómo organizo mi CSS?

:root {
  --main-color: #db504a;
  --secondary-color: #4f6d7a;
}
.site-logo {
  display: inline-block;
  background-color: var(--main-color);
  padding: 0 7px;
  margin-top: 6px;
  border-radius: 15px;
}
@media screen and (max-width: 575px) {
  .site-logo {
    width: 80%;
    max-width: 240px;
  }
  .site-logo .logo {
    width: 40px;
  }
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .site-logo {
    width: 120%;
    margin-top: 19px;
  }
  .site-logo .logo {
    width: 30px;
  }
}
@media screen and (min-width: 992px) and (max-width: 1199px) {
  .site-logo {
    width: 100%;
  }
}
.site-logo img {
  width: 50px;
  display: inline-block;
  margin-top: -30px;
  color: #fff;
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .site-logo img {
    margin-top: -17px;
  }
}
.site-logo h1 {
  display: inline-block;
  font-family: Dosis, sans-serif;
  color: #fff;
  font-size: 54px;
  margin-top: -20px;
}
@media screen and (min-width: 768px) and (max-width: 1199px) {
  .site-logo h1 {
    font-size: 35px;
  }
}
@media screen and (max-width: 575px) {
  .site-logo h1 {
    font-size: 45px;
  }
}
.course-item a,
.site-logo h1 a {
  color: inherit;
}
.course-item .course-thumb {
  position: relative;
}
.course-item .course-thumb > a {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}
.course-item .course-author .ca-pic {
  position: relative;
}
.course-item .course-author .ca-pic a {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
}
#cookieModal .modal-footer .btn-success {
  background-color: var(--main-color);
  border-color: transparent;
}
.privacy-policy-page h6 {
  margin: 20px 0 10px;
}
body,
html {
  height: 100%;
  font-family: Inter, sans-serif;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
  font-weight: 600;
  color: #474747;
}
h1 {
  font-size: 70px;
}
h2 {
  font-size: 36px;
}
h3 {
  font-size: 30px;
}
h4 {
  font-size: 24px;
}
h5 {
  font-size: 20px;
}
h6 {
  font-size: 16px;
}
p {
  font-size: 14.1px;
  color: #878787;
  line-height: 2.2;
  font-weight: 500;
}
img {
  max-width: 100%;
}
button:focus,
input:focus,
select:focus,
textarea:focus {
  outline: none;
}
::-webkit-input-placeholder {
  font-style: italic;
}
::-ms-input-placeholder {
  font-style: italic;
}
:-ms-input-placeholder {
  font-style: italic;
}
::-moz-placeholder {
  font-style: italic;
}
::placeholder {
  font-style: italic;
}
a:hover {
  color: var(--main-color);
}
a:focus,
a:hover {
  text-decoration: none;
  outline: none;
}
ol,
ul {
  padding: 0;
  margin: 0;
}
.section-title {
  text-align: center;
  padding: 0 110px;
  margin-bottom: 110px;
}
.section-title h2 {
  font-size: 48px;
  font-weight: 600;
  margin-bottom: 25px;
}
.section-title p {
  margin-bottom: 0;
  font-weight: 500;
}
.set-bg {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top;
}
.spad {
  padding-top: 115px;
  padding-bottom: 115px;
}
.text-white a,
.text-white h1,
.text-white h2,
.text-white h3,
.text-white h4,
.text-white h5,
.text-white h6,
.text-white li,
.text-white p,
.text-white span {
  color: #fff;
}
.rating i,
.rating svg {
  color: #fbb710;
}
.rating .is-fade {
  color: #e0e3e4;
}
.site-btn {
  display: inline-block;
  min-width: 196px;
  text-align: center;
  border: none;
  padding: 15px 10px;
  font-weight: 600;
  font-size: 16px;
  position: relative;
  cursor: pointer;
  background: var(--main-color);
}
.site-btn,
.site-btn:hover {
  color: #fff;
}
.site-btn.btn-dark {
  background: #000;
}
.site-btn.btn-fade {
  background: #e4edef;
  color: #1f1f1f;
}
#preloder {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 999999;
  background: #fff;
}
.loader {
  width: 40px;
  height: 40px;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: -13px;
  margin-left: -13px;
  border-radius: 60px;
  animation: loader 0.8s linear infinite;
  -webkit-animation: loader 0.8s linear infinite;
}
@keyframes loader {
  0% {
    transform: rotate(0deg);
    border: 4px solid #f44336;
    border-left-color: transparent;
  }
  50% {
    transform: rotate(180deg);
    border: 4px solid #673ab7;
    border-left-color: transparent;
  }
  to {
    transform: rotate(1turn);
    border: 4px solid #f44336;
    border-left-color: transparent;
  }
}
@-webkit-keyframes loader {
  0% {
    -webkit-transform: rotate(0deg);
    border: 4px solid #f44336;
    border-left-color: transparent;
  }
  50% {
    -webkit-transform: rotate(180deg);
    border: 4px solid #673ab7;
    border-left-color: transparent;
  }
  to {
    -webkit-transform: rotate(1turn);
    border: 4px solid #f44336;
    border-left-color: transparent;
  }
}
.header-section {
  position: absolute;
  width: 100%;
  top: 0;
  left: 0;
  padding-top: 60px;
}
.main-menu ul {
  list-style: none;
}
.main-menu ul li {
  display: inline;
}
.main-menu ul li a {
  display: inline-block;
  font-size: 16px;
  color: #fff;
  margin-left: 45px;
  font-weight: 600;
  padding: 20px 0 5px;
}
.main-menu ul li a:hover {
  color: var(--main-color);
}
.header-btn {
  float: right;
  margin-right: 0;
}
.nav-switch {
  display: none;
}
.hero-section {
  height: 948px;
}
@media screen and (max-width: 767px) {
  .hero-section {
    background-position: 0;
  }
}
.hero-text {
  text-align: center;
  padding-top: 240px;
  margin-bottom: 105px;
}
.hero-text h2 {
  font-size: 60px;
  font-weight: 500;
  margin-bottom: 20px;
}

Arquitectura CSS

Arquitectura CSS

Arquitectura CSS

espaciado

layout

variables

resets

globals

componentes

ese elemento que quieres posicionar nosedónde

Arquitectura CSS

aprovecha la herencia

herencia

herencia

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

font-family

Arquitectura CSS

aprovecha la herencia

body,
h1,
h2,
h3,
h4,
h5,
h6,
p {
  font-family: $font.family.main-text;
}

Diseño centrado en el usuario

UX

dev

UI

NO es centrado en el usuario cuando decimos...

"en mi pantalla se ve bien"

la pantalla

del usuario

NO es centrado en el usuario cuando decimos...

"la tipografía no es pequeña, yo leo el texto perfectamente"

la pantalla

del usuario

NO es centrado en el usuario cuando decimos...

"Yo distingo los colores perfectamente, tienen suficiente contraste"

la pantalla

del usuario

NO es centrado en el usuario cuando decimos...

"Ya probé la app en el móvil el otro día"

la pantalla

del usuario

NO es centrado en el usuario cuando decimos...

"Si el usuario no lo entiende es su culpa"

la navegación súper intuitiva que me he inventao

NO es centrado en el usuario cuando usamos...

Un botón con un texto "Submit"

El usuario programador

Un botón con un texto "Submit"

NO es centrado en el usuario cuando usamos...

Un link con un texto "Click here"

NO es centrado en el usuario cuando usamos...

Placeholders sin labels porque fuá cómo molan

Sí me estoy centrando en el usuario si...

le doy importancia a la accesibilidad

Me estoy centrando en el usuario si...

desarrollo con enfoque mobile first

Me estoy centrando en el usuario si...

mi app da feedback al usuario

cuidado con las incoherencias en el feedback

Me estoy centrando en el usuario si...

la navegación es intuitiva y cómoda

Me estoy centrando en el usuario si...

priorizo la velocidad de carga

Me estoy centrando en el usuario si...

busco un alto grado de legibilidad

Me estoy centrando en el usuario si...

tengo en cuenta sus decisiones

Me estoy centrando en el usuario si...

pruebo mi app con usuarios reales

Me estoy centrando en el usuario si...

hago target sizes suficientemente grandes

Conocimientos básicos de diseño

Tipografías
Paleta de colores
Espaciado
Legibilidad

Tipografías

Tipografías - familias genéricas

serif

El veloz murciélago hindú comía feliz cardillo y kiwi

Tipografías - familias genéricas

sans serif

El veloz murciélago hindú comía feliz cardillo y kiwi

Tipografías - familias genéricas

monospace

El veloz murciélago hindú comía feliz cardillo y kiwi

Tipografías - familias genéricas

script

El veloz murciélago hindú comía feliz cardillo y kiwi

Propiedades de las tipografías

  • Tamaño

  • Peso

  • Tracking

  • Kerning

  • Leading

  • Ligaduras

Propiedades de las tipografías

Tamaño

Propiedades de las tipografías

Peso

Propiedades de las tipografías

Tracking

Propiedades de las tipografías

Kerning

Propiedades de las tipografías

Leading

Propiedades de las tipografías

Ligaduras

Paleta de colores

Paleta de colores

Naming:

- Definitive

- Semantic

- Contextual

Definitive: nombre del color

Semantic: propósito, intención

Contextual: qué elemento es

Mezclados

Espaciado

por favor

usa

paddings

Legibilidad

Legibilidad

Legibilidad

Legibilidad

Legibilidad

Accesibility

Buena jerarquía de encabezados

Labels en los formularios

<a> o <button> para elementos clicables

prefers-reduced-motion

probado por personas con diferentes capacidades

Unidades CSS: rem cuando toque

Nombres accesibles

Textos alternativos

prefers-color-scheme

Usable con teclado

Herramientas para accesibilidad

Herramientas para accesibilidad

Herramientas para accesibilidad

Herramientas para accesibilidad

Herramientas para accesibilidad

Herramientas para accesibilidad

Herramientas para accesibilidad

Herramientas para accesibilidad

Antipatrones

Interfaces sobrecargadas

Interfaces sobrecargadas

Diseño inconsistente

Mistery meat

Mystery meat

Overuse of popups

Overuse of popups

Overuse of popups

Overuse of popups

Placeholder misuse

Placeholder misuse

Formularios

1. Usa la etiqueta <form>

Formularios

2. Elige el type correcto

Formularios

3. Permite ver la contraseña

Formularios

4. Deja clara la acción del submit

Formularios

5. Da feedback antes de enviar

Formularios

6. Usa label para los checkboxes

Formularios

7. "opcional" mejor que "*"

Formularios

Formularios

8. Usables con teclado

Validación de formularios

1. Evita la validación prematura

Validación de formularios

2. Evita la validación onBlur para todo

Validación de formularios

3. Evita errores desactualizados

Validación de formularios

4. Ahorra tiempo al usuario

Validación de formularios

4. Ten en cuenta los screen-readers

aria-invalid

aria-errormessage

required

Validación de formularios

Performance

Performance

Hay que seguir a Joan León @nucliweb

UX RESEARCH

y ahora...

UX for developers

By mariogl

UX for developers

  • 209