mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
252918b70c
ref https://linear.app/ghost/issue/DES-1021/create-posts-app Part of establishing React patterns in Ghost is to build a well-defined and fairly self-encapsulated app through which we can test assumptions and define best practices. Our guinea pig is Post analytics for this purpose. This PR creates a new React app (posts) using Shade (the new design system).
100 lines
No EOL
3.5 KiB
JSON
100 lines
No EOL
3.5 KiB
JSON
{
|
|
"name": "@tryghost/shade",
|
|
"type": "module",
|
|
"version": "0.0.0",
|
|
"repository": "https://github.com/TryGhost/Ghost/tree/main/packages/shade",
|
|
"author": "Ghost Foundation",
|
|
"private": true,
|
|
"main": "es/index.js",
|
|
"types": "types/index.d.ts",
|
|
"sideEffects": false,
|
|
"scripts": {
|
|
"build": "tsc -p tsconfig.declaration.json && vite build",
|
|
"prepare": "yarn build",
|
|
"test": "yarn test:unit",
|
|
"test:unit": "yarn test:types && yarn nx build && vitest run",
|
|
"test:types": "tsc --noEmit",
|
|
"lint:code": "eslint --ext .js,.ts,.cjs,.tsx src/ --cache",
|
|
"lint": "yarn lint:code && yarn lint:test",
|
|
"lint:test": "eslint -c test/.eslintrc.cjs --ext .js,.ts,.cjs,.tsx test/ --cache",
|
|
"storybook": "storybook dev -p 6006",
|
|
"build-storybook": "storybook build"
|
|
},
|
|
"files": [
|
|
"es",
|
|
"types",
|
|
"tailwind.cjs",
|
|
"tailwind.config.cjs"
|
|
],
|
|
"devDependencies": {
|
|
"@codemirror/lang-html": "6.4.9",
|
|
"@radix-ui/react-tooltip": "1.1.2",
|
|
"@storybook/addon-essentials": "7.6.20",
|
|
"@storybook/addon-interactions": "7.6.20",
|
|
"@storybook/addon-links": "7.6.20",
|
|
"@storybook/addon-styling": "1.3.7",
|
|
"@storybook/blocks": "7.6.20",
|
|
"@storybook/react": "7.6.20",
|
|
"@storybook/react-vite": "7.6.4",
|
|
"@storybook/testing-library": "0.2.2",
|
|
"@testing-library/react": "14.3.1",
|
|
"@testing-library/react-hooks": "8.0.1",
|
|
"@types/lodash-es": "4.17.12",
|
|
"@types/node": "^22.10.1",
|
|
"@vitejs/plugin-react": "4.2.1",
|
|
"c8": "8.0.1",
|
|
"chai": "4.3.8",
|
|
"eslint-plugin-react-hooks": "4.6.0",
|
|
"eslint-plugin-react-refresh": "0.4.3",
|
|
"eslint-plugin-tailwindcss": "3.13.0",
|
|
"jsdom": "24.1.3",
|
|
"lodash-es": "4.17.21",
|
|
"mocha": "10.2.0",
|
|
"react": "18.3.1",
|
|
"react-dom": "18.3.1",
|
|
"rollup-plugin-node-builtins": "2.1.2",
|
|
"sinon": "17.0.0",
|
|
"storybook": "7.6.20",
|
|
"ts-node": "10.9.2",
|
|
"typescript": "5.4.5",
|
|
"validator": "13.12.0",
|
|
"vite": "4.5.3",
|
|
"vite-plugin-svgr": "3.3.0"
|
|
},
|
|
"dependencies": {
|
|
"@dnd-kit/core": "6.1.0",
|
|
"@dnd-kit/sortable": "7.0.2",
|
|
"@ebay/nice-modal-react": "1.2.13",
|
|
"@radix-ui/react-avatar": "1.1.0",
|
|
"@radix-ui/react-checkbox": "1.1.1",
|
|
"@radix-ui/react-dropdown-menu": "2.1.3",
|
|
"@radix-ui/react-form": "0.0.3",
|
|
"@radix-ui/react-popover": "1.1.1",
|
|
"@radix-ui/react-radio-group": "1.2.0",
|
|
"@radix-ui/react-separator": "1.1.0",
|
|
"@radix-ui/react-slot": "^1.1.0",
|
|
"@radix-ui/react-switch": "1.1.0",
|
|
"@radix-ui/react-tabs": "1.1.2",
|
|
"@radix-ui/react-tooltip": "1.1.2",
|
|
"@sentry/react": "7.119.2",
|
|
"@tailwindcss/forms": "0.5.9",
|
|
"@tailwindcss/line-clamp": "0.4.4",
|
|
"@uiw/react-codemirror": "4.23.7",
|
|
"autoprefixer": "10.4.19",
|
|
"class-variance-authority": "^0.7.1",
|
|
"clsx": "^2.1.1",
|
|
"lucide-react": "^0.468.0",
|
|
"postcss": "8.4.39",
|
|
"postcss-import": "16.1.0",
|
|
"react-colorful": "5.6.1",
|
|
"react-hot-toast": "2.4.1",
|
|
"react-select": "5.8.2",
|
|
"tailwind-merge": "^2.5.5",
|
|
"tailwindcss": "3.4.14",
|
|
"tailwindcss-animate": "^1.0.7"
|
|
},
|
|
"peerDependencies": {
|
|
"react": "^18.2.0",
|
|
"react-dom": "^18.2.0"
|
|
}
|
|
} |