Files
react/components/css-baseline/css-baseline.tsx
witt 299f7741ea chore: release v2.2.0 (#602)
* feat(slider): add option to hide slider value (#494)

* feat(slider): hideValue prop added

* test(slider): test added for hideValue prop

docs(slider): add hideValue prop

docs(slider): add hideValue prop for cn docs

feat(slider): ensure the dot stays round when no content

test(slider): update snapshots

* feat(loading): apply width & height props (#500)

* feat(loading): apply width & height props

* test(loading): test case added & updating snapshots

* fix(loading): add a string type for size prop

test(loading): update test case & snapshots

* feat(loading): support custom the ratio of spaces

* docs(loading): append size and spaceRatio

test(loading): update snapshots

Co-authored-by: unix <unix.bio@gmail.com>

* chore(deps): update styled-jsx to ^3.3.1 (#520)

* chore(deps): update styled-jsx to ^3.3.1

update styled-jsx to ^3.3.1 to allow compatiblity with react@^17

* fix(modules): fix 695-issue to compatible with React 17

* docs: fix module error caused by styled-jsx update

Co-authored-by: unix <unix.bio@gmail.com>

* chore: release v2.2.0-rc.0

* fix(modal): disable backdrop even if actions missing (#532)

* fix: upgrade to be compatible with React-17's event system (#533)

* feat: useKeyboard hooks (#541)

* feat(keyboard): create keyboard hooks

* feat(usekeyboard): redesign event handler to match keyboard events from browser

\

* test(usekeyboard): add testcase

* docs(usekeyboard): create new hooks document

* chore: release v2.2.0-rc.1

* feat(auto-complete): add forwardRef for input element (#542)

* feat(auto-complete): add forwardRef for input element

* test(auto-complete): add testcase to ensure ref is available

* docs(auto-complete): append props for ref

* chore: release v2.2.0-rc.2

* fix(auto-complete): fix size of loading icon (#546)

* chore: release v2.2.0-rc.3

* fix(auto-complete): hide shadow when no content (#547)

* chore: release v2.2.0-rc.4

* feat: add status prop in checkbox, radio, select, slider and toggle (#530)

* feat: added status prop to set color by states

test: check status success, warning and error

* docs: added playground example and API reference

fix: replaced ´_´ as it's not recommended to use

fix: removed redundant return

refactor: renamed prop from status to type

test: update test with the renamed prop

* docs: update prop references from status to type

fix: status prop not updated to type

fix: missing return

* fix(select): set icons and hover state to follow the theme

* test(slider): update snapshots

* chore: always use relative paths when import types

Co-authored-by: unix <unix.bio@gmail.com>

* feat(auto-complete): add props for popup container (#558)

* feat(auto-complete): add props for popup container

* docs(auto-complete): add attribute for popup container

* chore: release v2.2.0-rc.5

* fix: fix path error under esm

* chore: release v2.2.0-rc.6

* feat(scaleable): add scaleable props to each component (#531)

* feat(scaleable): add scaleable props to each component

* chore(scaleable): update the exported type

* feat: apply scaleable to components

chore: remove with-default

test: improve testcase for scaleable

chore: resolve test warning

ci: upgrade nodejs to latest lts

docs: fix type error in document site

* docs: update documents to be compatible with scaleable

chore: fix build errors

* chore: remove all size-related attributes

docs: improve guide document

* docs: add scaleable documentation

test: update snapshots

chore: remove unused

* feat: add scaleable to grid components

* docs: improve docs

* test: update snapshots

* fix(grid): fix basic component props

* feat: export all types related to components (#562)

* feat: export all types related to components

fix(tooltip): fix the vertical offset of the arrow

* refactor: optimize events of all popup related components

* test: append testcases for popup base component

* test: add testcase for visible events

* test: update snapshots

* fix(bundle): fix modules missing in yarn berry (#563)

* chore: add peer dependencies

* fix(bundle): fix modules missing in yarn berry

* chore: upgrade configs for jest 27

* chore(examples): upgrade next examples for scaleable (#564)

* chore: release v2.2.0-rc.7

* feat(rating): a new component rating indicator (#543)

* chore(deps): bump lodash from 4.17.20 to 4.17.21 (#537)

Bumps [lodash](https://github.com/lodash/lodash) from 4.17.20 to 4.17.21.
- [Release notes](https://github.com/lodash/lodash/releases)
- [Commits](https://github.com/lodash/lodash/compare/4.17.20...4.17.21)

Signed-off-by: dependabot[bot] <support@github.com>

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>

* (feature) rating state working and islocked working

* (feature) custom emojis for the ratings added

* refactor(rating): migrate component to scaleable

* feat(rating): use inline icon component

test(rating): update testcase

* docs(rating): add document for zh-cn

Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: unix <unix.bio@gmail.com>

* refactor(table): redesign interfaces to improve the experience in TypeScript (#569)

* refactor(table): redesign interfaces to improve the experience in TypeScript

* docs: upgrade to new type exports

* style: fix lint warnings

* docs: fix sidebar text-transform (#570)

* docs: improve the copywriting content of the document (#571)

* docs: export individual style types for each component

* docs: improve the copywriting content of the document

* docs: optimize the document site experience on mobile devices

* chore: release v2.2.0-rc.8

* feat(modal): responds to keyboard events when modal is displayed (#574)

* docs: redesign mobile navigation (#576)

* docs: redesign mobile navigation

* docs: fix subheading active color

* fix(avatar): fix margin on first child (#578)

Co-authored-by: witt <unix.bio@gmail.com>

* feat(select): imporve the focus events to export simulated ref (#579)

* feat(select): imporve the focus events to export simulated ref

* test: improve testcase and fix warnings

* docs(select): add label and divider to props docs

* fix: rename hymlType to htmlType (#599)

* feat(drawer): create component (#575)

* feat(drawer): create component

* feat(drawer): refinement of drawer component

* test: update tool chain for jest

* test: simplify events case for jest

* docs(drawer): add playground

* docs(drawer): add api docs

* docs: add home page (#573)

* docs: add home page

* docs(homepage): apply suggestions from code review

* docs(homepage): make cards clickable

Co-authored-by: witt <unix.bio@gmail.com>

* test: update snapshots for scaleable

* chore: update lock file

* chore: upgrade styled-jsx

* test: update snapshots for styled-jsx

Co-authored-by: Deepankar <deep14bhade@gmail.com>
Co-authored-by: Deepankar <statisticsaffinity@gmail.com>
Co-authored-by: Florian Levis <levis.florian@gmail.com>
Co-authored-by: gepd <guillermoepd@hotmail.com>
Co-authored-by: Nils J <nils.jorek@gmx.de>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
Co-authored-by: Ofek Ashery <ofek.ashery@gmail.com>
Co-authored-by: Sanna Jammeh <50969683+sannajammeh@users.noreply.github.com>
2021-08-13 17:31:45 +08:00

314 lines
6.8 KiB
TypeScript
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

import React from 'react'
import useTheme from '../use-theme'
import flush from 'styled-jsx/server'
import flushToReact from 'styled-jsx/server'
const CssBaseline: React.FC<React.PropsWithChildren<unknown>> = ({ children }) => {
const theme = useTheme()
return (
<>
{children}
<style global jsx>{`
html,
body {
background-color: ${theme.palette.background};
color: ${theme.palette.foreground};
}
html {
font-size: 16px;
--geist-icons-background: ${theme.palette.background};
}
body {
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-rendering: optimizeLegibility;
font-size: 1rem;
line-height: 1.5;
margin: 0;
padding: 0;
min-height: 100%;
position: relative;
overflow-x: hidden;
font-family: ${theme.font.sans};
}
#__next {
overflow-x: hidden;
}
*,
*:before,
*:after {
box-sizing: inherit;
text-rendering: geometricPrecision;
-webkit-tap-highlight-color: transparent;
}
p,
small {
font-weight: 400;
color: inherit;
letter-spacing: -0.005625em;
font-family: ${theme.font.sans};
}
p {
margin: 1em 0;
font-size: 1em;
line-height: 1.625em;
}
small {
margin: 0;
line-height: 1.5;
font-size: 0.875em;
}
b {
font-weight: 600;
}
span {
font-size: inherit;
color: inherit;
font-weight: inherit;
}
img {
max-width: 100%;
}
a {
cursor: pointer;
font-size: inherit;
-webkit-touch-callout: none;
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
-webkit-box-align: center;
align-items: center;
color: ${theme.palette.link};
text-decoration: ${theme.expressiveness.linkStyle};
}
a:hover {
text-decoration: ${theme.expressiveness.linkHoverStyle};
}
ul,
ol {
padding: 0;
list-style-type: none;
margin: ${theme.layout.gapHalf} ${theme.layout.gapHalf} ${theme.layout.gapHalf}
${theme.layout.gap};
color: ${theme.palette.foreground};
}
ol {
list-style-type: decimal;
}
li {
margin-bottom: 0.625em;
font-size: 1em;
line-height: 1.625em;
}
ul li:before {
content: '';
display: inline-block;
color: ${theme.palette.accents_4};
position: absolute;
margin-left: -0.9375em;
}
h1,
h2,
h3,
h4,
h5,
h6 {
color: inherit;
margin: 0 0 0.7rem 0;
}
h1 {
font-size: 3rem;
letter-spacing: -0.02em;
line-height: 1.5;
font-weight: 700;
}
h2 {
font-size: 2.25rem;
letter-spacing: -0.02em;
font-weight: 600;
}
h3 {
font-size: 1.5rem;
letter-spacing: -0.02em;
font-weight: 600;
}
h4 {
font-size: 1.25rem;
letter-spacing: -0.02em;
font-weight: 600;
}
h5 {
font-size: 1rem;
letter-spacing: -0.01em;
font-weight: 600;
}
h6 {
font-size: 0.875rem;
letter-spacing: -0.005em;
font-weight: 600;
}
button,
input,
select,
textarea {
font-family: inherit;
font-size: inherit;
line-height: inherit;
color: inherit;
margin: 0;
}
button:focus,
input:focus,
select:focus,
textarea:focus {
outline: none;
}
code {
color: ${theme.palette.code};
font-family: ${theme.font.mono};
font-size: 0.9em;
white-space: pre-wrap;
}
code:before,
code:after {
content: '\`';
}
pre {
padding: calc(${theme.layout.gap} * 0.75) ${theme.layout.gap};
margin: ${theme.layout.gap} 0;
border: 1px solid ${theme.palette.accents_2};
border-radius: ${theme.layout.radius};
font-family: ${theme.font.mono};
white-space: pre;
overflow: auto;
line-height: 1.5;
text-align: left;
font-size: 13px;
-webkit-overflow-scrolling: touch;
}
pre code {
color: ${theme.palette.foreground};
font-size: 0.8125rem;
line-height: 1.25em;
white-space: pre;
}
pre code:before,
pre code:after {
display: none;
}
pre :global(p) {
margin: 0;
}
pre::-webkit-scrollbar {
display: none;
width: 0;
height: 0;
background: transparent;
}
hr {
border-color: ${theme.palette.accents_2};
}
details {
background-color: ${theme.palette.accents_1};
border: none;
}
details:focus,
details:hover,
details:active {
outline: none;
}
summary {
cursor: pointer;
user-select: none;
list-style: none;
outline: none;
}
summary::marker,
summary::before {
display: none;
}
summary::-moz-list-bullet {
font-size: 0;
}
summary:focus,
summary:hover,
summary:active {
outline: none;
list-style: none;
}
blockquote {
padding: calc(0.667 * ${theme.layout.gap}) ${theme.layout.gap};
color: ${theme.palette.accents_5};
background-color: ${theme.palette.accents_1};
border-radius: ${theme.layout.radius};
margin: 1.5em 0;
border: 1px solid ${theme.palette.border};
}
blockquote :global(*:first-child) {
margin-top: 0;
}
blockquote :global(*:last-child) {
margin-bottom: 0;
}
::selection {
background-color: ${theme.palette.selection};
color: ${theme.palette.foreground};
}
`}</style>
</>
)
}
type MemoCssBaselineComponent<P = {}> = React.NamedExoticComponent<P> & {
flush: typeof flushToReact
}
const MemoCssBaseline = React.memo(CssBaseline) as MemoCssBaselineComponent<
React.PropsWithChildren<unknown>
>
MemoCssBaseline.flush = flush
export default MemoCssBaseline