Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(theme): introduce new *-container-minimum theme colors, and ad… #441

Merged
merged 2 commits into from
Dec 7, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
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
Loading