Files
dees-domtools/ts/domtools.css.breakpoints.ts

100 lines
3.4 KiB
TypeScript
Raw Permalink Normal View History

2022-03-16 13:39:50 +01:00
import { DomTools } from './domtools.classes.domtools.js';
2020-05-27 21:15:38 +00:00
import { css, CSSResult, unsafeCSS } from 'lit';
2021-11-21 15:52:49 +01:00
2022-04-19 18:13:26 +02:00
export const desktop = 1600;
export const notebook = 1240;
2020-06-03 09:07:31 +00:00
export const tablet = 1024;
export const phablet = 600;
2020-06-01 12:30:21 +00:00
export const phone = 400;
2020-05-23 15:00:01 +00:00
2020-05-27 21:15:38 +00:00
export type TViewport = 'native' | 'desktop' | 'tablet' | 'phablet' | 'phone';
2020-05-23 15:00:01 +00:00
// ---------------------------------------------------------------------------
// Constraint-based helpers
// ---------------------------------------------------------------------------
export interface ICssForConstraints {
maxWidth?: number;
minWidth?: number;
}
const buildCondition = (constraints: ICssForConstraints): string => {
const parts: string[] = [];
if (constraints.minWidth) parts.push(`(min-width: ${constraints.minWidth}px)`);
if (constraints.maxWidth) parts.push(`(max-width: ${constraints.maxWidth}px)`);
return parts.join(' and ');
};
// ---------------------------------------------------------------------------
// Viewport-level: @container wccToolsViewport + @media
// ---------------------------------------------------------------------------
export const cssForViewport = (cssArg: CSSResult, condition: string) => {
2022-04-19 18:16:20 +02:00
return unsafeCSS(`
@container wccToolsViewport ${condition} {
2022-04-19 18:16:20 +02:00
${cssArg.cssText}
}
@media ${condition} {
2022-04-19 18:16:20 +02:00
${cssArg.cssText}
}
`);
};
// ---------------------------------------------------------------------------
// Component-level: @container <name> only
// ---------------------------------------------------------------------------
export const cssForContainer = (cssArg: CSSResult, condition: string, containerName: string) => {
2022-04-19 18:13:26 +02:00
return unsafeCSS(`
@container ${containerName} ${condition} {
2022-04-19 18:13:26 +02:00
${cssArg.cssText}
}
`);
};
// ---------------------------------------------------------------------------
// Custom constraints (curried)
// ---------------------------------------------------------------------------
export const cssForCustom = (constraints: ICssForConstraints) =>
(cssArg: CSSResult) => cssForViewport(cssArg, buildCondition(constraints));
export const cssForCustomContainer = (constraints: ICssForConstraints, containerName: string) =>
(cssArg: CSSResult) => cssForContainer(cssArg, buildCondition(constraints), containerName);
// ---------------------------------------------------------------------------
// Container context style factory — used by @containerResponsive()
// ---------------------------------------------------------------------------
export const containerContextStyles = (containerName: string) => css`
:host {
container-type: inline-size;
container-name: ${unsafeCSS(containerName)};
}
`;
// ---------------------------------------------------------------------------
// Preset viewport breakpoint helpers (existing API, unchanged behaviour)
// ---------------------------------------------------------------------------
export const cssForDesktop = (cssArg: CSSResult) => {
return cssForViewport(cssArg, `(min-width: ${desktop}px)`);
};
export const cssForNotebook = (cssArg: CSSResult) => {
return cssForViewport(cssArg, `(max-width: ${notebook}px)`);
};
2021-11-21 15:52:49 +01:00
export const cssForTablet = (cssArg: CSSResult) => {
return cssForViewport(cssArg, `(max-width: ${tablet}px)`);
2020-05-23 15:00:01 +00:00
};
2021-11-21 15:52:49 +01:00
export const cssForPhablet = (cssArg: CSSResult) => {
return cssForViewport(cssArg, `(max-width: ${phablet}px)`);
2020-05-23 15:00:01 +00:00
};
2021-11-21 15:52:49 +01:00
export const cssForPhone = (cssArg: CSSResult) => {
return cssForViewport(cssArg, `(max-width: ${phone}px)`);
2020-05-23 15:00:01 +00:00
};