Skip to content

Commit

Permalink
feat(theme): introduce new *-container-minimum theme colors, and ad… (
Browse files Browse the repository at this point in the history
  • Loading branch information
DRiFTy17 authored Dec 7, 2023
1 parent d1ab4d5 commit cc6b063
Show file tree
Hide file tree
Showing 11 changed files with 50 additions and 18 deletions.
2 changes: 1 addition & 1 deletion src/dev/pages/icon-button/icon-button.ejs
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@
<forge-circular-progress aria-label="Tonal with circular progress"></forge-circular-progress>
</forge-icon-button>

<forge-icon-button variant="Filled">
<forge-icon-button variant="filled">
<forge-circular-progress aria-label="Filled with circular progress"></forge-circular-progress>
</forge-icon-button>

Expand Down
4 changes: 4 additions & 0 deletions src/dev/pages/theme/theme.scss
Original file line number Diff line number Diff line change
@@ -1,3 +1,7 @@
.content .card {
max-width: 1075px;
}

.swatches {
display: flex;
flex-direction: column;
Expand Down
11 changes: 10 additions & 1 deletion src/dev/pages/theme/theme.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ const SWATCH_GROUPS: ISwatchGroup[] = [
{
swatches: [
{ text: 'Surface container', background: 'surface-container', foreground: 'on-surface-container' },
{ text: 'Surface container (minimum)', background: 'surface-container-minimum', foreground: 'on-surface' },
{ text: 'Surface container (low)', background: 'surface-container-low', foreground: 'on-surface' },
{ text: 'Surface container (medium)', background: 'surface-container-medium', foreground: 'on-surface' },
{ text: 'Surface container (high)', background: 'surface-container-high', foreground: 'on-surface-container-high' }
Expand All @@ -40,6 +41,7 @@ const SWATCH_GROUPS: ISwatchGroup[] = [
header: 'Key colors',
swatches: [
{ text: 'Primary', background: 'primary', foreground: 'on-primary' },
{ text: 'Primary container (minimum)', background: 'primary-container-minimum', foreground: 'on-primary-container-minimum' },
{ text: 'Primary container (low)', background: 'primary-container-low', foreground: 'on-primary-container-low' },
{ text: 'Primary container', background: 'primary-container', foreground: 'on-primary-container' },
{ text: 'Primary container (high)', background: 'primary-container-high', foreground: 'on-primary-container-high' }
Expand All @@ -48,6 +50,7 @@ const SWATCH_GROUPS: ISwatchGroup[] = [
{
swatches: [
{ text: 'Secondary', background: 'secondary', foreground: 'on-secondary' },
{ text: 'Secondary container (minimum)', background: 'secondary-container-minimum', foreground: 'on-secondary-container-minimum' },
{ text: 'Secondary container (low)', background: 'secondary-container-low', foreground: 'on-secondary-container-low'},
{ text: 'Secondary container', background: 'secondary-container', foreground: 'on-secondary-container' },
{ text: 'Secondary container (high)', background: 'secondary-container-high', foreground: 'on-secondary-container-high' }
Expand All @@ -56,6 +59,7 @@ const SWATCH_GROUPS: ISwatchGroup[] = [
{
swatches: [
{ text: 'Tertiary', background: 'tertiary', foreground: 'on-tertiary' },
{ text: 'Tertiary container (minimum)', background: 'tertiary-container-minimum', foreground: 'on-tertiary-container-minimum' },
{ text: 'Tertiary container (low)', background: 'tertiary-container-low', foreground: 'on-tertiary-container-low' },
{ text: 'Tertiary container', background: 'tertiary-container', foreground: 'on-tertiary-container' },
{ text: 'Tertiary container (high)', background: 'tertiary-container-high', foreground: 'on-tertiary-container-high' }
Expand All @@ -65,6 +69,7 @@ const SWATCH_GROUPS: ISwatchGroup[] = [
header: 'Status',
swatches: [
{ text: 'Success', background: 'success', foreground: 'on-success' },
{ text: 'Success container (minimum)', background: 'success-container-minimum', foreground: 'on-success-container-minimum' },
{ text: 'Success container (low)', background: 'success-container-low', foreground: 'on-success-container-low' },
{ text: 'Success container', background: 'success-container', foreground: 'on-success-container' },
{ text: 'Success container (high)', background: 'success-container-high', foreground: 'on-success-container-high' }
Expand All @@ -73,6 +78,7 @@ const SWATCH_GROUPS: ISwatchGroup[] = [
{
swatches: [
{ text: 'Error ', background: 'error', foreground: 'on-error' },
{ text: 'Error container (minimum)', background: 'error-container-minimum', foreground: 'on-error-container-minimum' },
{ text: 'Error container (low)', background: 'error-container-low', foreground: 'on-error-container-low' },
{ text: 'Error container', background: 'error-container', foreground: 'on-error-container' },
{ text: 'Error container (high)', background: 'error-container-high', foreground: 'on-error-container-high' }
Expand All @@ -81,6 +87,7 @@ const SWATCH_GROUPS: ISwatchGroup[] = [
{
swatches: [
{ text: 'Warning', background: 'warning', foreground: 'on-warning' },
{ text: 'Warning container (minimum)', background: 'warning-container-minimum', foreground: 'on-warning-container-minimum' },
{ text: 'Warning container (low)', background: 'warning-container-low', foreground: 'on-warning-container-low' },
{ text: 'Warning container', background: 'warning-container', foreground: 'on-warning-container' },
{ text: 'Warning container (high)', background: 'warning-container-high', foreground: 'on-warning-container-high' }
Expand All @@ -89,6 +96,7 @@ const SWATCH_GROUPS: ISwatchGroup[] = [
{
swatches: [
{ text: 'Info', background: 'info', foreground: 'on-info' },
{ text: 'Info container (minimum)', background: 'info-container-minimum', foreground: 'on-info-container-minimum' },
{ text: 'Info container (low)', background: 'info-container-low', foreground: 'on-info-container-low' },
{ text: 'Info container', background: 'info-container', foreground: 'on-info-container' },
{ text: 'Info container (high)', background: 'info-container-high', foreground: 'on-info-container-high' }
Expand All @@ -106,7 +114,8 @@ const SWATCH_GROUPS: ISwatchGroup[] = [
{
header: 'Utilities',
swatches: [
{ text: 'Outline', background: 'outline', foreground: 'text-high' }
{ text: 'Outline', background: 'outline', foreground: 'text-high' },
{ text: 'Outline (high)', background: 'outline-high', foreground: 'text-high-inverse' }
]
}
];
Expand Down
6 changes: 5 additions & 1 deletion src/lib/circular-progress/circular-progress.scss
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,11 @@ svg {
@include theme(warning);
@include theme(info);

:host([track]) {
//
// Track
//

:host(:is([track],[determinate])) {
.forge-circular-progress {
@include override(track-color, track-fill-color);
}
Expand Down
5 changes: 5 additions & 0 deletions src/lib/core/base/base-adapter.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ export interface IBaseAdapter<T extends HTMLElement = HTMLElement> {
setBodyAttribute(name: string, value: string): void;
removeBodyAttribute(name: string): void;
focusHost(options?: FocusOptions): void;
clickHost(): void;
}

export class BaseAdapter<T extends IBaseComponent> implements IBaseAdapter {
Expand Down Expand Up @@ -127,6 +128,10 @@ export class BaseAdapter<T extends IBaseComponent> implements IBaseAdapter {
HTMLElement.prototype.focus.call(this._component, options);
}

public clickHost(): void {
HTMLElement.prototype.click.call(this._component);
}

public get isConnected(): boolean {
return this._component.isConnected;
}
Expand Down
6 changes: 3 additions & 3 deletions src/lib/core/styles/tokens/_token-utils.scss
Original file line number Diff line number Diff line change
Expand Up @@ -86,11 +86,11 @@
@mixin tokens($module, $tokens, $includes: null, $excludes: null) {
@if ($includes) {
// We are including only specific tokens
@each $token in $includes {
@if (not map.has-key($tokens, $token)) {
@each $token-name in $includes {
@if (not map.has-key($tokens, $token-name)) {
@error 'Invalid include token "#{$token}" for module "#{$module}"';
}
#{declare($module, $token)}: #{map.get($tokens, $token)};
#{declare($module, $token-name)}: #{map.get($tokens, $token-name)};
}
} @else {
// We are including all tokens, but first we need to check if any excluded tokens were provided
Expand Down
4 changes: 4 additions & 0 deletions src/lib/core/styles/tokens/theme/_token-utils.scss
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
$surface-tone: color-utils.tone($surface);

// The container colors are the provided color mixed with the surface color at lower emphasis levels
$container-minimum: theme-utils.hexify($color, $surface, color-emphasis.value(if($surface-tone == 'light', minimum, lowest)));
$container-low: theme-utils.hexify($color, $surface, color-emphasis.value(if($surface-tone == 'light', lower, low)));
$container: theme-utils.hexify($color, $surface, color-emphasis.value(if($surface-tone == 'light', low, medium-low)));
$container-high: theme-utils.hexify($color, $surface, color-emphasis.value(if($surface-tone == 'light', medium-low, medium)));
Expand All @@ -28,16 +29,19 @@
// The on-container colors are the contrast color for the provided color mixed with the
// container color at a lower emphasis to let the contrast color bleed through for
// increased contrast against the lower emphasis container color
$on-container-minimum: theme-utils.hexify($color, theme-utils.contrast($container-minimum), color-emphasis.value(medium));
$on-container-low: theme-utils.hexify($color, theme-utils.contrast($container-low), color-emphasis.value(medium));
$on-container: theme-utils.hexify($color, theme-utils.contrast($container), color-emphasis.value(medium));
$on-container-high: theme-utils.contrast($container-high);

@return (
#{$name}: $color,
#{$name}-container-minimum: $container-minimum,
#{$name}-container-low: $container-low,
#{$name}-container: $container,
#{$name}-container-high: $container-high,
on-#{$name}: $on-color,
on-#{$name}-container-minimum: $on-container-minimum,
on-#{$name}-container-low: $on-container-low,
on-#{$name}-container: $on-container,
on-#{$name}-container-high: $on-container-high
Expand Down
3 changes: 3 additions & 0 deletions src/lib/core/styles/tokens/theme/_tokens.surface.scss
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@
$surface-inverse: theme-utils.hexify($on-surface, $surface, color-emphasis.value(inverse));

$surface-container: theme-utils.hexify($on-surface, $surface, color-emphasis.value(lower));
$surface-container-minimum: theme-utils.hexify($on-surface, $surface, color-emphasis.value(minimum));
$surface-container-low: theme-utils.hexify($on-surface, $surface, color-emphasis.value(lowest));
$surface-container-medium: theme-utils.hexify($on-surface, $surface, color-emphasis.value(if($surface-tone == 'light', low, medium-low)));
$surface-container-high: theme-utils.hexify($on-surface, $surface, color-emphasis.value(if($surface-tone == 'light', medium-low, medium)));
Expand All @@ -26,6 +27,7 @@
surface: $surface,
surface-inverse: $surface-inverse,
surface-container: $surface-container,
surface-container-minimum: $surface-container-minimum,
surface-container-low: $surface-container-low,
surface-container-medium: $surface-container-medium,
surface-container-high: $surface-container-high,
Expand All @@ -35,6 +37,7 @@
on-surface: $on-surface,
on-surface-inverse: theme-utils.contrast($surface-inverse),
on-surface-container: theme-utils.contrast($surface-container),
on-surface-container-minimum: theme-utils.contrast($surface-container-minimum),
on-surface-container-low: theme-utils.contrast($surface-container-low),
on-surface-container-medium: theme-utils.contrast($surface-container-medium),
on-surface-container-high: theme-utils.contrast($surface-container-high)
Expand Down
3 changes: 2 additions & 1 deletion src/lib/core/styles/tokens/theme/_tokens.utilities.scss
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,8 @@
$on-surface: map.get($surface-theme, on-surface);

@return (
outline: theme-utils.hexify($on-surface, $surface, color-emphasis.value(lower))
outline: theme-utils.hexify($on-surface, $surface, color-emphasis.value(lower)),
outline-high: theme-utils.hexify($on-surface, $surface, color-emphasis.value(medium))
);
}

Expand Down
4 changes: 1 addition & 3 deletions src/lib/menu/menu.ts
Original file line number Diff line number Diff line change
Expand Up @@ -52,9 +52,7 @@ declare global {
name: MENU_CONSTANTS.elementName,
dependencies: [
PopupComponent,
ListComponent,
CircularProgressComponent,
LinearProgressComponent
ListComponent
]
})
export class MenuComponent extends ListDropdownAware implements IMenuComponent {
Expand Down
20 changes: 12 additions & 8 deletions src/lib/state-layer/state-layer-foundation.ts
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,10 @@ export class StateLayerFoundation implements IStateLayerFoundation {
public initialize(): void {
this._adapter.trySetTarget(this._target);

// Clicks could be triggered programmatically so we need to listen for them regardless
// of deferred initialization status
this._adapter.addTargetListener('click', this._clickListener);

// We defer initialization until the first pointerenter event is received.
//
// This is a performance optimization to avoid attaching many listeners to the target element
Expand Down Expand Up @@ -77,7 +81,6 @@ export class StateLayerFoundation implements IStateLayerFoundation {
this._adapter.addTargetListener('pointerdown', this._pointerDownListener);
this._adapter.addTargetListener('pointerup', this._pointerUpListener);
this._adapter.addTargetListener('pointercancel', this._pointerCancelListener);
this._adapter.addTargetListener('click', this._clickListener);
this._adapter.addTargetListener('contextmenu', this._contextmenuListener);
this._attached = true;
}
Expand Down Expand Up @@ -246,10 +249,10 @@ export class StateLayerFoundation implements IStateLayerFoundation {
}
public set targetElement(el: HTMLElement | null) {
// Always remove the listeners from the previous target element
if (this._attached) {
this._removeListeners();
} else {
// If unattached destroy the defer listener to recreate on the new target element
this._removeListeners();

// If unattached destroy the defer listener to recreate on the new target element
if (!this._attached) {
this._adapter.destroy();
this._deferred = false;
}
Expand All @@ -270,9 +273,10 @@ export class StateLayerFoundation implements IStateLayerFoundation {
this._target = value;

if (this._adapter.isConnected) {
if (this._attached) {
this._removeListeners();
} else {
// Always remove the listeners from the previous target element
this._removeListeners();

if (!this._attached) {
this._adapter.destroy();
this._deferred = false;
}
Expand Down

0 comments on commit cc6b063

Please sign in to comment.