@slimr/styled 2.0.2 → 2.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@slimr/styled",
3
- "version": "2.0.2",
3
+ "version": "2.0.4",
4
4
  "author": "Brian Dombrowski",
5
5
  "license": "ISC",
6
6
  "private": false,
@@ -17,31 +17,16 @@
17
17
  "url": "https://github.com/bdombro/slimr.git"
18
18
  },
19
19
  "type": "module",
20
- "main": "./src/index.cjs",
21
- "module": "./src/index.js",
22
- "types": "./src/index.ts",
23
- "exports": {
24
- ".": {
25
- "import": "./src/index.js",
26
- "require": "./src/index.cjs",
27
- "types": "./src/index.ts"
28
- },
29
- "./withHtmlTags": {
30
- "import": "./src/withHtmlTags.js",
31
- "require": "./src/withHtmlTags.cjs",
32
- "types": "./src/withHtmlTags.ts"
33
- }
34
- },
35
- "files": [
36
- "src",
37
- "README.md",
38
- "tsconfig.json"
39
- ],
20
+ "main": "./cjs/index.js",
21
+ "module": "./esm/index.js",
22
+ "types": "./esm/index.d.ts",
40
23
  "scripts": {
41
- "build": "npm run clean && tsup",
42
- "clean": "find -E ./src -regex '.*(\\.js|\\.cjs|\\.d\\.ts|\\.map)' -delete",
43
- "prepack": "npm run build && npm version patch",
44
- "postpublish": "npm run clean"
24
+ "build": "npm-run-all clean --parallel build:*",
25
+ "build:esm": "OUT=esm; tsc -d -m es2020 --outDir $OUT --noEmit false && cp -r src/* $OUT",
26
+ "build:cjs": "OUT=cjs; tsc -d -m commonjs --outDir $OUT --noEmit false && cp -r src/* $OUT",
27
+ "clean": "rm -rf esm cjs",
28
+ "lint": "tsc && eslint .",
29
+ "prepack": "run-s clean lint && npm version patch && run-s build"
45
30
  },
46
31
  "peerDependencies": {
47
32
  "@types/react": "^18",
@@ -50,6 +35,6 @@
50
35
  "react-dom": "^18"
51
36
  },
52
37
  "dependencies": {
53
- "@slimr/css": "^2.0.1"
38
+ "@slimr/css": "^2.0.7"
54
39
  }
55
40
  }
package/src/core.ts CHANGED
@@ -1,5 +1,10 @@
1
- import { createElement, CSSProperties, FC, forwardRef, HTMLAttributes } from 'react'
2
- import { classJoin, css, ShorthandProps, shorthandPropsMap, TemplateStringProps } from '@slimr/css'
1
+ /* eslint-disable prefer-const */
2
+ import {ShorthandProps, TemplateStringProps, classJoin, css, shorthandPropsMap} from '@slimr/css'
3
+
4
+ import {CSSProperties, FC, HTMLAttributes, createElement, forwardRef} from 'react'
5
+
6
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
7
+ type allowableAny = any
3
8
 
4
9
  /** A type that represents all the css properties + shorthand props */
5
10
  export interface ZxProps extends CSSProperties, ShorthandProps {}
@@ -51,16 +56,19 @@ export interface SCProps extends _Props {
51
56
  }
52
57
 
53
58
  /** Styled Component: Like FunctionalComponent but adds SCProps */
54
- export type SC<T extends { className?: HTMLAttributes<any>['className'] }> = FC<T & SCProps>
59
+ export type SC<T extends {className?: HTMLAttributes<allowableAny>['className']}> = FC<T & SCProps>
55
60
 
61
+ /** Converts a string to kebab case */
56
62
  function toKebabCase(str: string) {
57
63
  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase()
58
64
  }
59
65
 
66
+ /** Converts a string to camel case */
60
67
  function toCamelCase(str: string) {
61
- return str.replace(/-./g, (x) => x[1].toUpperCase())
68
+ return str.replace(/-./g, x => x[1].toUpperCase())
62
69
  }
63
70
 
71
+ /** Expands the shorthand props of a zx prop into css full */
64
72
  function expandShorthandProps(zx: Zx) {
65
73
  return Object.entries(zx).reduce((acc, [k, v]) => {
66
74
  if (k === 'mx') {
@@ -81,9 +89,10 @@ function expandShorthandProps(zx: Zx) {
81
89
  acc[k] = v
82
90
  }
83
91
  return acc
84
- }, {} as any)
92
+ }, {} as Record<string, allowableAny>)
85
93
  }
86
94
 
