{"id":48514292,"url":"https://github.com/itsyuimorii/practice-kanbanboard-react-ts","last_synced_at":"2026-04-07T18:31:37.821Z","repository":{"id":65087624,"uuid":"581031427","full_name":"itsyuimorii/practice-kanbanboard-react-ts","owner":"itsyuimorii","description":"💥Learn Node.js by building real-world applications with Node JS, Express, MongoDB, Jest, and more!","archived":false,"fork":false,"pushed_at":"2024-01-28T20:37:57.000Z","size":1658,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2026-04-07T01:33:01.698Z","etag":null,"topics":["es6","express","jest","jwt-authentication","mongodb","nodejs","restful-api","socket-io"],"latest_commit_sha":null,"homepage":"https://www.udemy.com/course/the-complete-nodejs-developer-course-2/","language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/itsyuimorii.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2022-12-22T04:58:31.000Z","updated_at":"2024-11-18T05:06:41.000Z","dependencies_parsed_at":"2025-02-19T23:33:45.526Z","dependency_job_id":null,"html_url":"https://github.com/itsyuimorii/practice-kanbanboard-react-ts","commit_stats":null,"previous_names":["itsyuimorii/--project--kanbanborad-react-ts--","itsyuimorii/practice-kanbanboard-react-ts","itsiiromiuy/practice-kanbanboard-react-ts"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/itsyuimorii/practice-kanbanboard-react-ts","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/itsyuimorii%2Fpractice-kanbanboard-react-ts","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/itsyuimorii%2Fpractice-kanbanboard-react-ts/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/itsyuimorii%2Fpractice-kanbanboard-react-ts/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/itsyuimorii%2Fpractice-kanbanboard-react-ts/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/itsyuimorii","download_url":"https://codeload.github.com/itsyuimorii/practice-kanbanboard-react-ts/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/itsyuimorii%2Fpractice-kanbanboard-react-ts/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":31524524,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-04-07T16:28:08.000Z","status":"ssl_error","status_checked_at":"2026-04-07T16:28:06.951Z","response_time":105,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.5:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["es6","express","jest","jwt-authentication","mongodb","nodejs","restful-api","socket-io"],"created_at":"2026-04-07T18:31:37.313Z","updated_at":"2026-04-07T18:31:37.812Z","avatar_url":"https://github.com/itsyuimorii.png","language":"TypeScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# React + TypeScript + Vite\n\nThis template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.\n\nCurrently, two official plugins are available:\n\n- [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react/README.md) uses [Babel](https://babeljs.io/) for Fast Refresh\n- [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh\n\n## Expanding the ESLint configuration\n\nIf you are developing a production application, we recommend updating the configuration to enable type aware lint rules:\n\n- Configure the top-level `parserOptions` property like this:\n\n```js\nexport default {\n  // other rules...\n  parserOptions: {\n    ecmaVersion: \"latest\",\n    sourceType: \"module\",\n    project: [\"./tsconfig.json\", \"./tsconfig.node.json\"],\n    tsconfigRootDir: __dirname,\n  },\n};\n```\n\n- Replace `plugin:@typescript-eslint/recommended` to `plugin:@typescript-eslint/recommended-type-checked` or `plugin:@typescript-eslint/strict-type-checked`\n- Optionally add `plugin:@typescript-eslint/stylistic-type-checked`\n- Install [eslint-plugin-react](https://github.com/jsx-eslint/eslint-plugin-react) and add `plugin:react/recommended` \u0026 `plugin:react/jsx-runtime` to the `extends` list\n\nnpx vs npm 區別:\n\n`npm create vite` 时选择 `react-ts` 模板，会自动安装 `@vitejs/plugin-react` 插件。\n\n`npm install @dnd-kit/core @dnd-kit/sortable @dnd-kit/modifiers` 安装拖拽库。\n\n`@dnd-kit` 是一個 React 拖拽庫，它提供了一個可擴展的、可組合的、可設置的和可訂製的 API，用於構建拖拽功能。\n\n## Install TailwindCSS\n\n在命令 `npx tailwindcss init -p` 中，`-p` 参数是用来同时生成 Tailwind CSS 配置文件 (`tailwind.config.js`) 和 PostCSS 配置文件 (`postcss.config.js`)。\n\n简而言之：\n\n- `npx tailwindcss init`：这个命令会创建一个基本的 `tailwind.config.js` 文件。这是一个配置文件，你可以在其中自定义 Tailwind 的许多方面，例如主题、变体等。\n\n- `npx tailwindcss init -p`：加上 `-p` 参数后，除了 `tailwind.config.js` 文件，还会创建 `postcss.config.js` 文件。PostCSS 是一个用于转换 CSS 的工具，而 Tailwind CSS 通常作为 PostCSS 的一个插件来使用。`postcss.config.js` 文件允许你配置 PostCSS 相关的选项，包括使用 Tailwind CSS 插件。\n\n因此，如果你打算在项目中使用 Tailwind CSS 并结合 PostCSS 工具链，使用 `-p` 参数是一个方便的方式来一次性生成这两个配置文件。在命令 `npx tailwindcss init -p` 中，`-p` 参数是用来同时生成 Tailwind CSS 配置文件 (`tailwind.config.js`) 和 PostCSS 配置文件 (`postcss.config.js`)。\n\n简而言之：\n\n- `npx tailwindcss init`：这个命令会创建一个基本的 `tailwind.config.js` 文件。这是一个配置文件，你可以在其中自定义 Tailwind 的许多方面，例如主题、变体等。\n\n- `npx tailwindcss init -p`：加上 `-p` 参数后，除了 `tailwind.config.js` 文件，还会创建 `postcss.config.js` 文件。PostCSS 是一个用于转换 CSS 的工具，而 Tailwind CSS 通常作为 PostCSS 的一个插件来使用。`postcss.config.js` 文件允许你配置 PostCSS 相关的选项，包括使用 Tailwind CSS 插件。\n\n因此，如果你打算在项目中使用 Tailwind CSS 并结合 PostCSS 工具链，使用 `-p` 参数是一个方便的方式来一次性生成这两个配置文件。\n\n- `npm install tailwind-merge` 安装 tailwind-merge 插件，用于合并 Tailwind CSS 配置文件。\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fitsyuimorii%2Fpractice-kanbanboard-react-ts","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fitsyuimorii%2Fpractice-kanbanboard-react-ts","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fitsyuimorii%2Fpractice-kanbanboard-react-ts/lists"}