Skip to content

Commit 13ffada

Browse files
committed
🎉 feat: use ui react
1 parent d2ce3dc commit 13ffada

File tree

14 files changed

+264
-0
lines changed

14 files changed

+264
-0
lines changed

packages/@react/components/index.tsx

Whitespace-only changes.

packages/@react/index.html

+13
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
<!DOCTYPE html>
2+
<html lang="en">
3+
<head>
4+
<meta charset="UTF-8" />
5+
<link rel="icon" type="image/svg+xml" href="./public/vite.svg" />
6+
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
7+
<title>Use UI React</title>
8+
</head>
9+
<body>
10+
<div id="root"></div>
11+
<script type="module" src="/sample/main.tsx"></script>
12+
</body>
13+
</html>

packages/@react/package.json

+29
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,29 @@
1+
{
2+
"name": "@use-ui/react",
3+
"version": "0.0.0",
4+
"description": "",
5+
"type": "module",
6+
"files": [
7+
"dist"
8+
],
9+
"main": "./dist/use-ui.umd.cjs",
10+
"module": "./dist/use-ui.js",
11+
"exports": {
12+
".": {
13+
"import": "./dist/use-ui.js",
14+
"require": "./dist/use-ui.umd.cjs"
15+
}
16+
},
17+
"scripts": {
18+
"dev": "vite",
19+
"build": "tsc && vite build"
20+
},
21+
"devDependencies": {
22+
"unocss": "^0.45.7",
23+
"vite-plugin-dts": "^1.4.1",
24+
"vite-plugin-libcss": "^1.0.5"
25+
},
26+
"keywords": [],
27+
"author": "akashi",
28+
"license": "MIT"
29+
}

packages/@react/public/vite.svg

+1
Loading

packages/@react/sample/App.css