95
+ /** Converts a zx prop into css string */
87
96
  function zxToCss(zx: Zx): string {
88
97
  return Object.entries(zx)
89
98
  .map(([k, v]) => {
@@ -91,8 +100,8 @@ function zxToCss(zx: Zx): string {
91
100
  k = toKebabCase(k)
92
101
  if (typeof v === 'number') v = v + 'px'
93
102
  if (Array.isArray(v)) {
94
- // @ts-ignore
95
- v = '[' + v.map((v) => (typeof v === 'number' ? v + 'px' : v)).join(',') + ']'
103
+ // @ts-expect-error - TS gets confused by the complexity
104
+ v = '[' + v.map(v => (typeof v === 'number' ? v + 'px' : v)).join(',') + ']'
96
105
  }
97
106
  return k + ':' + v + ';'
98
107
  })
@@ -104,13 +113,13 @@ function zxToCss(zx: Zx): string {
104
113
  * @param function - a functional component to be styled; must accept a className prop
105
114
  * @returns a function that accepts a template string of css returns a decorated functional component
106
115
  */
107
- export function styledBase<C extends FC<any>>(Component: C) {
116
+ export function styledBase<C extends FC<allowableAny>>(Component: C) {
108
117
  return (...cssProps: TemplateStringProps) => {
109
118
  const className = css(...cssProps)
110
119
  /**
111
120
  * A functional component that accepts Styled Props
112
121
  */
113
- const CStyled = forwardRef((props: SCProps, ref) => {
122
+ const CStyled = forwardRef(function CStyled(props: SCProps, ref) {
114
123
  let {
115
124
  _active,
116
125
  _css,
@@ -128,9 +137,9 @@ export function styledBase<C extends FC<any>>(Component: C) {
128
137
  // Pluck out $ prefixed props
129
138
  Object.entries(props).forEach(([k, v]) => {
130
139
  if (k.startsWith('_')) {
131
- // @ts-ignore
140
+ // @ts-expect-error - We know the key exists but ts doesn't
132
141
  _zx[k.slice(1)] = v
133
- // @ts-ignore
142
+ // @ts-expect-error - We know the key exists but ts doesn't
134
143
  delete rest[k]
135
144
  }
136
145
  })
@@ -194,13 +203,13 @@ export function styledBase<C extends FC<any>>(Component: C) {
194
203
  `
195
204
  }
196
205
 
197
- const hasMediaQuery = Object.values(_zx).some((v) => Array.isArray(v))
206
+ const hasMediaQuery = Object.values(_zx).some(v => Array.isArray(v))
198
207
  // If has media query styles, use css class. Otherwise favor inline styles
199
208
  if (hasMediaQuery || cssStr) {
200
209
  cssStr = zxToCss(_zx) + cssStr
201
210
  } else {
202
211
  _zx = expandShorthandProps(_zx)
203
- rest.style = { ...rest.style, ..._zx } as CSSProperties
212
+ rest.style = {...rest.style, ..._zx} as CSSProperties
204
213
  }
205
214
 
206
215
  return createElement(Component, {
package/src/index.ts CHANGED
@@ -1,6 +1,8 @@
1
- import { FC } from 'react'
2
- import { TemplateStringProps } from '@slimr/css'
3
- import { styledBase as s } from './core.js'
1
+ import {TemplateStringProps} from '@slimr/css'
2
+
3
+ import {FC} from 'react'
4
+
5
+ import {styledBase as s} from './core.js'
4
6
 
5
7
  export * from '@slimr/css'
6
8
  export * from './core.js'
package/src/core.cjs DELETED
@@ -1,35 +0,0 @@
1
- "use strict";var P=Object.defineProperty;var S=Object.getOwnPropertyDescriptor;var b=Object.getOwnPropertyNames;var $=Object.prototype.hasOwnProperty;var T=(s,e)=>{for(var t in e)P(s,t,{get:e[t],enumerable:!0})},A=(s,e,t,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of b(e))!$.call(s,i)&&i!==t&&P(s,i,{get:()=>e[i],enumerable:!(r=S(e,i))||r.enumerable});return s};var j=s=>A(P({},"__esModule",{value:!0}),s);var z={};T(z,{styledBase:()=>w});module.exports=j(z);var p=require("react"),l=require("@slimr/css");function M(s){return s.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}function N(s){return s.replace(/-./g,e=>e[1].toUpperCase())}function L(s){return Object.entries(s).reduce((e,[t,r])=>(t==="mx"?(e.marginLeft=r,e.marginRight=r):t==="my"?(e.marginTop=r,e.marginBottom=r):t==="px"?(e.paddingLeft=r,e.paddingRight=r):t==="py"?(e.paddingTop=r,e.paddingBottom=r):t in l.shorthandPropsMap?e[N(l.shorthandPropsMap[t])]=r:e[t]=r,e),{})}function o(s){return Object.entries(s).map(([e,t])=>t?(e=M(e),typeof t=="number"&&(t=t+"px"),Array.isArray(t)&&(t="["+t.map(r=>typeof r=="number"?r+"px":r).join(",")+"]"),e+":"+t+";"):"").join(`
2
- `)}function w(s){return(...e)=>{let t=(0,l.css)(...e),r=(0,p.forwardRef)((i,h)=>{let{_active:Z,_css:u,_dark:d,_focus:m,_focusVisible:k,_focusWithin:c,_hover:y,_target:_,_visited:g,_zx:a={},...f}=i;Object.entries(i).forEach(([x,C])=>{x.startsWith("_")&&(a[x.slice(1)]=C,delete f[x])});let n="";return Z&&(n+=`
3
- &:active {
4
- ${o(Z)}
5
- }
6
- `),d&&(n+=`
7
- @media (prefers-color-scheme: dark) {
8
- ${o(d)}
9
- }
10
- `),m&&(n+=`
11
- &:focus {
12
- ${o(m)}
13
- }
14
- `),k&&(n+=`
15
- &:focus-visible {
16
- ${o(k)}
17
- }
18
- `),c&&(n+=`
19
- &:focus-within {
20
- ${o(c)}
21
- }
22
- `),y&&(n+=`
23
- &:hover {
24
- ${o(y)}
25
- }
26
- `),_&&(n+=`
27
- &:target {
28
- ${o(_)}
29
- }
30
- `),g&&(n+=`
31
- &:visited {
32
- ${o(g)}
33
- }
34
- `),Object.values(a).some(x=>Array.isArray(x))||n?n=o(a)+n:(a=L(a),f.style={...f.style,...a}),(0,p.createElement)(s,{ref:h,...f,className:(0,l.classJoin)(t,u?u.includes(":")?(0,l.css)(u):u:void 0,n?(0,l.css)(n):void 0,i.className)})});return r.toString=()=>"."+t,r}}0&&(module.exports={styledBase});
35
- //# sourceMappingURL=core.cjs.map
package/src/core.cjs.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"sources":["core.ts"],"sourcesContent":["import { createElement, CSSProperties, FC, forwardRef, HTMLAttributes } from 'react'\nimport { classJoin, css, ShorthandProps, shorthandPropsMap, TemplateStringProps } from '@slimr/css'\n\n/** A type that represents all the css properties + shorthand props */\nexport interface ZxProps extends CSSProperties, ShorthandProps {}\ntype ZxP = ZxProps\n\ntype Zx = {\n [k in keyof ZxP]:\n | ZxP[k]\n | [ZxP[k] | null, ZxP[k]]\n | [ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k], ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k], ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n}\n\ntype _Props = {\n [k in keyof Zx as `_${k}`]?: Zx[k]\n}\n\nexport interface SCProps extends _Props {\n /** Like zx prop, but applies only on :active */\n _active?: Zx\n className?: string\n /** A string of css or classname to be added to the component */\n _css?: string\n /** Like zx prop, but applies only when user prefers dark theme */\n _dark?: Zx\n /** Like zx prop, but applies only on :focus */\n _focus?: Zx\n /** Like zx prop, but applies only on :focus-visible */\n _focusVisible?: Zx\n /** Like zx prop, but applies only on :focus-within */\n _focusWithin?: Zx\n /** Like zx prop, but applies only on :hover */\n _hover?: Zx\n style?: CSSProperties\n /** Like zx prop, but applies only on :target */\n _target?: Zx\n /** Like zx prop, but applies only on :visited */\n _visited?: Zx\n /**\n * Like style prop, but enhanced with features like chakra\n * - Array values are converted to media query breakpoints\n * - Numbers are converted to px\n * - Shorthand props are supported\n */\n _zx?: Zx\n}\n\n/** Styled Component: Like FunctionalComponent but adds SCProps */\nexport type SC<T extends { className?: HTMLAttributes<any>['className'] }> = FC<T & SCProps>\n\nfunction toKebabCase(str: string) {\n return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase()\n}\n\nfunction toCamelCase(str: string) {\n return str.replace(/-./g, (x) => x[1].toUpperCase())\n}\n\nfunction expandShorthandProps(zx: Zx) {\n return Object.entries(zx).reduce((acc, [k, v]) => {\n if (k === 'mx') {\n acc.marginLeft = v\n acc.marginRight = v\n } else if (k === 'my') {\n acc.marginTop = v\n acc.marginBottom = v\n } else if (k === 'px') {\n acc.paddingLeft = v\n acc.paddingRight = v\n } else if (k === 'py') {\n acc.paddingTop = v\n acc.paddingBottom = v\n } else if (k in shorthandPropsMap) {\n acc[toCamelCase(shorthandPropsMap[k as keyof typeof shorthandPropsMap])] = v\n } else {\n acc[k] = v\n }\n return acc\n }, {} as any)\n}\n\nfunction zxToCss(zx: Zx): string {\n return Object.entries(zx)\n .map(([k, v]) => {\n if (!v) return ''\n k = toKebabCase(k)\n if (typeof v === 'number') v = v + 'px'\n if (Array.isArray(v)) {\n // @ts-ignore\n v = '[' + v.map((v) => (typeof v === 'number' ? v + 'px' : v)).join(',') + ']'\n }\n return k + ':' + v + ';'\n })\n .join('\\n')\n}\n\n/**\n * A lightweight alternative to styled-components\n * @param function - a functional component to be styled; must accept a className prop\n * @returns a function that accepts a template string of css returns a decorated functional component\n */\nexport function styledBase<C extends FC<any>>(Component: C) {\n return (...cssProps: TemplateStringProps) => {\n const className = css(...cssProps)\n /**\n * A functional component that accepts Styled Props\n */\n const CStyled = forwardRef((props: SCProps, ref) => {\n let {\n _active,\n _css,\n _dark,\n _focus,\n _focusVisible,\n _focusWithin,\n _hover,\n _target,\n _visited,\n _zx = {},\n ...rest\n } = props\n\n // Pluck out $ prefixed props\n Object.entries(props).forEach(([k, v]) => {\n if (k.startsWith('_')) {\n // @ts-ignore\n _zx[k.slice(1)] = v\n // @ts-ignore\n delete rest[k]\n }\n })\n\n let cssStr = ''\n\n if (_active) {\n cssStr += `\n &:active {\n ${zxToCss(_active)}\n }\n `\n }\n if (_dark) {\n cssStr += `\n @media (prefers-color-scheme: dark) {\n ${zxToCss(_dark)}\n }\n `\n }\n if (_focus) {\n cssStr += `\n &:focus {\n ${zxToCss(_focus)}\n }\n `\n }\n if (_focusVisible) {\n cssStr += `\n &:focus-visible {\n ${zxToCss(_focusVisible)}\n }\n `\n }\n if (_focusWithin) {\n cssStr += `\n &:focus-within {\n ${zxToCss(_focusWithin)}\n }\n `\n }\n if (_hover) {\n cssStr += `\n &:hover {\n ${zxToCss(_hover)}\n }\n `\n }\n if (_target) {\n cssStr += `\n &:target {\n ${zxToCss(_target)}\n }\n `\n }\n if (_visited) {\n cssStr += `\n &:visited {\n ${zxToCss(_visited)}\n }\n `\n }\n\n const hasMediaQuery = Object.values(_zx).some((v) => Array.isArray(v))\n // If has media query styles, use css class. Otherwise favor inline styles\n if (hasMediaQuery || cssStr) {\n cssStr = zxToCss(_zx) + cssStr\n } else {\n _zx = expandShorthandProps(_zx)\n rest.style = { ...rest.style, ..._zx } as CSSProperties\n }\n\n return createElement(Component, {\n ref,\n ...rest,\n className: classJoin(\n className,\n _css ? (_css.includes(':') ? css(_css) : _css) : undefined,\n cssStr ? css(cssStr) : undefined,\n props.className\n ),\n })\n })\n CStyled.toString = () => '.' + className\n return CStyled as unknown as SC<Parameters<C>[0]>\n }\n}\n"],"mappings":"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","names":["core_exports","__export","styledBase","__toCommonJS","import_react","import_css","toKebabCase","str","toCamelCase","x","expandShorthandProps","zx","acc","k","v","zxToCss","Component","cssProps","className","CStyled","props","ref","_active","_css","_dark","_focus","_focusVisible","_focusWithin","_hover","_target","_visited","_zx","rest","cssStr"]}
package/src/core.js DELETED
@@ -1,35 +0,0 @@
1
- import{createElement as C,forwardRef as S}from"react";import{classJoin as b,css as f,shorthandPropsMap as _}from"@slimr/css";function $(n){return n.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}function T(n){return n.replace(/-./g,e=>e[1].toUpperCase())}function A(n){return Object.entries(n).reduce((e,[t,r])=>(t==="mx"?(e.marginLeft=r,e.marginRight=r):t==="my"?(e.marginTop=r,e.marginBottom=r):t==="px"?(e.paddingLeft=r,e.paddingRight=r):t==="py"?(e.paddingTop=r,e.paddingBottom=r):t in _?e[T(_[t])]=r:e[t]=r,e),{})}function i(n){return Object.entries(n).map(([e,t])=>t?(e=$(e),typeof t=="number"&&(t=t+"px"),Array.isArray(t)&&(t="["+t.map(r=>typeof r=="number"?r+"px":r).join(",")+"]"),e+":"+t+";"):"").join(`
2
- `)}function F(n){return(...e)=>{let t=f(...e),r=S((u,g)=>{let{_active:p,_css:a,_dark:P,_focus:Z,_focusVisible:d,_focusWithin:m,_hover:k,_target:c,_visited:y,_zx:o={},...x}=u;Object.entries(u).forEach(([l,h])=>{l.startsWith("_")&&(o[l.slice(1)]=h,delete x[l])});let s="";return p&&(s+=`
3
- &:active {
4
- ${i(p)}
5
- }
6
- `),P&&(s+=`
7
- @media (prefers-color-scheme: dark) {
8
- ${i(P)}
9
- }
10
- `),Z&&(s+=`
11
- &:focus {
12
- ${i(Z)}
13
- }
14
- `),d&&(s+=`
15
- &:focus-visible {
16
- ${i(d)}
17
- }
18
- `),m&&(s+=`
19
- &:focus-within {
20
- ${i(m)}
21
- }
22
- `),k&&(s+=`
23
- &:hover {
24
- ${i(k)}
25
- }
26
- `),c&&(s+=`
27
- &:target {
28
- ${i(c)}
29
- }
30
- `),y&&(s+=`
31
- &:visited {
32
- ${i(y)}
33
- }
34
- `),Object.values(o).some(l=>Array.isArray(l))||s?s=i(o)+s:(o=A(o),x.style={...x.style,...o}),C(n,{ref:g,...x,className:b(t,a?a.includes(":")?f(a):a:void 0,s?f(s):void 0,u.className)})});return r.toString=()=>"."+t,r}}export{F as styledBase};
35
- //# sourceMappingURL=core.js.map
package/src/core.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"sources":["core.ts"],"sourcesContent":["import { createElement, CSSProperties, FC, forwardRef, HTMLAttributes } from 'react'\nimport { classJoin, css, ShorthandProps, shorthandPropsMap, TemplateStringProps } from '@slimr/css'\n\n/** A type that represents all the css properties + shorthand props */\nexport interface ZxProps extends CSSProperties, ShorthandProps {}\ntype ZxP = ZxProps\n\ntype Zx = {\n [k in keyof ZxP]:\n | ZxP[k]\n | [ZxP[k] | null, ZxP[k]]\n | [ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k], ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k], ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n}\n\ntype _Props = {\n [k in keyof Zx as `_${k}`]?: Zx[k]\n}\n\nexport interface SCProps extends _Props {\n /** Like zx prop, but applies only on :active */\n _active?: Zx\n className?: string\n /** A string of css or classname to be added to the component */\n _css?: string\n /** Like zx prop, but applies only when user prefers dark theme */\n _dark?: Zx\n /** Like zx prop, but applies only on :focus */\n _focus?: Zx\n /** Like zx prop, but applies only on :focus-visible */\n _focusVisible?: Zx\n /** Like zx prop, but applies only on :focus-within */\n _focusWithin?: Zx\n /** Like zx prop, but applies only on :hover */\n _hover?: Zx\n style?: CSSProperties\n /** Like zx prop, but applies only on :target */\n _target?: Zx\n /** Like zx prop, but applies only on :visited */\n _visited?: Zx\n /**\n * Like style prop, but enhanced with features like chakra\n * - Array values are converted to media query breakpoints\n * - Numbers are converted to px\n * - Shorthand props are supported\n */\n _zx?: Zx\n}\n\n/** Styled Component: Like FunctionalComponent but adds SCProps */\nexport type SC<T extends { className?: HTMLAttributes<any>['className'] }> = FC<T & SCProps>\n\nfunction toKebabCase(str: string) {\n return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase()\n}\n\nfunction toCamelCase(str: string) {\n return str.replace(/-./g, (x) => x[1].toUpperCase())\n}\n\nfunction expandShorthandProps(zx: Zx) {\n return Object.entries(zx).reduce((acc, [k, v]) => {\n if (k === 'mx') {\n acc.marginLeft = v\n acc.marginRight = v\n } else if (k === 'my') {\n acc.marginTop = v\n acc.marginBottom = v\n } else if (k === 'px') {\n acc.paddingLeft = v\n acc.paddingRight = v\n } else if (k === 'py') {\n acc.paddingTop = v\n acc.paddingBottom = v\n } else if (k in shorthandPropsMap) {\n acc[toCamelCase(shorthandPropsMap[k as keyof typeof shorthandPropsMap])] = v\n } else {\n acc[k] = v\n }\n return acc\n }, {} as any)\n}\n\nfunction zxToCss(zx: Zx): string {\n return Object.entries(zx)\n .map(([k, v]) => {\n if (!v) return ''\n k = toKebabCase(k)\n if (typeof v === 'number') v = v + 'px'\n if (Array.isArray(v)) {\n // @ts-ignore\n v = '[' + v.map((v) => (typeof v === 'number' ? v + 'px' : v)).join(',') + ']'\n }\n return k + ':' + v + ';'\n })\n .join('\\n')\n}\n\n/**\n * A lightweight alternative to styled-components\n * @param function - a functional component to be styled; must accept a className prop\n * @returns a function that accepts a template string of css returns a decorated functional component\n */\nexport function styledBase<C extends FC<any>>(Component: C) {\n return (...cssProps: TemplateStringProps) => {\n const className = css(...cssProps)\n /**\n * A functional component that accepts Styled Props\n */\n const CStyled = forwardRef((props: SCProps, ref) => {\n let {\n _active,\n _css,\n _dark,\n _focus,\n _focusVisible,\n _focusWithin,\n _hover,\n _target,\n _visited,\n _zx = {},\n ...rest\n } = props\n\n // Pluck out $ prefixed props\n Object.entries(props).forEach(([k, v]) => {\n if (k.startsWith('_')) {\n // @ts-ignore\n _zx[k.slice(1)] = v\n // @ts-ignore\n delete rest[k]\n }\n })\n\n let cssStr = ''\n\n if (_active) {\n cssStr += `\n &:active {\n ${zxToCss(_active)}\n }\n `\n }\n if (_dark) {\n cssStr += `\n @media (prefers-color-scheme: dark) {\n ${zxToCss(_dark)}\n }\n `\n }\n if (_focus) {\n cssStr += `\n &:focus {\n ${zxToCss(_focus)}\n }\n `\n }\n if (_focusVisible) {\n cssStr += `\n &:focus-visible {\n ${zxToCss(_focusVisible)}\n }\n `\n }\n if (_focusWithin) {\n cssStr += `\n &:focus-within {\n ${zxToCss(_focusWithin)}\n }\n `\n }\n if (_hover) {\n cssStr += `\n &:hover {\n ${zxToCss(_hover)}\n }\n `\n }\n if (_target) {\n cssStr += `\n &:target {\n ${zxToCss(_target)}\n }\n `\n }\n if (_visited) {\n cssStr += `\n &:visited {\n ${zxToCss(_visited)}\n }\n `\n }\n\n const hasMediaQuery = Object.values(_zx).some((v) => Array.isArray(v))\n // If has media query styles, use css class. Otherwise favor inline styles\n if (hasMediaQuery || cssStr) {\n cssStr = zxToCss(_zx) + cssStr\n } else {\n _zx = expandShorthandProps(_zx)\n rest.style = { ...rest.style, ..._zx } as CSSProperties\n }\n\n return createElement(Component, {\n ref,\n ...rest,\n className: classJoin(\n className,\n _css ? (_css.includes(':') ? css(_css) : _css) : undefined,\n cssStr ? css(cssStr) : undefined,\n props.className\n ),\n })\n })\n CStyled.toString = () => '.' + className\n return CStyled as unknown as SC<Parameters<C>[0]>\n }\n}\n"],"mappings":"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","names":["createElement","forwardRef","classJoin","css","shorthandPropsMap","toKebabCase","str","toCamelCase","x","expandShorthandProps","zx","acc","k","v","zxToCss","styledBase","Component","cssProps","className","CStyled","props","ref","_active","_css","_dark","_focus","_focusVisible","_focusWithin","_hover","_target","_visited","_zx","rest","cssStr"]}
package/src/index.cjs DELETED
@@ -1,35 +0,0 @@
1
- "use strict";var F=Object.defineProperty;var _=Object.getOwnPropertyDescriptor;var $=Object.getOwnPropertyNames;var j=Object.prototype.hasOwnProperty;var A=(s,e)=>{for(var n in e)F(s,n,{get:e[n],enumerable:!0})},d=(s,e,n,t)=>{if(e&&typeof e=="object"||typeof e=="function")for(let r of $(e))!j.call(s,r)&&r!==n&&F(s,r,{get:()=>e[r],enumerable:!(t=_(e,r))||t.enumerable});return s},l=(s,e,n)=>(d(s,e,"default"),n&&d(n,e,"default"));var q=s=>d(F({},"__esModule",{value:!0}),s);var o={};A(o,{styled:()=>L,styledBase:()=>a});module.exports=q(o);var C=require("react"),T=require("@slimr/css");function M(s){return s.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}function N(s){return s.replace(/-./g,e=>e[1].toUpperCase())}function w(s){return Object.entries(s).reduce((e,[n,t])=>(n==="mx"?(e.marginLeft=t,e.marginRight=t):n==="my"?(e.marginTop=t,e.marginBottom=t):n==="px"?(e.paddingLeft=t,e.paddingRight=t):n==="py"?(e.paddingTop=t,e.paddingBottom=t):n in T.shorthandPropsMap?e[N(T.shorthandPropsMap[n])]=t:e[n]=t,e),{})}function u(s){return Object.entries(s).map(([e,n])=>n?(e=M(e),typeof n=="number"&&(n=n+"px"),Array.isArray(n)&&(n="["+n.map(t=>typeof t=="number"?t+"px":t).join(",")+"]"),e+":"+n+";"):"").join(`
2
- `)}function a(s){return(...e)=>{let n=(0,T.css)(...e),t=(0,C.forwardRef)((r,Z)=>{let{_active:H,_css:p,_dark:m,_focus:f,_focusVisible:x,_focusWithin:c,_hover:b,_target:g,_visited:h,_zx:i={},...S}=r;Object.entries(r).forEach(([k,y])=>{k.startsWith("_")&&(i[k.slice(1)]=y,delete S[k])});let P="";return H&&(P+=`
3
- &:active {
4
- ${u(H)}
5
- }
6
- `),m&&(P+=`
7
- @media (prefers-color-scheme: dark) {
8
- ${u(m)}
9
- }
10
- `),f&&(P+=`
11
- &:focus {
12
- ${u(f)}
13
- }
14
- `),x&&(P+=`
15
- &:focus-visible {
16
- ${u(x)}
17
- }
18
- `),c&&(P+=`
19
- &:focus-within {
20
- ${u(c)}
21
- }
22
- `),b&&(P+=`
23
- &:hover {
24
- ${u(b)}
25
- }
26
- `),g&&(P+=`
27
- &:target {
28
- ${u(g)}
29
- }
30
- `),h&&(P+=`
31
- &:visited {
32
- ${u(h)}
33
- }
34
- `),Object.values(i).some(k=>Array.isArray(k))||P?P=u(i)+P:(i=w(i),S.style={...S.style,...i}),(0,C.createElement)(s,{ref:Z,...S,className:(0,T.classJoin)(n,p?p.includes(":")?(0,T.css)(p):p:void 0,P?(0,T.css)(P):void 0,r.className)})});return t.toString=()=>"."+n,t}}l(o,require("@slimr/css"),module.exports);var L=Object.assign(a,{a:(...s)=>a("a")(...s),abbr:(...s)=>a("abbr")(...s),address:(...s)=>a("address")(...s),area:(...s)=>a("area")(...s),article:(...s)=>a("article")(...s),aside:(...s)=>a("aside")(...s),audio:(...s)=>a("audio")(...s),b:(...s)=>a("b")(...s),blockquote:(...s)=>a("blockquote")(...s),br:(...s)=>a("br")(...s),button:(...s)=>a("button")(...s),caption:(...s)=>a("caption")(...s),cite:(...s)=>a("cite")(...s),code:(...s)=>a("code")(...s),col:(...s)=>a("col")(...s),colgroup:(...s)=>a("colgroup")(...s),dd:(...s)=>a("dd")(...s),del:(...s)=>a("del")(...s),details:(...s)=>a("details")(...s),dfn:(...s)=>a("dfn")(...s),dialog:(...s)=>a("dialog")(...s),div:(...s)=>a("div")(...s),dl:(...s)=>a("dl")(...s),dt:(...s)=>a("dt")(...s),em:(...s)=>a("em")(...s),embed:(...s)=>a("embed")(...s),fieldset:(...s)=>a("fieldset")(...s),figcaption:(...s)=>a("figcaption")(...s),figure:(...s)=>a("figure")(...s),footer:(...s)=>a("footer")(...s),form:(...s)=>a("form")(...s),h1:(...s)=>a("h1")(...s),h2:(...s)=>a("h2")(...s),h3:(...s)=>a("h3")(...s),h4:(...s)=>a("h4")(...s),h5:(...s)=>a("h5")(...s),h6:(...s)=>a("h6")(...s),header:(...s)=>a("header")(...s),hgroup:(...s)=>a("hgroup")(...s),hr:(...s)=>a("hr")(...s),i:(...s)=>a("i")(...s),iframe:(...s)=>a("iframe")(...s),img:(...s)=>a("img")(...s),input:(...s)=>a("input")(...s),ins:(...s)=>a("ins")(...s),kbd:(...s)=>a("kbd")(...s),label:(...s)=>a("label")(...s),legend:(...s)=>a("legend")(...s),li:(...s)=>a("li")(...s),main:(...s)=>a("main")(...s),map:(...s)=>a("map")(...s),mark:(...s)=>a("mark")(...s),meter:(...s)=>a("meter")(...s),nav:(...s)=>a("nav")(...s),object:(...s)=>a("object")(...s),ol:(...s)=>a("ol")(...s),optgroup:(...s)=>a("optgroup")(...s),option:(...s)=>a("option")(...s),output:(...s)=>a("output")(...s),p:(...s)=>a("p")(...s),picture:(...s)=>a("picture")(...s),pre:(...s)=>a("pre")(...s),progress:(...s)=>a("progress")(...s),q:(...s)=>a("q")(...s),rp:(...s)=>a("rp")(...s),rt:(...s)=>a("rt")(...s),ruby:(...s)=>a("ruby")(...s),s:(...s)=>a("s")(...s),samp:(...s)=>a("samp")(...s),section:(...s)=>a("section")(...s),select:(...s)=>a("select")(...s),small:(...s)=>a("small")(...s),span:(...s)=>a("span")(...s),strong:(...s)=>a("strong")(...s),sub:(...s)=>a("sub")(...s),summary:(...s)=>a("summary")(...s),sup:(...s)=>a("sup")(...s),table:(...s)=>a("table")(...s),tbody:(...s)=>a("tbody")(...s),td:(...s)=>a("td")(...s),textarea:(...s)=>a("textarea")(...s),tfoot:(...s)=>a("tfoot")(...s),th:(...s)=>a("th")(...s),thead:(...s)=>a("thead")(...s),time:(...s)=>a("time")(...s),tr:(...s)=>a("tr")(...s),u:(...s)=>a("u")(...s),ul:(...s)=>a("ul")(...s),video:(...s)=>a("video")(...s)});0&&(module.exports={styled,styledBase});
35
- //# sourceMappingURL=index.cjs.map
package/src/index.cjs.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"sources":["index.ts","core.ts"],"sourcesContent":["import { FC } from 'react'\nimport { TemplateStringProps } from '@slimr/css'\nimport { styledBase as s } from './core.js'\n\nexport * from '@slimr/css'\nexport * from './core.js'\n\n/** Shorthand type */\ntype unk = unknown\n/** Shorthand type */\ntype TSP = TemplateStringProps\n/** Shorthand type */\ntype HTP = JSX.IntrinsicElements\n\nexport const styled = Object.assign(s, {\n /** creates a 'a' component with css applied */\n a: (...p: TSP) => s('a' as unk as FC<HTP['a']>)(...p),\n /** creates a 'abbr' component with css applied */\n abbr: (...p: TSP) => s('abbr' as unk as FC<HTP['abbr']>)(...p),\n /** creates a 'address' component with css applied */\n address: (...p: TSP) => s('address' as unk as FC<HTP['address']>)(...p),\n /** creates a 'area' component with css applied */\n area: (...p: TSP) => s('area' as unk as FC<HTP['area']>)(...p),\n /** creates a 'article' component with css applied */\n article: (...p: TSP) => s('article' as unk as FC<HTP['article']>)(...p),\n /** creates a 'aside' component with css applied */\n aside: (...p: TSP) => s('aside' as unk as FC<HTP['aside']>)(...p),\n /** creates a 'audio' component with css applied */\n audio: (...p: TSP) => s('audio' as unk as FC<HTP['audio']>)(...p),\n /** creates a 'b' component with css applied */\n b: (...p: TSP) => s('b' as unk as FC<HTP['b']>)(...p),\n /** creates a 'big' component with css applied; Deprecated so left out */\n // big: (...p: TSP) => styled('big' as unk as FC<HTP['big']>)(...p),\n /** creates a 'blockquote' component with css applied */\n blockquote: (...p: TSP) => s('blockquote' as unk as FC<HTP['blockquote']>)(...p),\n /** creates a 'body' component with css applied; omitted bc doesnt seem useful */\n // body: (...p: TSP) => styled('body' as unk as FC<HTP['body']>)(...p),\n /** creates a 'br' component with css applied; omitted bc doesnt seem useful */\n br: (...p: TSP) => s('br' as unk as FC<HTP['br']>)(...p),\n /** creates a 'button' component with css applied */\n button: (...p: TSP) => s('button' as unk as FC<HTP['button']>)(...p),\n /** creates a 'caption' component with css applied */\n caption: (...p: TSP) => s('caption' as unk as FC<HTP['caption']>)(...p),\n /** creates a 'cite' component with css applied */\n cite: (...p: TSP) => s('cite' as unk as FC<HTP['cite']>)(...p),\n /** creates a 'code' component with css applied */\n code: (...p: TSP) => s('code' as unk as FC<HTP['code']>)(...p),\n /** creates a 'col' component with css applied */\n col: (...p: TSP) => s('col' as unk as FC<HTP['col']>)(...p),\n /** creates a 'colgroup' component with css applied */\n colgroup: (...p: TSP) => s('colgroup' as unk as FC<HTP['colgroup']>)(...p),\n /** creates a 'dd' component with css applied */\n dd: (...p: TSP) => s('dd' as unk as FC<HTP['dd']>)(...p),\n /** creates a 'del' component with css applied */\n del: (...p: TSP) => s('del' as unk as FC<HTP['del']>)(...p),\n /** creates a 'details' component with css applied */\n details: (...p: TSP) => s('details' as unk as FC<HTP['details']>)(...p),\n /** creates a 'dfn' component with css applied */\n dfn: (...p: TSP) => s('dfn' as unk as FC<HTP['dfn']>)(...p),\n /** creates a 'dialog' component with css applied */\n dialog: (...p: TSP) => s('dialog' as unk as FC<HTP['dialog']>)(...p),\n /** creates a 'div' component with css applied */\n div: (...p: TSP) => s('div' as unk as FC<HTP['div']>)(...p),\n /** creates a 'dl' component with css applied */\n dl: (...p: TSP) => s('dl' as unk as FC<HTP['dl']>)(...p),\n /** creates a 'dt' component with css applied */\n dt: (...p: TSP) => s('dt' as unk as FC<HTP['dt']>)(...p),\n /** creates a 'em' component with css applied */\n em: (...p: TSP) => s('em' as unk as FC<HTP['em']>)(...p),\n /** creates a 'embed' component with css applied */\n embed: (...p: TSP) => s('embed' as unk as FC<HTP['embed']>)(...p),\n /** creates a 'fieldset' component with css applied */\n fieldset: (...p: TSP) => s('fieldset' as unk as FC<HTP['fieldset']>)(...p),\n /** creates a 'figcaption' component with css applied */\n figcaption: (...p: TSP) => s('figcaption' as unk as FC<HTP['figcaption']>)(...p),\n /** creates a 'figure' component with css applied */\n figure: (...p: TSP) => s('figure' as unk as FC<HTP['figure']>)(...p),\n /** creates a 'footer' component with css applied */\n footer: (...p: TSP) => s('footer' as unk as FC<HTP['footer']>)(...p),\n /** creates a 'form' component with css applied */\n form: (...p: TSP) => s('form' as unk as FC<HTP['form']>)(...p),\n /** creates a 'h1' component with css applied */\n h1: (...p: TSP) => s('h1' as unk as FC<HTP['h1']>)(...p),\n /** creates a 'h2' component with css applied */\n h2: (...p: TSP) => s('h2' as unk as FC<HTP['h2']>)(...p),\n /** creates a 'h3' component with css applied */\n h3: (...p: TSP) => s('h3' as unk as FC<HTP['h3']>)(...p),\n /** creates a 'h4' component with css applied */\n h4: (...p: TSP) => s('h4' as unk as FC<HTP['h4']>)(...p),\n /** creates a 'h5' component with css applied */\n h5: (...p: TSP) => s('h5' as unk as FC<HTP['h5']>)(...p),\n /** creates a 'h6' component with css applied */\n h6: (...p: TSP) => s('h6' as unk as FC<HTP['h6']>)(...p),\n /** creates a 'header' component with css applied */\n header: (...p: TSP) => s('header' as unk as FC<HTP['header']>)(...p),\n /** creates a 'hgroup' component with css applied */\n hgroup: (...p: TSP) => s('hgroup' as unk as FC<HTP['hgroup']>)(...p),\n /** creates a 'hr' component with css applied */\n hr: (...p: TSP) => s('hr' as unk as FC<HTP['hr']>)(...p),\n /** creates a 'i' component with css applied */\n i: (...p: TSP) => s('i' as unk as FC<HTP['i']>)(...p),\n /** creates a 'iframe' component with css applied */\n iframe: (...p: TSP) => s('iframe' as unk as FC<HTP['iframe']>)(...p),\n /** creates a 'img' component with css applied */\n img: (...p: TSP) => s('img' as unk as FC<HTP['img']>)(...p),\n /** creates a 'input' component with css applied */\n input: (...p: TSP) => s('input' as unk as FC<HTP['input']>)(...p),\n /** creates a 'ins' component with css applied */\n ins: (...p: TSP) => s('ins' as unk as FC<HTP['ins']>)(...p),\n /** creates a 'kbd' component with css applied */\n kbd: (...p: TSP) => s('kbd' as unk as FC<HTP['kbd']>)(...p),\n /** creates a 'label' component with css applied */\n label: (...p: TSP) => s('label' as unk as FC<HTP['label']>)(...p),\n /** creates a 'legend' component with css applied */\n legend: (...p: TSP) => s('legend' as unk as FC<HTP['legend']>)(...p),\n /** creates a 'li' component with css applied */\n li: (...p: TSP) => s('li' as unk as FC<HTP['li']>)(...p),\n /** creates a 'main' component with css applied */\n main: (...p: TSP) => s('main' as unk as FC<HTP['main']>)(...p),\n /** creates a 'map' component with css applied */\n map: (...p: TSP) => s('map' as unk as FC<HTP['map']>)(...p),\n /** creates a 'mark' component with css applied */\n mark: (...p: TSP) => s('mark' as unk as FC<HTP['mark']>)(...p),\n /** creates a 'meter' component with css applied */\n meter: (...p: TSP) => s('meter' as unk as FC<HTP['meter']>)(...p),\n /** creates a 'nav' component with css applied */\n nav: (...p: TSP) => s('nav' as unk as FC<HTP['nav']>)(...p),\n /** creates a 'object' component with css applied */\n object: (...p: TSP) => s('object' as unk as FC<HTP['object']>)(...p),\n /** creates a 'ol' component with css applied */\n ol: (...p: TSP) => s('ol' as unk as FC<HTP['ol']>)(...p),\n /** creates a 'optgroup' component with css applied */\n optgroup: (...p: TSP) => s('optgroup' as unk as FC<HTP['optgroup']>)(...p),\n /** creates a 'option' component with css applied */\n option: (...p: TSP) => s('option' as unk as FC<HTP['option']>)(...p),\n /** creates a 'output' component with css applied */\n output: (...p: TSP) => s('output' as unk as FC<HTP['output']>)(...p),\n /** creates a 'p' component with css applied */\n p: (...p: TSP) => s('p' as unk as FC<HTP['p']>)(...p),\n /** creates a 'picture' component with css applied */\n picture: (...p: TSP) => s('picture' as unk as FC<HTP['picture']>)(...p),\n /** creates a 'pre' component with css applied */\n pre: (...p: TSP) => s('pre' as unk as FC<HTP['pre']>)(...p),\n /** creates a 'progress' component with css applied */\n progress: (...p: TSP) => s('progress' as unk as FC<HTP['progress']>)(...p),\n /** creates a 'q' component with css applied */\n q: (...p: TSP) => s('q' as unk as FC<HTP['q']>)(...p),\n /** creates a 'rp' component with css applied */\n rp: (...p: TSP) => s('rp' as unk as FC<HTP['rp']>)(...p),\n /** creates a 'rt' component with css applied */\n rt: (...p: TSP) => s('rt' as unk as FC<HTP['rt']>)(...p),\n /** creates a 'ruby' component with css applied */\n ruby: (...p: TSP) => s('ruby' as unk as FC<HTP['ruby']>)(...p),\n /** creates a 's' component with css applied */\n s: (...p: TSP) => s('s' as unk as FC<HTP['s']>)(...p),\n /** creates a 'samp' component with css applied */\n samp: (...p: TSP) => s('samp' as unk as FC<HTP['samp']>)(...p),\n /** creates a 'section' component with css applied */\n section: (...p: TSP) => s('section' as unk as FC<HTP['section']>)(...p),\n /** creates a 'select' component with css applied */\n select: (...p: TSP) => s('select' as unk as FC<HTP['select']>)(...p),\n /** creates a 'small' component with css applied */\n small: (...p: TSP) => s('small' as unk as FC<HTP['small']>)(...p),\n /** creates a 'span' component with css applied */\n span: (...p: TSP) => s('span' as unk as FC<HTP['span']>)(...p),\n /** creates a 'strong' component with css applied */\n strong: (...p: TSP) => s('strong' as unk as FC<HTP['strong']>)(...p),\n /** creates a 'sub' component with css applied */\n sub: (...p: TSP) => s('sub' as unk as FC<HTP['sub']>)(...p),\n /** creates a 'summary' component with css applied */\n summary: (...p: TSP) => s('summary' as unk as FC<HTP['summary']>)(...p),\n /** creates a 'sup' component with css applied */\n sup: (...p: TSP) => s('sup' as unk as FC<HTP['sup']>)(...p),\n /** creates a 'table' component with css applied */\n table: (...p: TSP) => s('table' as unk as FC<HTP['table']>)(...p),\n /** creates a 'tbody' component with css applied */\n tbody: (...p: TSP) => s('tbody' as unk as FC<HTP['tbody']>)(...p),\n /** creates a 'td' component with css applied */\n td: (...p: TSP) => s('td' as unk as FC<HTP['td']>)(...p),\n /** creates a 'textarea' component with css applied */\n textarea: (...p: TSP) => s('textarea' as unk as FC<HTP['textarea']>)(...p),\n /** creates a 'tfoot' component with css applied */\n tfoot: (...p: TSP) => s('tfoot' as unk as FC<HTP['tfoot']>)(...p),\n /** creates a 'th' component with css applied */\n th: (...p: TSP) => s('th' as unk as FC<HTP['th']>)(...p),\n /** creates a 'thead' component with css applied */\n thead: (...p: TSP) => s('thead' as unk as FC<HTP['thead']>)(...p),\n /** creates a 'time' component with css applied */\n time: (...p: TSP) => s('time' as unk as FC<HTP['time']>)(...p),\n /** creates a 'tr' component with css applied */\n tr: (...p: TSP) => s('tr' as unk as FC<HTP['tr']>)(...p),\n /** creates a 'u' component with css applied */\n u: (...p: TSP) => s('u' as unk as FC<HTP['u']>)(...p),\n /** creates a 'ul' component with css applied */\n ul: (...p: TSP) => s('ul' as unk as FC<HTP['ul']>)(...p),\n /** creates a 'video' component with css applied */\n video: (...p: TSP) => s('video' as unk as FC<HTP['video']>)(...p),\n})\n","import { createElement, CSSProperties, FC, forwardRef, HTMLAttributes } from 'react'\nimport { classJoin, css, ShorthandProps, shorthandPropsMap, TemplateStringProps } from '@slimr/css'\n\n/** A type that represents all the css properties + shorthand props */\nexport interface ZxProps extends CSSProperties, ShorthandProps {}\ntype ZxP = ZxProps\n\ntype Zx = {\n [k in keyof ZxP]:\n | ZxP[k]\n | [ZxP[k] | null, ZxP[k]]\n | [ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k], ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n | [ZxP[k], ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k] | null, ZxP[k]]\n}\n\ntype _Props = {\n [k in keyof Zx as `_${k}`]?: Zx[k]\n}\n\nexport interface SCProps extends _Props {\n /** Like zx prop, but applies only on :active */\n _active?: Zx\n className?: string\n /** A string of css or classname to be added to the component */\n _css?: string\n /** Like zx prop, but applies only when user prefers dark theme */\n _dark?: Zx\n /** Like zx prop, but applies only on :focus */\n _focus?: Zx\n /** Like zx prop, but applies only on :focus-visible */\n _focusVisible?: Zx\n /** Like zx prop, but applies only on :focus-within */\n _focusWithin?: Zx\n /** Like zx prop, but applies only on :hover */\n _hover?: Zx\n style?: CSSProperties\n /** Like zx prop, but applies only on :target */\n _target?: Zx\n /** Like zx prop, but applies only on :visited */\n _visited?: Zx\n /**\n * Like style prop, but enhanced with features like chakra\n * - Array values are converted to media query breakpoints\n * - Numbers are converted to px\n * - Shorthand props are supported\n */\n _zx?: Zx\n}\n\n/** Styled Component: Like FunctionalComponent but adds SCProps */\nexport type SC<T extends { className?: HTMLAttributes<any>['className'] }> = FC<T & SCProps>\n\nfunction toKebabCase(str: string) {\n return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase()\n}\n\nfunction toCamelCase(str: string) {\n return str.replace(/-./g, (x) => x[1].toUpperCase())\n}\n\nfunction expandShorthandProps(zx: Zx) {\n return Object.entries(zx).reduce((acc, [k, v]) => {\n if (k === 'mx') {\n acc.marginLeft = v\n acc.marginRight = v\n } else if (k === 'my') {\n acc.marginTop = v\n acc.marginBottom = v\n } else if (k === 'px') {\n acc.paddingLeft = v\n acc.paddingRight = v\n } else if (k === 'py') {\n acc.paddingTop = v\n acc.paddingBottom = v\n } else if (k in shorthandPropsMap) {\n acc[toCamelCase(shorthandPropsMap[k as keyof typeof shorthandPropsMap])] = v\n } else {\n acc[k] = v\n }\n return acc\n }, {} as any)\n}\n\nfunction zxToCss(zx: Zx): string {\n return Object.entries(zx)\n .map(([k, v]) => {\n if (!v) return ''\n k = toKebabCase(k)\n if (typeof v === 'number') v = v + 'px'\n if (Array.isArray(v)) {\n // @ts-ignore\n v = '[' + v.map((v) => (typeof v === 'number' ? v + 'px' : v)).join(',') + ']'\n }\n return k + ':' + v + ';'\n })\n .join('\\n')\n}\n\n/**\n * A lightweight alternative to styled-components\n * @param function - a functional component to be styled; must accept a className prop\n * @returns a function that accepts a template string of css returns a decorated functional component\n */\nexport function styledBase<C extends FC<any>>(Component: C) {\n return (...cssProps: TemplateStringProps) => {\n const className = css(...cssProps)\n /**\n * A functional component that accepts Styled Props\n */\n const CStyled = forwardRef((props: SCProps, ref) => {\n let {\n _active,\n _css,\n _dark,\n _focus,\n _focusVisible,\n _focusWithin,\n _hover,\n _target,\n _visited,\n _zx = {},\n ...rest\n } = props\n\n // Pluck out $ prefixed props\n Object.entries(props).forEach(([k, v]) => {\n if (k.startsWith('_')) {\n // @ts-ignore\n _zx[k.slice(1)] = v\n // @ts-ignore\n delete rest[k]\n }\n })\n\n let cssStr = ''\n\n if (_active) {\n cssStr += `\n &:active {\n ${zxToCss(_active)}\n }\n `\n }\n if (_dark) {\n cssStr += `\n @media (prefers-color-scheme: dark) {\n ${zxToCss(_dark)}\n }\n `\n }\n if (_focus) {\n cssStr += `\n &:focus {\n ${zxToCss(_focus)}\n }\n `\n }\n if (_focusVisible) {\n cssStr += `\n &:focus-visible {\n ${zxToCss(_focusVisible)}\n }\n `\n }\n if (_focusWithin) {\n cssStr += `\n &:focus-within {\n ${zxToCss(_focusWithin)}\n }\n `\n }\n if (_hover) {\n cssStr += `\n &:hover {\n ${zxToCss(_hover)}\n }\n `\n }\n if (_target) {\n cssStr += `\n &:target {\n ${zxToCss(_target)}\n }\n `\n }\n if (_visited) {\n cssStr += `\n &:visited {\n ${zxToCss(_visited)}\n }\n `\n }\n\n const hasMediaQuery = Object.values(_zx).some((v) => Array.isArray(v))\n // If has media query styles, use css class. Otherwise favor inline styles\n if (hasMediaQuery || cssStr) {\n cssStr = zxToCss(_zx) + cssStr\n } else {\n _zx = expandShorthandProps(_zx)\n rest.style = { ...rest.style, ..._zx } as CSSProperties\n }\n\n return createElement(Component, {\n ref,\n ...rest,\n className: classJoin(\n className,\n _css ? (_css.includes(':') ? css(_css) : _css) : undefined,\n cssStr ? css(cssStr) : undefined,\n props.className\n ),\n })\n })\n CStyled.toString = () => '.' + className\n return CStyled as unknown as SC<Parameters<C>[0]>\n }\n}\n"],"mappings":"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","names":["src_exports","__export","styled","styledBase","__toCommonJS","import_react","import_css","toKebabCase","str","toCamelCase","x","expandShorthandProps","zx","acc","k","v","zxToCss","styledBase","Component","cssProps","className","CStyled","props","ref","_active","_css","_dark","_focus","_focusVisible","_focusWithin","_hover","_target","_visited","_zx","rest","cssStr","__reExport","src_exports","styled","styledBase","p"]}
package/src/index.d.ts DELETED
@@ -1,189 +0,0 @@
1
- import { styledBase, SC } from './core.js';
2
- export { SCProps, ZxProps } from './core.js';
3
- import * as react from 'react';
4
- export * from '@slimr/css';
5
-
6
- declare const styled: typeof styledBase & {
7
- /** creates a 'a' component with css applied */
8
- a: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.AnchorHTMLAttributes<HTMLAnchorElement>, HTMLAnchorElement>>;
9
- /** creates a 'abbr' component with css applied */
10
- abbr: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
11
- /** creates a 'address' component with css applied */
12
- address: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
13
- /** creates a 'area' component with css applied */
14
- area: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.AreaHTMLAttributes<HTMLAreaElement>, HTMLAreaElement>>;
15
- /** creates a 'article' component with css applied */
16
- article: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
17
- /** creates a 'aside' component with css applied */
18
- aside: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
19
- /** creates a 'audio' component with css applied */
20
- audio: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.AudioHTMLAttributes<HTMLAudioElement>, HTMLAudioElement>>;
21
- /** creates a 'b' component with css applied */
22
- b: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
23
- /** creates a 'big' component with css applied; Deprecated so left out */
24
- /** creates a 'blockquote' component with css applied */
25
- blockquote: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.BlockquoteHTMLAttributes<HTMLQuoteElement>, HTMLQuoteElement>>;
26
- /** creates a 'body' component with css applied; omitted bc doesnt seem useful */
27
- /** creates a 'br' component with css applied; omitted bc doesnt seem useful */
28
- br: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLBRElement>, HTMLBRElement>>;
29
- /** creates a 'button' component with css applied */
30
- button: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>>;
31
- /** creates a 'caption' component with css applied */
32
- caption: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
33
- /** creates a 'cite' component with css applied */
34
- cite: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
35
- /** creates a 'code' component with css applied */
36
- code: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
37
- /** creates a 'col' component with css applied */
38
- col: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.ColHTMLAttributes<HTMLTableColElement>, HTMLTableColElement>>;
39
- /** creates a 'colgroup' component with css applied */
40
- colgroup: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.ColgroupHTMLAttributes<HTMLTableColElement>, HTMLTableColElement>>;
41
- /** creates a 'dd' component with css applied */
42
- dd: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
43
- /** creates a 'del' component with css applied */
44
- del: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.DelHTMLAttributes<HTMLModElement>, HTMLModElement>>;
45
- /** creates a 'details' component with css applied */
46
- details: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.DetailsHTMLAttributes<HTMLDetailsElement>, HTMLDetailsElement>>;
47
- /** creates a 'dfn' component with css applied */
48
- dfn: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
49
- /** creates a 'dialog' component with css applied */
50
- dialog: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.DialogHTMLAttributes<HTMLDialogElement>, HTMLDialogElement>>;
51
- /** creates a 'div' component with css applied */
52
- div: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLDivElement>, HTMLDivElement>>;
53
- /** creates a 'dl' component with css applied */
54
- dl: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLDListElement>, HTMLDListElement>>;
55
- /** creates a 'dt' component with css applied */
56
- dt: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
57
- /** creates a 'em' component with css applied */
58
- em: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
59
- /** creates a 'embed' component with css applied */
60
- embed: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.EmbedHTMLAttributes<HTMLEmbedElement>, HTMLEmbedElement>>;
61
- /** creates a 'fieldset' component with css applied */
62
- fieldset: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.FieldsetHTMLAttributes<HTMLFieldSetElement>, HTMLFieldSetElement>>;
63
- /** creates a 'figcaption' component with css applied */
64
- figcaption: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
65
- /** creates a 'figure' component with css applied */
66
- figure: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
67
- /** creates a 'footer' component with css applied */
68
- footer: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
69
- /** creates a 'form' component with css applied */
70
- form: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.FormHTMLAttributes<HTMLFormElement>, HTMLFormElement>>;
71
- /** creates a 'h1' component with css applied */
72
- h1: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>>;
73
- /** creates a 'h2' component with css applied */
74
- h2: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>>;
75
- /** creates a 'h3' component with css applied */
76
- h3: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>>;
77
- /** creates a 'h4' component with css applied */
78
- h4: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>>;
79
- /** creates a 'h5' component with css applied */
80
- h5: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>>;
81
- /** creates a 'h6' component with css applied */
82
- h6: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>>;
83
- /** creates a 'header' component with css applied */
84
- header: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
85
- /** creates a 'hgroup' component with css applied */
86
- hgroup: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
87
- /** creates a 'hr' component with css applied */
88
- hr: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLHRElement>, HTMLHRElement>>;
89
- /** creates a 'i' component with css applied */
90
- i: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
91
- /** creates a 'iframe' component with css applied */
92
- iframe: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.IframeHTMLAttributes<HTMLIFrameElement>, HTMLIFrameElement>>;
93
- /** creates a 'img' component with css applied */
94
- img: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.ImgHTMLAttributes<HTMLImageElement>, HTMLImageElement>>;
95
- /** creates a 'input' component with css applied */
96
- input: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>>;
97
- /** creates a 'ins' component with css applied */
98
- ins: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.InsHTMLAttributes<HTMLModElement>, HTMLModElement>>;
99
- /** creates a 'kbd' component with css applied */
100
- kbd: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
101
- /** creates a 'label' component with css applied */
102
- label: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.LabelHTMLAttributes<HTMLLabelElement>, HTMLLabelElement>>;
103
- /** creates a 'legend' component with css applied */
104
- legend: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLLegendElement>, HTMLLegendElement>>;
105
- /** creates a 'li' component with css applied */
106
- li: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.LiHTMLAttributes<HTMLLIElement>, HTMLLIElement>>;
107
- /** creates a 'main' component with css applied */
108
- main: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
109
- /** creates a 'map' component with css applied */
110
- map: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.MapHTMLAttributes<HTMLMapElement>, HTMLMapElement>>;
111
- /** creates a 'mark' component with css applied */
112
- mark: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
113
- /** creates a 'meter' component with css applied */
114
- meter: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.MeterHTMLAttributes<HTMLMeterElement>, HTMLMeterElement>>;
115
- /** creates a 'nav' component with css applied */
116
- nav: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
117
- /** creates a 'object' component with css applied */
118
- object: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.ObjectHTMLAttributes<HTMLObjectElement>, HTMLObjectElement>>;
119
- /** creates a 'ol' component with css applied */
120
- ol: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.OlHTMLAttributes<HTMLOListElement>, HTMLOListElement>>;
121
- /** creates a 'optgroup' component with css applied */
122
- optgroup: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.OptgroupHTMLAttributes<HTMLOptGroupElement>, HTMLOptGroupElement>>;
123
- /** creates a 'option' component with css applied */
124
- option: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.OptionHTMLAttributes<HTMLOptionElement>, HTMLOptionElement>>;
125
- /** creates a 'output' component with css applied */
126
- output: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.OutputHTMLAttributes<HTMLOutputElement>, HTMLOutputElement>>;
127
- /** creates a 'p' component with css applied */
128
- p: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLParagraphElement>, HTMLParagraphElement>>;
129
- /** creates a 'picture' component with css applied */
130
- picture: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
131
- /** creates a 'pre' component with css applied */
132
- pre: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLPreElement>, HTMLPreElement>>;
133
- /** creates a 'progress' component with css applied */
134
- progress: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.ProgressHTMLAttributes<HTMLProgressElement>, HTMLProgressElement>>;
135
- /** creates a 'q' component with css applied */
136
- q: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.QuoteHTMLAttributes<HTMLQuoteElement>, HTMLQuoteElement>>;
137
- /** creates a 'rp' component with css applied */
138
- rp: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
139
- /** creates a 'rt' component with css applied */
140
- rt: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
141
- /** creates a 'ruby' component with css applied */
142
- ruby: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
143
- /** creates a 's' component with css applied */
144
- s: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
145
- /** creates a 'samp' component with css applied */
146
- samp: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
147
- /** creates a 'section' component with css applied */
148
- section: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
149
- /** creates a 'select' component with css applied */
150
- select: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.SelectHTMLAttributes<HTMLSelectElement>, HTMLSelectElement>>;
151
- /** creates a 'small' component with css applied */
152
- small: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
153
- /** creates a 'span' component with css applied */
154
- span: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>>;
155
- /** creates a 'strong' component with css applied */
156
- strong: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
157
- /** creates a 'sub' component with css applied */
158
- sub: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
159
- /** creates a 'summary' component with css applied */
160
- summary: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
161
- /** creates a 'sup' component with css applied */
162
- sup: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
163
- /** creates a 'table' component with css applied */
164
- table: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.TableHTMLAttributes<HTMLTableElement>, HTMLTableElement>>;
165
- /** creates a 'tbody' component with css applied */
166
- tbody: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLTableSectionElement>, HTMLTableSectionElement>>;
167
- /** creates a 'td' component with css applied */
168
- td: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.TdHTMLAttributes<HTMLTableDataCellElement>, HTMLTableDataCellElement>>;
169
- /** creates a 'textarea' component with css applied */
170
- textarea: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.TextareaHTMLAttributes<HTMLTextAreaElement>, HTMLTextAreaElement>>;
171
- /** creates a 'tfoot' component with css applied */
172
- tfoot: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLTableSectionElement>, HTMLTableSectionElement>>;
173
- /** creates a 'th' component with css applied */
174
- th: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.ThHTMLAttributes<HTMLTableHeaderCellElement>, HTMLTableHeaderCellElement>>;
175
- /** creates a 'thead' component with css applied */
176
- thead: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLTableSectionElement>, HTMLTableSectionElement>>;
177
- /** creates a 'time' component with css applied */
178
- time: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.TimeHTMLAttributes<HTMLTimeElement>, HTMLTimeElement>>;
179
- /** creates a 'tr' component with css applied */
180
- tr: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLTableRowElement>, HTMLTableRowElement>>;
181
- /** creates a 'u' component with css applied */
182
- u: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLElement>, HTMLElement>>;
183
- /** creates a 'ul' component with css applied */
184
- ul: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.HTMLAttributes<HTMLUListElement>, HTMLUListElement>>;
185
- /** creates a 'video' component with css applied */
186
- video: (strings: string | TemplateStringsArray, ...placeHolders: string[]) => SC<react.DetailedHTMLProps<react.VideoHTMLAttributes<HTMLVideoElement>, HTMLVideoElement>>;
187
- };
188
-
189
- export { SC, styled, styledBase };