feat(badge): add hue property for the ionic theme (#30307)

Issue number: internal

---------

## What is the current behavior?
The badge component does not support the `hue` property.

## What is the new behavior?
Adds support for the `subtle` hue for the badge. Defaults to `subtle`
when the badge contains icon or text. Defaults to `bold` when the badge
is empty or when it is inside of a button or tab button.

## Does this introduce a breaking change?
- [ ] Yes
- [x] No
This commit is contained in:
Brandy Smith
2025-04-11 13:07:01 -04:00
committed by GitHub
parent 207d4858a6
commit a9aa59bc36
116 changed files with 265 additions and 11 deletions

View File

@ -314,6 +314,7 @@ ion-backdrop,event,ionBackdropTap,void,true
ion-badge,shadow ion-badge,shadow
ion-badge,prop,color,"danger" | "dark" | "light" | "medium" | "primary" | "secondary" | "success" | "tertiary" | "warning" | string & Record<never, never> | undefined,undefined,false,true ion-badge,prop,color,"danger" | "dark" | "light" | "medium" | "primary" | "secondary" | "success" | "tertiary" | "warning" | string & Record<never, never> | undefined,undefined,false,true
ion-badge,prop,hue,"bold" | "subtle" | undefined,undefined,false,false
ion-badge,prop,mode,"ios" | "md",undefined,false,false ion-badge,prop,mode,"ios" | "md",undefined,false,false
ion-badge,prop,shape,"round | rectangular" | "soft" | undefined,undefined,false,false ion-badge,prop,shape,"round | rectangular" | "soft" | undefined,undefined,false,false
ion-badge,prop,size,"large" | "medium" | "small" | "xlarge" | "xsmall" | "xxsmall" | undefined,undefined,false,false ion-badge,prop,size,"large" | "medium" | "small" | "xlarge" | "xsmall" | "xxsmall" | undefined,undefined,false,false

View File

@ -429,6 +429,10 @@ export namespace Components {
* The color to use from your application's color palette. Default options are: `"primary"`, `"secondary"`, `"tertiary"`, `"success"`, `"warning"`, `"danger"`, `"light"`, `"medium"`, and `"dark"`. For more information on colors, see [theming](/docs/theming/basics). * The color to use from your application's color palette. Default options are: `"primary"`, `"secondary"`, `"tertiary"`, `"success"`, `"warning"`, `"danger"`, `"light"`, `"medium"`, and `"dark"`. For more information on colors, see [theming](/docs/theming/basics).
*/ */
"color"?: Color; "color"?: Color;
/**
* Set to `"bold"` for a badge with vibrant, bold colors or to `"subtle"` for a badge with muted, subtle colors. Only applies to the `ionic` theme.
*/
"hue"?: 'bold' | 'subtle';
/** /**
* The mode determines the platform behaviors of the component. * The mode determines the platform behaviors of the component.
*/ */
@ -5870,6 +5874,10 @@ declare namespace LocalJSX {
* The color to use from your application's color palette. Default options are: `"primary"`, `"secondary"`, `"tertiary"`, `"success"`, `"warning"`, `"danger"`, `"light"`, `"medium"`, and `"dark"`. For more information on colors, see [theming](/docs/theming/basics). * The color to use from your application's color palette. Default options are: `"primary"`, `"secondary"`, `"tertiary"`, `"success"`, `"warning"`, `"danger"`, `"light"`, `"medium"`, and `"dark"`. For more information on colors, see [theming](/docs/theming/basics).
*/ */
"color"?: Color; "color"?: Color;
/**
* Set to `"bold"` for a badge with vibrant, bold colors or to `"subtle"` for a badge with muted, subtle colors. Only applies to the `ionic` theme.
*/
"hue"?: 'bold' | 'subtle';
/** /**
* The mode determines the platform behaviors of the component. * The mode determines the platform behaviors of the component.
*/ */

View File

@ -43,11 +43,6 @@
vertical-align: baseline; vertical-align: baseline;
} }
:host(.ion-color) {
background: #{color.current-color(base)};
color: #{color.current-color(contrast)};
}
// Badge (hint) // Badge (hint)
// -------------------------------------------------- // --------------------------------------------------

View File

@ -5,8 +5,6 @@
// -------------------------------------------------- // --------------------------------------------------
:host { :host {
--background: #{globals.ion-color(primary, base)};
--color: #{globals.ion-color(primary, contrast)};
--padding-start: #{globals.$ion-space-200}; --padding-start: #{globals.$ion-space-200};
--padding-end: #{globals.$ion-space-200}; --padding-end: #{globals.$ion-space-200};
--padding-top: #{globals.$ion-space-0}; --padding-top: #{globals.$ion-space-0};
@ -20,6 +18,32 @@
font-weight: globals.$ion-font-weight-medium; font-weight: globals.$ion-font-weight-medium;
} }
// Bold Badge
// --------------------------------------------------
:host(.badge-bold) {
--background: #{globals.ion-color(primary, base)};
--color: #{globals.ion-color(primary, contrast)};
}
:host(.badge-bold.ion-color) {
background: globals.current-color(base);
color: globals.current-color(contrast);
}
// Subtle Badge
// --------------------------------------------------
:host(.badge-subtle) {
--background: #{globals.ion-color(primary, base, $subtle: true)};
--color: #{globals.ion-color(primary, contrast, $subtle: true)};
}
:host(.badge-subtle.ion-color) {
background: globals.current-color(base, $subtle: true);
color: globals.current-color(contrast, $subtle: true);
}
// Badge Shapes // Badge Shapes
// -------------------------------------------------- // --------------------------------------------------

View File

@ -12,6 +12,11 @@
font-family: $font-family-base; font-family: $font-family-base;
} }
:host(.ion-color) {
background: current-color(base);
color: current-color(contrast);
}
// TODO(ROU-10747): Review size styles when sizes are defined for native themes. // TODO(ROU-10747): Review size styles when sizes are defined for native themes.
:host([vertical]:not(.in-button):not(.in-tab-button)), :host([vertical]:not(.in-button):not(.in-tab-button)),
:host(:empty) { :host(:empty) {

View File

@ -28,6 +28,14 @@ export class Badge implements ComponentInterface {
*/ */
@Prop({ reflect: true }) color?: Color; @Prop({ reflect: true }) color?: Color;
/**
* Set to `"bold"` for a badge with vibrant, bold colors or to `"subtle"` for
* a badge with muted, subtle colors.
*
* Only applies to the `ionic` theme.
*/
@Prop() hue?: 'bold' | 'subtle';
/** /**
* Set to `"rectangular"` for non-rounded corners. * Set to `"rectangular"` for non-rounded corners.
* Set to `"soft"` for slightly rounded corners. * Set to `"soft"` for slightly rounded corners.
@ -87,7 +95,33 @@ export class Badge implements ComponentInterface {
return size; return size;
} }
// The 'subtle' hue is the default for badges containing text or icons
// The 'bold' hue is used when inside of an avatar, button, tab button,
// or when the badge is empty (no text or icon).
private getHue(): string | undefined {
const { hue } = this;
if (hue !== undefined) {
return hue;
}
const inAvatar = hostContext('ion-avatar', this.el);
const inButton = hostContext('ion-button', this.el);
const inTabButton = hostContext('ion-tab-button', this.el);
const hasContent = this.el.textContent?.trim() !== '' || this.el.querySelector('ion-icon') !== null;
// Return 'bold' if the badge is inside an avatar, button, tab button,
// or has no content
if (inAvatar || inButton || inTabButton || !hasContent) {
return 'bold';
}
// Return 'subtle' if the badge contains visible text or an icon
return 'subtle';
}
render() { render() {
const hue = this.getHue();
const shape = this.getShape(); const shape = this.getShape();
const size = this.getSize(); const size = this.getSize();
const theme = getIonTheme(this); const theme = getIonTheme(this);
@ -96,6 +130,7 @@ export class Badge implements ComponentInterface {
<Host <Host
class={createColorClasses(this.color, { class={createColorClasses(this.color, {
[theme]: true, [theme]: true,
[`badge-${hue}`]: hue !== undefined,
[`badge-${shape}`]: shape !== undefined, [`badge-${shape}`]: shape !== undefined,
[`badge-${size}`]: size !== undefined, [`badge-${size}`]: size !== undefined,
[`badge-vertical-${this.vertical}`]: this.vertical !== undefined, [`badge-vertical-${this.vertical}`]: this.vertical !== undefined,

Binary file not shown.

Before

Width:  |  Height:  |  Size: 88 KiB

After

Width:  |  Height:  |  Size: 84 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 110 KiB

After

Width:  |  Height:  |  Size: 106 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 107 KiB

After

Width:  |  Height:  |  Size: 102 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 89 KiB

After

Width:  |  Height:  |  Size: 84 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 111 KiB

After

Width:  |  Height:  |  Size: 107 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 108 KiB

After

Width:  |  Height:  |  Size: 103 KiB

View File

@ -0,0 +1,80 @@
import { expect } from '@playwright/test';
import { configs, test } from '@utils/test/playwright';
configs({ directions: ['ltr'], modes: ['ionic-md'] }).forEach(({ config, screenshot, title }) => {
test.describe(title('badge: hue'), () => {
test('should render subtle badges', async ({ page }) => {
await page.setContent(
`
<div id="container">
<ion-badge>99</ion-badge>
<ion-badge color="primary">99</ion-badge>
<ion-badge color="secondary">99</ion-badge>
<ion-badge color="tertiary">99</ion-badge>
<ion-badge color="success">99</ion-badge>
<ion-badge color="warning">99</ion-badge>
<ion-badge color="danger">99</ion-badge>
<ion-badge color="light">99</ion-badge>
<ion-badge color="medium">99</ion-badge>
<ion-badge color="dark">99</ion-badge>
<br>
<ion-badge><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="primary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="secondary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="tertiary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="success"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="warning"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="danger"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="light"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="medium"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="dark"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
</div>
`,
config
);
const container = page.locator('#container');
await expect(container).toHaveScreenshot(screenshot(`badge-hue-subtle`));
});
test('should render bold badges', async ({ page }) => {
await page.setContent(
`
<div id="container">
<ion-badge hue="bold">99</ion-badge>
<ion-badge hue="bold" color="primary">99</ion-badge>
<ion-badge hue="bold" color="secondary">99</ion-badge>
<ion-badge hue="bold" color="tertiary">99</ion-badge>
<ion-badge hue="bold" color="success">99</ion-badge>
<ion-badge hue="bold" color="warning">99</ion-badge>
<ion-badge hue="bold" color="danger">99</ion-badge>
<ion-badge hue="bold" color="light">99</ion-badge>
<ion-badge hue="bold" color="medium">99</ion-badge>
<ion-badge hue="bold" color="dark">99</ion-badge>
<br>
<ion-badge hue="bold"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="primary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="secondary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="tertiary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="success"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="warning"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="danger"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="light"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="medium"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="dark"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
</div>
`,
config
);
const container = page.locator('#container');
await expect(container).toHaveScreenshot(screenshot(`badge-hue-bold`));
});
});
});

View File

@ -0,0 +1,78 @@
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<meta charset="UTF-8" />
<title>Badge - Hue</title>
<meta
name="viewport"
content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"
/>
<link href="../../../../../css/ionic.bundle.css" rel="stylesheet" />
<link href="../../../../../scripts/testing/styles.css" rel="stylesheet" />
<script src="../../../../../scripts/testing/scripts.js"></script>
<script nomodule src="../../../../../dist/ionic/ionic.js"></script>
<script type="module" src="../../../../../dist/ionic/ionic.esm.js"></script>
</head>
<body>
<ion-app>
<ion-header>
<ion-toolbar>
<ion-title>Badge - Hue</ion-title>
</ion-toolbar>
</ion-header>
<ion-content id="content">
<h2>Badge Hue: Subtle</h2>
<ion-badge>99</ion-badge>
<ion-badge color="primary">99</ion-badge>
<ion-badge color="secondary">99</ion-badge>
<ion-badge color="tertiary">99</ion-badge>
<ion-badge color="success">99</ion-badge>
<ion-badge color="warning">99</ion-badge>
<ion-badge color="danger">99</ion-badge>
<ion-badge color="light">99</ion-badge>
<ion-badge color="medium">99</ion-badge>
<ion-badge color="dark">99</ion-badge>
<br />
<ion-badge><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="primary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="secondary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="tertiary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="success"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="warning"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="danger"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="light"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="medium"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge color="dark"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<h2>Badge Hue: Bold</h2>
<ion-badge hue="bold">99</ion-badge>
<ion-badge hue="bold" color="primary">99</ion-badge>
<ion-badge hue="bold" color="secondary">99</ion-badge>
<ion-badge hue="bold" color="tertiary">99</ion-badge>
<ion-badge hue="bold" color="success">99</ion-badge>
<ion-badge hue="bold" color="warning">99</ion-badge>
<ion-badge hue="bold" color="danger">99</ion-badge>
<ion-badge hue="bold" color="light">99</ion-badge>
<ion-badge hue="bold" color="medium">99</ion-badge>
<ion-badge hue="bold" color="dark">99</ion-badge>
<br />
<ion-badge hue="bold"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="primary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="secondary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="tertiary"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="success"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="warning"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="danger"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="light"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="medium"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
<ion-badge hue="bold" color="dark"><ion-icon name="logo-ionic"></ion-icon></ion-badge>
</ion-content>
</ion-app>
</body>
</html>

Binary file not shown.

Before

Width:  |  Height:  |  Size: 884 B

After

Width:  |  Height:  |  Size: 864 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1013 B

After

Width:  |  Height:  |  Size: 1.0 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 836 B

After

Width:  |  Height:  |  Size: 962 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 204 B

After

Width:  |  Height:  |  Size: 204 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 217 B

After

Width:  |  Height:  |  Size: 221 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 239 B

After

Width:  |  Height:  |  Size: 241 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 566 B

After

Width:  |  Height:  |  Size: 550 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 656 B

After

Width:  |  Height:  |  Size: 649 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 696 B

After

Width:  |  Height:  |  Size: 683 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

After

Width:  |  Height:  |  Size: 1.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 847 B

After

Width:  |  Height:  |  Size: 503 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 720 B

After

Width:  |  Height:  |  Size: 535 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 862 B

After

Width:  |  Height:  |  Size: 541 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

After

Width:  |  Height:  |  Size: 865 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

After

Width:  |  Height:  |  Size: 934 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.2 KiB

After

Width:  |  Height:  |  Size: 997 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.6 KiB

After

Width:  |  Height:  |  Size: 4.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.1 KiB

After

Width:  |  Height:  |  Size: 6.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 5.2 KiB

After

Width:  |  Height:  |  Size: 5.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.2 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.0 KiB

After

Width:  |  Height:  |  Size: 1.8 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.6 KiB

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.6 KiB

After

Width:  |  Height:  |  Size: 2.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.2 KiB

After

Width:  |  Height:  |  Size: 4.0 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 4.0 KiB

After

Width:  |  Height:  |  Size: 3.8 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.2 KiB

After

Width:  |  Height:  |  Size: 2.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.9 KiB

After

Width:  |  Height:  |  Size: 2.8 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.5 KiB

After

Width:  |  Height:  |  Size: 2.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 759 B

After

Width:  |  Height:  |  Size: 735 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.2 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 975 B

After

Width:  |  Height:  |  Size: 820 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.8 KiB

After

Width:  |  Height:  |  Size: 1.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.3 KiB

After

Width:  |  Height:  |  Size: 2.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.2 KiB

After

Width:  |  Height:  |  Size: 2.0 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.1 KiB

After

Width:  |  Height:  |  Size: 1.8 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.4 KiB

After

Width:  |  Height:  |  Size: 2.0 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.0 KiB

After

Width:  |  Height:  |  Size: 1.9 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.0 KiB

After

Width:  |  Height:  |  Size: 672 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 978 B

After

Width:  |  Height:  |  Size: 744 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.2 KiB

After

Width:  |  Height:  |  Size: 788 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.5 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.7 KiB

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.0 KiB

After

Width:  |  Height:  |  Size: 1.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.6 KiB

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.8 KiB

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.6 KiB

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 928 B

After

Width:  |  Height:  |  Size: 595 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 834 B

After

Width:  |  Height:  |  Size: 680 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 937 B

After

Width:  |  Height:  |  Size: 674 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

After

Width:  |  Height:  |  Size: 981 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.7 KiB

After

Width:  |  Height:  |  Size: 1.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.4 KiB

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

After

Width:  |  Height:  |  Size: 1.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 847 B

After

Width:  |  Height:  |  Size: 503 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 720 B

After

Width:  |  Height:  |  Size: 535 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 862 B

After

Width:  |  Height:  |  Size: 541 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

After

Width:  |  Height:  |  Size: 865 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

After

Width:  |  Height:  |  Size: 934 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.2 KiB

After

Width:  |  Height:  |  Size: 997 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.5 KiB

After

Width:  |  Height:  |  Size: 2.2 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.9 KiB

After

Width:  |  Height:  |  Size: 2.6 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.7 KiB

After

Width:  |  Height:  |  Size: 2.4 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

After

Width:  |  Height:  |  Size: 788 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

After

Width:  |  Height:  |  Size: 855 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.3 KiB

After

Width:  |  Height:  |  Size: 861 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.7 KiB

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.1 KiB

After

Width:  |  Height:  |  Size: 1.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 2.1 KiB

After

Width:  |  Height:  |  Size: 1.7 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.0 KiB

After

Width:  |  Height:  |  Size: 857 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 KiB

After

Width:  |  Height:  |  Size: 915 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 998 B

After

Width:  |  Height:  |  Size: 939 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 608 B

After

Width:  |  Height:  |  Size: 415 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 551 B

After

Width:  |  Height:  |  Size: 421 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 640 B

After

Width:  |  Height:  |  Size: 425 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 948 B

After

Width:  |  Height:  |  Size: 749 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 890 B

After

Width:  |  Height:  |  Size: 773 B

Some files were not shown because too many files have changed in this diff Show More