+41
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,41 @@
1+
#root {
2+
max-width: 1280px;
3+
margin: 0 auto;
4+
padding: 2rem;
5+
text-align: center;
6+
}
7+
8+
.logo {
9+
height: 6em;
10+
padding: 1.5em;
11+
will-change: filter;
12+
}
13+
.logo:hover {
14+
filter: drop-shadow(0 0 2em #646cffaa);
15+
}
16+
.logo.react:hover {
17+
filter: drop-shadow(0 0 2em #61dafbaa);
18+
}
19+
20+
@keyframes logo-spin {
21+
from {
22+
transform: rotate(0deg);
23+
}
24+
to {
25+
transform: rotate(360deg);
26+
}
27+
}
28+
29+
@media (prefers-reduced-motion: no-preference) {
30+
a:nth-of-type(2) .logo {
31+
animation: logo-spin infinite 20s linear;
32+
}
33+
}
34+
35+
.card {
36+
padding: 2em;
37+
}
38+
39+
.read-the-docs {
40+
color: #888;
41+
}

packages/@react/sample/App.tsx

+21
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
import { useState } from 'react'
2+
import reactLogo from './assets/react.svg'
3+
import './App.css'
4+
5+
function App() {
6+
return (
7+
<div className="App">
8+
<div>
9+
<a href="https://vitejs.dev" target="_blank">
10+
<img src="/vite.svg" className="logo" alt="Vite logo" />
11+
</a>
12+
<a href="https://reactjs.org" target="_blank">
13+
<img src={reactLogo} className="logo react" alt="React logo" />
14+
</a>
15+
</div>
16+
<h1>Vite + React</h1>
17+
</div>
18+
)
19+
}
20+
21+
export default App
+1
Loading

packages/@react/sample/index.css

+70
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
:root {
2+
font-family: Inter, Avenir, Helvetica, Arial, sans-serif;
3+
font-size: 16px;
4+
line-height: 24px;
5+
font-weight: 400;
6+
7+
color-scheme: light dark;
8+
color: rgba(255, 255, 255, 0.87);
9+
background-color: #242424;
10+
11+
font-synthesis: none;
12+
text-rendering: optimizeLegibility;
13+
-webkit-font-smoothing: antialiased;
14+
-moz-osx-font-smoothing: grayscale;
15+
-webkit-text-size-adjust: 100%;
16+
}
17+
18+
a {
19+
font-weight: 500;
20+
color: #646cff;
21+
text-decoration: inherit;
22+
}
23+
a:hover {
24+
color: #535bf2;
25+
}
26+
27+
body {
28+
margin: 0;
29+
display: flex;
30+
place-items: center;
31+
min-width: 320px;
32+
min-height: 100vh;
33+
}
34+
35+
h1 {
36+
font-size: 3.2em;
37+
line-height: 1.1;
38+
}
39+
40+
button {
41+
border-radius: 8px;
42+
border: 1px solid transparent;
43+
padding: 0.6em 1.2em;
44+
font-size: 1em;
45+
font-weight: 500;
46+
font-family: inherit;
47+
background-color: #1a1a1a;
48+
cursor: pointer;
49+
transition: border-color 0.25s;
50+
}
51+
button:hover {
52+
border-color: #646cff;
53+
}
54+
button:focus,
55+
button:focus-visible {
56+
outline: 4px auto -webkit-focus-ring-color;
57+
}
58+
59+
@media (prefers-color-scheme: light) {
60+
:root {
61+
color: #213547;
62+
background-color: #ffffff;
63+
}
64+
a:hover {
65+
color: #747bff;
66+
}
67+
button {
68+
background-color: #f9f9f9;
69+
}
70+
}

packages/@react/sample/main.tsx

+10
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,10 @@
1+
import React from 'react'
2+
import ReactDOM from 'react-dom/client'
3+
import App from './App'
4+
import './index.css'
5+
6+
ReactDOM.createRoot(document.getElementById('root') as HTMLElement).render(
7+
<React.StrictMode>
8+
<App />
9+
</React.StrictMode>
10+
)

packages/@react/sample/vite-env.d.ts

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
/// <reference types="vite/client" />

packages/@react/tsconfig.json

+18
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
{
2+
"compilerOptions": {
3+
"target": "esnext",
4+
"useDefineForClassFields": true,
5+
"module": "esnext",
6+
"moduleResolution": "node",
7+
"strict": true,
8+
"jsx": "preserve",
9+
"sourceMap": true,
10+
"resolveJsonModule": true,
11+
"esModuleInterop": true,
12+
"lib": [
13+
"esnext",
14+
"dom"
15+
]
16+
},
17+
// "include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue"],
18+
}

packages/@react/unocss.config.ts

+35
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,35 @@
1+
import {
2+
defineConfig,
3+
presetAttributify,
4+
presetIcons,
5+
presetUno,
6+
presetWebFonts,
7+
// transformerDirectives,
8+
// transformerVariantGroup,
9+
} from 'unocss'
10+
11+
export default defineConfig({
12+
shortcuts: [
13+
['btn', 'px-4 py-1 rounded inline-block bg-teal-600 text-white cursor-pointer hover:bg-teal-700 disabled:cursor-default disabled:bg-gray-600 disabled:opacity-50'],
14+
['icon-btn', 'text-[0.9em] inline-block cursor-pointer select-none opacity-75 transition duration-200 ease-in-out hover:opacity-100 hover:text-teal-600'],
15+
],
16+
presets: [
17+
presetUno(),
18+
presetAttributify(),
19+
presetIcons({
20+
scale: 1.2,
21+
warn: true,
22+
}),
23+
presetWebFonts({
24+
fonts: {
25+
sans: 'DM Sans',
26+
serif: 'DM Serif Display',
27+
mono: 'DM Mono',
28+
},
29+
}),
30+
],
31+
// transformers: [
32+
// transformerDirectives(),
33+
// transformerVariantGroup(),
34+
// ],
35+
})

packages/@react/utils/index.tsx

Whitespace-only changes.

packages/@react/vite.config.ts

+24
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,24 @@
1+
import { defineConfig } from 'vite'
2+
import react from '@vitejs/plugin-react'
3+
import unocss from 'unocss/vite'
4+
import dts from 'vite-plugin-dts'
5+
import libCss from 'vite-plugin-libcss'
6+
7+
export default defineConfig({
8+
build: {
9+
// minify: false,
10+
lib: {
11+
entry: 'index.ts',
12+
name: 'use-ui',
13+
fileName: 'use-ui'
14+
},
15+
},
16+
plugins: [
17+
react(),
18+
unocss(),
19+
dts({
20+
outputDir: 'dist/types'
21+
}),
22+
libCss(),
23+
]
24+
})

0 commit comments

Comments
 (0)