Comparing version 0.0.0-beta.0500a3f to 0.0.0-beta.0a10d17
@@ -71,3 +71,4 @@ #!/usr/bin/env node | ||
alias: null, | ||
srcDir: false | ||
srcDir: false, | ||
appDir: false | ||
}; | ||
@@ -81,3 +82,4 @@ try { | ||
alias, | ||
srcDir: existsSync(path2.resolve("./src")) | ||
srcDir: existsSync(path2.resolve("./src")), | ||
appDir: existsSync(path2.resolve("./app")) || existsSync(path2.resolve("./src/app")) | ||
}; | ||
@@ -207,2 +209,77 @@ } catch (error) { | ||
`; | ||
var TAILWIND_CONFIG = `/** @type {import('tailwindcss').Config} */ | ||
module.exports = { | ||
darkMode: ["class"], | ||
content: [ | ||
'./pages/**/*.{ts,tsx}', | ||
'./components/**/*.{ts,tsx}', | ||
'./app/**/*.{ts,tsx}', | ||
], | ||
theme: { | ||
container: { | ||
center: true, | ||
padding: "2rem", | ||
screens: { | ||
"2xl": "1400px", | ||
}, | ||
}, | ||
extend: { | ||
colors: { | ||
border: "hsl(var(--border))", | ||
input: "hsl(var(--input))", | ||
ring: "hsl(var(--ring))", | ||
background: "hsl(var(--background))", | ||
foreground: "hsl(var(--foreground))", | ||
primary: { | ||
DEFAULT: "hsl(var(--primary))", | ||
foreground: "hsl(var(--primary-foreground))", | ||
}, | ||
secondary: { | ||
DEFAULT: "hsl(var(--secondary))", | ||
foreground: "hsl(var(--secondary-foreground))", | ||
}, | ||
destructive: { | ||
DEFAULT: "hsl(var(--destructive))", | ||
foreground: "hsl(var(--destructive-foreground))", | ||
}, | ||
muted: { | ||
DEFAULT: "hsl(var(--muted))", | ||
foreground: "hsl(var(--muted-foreground))", | ||
}, | ||
accent: { | ||
DEFAULT: "hsl(var(--accent))", | ||
foreground: "hsl(var(--accent-foreground))", | ||
}, | ||
popover: { | ||
DEFAULT: "hsl(var(--popover))", | ||
foreground: "hsl(var(--popover-foreground))", | ||
}, | ||
card: { | ||
DEFAULT: "hsl(var(--card))", | ||
foreground: "hsl(var(--card-foreground))", | ||
}, | ||
}, | ||
borderRadius: { | ||
lg: "var(--radius)", | ||
md: "calc(var(--radius) - 2px)", | ||
sm: "calc(var(--radius) - 4px)", | ||
}, | ||
keyframes: { | ||
"accordion-down": { | ||
from: { height: 0 }, | ||
to: { height: "var(--radix-accordion-content-height)" }, | ||
}, | ||
"accordion-up": { | ||
from: { height: "var(--radix-accordion-content-height)" }, | ||
to: { height: 0 }, | ||
}, | ||
}, | ||
animation: { | ||
"accordion-down": "accordion-down 0.2s ease-out", | ||
"accordion-up": "accordion-up 0.2s ease-out", | ||
}, | ||
}, | ||
}, | ||
plugins: [require("tailwindcss-animate")], | ||
}`; | ||
@@ -228,25 +305,20 @@ // src/index.ts | ||
); | ||
program.command("init").description("Configure your Next.js project.").action(async () => { | ||
program.command("init").description("Configure your Next.js project.").option("-y, --yes", "Skip confirmation prompt.").action(async (options) => { | ||
logger.warn( | ||
"Running the following command will overwrite existing files." | ||
); | ||
logger.warn( | ||
"Make sure you have committed your changes before proceeding." | ||
); | ||
logger.warn(""); | ||
logger.warn( | ||
"This command assumes a Next.js project with TypeScript and Tailwind CSS." | ||
); | ||
logger.warn( | ||
"If you don't have these, follow the steps in the documentation at https://ui.shadcn.com/docs/installation." | ||
"If you don't have these, follow the manual steps at https://ui.shadcn.com/docs/installation." | ||
); | ||
logger.warn(""); | ||
const { proceed } = await prompts({ | ||
type: "confirm", | ||
name: "proceed", | ||
message: "Running this command will install dependencies and overwrite files. Proceed?", | ||
initial: true | ||
}); | ||
if (!proceed) { | ||
process.exit(0); | ||
if (!options.yes) { | ||
const { proceed } = await prompts({ | ||
type: "confirm", | ||
name: "proceed", | ||
message: "Running this command will install dependencies and overwrite your existing tailwind.config.js. Proceed?", | ||
initial: true | ||
}); | ||
if (!proceed) { | ||
process.exit(0); | ||
} | ||
} | ||
@@ -256,11 +328,16 @@ const dependenciesSpinner = ora(`Installing dependencies...`).start(); | ||
packageManager === "npm" ? "install" : "add", | ||
PROJECT_DEPENDENCIES.join(" ") | ||
...PROJECT_DEPENDENCIES | ||
]); | ||
dependenciesSpinner.succeed(); | ||
const stylesDir = projectInfo?.srcDir ? "./src/styles" : "./styles"; | ||
if (!existsSync2(path3.resolve(stylesDir))) { | ||
await fs3.mkdir(path3.resolve(stylesDir), { recursive: true }); | ||
if (!projectInfo?.appDir) { | ||
const stylesDir = projectInfo?.srcDir ? "./src/styles" : "./styles"; | ||
if (!existsSync2(path3.resolve(stylesDir))) { | ||
await fs3.mkdir(path3.resolve(stylesDir), { recursive: true }); | ||
} | ||
} | ||
const stylesDestination = projectInfo?.srcDir ? "./src/styles/global.css" : "./styles/global.css"; | ||
const stylesSpinner = ora(`Updating ${stylesDestination}...`).start(); | ||
let stylesDestination = projectInfo?.srcDir ? "./src/styles/globals.css" : "./styles/globals.css"; | ||
if (projectInfo?.appDir) { | ||
stylesDestination = projectInfo?.srcDir ? "./src/app/globals.css" : "./app/globals.css"; | ||
} | ||
const stylesSpinner = ora(`Adding styles with CSS variables...`).start(); | ||
await fs3.writeFile(stylesDestination, STYLES, "utf8"); | ||
@@ -273,5 +350,9 @@ stylesSpinner.succeed(); | ||
const utilsDestination = projectInfo?.srcDir ? "./src/lib/utils.ts" : "./lib/utils.ts"; | ||
const utilsSpinner = ora(`Creating ${utilsDestination}...`).start(); | ||
const utilsSpinner = ora(`Adding utils...`).start(); | ||
await fs3.writeFile(utilsDestination, UTILS, "utf8"); | ||
utilsSpinner.succeed(); | ||
const tailwindDestination = "./tailwind.config.js"; | ||
const tailwindSpinner = ora(`Updating tailwind.config.js...`).start(); | ||
await fs3.writeFile(tailwindDestination, TAILWIND_CONFIG, "utf8"); | ||
tailwindSpinner.succeed(); | ||
}); | ||
@@ -323,6 +404,5 @@ program.command("add").description("add components to your project").argument("[components...]", "name of components").action(async (components) => { | ||
if (component.dependencies?.length) { | ||
const dependencies = component.dependencies.join(" "); | ||
await execa(packageManager, [ | ||
packageManager === "npm" ? "install" : "add", | ||
dependencies | ||
...component.dependencies | ||
]); | ||
@@ -329,0 +409,0 @@ } |
{ | ||
"name": "shadcn-ui", | ||
"version": "0.0.0-beta.0500a3f", | ||
"version": "0.0.0-beta.0a10d17", | ||
"description": "Add components to your apps.", | ||
@@ -39,3 +39,2 @@ "publishConfig": { | ||
"prompts": "^2.4.2", | ||
"react-day-picker": "^8.6.0", | ||
"zod": "^3.20.2" | ||
@@ -42,0 +41,0 @@ }, |
# shadcn-ui | ||
A CLI for adding components to your project. | ||
## Usage | ||
Use the `init` command to initialize dependencies for a new project. | ||
The `init` command installs dependencies, adds the `cn` util, configures `tailwind.config.js`, and CSS variables for the project. | ||
```bash | ||
npx shadcn-ui init | ||
``` | ||
## add | ||
Use the `add` command to add components to your project. | ||
The `add` command adds a component to your project and installs all required dependencies. | ||
```bash | ||
npx shadcn-ui add [component] | ||
``` | ||
### Example | ||
```bash | ||
npx shadcn-ui add alert-dialog | ||
``` | ||
You can also run the command without any arguments to view a list of all available components: | ||
```bash | ||
npx shadcn-ui add | ||
``` | ||
## Documentation | ||
Visit http://ui.shadcn.com/docs to view the documentation. | ||
## License | ||
Licensed under the [MIT license](https://github.com/shadcn/ui/blob/main/LICENSE.md). |
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
36912
8
402
44
- Removedreact-day-picker@^8.6.0
- Removeddate-fns@3.6.0(transitive)
- Removedjs-tokens@4.0.0(transitive)
- Removedloose-envify@1.4.0(transitive)
- Removedreact@18.3.1(transitive)
- Removedreact-day-picker@8.10.1(transitive)