Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Introduce monorepo to manage packages using pnpm #880

Merged
merged 27 commits into from
Aug 16, 2024

Conversation

gwbaik9717
Copy link
Contributor

@gwbaik9717 gwbaik9717 commented Aug 13, 2024

What this PR does / why we need it?

  • Change yorkie-js-sdk to monorepo structure.
  • Change the monorepo structure to use only pnpm.

Any background context you want to provide?

Referred to the work from from #746 by @easylogic

  • Prepare
# install pnpm globally in your local environment
npm install -g pnpm
  • Install
git clone https://github.com/yorkie-team/yorkie-js-sdk

cd yorkie-js-sdk

pnpm install
  • Workspace
    The workspace is divided into two types: examples and packages.
examples/           
- nextjs-scheduler
- profile-stack
- react-tldraw
- react-todomvc
- simultaneous-cursors
- vanilla-codemirror6
- vanilla-quill
- vuejs-kanban

packages
- create-yorkie-app
- devtools
- sdk                  <-- yorkie-js-sdk package
  • Folder structure
# old path 
src/yorkie.ts
# new path 
packages/sdk/src/yorkie.ts 
  • Command line
  1. In case of SDK
# old 

npm run build 
npm run build:proto 
# new 

# In the root of the repository
pnpm sdk build
pnpm sdk build:proto 
  1. In case of examples for instance, react-tldraw
# old 

# in the specific example directory 
npm run dev
npm run build
# new

# In the root directory of the respository
pnpm react-tldraw dev
pnpm react-tldraw build 

# Or in the project directory
pnpm dev
pnpm build
  • Command Table
    packages
`sdk`
- [x] pnpm sdk build
- [x] pnpm sdk build:proto
- [x] pnpm sdk build:docs
- [x] pnpm sdk build:ghpages
- [x] pnpm sdk dev
- [x] pnpm sdk test
- [x] pnpm sdk test:watch
- [x] pnpm sdk test:bench
- [x] pnpm sdk test:ci
- [x] pnpm sdk test:yorkie.dev
- [x] pnpm sdk lint
- [x] pnpm sdk prepare

`devtools`
- [x] pnpm devtools dev
- [x] pnpm devtools build
- [x] pnpm devtools test

`create-yorkie-app`
- [x] pnpm create-yorkie-app start
- [x] pnpm create-yorkie-app build
- [x] pnpm create-yorkie-app build:copy-assets

examples

- [x] pnpm build:examples
   - build all examples at once
- [x] pnpm nextjs-scheduler dev
- [x] pnpm profile-stack dev
- [x] pnpm react-tldraw dev
- [x] pnpm react-todomvc dev
- [x] pnpm simultaneous-cursors dev
- [x] pnpm vanilla-codemirror6 dev
- [x] pnpm vanilla-quill dev
- [x] pnpm vuejs-kanban dev

Specs
update typescript version -> 5.3.3
update vite version -> 5.0.12
update @types/react -> 18.2.0
update @types/react-dom -> 18.2.0

What are the relevant tickets?

Fixes #648

Checklist

  • Added relevant tests or not required
  • Didn't break anything

Summary by CodeRabbit

  • New Features

    • Transitioned from npm to pnpm as the package manager across various workflows.
    • Introduced a new pnpm workspace configuration for improved dependency management.
    • Created a new package.json file for the yorkie-js-sdk project.
  • Bug Fixes

    • Improved type definitions for the displayLog function to incorporate YorkiePresence.
  • Documentation

    • Enhanced clarity in installation and usage instructions throughout various README files.
  • Chores

    • Added patterns to the .gitignore file to prevent tracking of unnecessary files.
    • Updated CI configuration to utilize pnpm for improved performance.

Copy link

coderabbitai bot commented Aug 13, 2024

Caution

Review failed

The pull request is closed.

Walkthrough

This update introduces a monorepo structure using pnpm to effectively manage multiple packages within a single repository. Key changes include transitioning from npm to pnpm across various workflows, updating dependency management, and restructuring project directories to enhance efficiency in building and testing processes. The addition of a pnpm workspace configuration streamlines package handling, making the development experience more cohesive and organized.

Changes

Files/Paths Change Summary
.github/workflows/*.yml Transitions from npm to pnpm for dependency management; updates caching and installation steps.
.gitignore Adds package-lock.json to ignore list to prevent tracking of npm lock files.
.npmrc Adds custom registry setting for @buf scope.
pnpm-workspace.yaml Introduces configuration for managing multiple packages in a pnpm workspace.
packages/sdk/test/helper/helper.ts Changes assertion library from Chai to Vitest in test helper file.
packages/yorkie-js-sdk/package.json New file created for the yorkie-js-sdk project, specifying its metadata and scripts.

Sequence Diagram(s)

sequenceDiagram
    participant Developer
    participant CI/CD
    participant pnpm
    participant Workspace

    Developer->>CI/CD: Push code changes
    CI/CD->>pnpm: Install dependencies
    pnpm->>Workspace: Manage package installations
    Workspace-->>CI/CD: Return installed packages
    CI/CD->>Workspace: Build and test applications
    Workspace-->>CI/CD: Return build results
Loading

Assessment against linked issues

Objective Addressed Explanation
Introduce monorepo to manage packages (Issue #648)
Transition package management to pnpm for improved efficiency (Issue #648)
Streamline build and test processes within the new structure (Issue #648)
Maintain clarity in documentation for new commands and configurations (Issue #648)
Ensure all examples reflect the new package manager usage (Issue #648) Some examples may still reference npm.

Possibly related PRs

Poem

🐇 In a world of code, so bright and neat,
With pnpm hopping, our tasks are complete.
Packages gathered, in harmony bound,
A monorepo structure, efficiency found.
So let’s celebrate, with carrots and cheer,
For a cleaner workspace, let’s give a loud cheer! 🎉


Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

CodeRabbit Configuration File (.coderabbit.yaml)

  • You can programmatically configure CodeRabbit by adding a .coderabbit.yaml file to the root of your repository.
  • Please see the configuration documentation for more information.
  • If your editor has YAML language server enabled, you can add the path at the top of this file to enable auto-completion and validation: # yaml-language-server: $schema=https://coderabbit.ai/integrations/schema.v2.json

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

@gwbaik9717
Copy link
Contributor Author

gwbaik9717 commented Aug 14, 2024

@chacha912 @hackerwins

I'm sharing the progress so far, as the scope of work is extensive. I want to discuss a few key points:

  1. Folder Structure and File Changes
    The overall folder structure and many files have been modified, which is likely to cause conflicts with future pull requests. We need to find a solution to manage these potential conflicts.

  2. Remove update-examples.sh ?
    This script seems to upgrade the yorkie-js-sdk version across all examples. However, since the examples now always reference the latest local version of yorkie-js-sdk using pnpm, this script may no longer be necessary.

  3. Inconsistent tsconfig.json Settings
    Each package currently has its own tsconfig.json file, and the differences in these configurations are causing problems. For instance, only vanilla-codemirror6 and vanilla-quill have the following settings, which conflict with the settings in the SDK’s tsconfig.json.

"noUnusedLocals": true,
"noUnusedParameters": true,
"noImplicitReturns": true,

For now, I've removed those settings which were causing conflicts as they don't appear to be critical options. However, it seems essential to standardize the tsconfig.json across all packages to ensure consistency.

4. Scripts in create-yorkie-app (Resolved)
To elaborate on this issue in Command Table above, running pnpm create start from the root directory works without any problems. However, when executing pnpm create build or pnpm build:copy-assets from the root directory, the following error occurs:

- [x] pnpm build
  - must be executed in the project directory, not the root. 
- [x] pnpm build:copy-assets
  - must be executed in the project directory, not the root.
Screenshot 2024-08-14 at 9 03 30 AM
    "start": "pnpm build && node dist/create-yorkie-app.mjs"

What’s odd is that the start command includes the build process, yet start works while build does not. Interestingly, running pnpm build directly within the specific directory, rather than from the root, works without any issues. Therefore, I’ve modified the process to first navigate to the appropriate directory before executing the command.

Any further questions or suggestions are welcome.

@gwbaik9717
Copy link
Contributor Author

gwbaik9717 commented Aug 15, 2024

Here is an update.

Issue above "4. Scripts in create-yorkie-app" has been resolved. It turns out that pnpm create is a reserved keyword in pnpm, which led to conflicts. Therefore, to run the scripts for create-yorkie-app use pnpm create-yorkie-app {script} instead of pnpm create {script}

@gwbaik9717 gwbaik9717 marked this pull request as ready for review August 15, 2024 07:29
Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 1

Outside diff range, codebase verification and nitpick comments (2)
examples/nextjs-scheduler/tsconfig.json (1)

7-7: Consider enabling strict mode for better type safety.

The strict option has been set to false, which disables several type-checking features. Consider enabling it to ensure better type safety and catch potential errors at compile time.

-    "strict": false,
+    "strict": true,
examples/README.md (1)

33-33: Consider using a markdown link for the URL.

Using a markdown link improves readability and follows best practices.

- Open the browser and go to the URL that is printed in the terminal.
+ Open the browser and go to the [URL](https://yorkie.dev) that is printed in the terminal.
Tools
Markdownlint

33-33: null
Bare URL used

(MD034, no-bare-urls)

Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

Commits

Files that changed from the base of the PR and between 267878f and ebd7a14.

Files ignored due to path filters (6)
  • examples/nextjs-scheduler/package-lock.json is excluded by !**/package-lock.json
  • package-lock.json is excluded by !**/package-lock.json
  • packages/devtools/assets/icon.png is excluded by !**/*.png
  • pnpm-lock.yaml is excluded by !**/pnpm-lock.yaml
  • tools/create-yorkie-app/package-lock.json is excluded by !**/package-lock.json
  • tools/devtools/package-lock.json is excluded by !**/package-lock.json
Files selected for processing (49)
  • .github/workflows/ci.yml (2 hunks)
  • .github/workflows/create-yorkie-app-publish.yml (2 hunks)
  • .github/workflows/devtools-publish.yml (2 hunks)
  • .github/workflows/github-page-publish.yml (1 hunks)
  • .github/workflows/npm-publish.yml (1 hunks)
  • .gitignore (1 hunks)
  • .npmrc (1 hunks)
  • CONTRIBUTING.md (5 hunks)
  • examples/README.md (1 hunks)
  • examples/nextjs-scheduler/.eslintrc.js (1 hunks)
  • examples/nextjs-scheduler/README.md (1 hunks)
  • examples/nextjs-scheduler/package.json (1 hunks)
  • examples/nextjs-scheduler/tsconfig.json (3 hunks)
  • examples/profile-stack/README.md (1 hunks)
  • examples/profile-stack/package.json (1 hunks)
  • examples/profile-stack/vite.config.js (1 hunks)
  • examples/react-tldraw/README.md (1 hunks)
  • examples/react-tldraw/package.json (1 hunks)
  • examples/react-tldraw/src/hooks/useMultiplayerState.ts (1 hunks)
  • examples/react-tldraw/tsconfig.json (1 hunks)
  • examples/react-tldraw/vite.config.ts (1 hunks)
  • examples/react-todomvc/README.md (1 hunks)
  • examples/react-todomvc/package.json (1 hunks)
  • examples/react-todomvc/tsconfig.json (1 hunks)
  • examples/react-todomvc/vite.config.ts (1 hunks)
  • examples/simultaneous-cursors/README.md (3 hunks)
  • examples/simultaneous-cursors/package.json (1 hunks)
  • examples/simultaneous-cursors/vite.config.js (1 hunks)
  • examples/vanilla-codemirror6/README.md (1 hunks)
  • examples/vanilla-codemirror6/package.json (2 hunks)
  • examples/vanilla-codemirror6/tsconfig.json (1 hunks)
  • examples/vanilla-codemirror6/vite.config.js (1 hunks)
  • examples/vanilla-quill/README.md (3 hunks)
  • examples/vanilla-quill/package.json (1 hunks)
  • examples/vanilla-quill/src/utils.ts (2 hunks)
  • examples/vanilla-quill/tsconfig.json (1 hunks)
  • examples/vanilla-quill/vite.config.js (1 hunks)
  • examples/vuejs-kanban/README.md (1 hunks)
  • examples/vuejs-kanban/package.json (1 hunks)
  • examples/vuejs-kanban/vite.config.js (1 hunks)
  • package.json (1 hunks)
  • packages/create-yorkie-app/README.md (1 hunks)
  • packages/create-yorkie-app/package.json (1 hunks)
  • packages/devtools/README.md (1 hunks)
  • packages/devtools/package.json (1 hunks)
  • packages/devtools/tsconfig.json (1 hunks)
  • packages/sdk/buf.gen.yaml (1 hunks)
  • packages/sdk/package.json (1 hunks)
  • pnpm-workspace.yaml (1 hunks)
Files skipped from review due to trivial changes (10)
  • .gitignore
  • examples/profile-stack/README.md
  • examples/react-tldraw/README.md
  • examples/simultaneous-cursors/README.md
  • examples/vanilla-codemirror6/README.md
  • examples/vanilla-quill/README.md
  • examples/vuejs-kanban/README.md
  • packages/create-yorkie-app/README.md
  • packages/create-yorkie-app/package.json
  • packages/devtools/README.md
Additional context used
yamllint
pnpm-workspace.yaml

[error] 7-7: no new line character at the end of file

(new-line-at-end-of-file)

Markdownlint
examples/README.md

33-33: null
Bare URL used

(MD034, no-bare-urls)

Additional comments not posted (81)
.npmrc (1)

2-2: Custom registry for @buf scope added.

The addition of @buf:registry=https://buf.build/gen/npm/v1 allows scoped packages to be fetched from a specific registry, which can improve package management and version control for @buf packages.

examples/nextjs-scheduler/.eslintrc.js (1)

2-2: Enhanced linting with Prettier integration.

The ESLint configuration now extends 'plugin:prettier/recommended', which helps maintain consistent code formatting alongside Next.js specific rules. This integration enhances code quality by enforcing uniform style guidelines.

packages/sdk/buf.gen.yaml (1)

6-11: Shift to TypeScript-only outputs.

The target output format for both es and connect-es plugins has been changed to ts, reflecting a focus on TypeScript. This aligns with modern development practices and simplifies the output by removing JavaScript support.

examples/profile-stack/package.json (1)

12-15: Dependency updates are appropriate for the monorepo setup.

The upgrade to vite and the use of workspace:* for yorkie-js-sdk align with the goals of the monorepo structure, enhancing development flexibility.

examples/vuejs-kanban/package.json (1)

11-15: Dependency updates are suitable for the monorepo structure.

The updates to @vitejs/plugin-vue, vite, and the use of workspace:* for yorkie-js-sdk are well-aligned with the monorepo strategy, promoting better integration and development efficiency.

examples/profile-stack/vite.config.js (1)

2-14: LGTM!

The addition of the alias for @yorkie-js-sdk/src using path.resolve is a good practice for managing imports more efficiently. This enhances maintainability and readability.

examples/vanilla-codemirror6/vite.config.js (1)

2-15: LGTM!

The alias configuration for @yorkie-js-sdk/src is consistent with other examples and effectively simplifies import paths. This is a beneficial change for code maintainability.

examples/vanilla-quill/vite.config.js (1)

2-15: LGTM!

The addition of the alias for @yorkie-js-sdk/src using path.resolve is consistent with other configurations and enhances the readability and maintainability of import paths.

packages/devtools/tsconfig.json (1)

1-13: Configuration looks good! Verify the base configuration.

The tsconfig.json file is well-structured and extends a base configuration. Ensure that plasmo/templates/tsconfig.base is correctly set up to provide the necessary compiler options for this package.

examples/simultaneous-cursors/vite.config.js (1)

1-17: Aliasing mechanism is well-implemented! Verify alias usage.

The addition of the alias for @yorkie-js-sdk/src in the Vite configuration is a good practice for simplifying imports. Ensure that this alias is used consistently across the project.

Verification successful

Alias Usage Verified

The alias @yorkie-js-sdk/src is consistently used across the project in various JavaScript and TypeScript files, confirming that the aliasing mechanism is effectively implemented. No issues found with its usage.

Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify the usage of the alias in the project files.

# Test: Search for instances where the alias is used in import statements.
rg --type js --type ts --type tsx "@yorkie-js-sdk/src"

Length of output: 82


Script:

#!/bin/bash
# Description: Verify the usage of the alias in the project files.

# Find all JavaScript and TypeScript files and search for the alias usage.
fd --type f --extension js --extension ts | xargs rg "@yorkie-js-sdk/src"

Length of output: 48420

examples/react-tldraw/vite.config.ts (1)

1-17: Enhancements are well-executed! Verify plugin and alias usage.

The introduction of vite-tsconfig-paths and the alias for @yorkie-js-sdk/src improve the configuration. Ensure that the plugin is functioning correctly and that the alias is used consistently.

Verification successful

Alias and Plugin Verification Completed Successfully

The alias @yorkie-js-sdk/src is actively used throughout the codebase, confirming its consistent application. Additionally, the vite-tsconfig-paths plugin is correctly listed as a development dependency in the examples/react-tldraw/package.json, ensuring its availability for the project. No issues were found regarding the plugin and alias usage.

  • The alias @yorkie-js-sdk/src is used in multiple TypeScript files.
  • The vite-tsconfig-paths plugin is present in examples/react-tldraw/package.json.
Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify the usage of the plugin and alias in the project files.

# Test: Check for the usage of the alias in import statements and confirm the plugin is listed in package.json.
rg --type ts --type tsx "@yorkie-js-sdk/src"
jq '.devDependencies | has("vite-tsconfig-paths")' package.json

Length of output: 144


Script:

#!/bin/bash
# Correct the file type error and verify the alias usage in TypeScript files.
rg --type ts --type tsx "@yorkie-js-sdk/src"

# Check again for the presence of vite-tsconfig-paths in package.json.
jq '.dependencies | has("vite-tsconfig-paths") or .devDependencies | has("vite-tsconfig-paths")' package.json

# Check for any mention of vite-tsconfig-paths in other configuration files.
rg "vite-tsconfig-paths" --type js --type json

Length of output: 515


Script:

#!/bin/bash
# Verify the alias usage in TypeScript files, focusing on .ts files.
rg --type ts "@yorkie-js-sdk/src"

# Confirm the presence of vite-tsconfig-paths in the specific example's package.json.
jq '.devDependencies | has("vite-tsconfig-paths")' examples/react-tldraw/package.json

Length of output: 48091

examples/react-todomvc/vite.config.ts (1)

1-17: LGTM! Verify alias path correctness.

The integration of vite-tsconfig-paths and the alias for @yorkie-js-sdk/src improves module resolution and maintainability.

Ensure that the alias path ../../packages/sdk/src correctly points to the SDK's source directory.

Verification successful

Alias path correctly points to the SDK's source directory. The alias path ../../packages/sdk/src in vite.config.ts is valid and correctly resolves to the intended directory.

Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify that the alias path in vite.config.ts correctly points to the SDK's source directory.

# Test: Check if the path exists. Expect: The path should exist.
if [ -d "examples/react-todomvc/../../packages/sdk/src" ]; then
  echo "Alias path exists."
else
  echo "Alias path does not exist."
fi

Length of output: 105

examples/vanilla-codemirror6/tsconfig.json (1)

14-17: Verify impact of removing strict options.

The removal of noUnusedLocals, noUnusedParameters, and noImplicitReturns may reduce code quality by allowing unused code and potential logical errors.

The addition of the paths mapping for @yorkie-js-sdk/src/* enhances module resolution.

examples/vanilla-quill/tsconfig.json (1)

14-17: Verify impact of removing strict options.

The removal of noUnusedLocals, noUnusedParameters, and noImplicitReturns may reduce code quality by allowing unused code and potential logical errors.

The addition of the paths mapping for @yorkie-js-sdk/src/* enhances module resolution.

examples/simultaneous-cursors/package.json (2)

14-14: Switch to workspace reference for yorkie-js-sdk.

The change to "yorkie-js-sdk": "workspace:*" allows the project to use the latest local version of the SDK, facilitating development within a monorepo setup.


17-20: Update devDependencies to the latest versions.

The updates to @types/react, @types/react-dom, @vitejs/plugin-react, and vite ensure compatibility with the latest features and improvements, enhancing the development experience.

examples/vanilla-quill/package.json (3)

14-14: Update TypeScript to version 5.3.3.

Upgrading TypeScript to ^5.3.3 introduces new features and improvements in type checking and compilation, aligning with modern development practices.


15-15: Update Vite to version 5.0.12.

The upgrade to Vite ^5.0.12 brings enhancements in the build process and development server capabilities, improving overall project performance.


22-22: Switch to workspace reference for yorkie-js-sdk.

The change to "yorkie-js-sdk": "workspace:*" allows the project to utilize the latest local version of the SDK, supporting the monorepo structure.

examples/vuejs-kanban/vite.config.js (1)

12-21: Enhance alias configuration with array-based structure.

The transition to an array-based alias configuration allows for multiple entries, improving flexibility and clarity. This setup facilitates better path resolution in the project.

examples/vanilla-codemirror6/package.json (2)

23-23: Switch to workspace reference for yorkie-js-sdk.

The yorkie-js-sdk dependency now uses a workspace reference (workspace:*). This change aligns with the monorepo structure, allowing for local development and testing.


12-13: Upgrade TypeScript and Vite versions.

The typescript and vite dependencies have been upgraded to versions 5.3.3 and 5.0.12, respectively. These updates should provide new features and improvements. Ensure compatibility with your current codebase.

examples/react-todomvc/package.json (5)

16-16: Switch to workspace reference for yorkie-js-sdk.

The yorkie-js-sdk dependency now uses a workspace reference (workspace:*). This change aligns with the monorepo structure, allowing for local development and testing.


22-23: Upgrade TypeScript and Vite versions.

The typescript and vite dependencies have been upgraded to versions 5.3.3 and 5.0.12, respectively. These updates should provide new features and improvements. Ensure compatibility with your current codebase.


24-24: Add vite-tsconfig-paths.

The vite-tsconfig-paths plugin has been added to facilitate TypeScript path mapping in Vite projects. This addition should improve path resolution and simplify imports.


21-21: Upgrade @vitejs/plugin-react.

The @vitejs/plugin-react dependency has been upgraded to version 4.2.1. This update may introduce new features or improvements. Ensure compatibility with your current Vite setup.


19-20: Upgrade React type definitions.

The @types/react and @types/react-dom dependencies have been upgraded to version 18.2.0. Ensure that these updates are compatible with your current React code.

examples/react-tldraw/tsconfig.json (1)

18-20: Add paths configuration for module resolution.

The new paths configuration allows for module resolution of @yorkie-js-sdk/src/* paths to point to ../../packages/sdk/src/*. This change simplifies imports and enhances maintainability.

examples/react-todomvc/tsconfig.json (1)

18-19: LGTM! Verify the usage of the new path alias.

The addition of the paths property for module resolution is a beneficial change that simplifies imports. Ensure that all imports using this alias are updated and functioning correctly across the codebase.

Verification successful

Path Alias Usage Verified

The new path alias @yorkie-js-sdk/src/ is used extensively throughout the codebase, indicating it is being correctly utilized for module resolution. Ensure that your build and test processes confirm the absence of any import-related issues.

  • Path alias @yorkie-js-sdk/src/ is present in both source and test files.
Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify the usage of the new path alias in the codebase.

# Test: Search for occurrences of the new path alias. Expect: Correct usage in imports.
rg --type js --type ts '@yorkie-js-sdk/src/'

Length of output: 47862

examples/nextjs-scheduler/package.json (1)

6-6: LGTM! Verify compatibility with updated dependencies.

The updates to the dependencies and devDependencies align with the monorepo setup and modernize the project. Ensure that the application functions correctly with these updated versions.

Also applies to: 12-16, 20-26

.github/workflows/devtools-publish.yml (1)

8-8: LGTM! Verify workflow execution.

The updates to the workflow configuration are consistent with the new monorepo structure and the adoption of pnpm. Ensure that the workflow executes successfully with these changes.

Also applies to: 20-20, 24-26, 32-32

Verification successful

Review the versioning process in the deployment workflow

The recent failure in the devtools-publish.yml workflow was due to an invalid version number in the manifest file during deployment. This issue is not related to the workflow configuration changes. Ensure that the versioning process is properly managed to prevent such deployment errors. The cancellation appears unrelated to the workflow changes and might be due to external factors.

Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify the successful execution of the updated workflow.

# Test: Check the latest workflow runs for any failures.
gh run list --workflow devtools-publish.yml --limit 5 --json name,conclusion

Length of output: 422


Script:

#!/bin/bash
# Fetch details of the failed and cancelled workflow runs to understand the reasons.
gh run view --workflow devtools-publish.yml --status failure --limit 1 --log
gh run view --workflow devtools-publish.yml --status cancelled --limit 1 --log

Length of output: 1635


Script:

#!/bin/bash
# List the run IDs for the failed and cancelled runs and fetch their details.

# Get the run ID for the most recent failed run
failed_run_id=$(gh run list --workflow devtools-publish.yml --limit 5 --json databaseId,conclusion | jq -r '.[] | select(.conclusion == "failure") | .databaseId' | head -n 1)

# Get the run ID for the most recent cancelled run
cancelled_run_id=$(gh run list --workflow devtools-publish.yml --limit 5 --json databaseId,conclusion | jq -r '.[] | select(.conclusion == "cancelled") | .databaseId' | head -n 1)

# Fetch details for the failed run
if [ -n "$failed_run_id" ]; then
  gh run view "$failed_run_id" --log
fi

# Fetch details for the cancelled run
if [ -n "$cancelled_run_id" ]; then
  gh run view "$cancelled_run_id" --log
fi

Length of output: 117495

examples/nextjs-scheduler/tsconfig.json (1)

23-25: Verify the correctness of path mappings.

The path mappings have been updated to include @yorkie-js-sdk/src/*. Ensure these mappings are correct and resolve to the intended modules within the monorepo structure.

Verification successful

Path mappings are correct.

The path mapping @yorkie-js-sdk/src/* in tsconfig.json is correctly set up and resolves to the intended modules. This is confirmed by its usage across multiple TypeScript files in the codebase.

Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify the correctness of the path mappings in tsconfig.json.

# Test: Check if the mapped paths exist in the file system. Expect: Paths should resolve correctly.
fd 'yorkie.ts' packages/sdk/src

Length of output: 58


Script:

#!/bin/bash
# Search for TypeScript files using the path alias `@yorkie-js-sdk/src/*` in their imports
rg --glob '*.ts' --glob '!node_modules' "from '@yorkie-js-sdk/src/" -A 1

Length of output: 57290

examples/react-tldraw/package.json (2)

20-20: Ensure compatibility with workspace reference.

The yorkie-js-sdk dependency has been changed to a workspace reference. Ensure that this change is compatible with the monorepo setup and that the package is correctly linked.


28-29: Check for compatibility with updated TypeScript and Vite versions.

The TypeScript and Vite versions have been significantly updated. Ensure that these updates do not introduce breaking changes and are compatible with the existing codebase.

Verification successful

Compatibility Verification for TypeScript and Vite Updates

The updated versions of TypeScript and Vite appear to be compatible with the existing configurations and plugins used in the codebase. Here are the key findings:

  • TypeScript Configuration: The tsconfig.json files use standard options that should be compatible with TypeScript 5.3.3. No deprecated or removed features were identified.
  • Vite Configuration: The Vite configuration files and plugins (vite-plugin-commonjs, vite-plugin-dts, vite-tsconfig-paths) seem to be compatible with Vite 5.0.12. No breaking changes were identified in the configuration or usage patterns.

Overall, the configurations and plugins do not indicate any immediate compatibility issues with the updated versions of TypeScript and Vite. However, it's always a good practice to run the actual build and test processes in a fully equipped environment to ensure everything works as expected.

Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify compatibility with updated TypeScript and Vite versions.

# Test: Check for any TypeScript compilation errors. Expect: No errors should be present.
pnpm tsc --noEmit

# Test: Ensure Vite can build the project without issues. Expect: Build should succeed.
pnpm vite build

Length of output: 181


Script:

#!/bin/bash
# Search for TypeScript configuration files to check for potential compatibility issues.
fd --type f --name "tsconfig.json" --exec cat {}

# Search for Vite configuration files to check for potential compatibility issues.
fd --type f --name "vite.config.*" --exec cat {}

# Search for TypeScript-specific syntax or features that might be incompatible with newer versions.
rg --lang typescript --pattern "namespace " -A 3

# Search for Vite-specific configurations or plugins that might be incompatible with newer versions.
rg "vite-plugin" -A 3

Length of output: 4025


Script:

#!/bin/bash
# Corrected search for TypeScript configuration files to check for potential compatibility issues.
fd 'tsconfig.json' --exec cat {}

# Corrected search for Vite configuration files to check for potential compatibility issues.
fd 'vite.config.*' --exec cat {}

# Search for TypeScript-specific syntax or features that might be incompatible with newer versions.
rg 'namespace ' -A 3

# Search for Vite-specific configurations or plugins that might be incompatible with newer versions.
rg 'vite-plugin' -A 3

Length of output: 10998

examples/vanilla-quill/src/utils.ts (1)

3-3: Verify the integration of YorkiePresence.

The type definition for displayLog now includes YorkiePresence. Ensure that this change aligns with the intended functionality and that all related code correctly handles the presence data.

.github/workflows/create-yorkie-app-publish.yml (4)

8-9: Update paths for monorepo structure.

The path updates from tools/create-yorkie-app/** to packages/create-yorkie-app/** reflect the new monorepo structure. Ensure all relevant files and directories are correctly moved and referenced.


24-24: Switch to pnpm for caching.

Switching the cache from npm to pnpm aligns with the transition to pnpm for package management. This should improve caching efficiency.


29-31: Use pnpm for installation and build.

The commands pnpm install and pnpm build replace the previous npm commands, which is consistent with the monorepo setup using pnpm. Ensure all scripts and dependencies are compatible with pnpm.


34-34: Update publish command to use pnpm.

The publish command now uses pnpm publish --provenance, reflecting the switch to pnpm. Verify that the provenance option is supported and correctly configured.

packages/devtools/package.json (3)

23-23: Shift yorkie-js-sdk to workspace reference.

Changing yorkie-js-sdk to "workspace:*" aligns with the monorepo structure, ensuring local development uses the latest package version. Verify that the workspace setup is correctly configured.


31-31: Upgrade TypeScript version.

Upgrading TypeScript to 5.3.3 introduces new features and improvements. Ensure that all TypeScript code is compatible with this version.


28-29: Downgrade React type definitions.

The downgrade of @types/react and @types/react-dom to 18.2.0 might affect compatibility. Ensure that this version is compatible with your React setup and doesn't introduce type issues.

package.json (4)

2-4: Update project metadata for monorepo.

The project name, version, and private flag updates reflect the transition to a monorepo structure. Ensure that all references to the old project name are updated.


8-20: Use pnpm for workspace management.

The scripts section now uses pnpm for workspace management, reflecting the monorepo setup. Ensure that all scripts are correctly defined and functional.


23-24: Update author and license information.

The author and license fields have been updated. Ensure that these changes are reflected in all relevant documentation and legal files.


6-6: Change main entry point.

The main entry point is now index.js, indicating a restructuring. Verify that this change aligns with the project's new file organization.

.github/workflows/npm-publish.yml (4)

14-16: LGTM: pnpm setup is correctly configured.

The setup for pnpm version 8 is appropriately added using the pnpm/action-setup action.


21-22: LGTM: Cache configuration for pnpm is correct.

The cache type and dependency path are correctly updated for pnpm.


25-32: LGTM: pnpm store caching is correctly configured.

The caching path and keys are appropriately set for pnpm.


36-39: LGTM: Commands updated to use pnpm.

The installation and build commands are correctly updated to use pnpm.

examples/README.md (3)

17-18: LGTM: Installation command updated to pnpm.

The command is correctly updated to use pnpm in the root directory.


24-28: LGTM: Running examples command updated to pnpm.

The documentation provides clear and flexible instructions for running examples using pnpm.


35-36: LGTM: Build command for releasing examples updated to pnpm.

The instructions are clear and correctly updated to use pnpm for building examples.

.github/workflows/github-page-publish.yml (3)

19-20: LGTM: Cache configuration for pnpm is correct.

The cache type and dependency path are correctly updated for pnpm.


22-29: LGTM: pnpm store caching is correctly configured.

The caching path and keys are appropriately set for pnpm.


33-40: LGTM: Commands updated to use pnpm.

The installation and build commands are correctly updated to use pnpm.

.github/workflows/ci.yml (6)

20-22: Correctly configured pnpm setup.

The pnpm setup step is correctly configured using pnpm/action-setup@v2 with version 8.


25-27: Correct Node.js setup with pnpm caching.

The Node.js setup step correctly configures caching for pnpm, optimizing the workflow.


29-36: Correct pnpm cache configuration.

The pnpm cache step is correctly configured with the path set to ~/.pnpm-store and appropriate cache keys.


39-41: Efficient dependencies installation with cache condition.

The dependencies installation step is efficiently conditioned on the cache hit, using pnpm install.


43-47: Correct use of pnpm for build and test steps.

The build and test steps correctly use pnpm commands, ensuring consistency with the new package manager.


55-57: Correct integration of Codecov and benchmark steps.

The Codecov and benchmark steps are correctly integrated using pnpm, aligning with the workflow changes.

packages/sdk/package.json (7)

2-5: Correctly specified package metadata.

The package metadata, including name, version, description, and entry point, is correctly specified.


6-13: Correct publish configuration and files setup.

The publishConfig and files array are correctly set up for package distribution.


14-26: Comprehensive scripts section.

The scripts section comprehensively covers build, test, lint, and other necessary tasks using pnpm.


28-30: Correctly specified engines.

The engines section correctly specifies minimum versions for Node.js and npm.


32-44: Accurate repository and author metadata.

The repository, author, license, bugs, and homepage fields are accurately specified.


45-70: Comprehensive devDependencies.

The devDependencies section includes necessary tools for building, testing, and linting.


72-82: Necessary dependencies and correctly configured husky hooks.

The dependencies are necessary for runtime, and husky hooks are correctly configured for pre-commit linting.

examples/react-todomvc/README.md (2)

22-23: Clear installation instructions with pnpm.

The installation instructions are clearly updated to use pnpm in the root directory.


29-33: Clear demo running instructions with pnpm options.

The demo running instructions provide clear options for using pnpm, depending on the directory.

examples/nextjs-scheduler/README.md (2)

22-23: Update dependency installation instructions.

The command for installing dependencies has been updated to use pnpm. Ensure that all users are aware of this change and have pnpm installed.


29-33: Clarify the demo execution instructions.

The instructions now specify that the demo can be run from either the root directory or the example directory. This provides flexibility but ensure users understand the context of each option.

CONTRIBUTING.md (7)

39-42: Ensure clarity in prerequisites.

The prerequisites section now specifies the required versions for Node.js and pnpm. This is crucial for avoiding compatibility issues.


47-48: Update package installation instructions.

The command for installing packages has been updated to use pnpm. Ensure contributors are aware of this change.


52-53: Update build instructions.

The build command has been updated to use pnpm. This aligns with the new monorepo structure.


63-64: Update proto message generation instructions.

The command for generating proto messages has been updated to use pnpm. Ensure contributors understand this change.


81-82: Update testing instructions.

The testing command has been updated to use pnpm. This is part of the transition to the new package manager.


118-119: Clarify test execution instructions.

The instructions now specify how to run specific test suites using pnpm. This is useful for targeted testing.


133-134: Update development server instructions.

The command for starting the development server has been updated to use pnpm. Ensure contributors are aware of this change.

examples/react-tldraw/src/hooks/useMultiplayerState.ts (1)

237-240: Improve clarity and safety in option construction.

The refactoring ensures that initialPresence is only included if app.currentUser is defined. This prevents potential errors and improves code readability.

pnpm-workspace.yaml Outdated Show resolved Hide resolved
@gwbaik9717
Copy link
Contributor Author

@chacha912
And finally, we are now able to use YorkieError in DevTools ! (related to #878 ).

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

Commits

Files that changed from the base of the PR and between ebd7a14 and a289c05.

Files selected for processing (4)
  • packages/devtools/src/devtools/contexts/SelectedNode.tsx (2 hunks)
  • packages/devtools/src/devtools/contexts/SelectedPresence.tsx (2 hunks)
  • packages/devtools/src/devtools/contexts/YorkieSource.tsx (4 hunks)
  • packages/sdk/src/util/error.ts (1 hunks)
Additional comments not posted (6)
packages/devtools/src/devtools/contexts/SelectedNode.tsx (1)

20-20: Enhanced error handling with YorkieError.

The change to use YorkieError with Code.ErrContextNotProvided improves error specificity and debugging clarity. Ensure YorkieError is consistently used across the codebase for similar contexts.

Also applies to: 44-45

packages/devtools/src/devtools/contexts/SelectedPresence.tsx (1)

20-20: Improved error handling with YorkieError.

The use of YorkieError with Code.ErrContextNotProvided enhances error clarity and consistency. Verify that YorkieError is used consistently for similar cases across the codebase.

Also applies to: 46-47

packages/sdk/src/util/error.ts (1)

60-61: Addition of ErrContextNotProvided to Code enum.

The new error code ErrContextNotProvided enhances the error handling capabilities by providing a specific identifier for missing React contexts.

packages/devtools/src/devtools/contexts/YorkieSource.tsx (3)

129-130: Improved Error Handling with YorkieError.

The use of YorkieError with Code.ErrContextNotProvided provides clearer context for errors, improving debugging and usage clarity.


140-143: Consistent Error Handling with YorkieError.

Switching to YorkieError enhances the semantic clarity of the error, ensuring consistency with other parts of the code.


176-177: Enhanced Error Context with YorkieError.

The use of YorkieError provides a more informative error message, aiding in better debugging and usage enforcement.

Copy link
Member

@hackerwins hackerwins left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for your contribution.
I will commit some necessary changes.

@hackerwins
Copy link
Member

hackerwins commented Aug 16, 2024

$ pnpm sdk test
...
 FAIL  test/integration/document_test.ts [ test/integration/document_test.ts ]
 FAIL  test/integration/object_test.ts [ test/integration/object_test.ts ]
 FAIL  test/integration/tree_test.ts [ test/integration/tree_test.ts ]
Error: Failed to load url chai (resolved id: chai) in /Users/hackerwins/Development/yorkie-team/yorkie-js-sdk/packages/sdk/test/helper/helper.ts. Does the file exist?

@hackerwins
Copy link
Member

$ pnpm sdk build:ghpages 

> yorkie-js-client@1.0.0 sdk /Users/hackerwins/Development/yorkie-team/yorkie-js-sdk
> pnpm --filter=yorkie-js-sdk "build:ghpages"


> yorkie-js-sdk@0.4.28 build:ghpages /Users/hackerwins/Development/yorkie-team/yorkie-js-sdk/packages/sdk
> mkdir -p ghpages/examples && cp -r docs ghpages/api-reference && find examples -name 'dist' -type d -exec sh -c 'cp -r {} ghpages/examples/$(basename $(dirname {}))' \;

cp: docs: No such file or directory
/Users/hackerwins/Development/yorkie-team/yorkie-js-sdk/packages/sdk:
 ERR_PNPM_RECURSIVE_RUN_FIRST_FAIL  yorkie-js-sdk@0.4.28 build:ghpages: `mkdir -p ghpages/examples && cp -r docs ghpages/api-reference && find examples -name 'dist' -type d -exec sh -c 'cp -r {} ghpages/examples/$(basename $(dirname {}))' \;`
Exit status 1
 ELIFECYCLE  Command failed with exit code 1.

Copy link

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Actionable comments posted: 0

Review details

Configuration used: CodeRabbit UI
Review profile: CHILL

Commits

Files that changed from the base of the PR and between a289c05 and 5651538.

Files selected for processing (5)
  • .github/workflows/create-yorkie-app-publish.yml (2 hunks)
  • .gitignore (1 hunks)
  • .npmrc (1 hunks)
  • packages/sdk/test/helper/helper.ts (1 hunks)
  • pnpm-workspace.yaml (1 hunks)
Files skipped from review due to trivial changes (1)
  • .gitignore
Files skipped from review as they are similar to previous changes (3)
  • .github/workflows/create-yorkie-app-publish.yml
  • .npmrc
  • pnpm-workspace.yaml
Additional comments not posted (1)
packages/sdk/test/helper/helper.ts (1)

17-17: Verify compatibility of assert.throws with vitest.

The import of assert has been changed from chai to vitest. Ensure that the assert.throws function used in assertThrowsAsync is compatible with vitest.

@hackerwins
Copy link
Member

hackerwins commented Aug 16, 2024

@chacha912 @gwbaik9717

It would be good to test after merging this PR to see if the examples are distributed properly on the homepage and work on it if necessary.

@hackerwins hackerwins merged commit e84ba27 into yorkie-team:main Aug 16, 2024
1 check passed
hackerwins added a commit that referenced this pull request Aug 16, 2024
Workspace:

```
examples/
- nextjs-scheduler
- profile-stack
- react-tldraw
- react-todomvc
- simultaneous-cursors
- vanilla-codemirror6
- vanilla-quill
- vuejs-kanban

packages/
- create-yorkie-app
- devtools
- sdk                  <-- previous yorkie-js-sdk package
```

Command:

```
`sdk`
- [x] pnpm sdk build
- [x] pnpm sdk build:proto
- [x] pnpm sdk build:docs
- [x] pnpm sdk build:ghpages
- [x] pnpm sdk dev
- [x] pnpm sdk test
- [x] pnpm sdk test:watch
- [x] pnpm sdk test:bench
- [x] pnpm sdk test:ci
- [x] pnpm sdk test:yorkie.dev
- [x] pnpm sdk lint
- [x] pnpm sdk prepare

`devtools`
- [x] pnpm devtools dev
- [x] pnpm devtools build
- [x] pnpm devtools test

`create-yorkie-app`
- [x] pnpm create-yorkie-app start
- [x] pnpm create-yorkie-app build
- [x] pnpm create-yorkie-app build:copy-assets
```

---------

Co-authored-by: Youngteac Hong <susukang98@gmail.com>
hackerwins added a commit that referenced this pull request Aug 16, 2024
Workspace:

```
examples/
- nextjs-scheduler
- profile-stack
- react-tldraw
- react-todomvc
- simultaneous-cursors
- vanilla-codemirror6
- vanilla-quill
- vuejs-kanban

packages/
- create-yorkie-app
- devtools
- sdk                  <-- previous yorkie-js-sdk package
```

Command:

```
`sdk`
- [x] pnpm sdk build
- [x] pnpm sdk build:proto
- [x] pnpm sdk build:docs
- [x] pnpm sdk build:ghpages
- [x] pnpm sdk dev
- [x] pnpm sdk test
- [x] pnpm sdk test:watch
- [x] pnpm sdk test:bench
- [x] pnpm sdk test:ci
- [x] pnpm sdk test:yorkie.dev
- [x] pnpm sdk lint
- [x] pnpm sdk prepare

`devtools`
- [x] pnpm devtools dev
- [x] pnpm devtools build
- [x] pnpm devtools test

`create-yorkie-app`
- [x] pnpm create-yorkie-app start
- [x] pnpm create-yorkie-app build
- [x] pnpm create-yorkie-app build:copy-assets
```

---------

Co-authored-by: Youngteac Hong <susukang98@gmail.com>
hackerwins added a commit that referenced this pull request Aug 16, 2024
Workspace:

```
examples/
- nextjs-scheduler
- profile-stack
- react-tldraw
- react-todomvc
- simultaneous-cursors
- vanilla-codemirror6
- vanilla-quill
- vuejs-kanban

packages/
- create-yorkie-app
- devtools
- sdk                  <-- previous yorkie-js-sdk package
```

Command:

```
`sdk`
- [x] pnpm sdk build
- [x] pnpm sdk build:proto
- [x] pnpm sdk build:docs
- [x] pnpm sdk build:ghpages
- [x] pnpm sdk dev
- [x] pnpm sdk test
- [x] pnpm sdk test:watch
- [x] pnpm sdk test:bench
- [x] pnpm sdk test:ci
- [x] pnpm sdk test:yorkie.dev
- [x] pnpm sdk lint
- [x] pnpm sdk prepare

`devtools`
- [x] pnpm devtools dev
- [x] pnpm devtools build
- [x] pnpm devtools test

`create-yorkie-app`
- [x] pnpm create-yorkie-app start
- [x] pnpm create-yorkie-app build
- [x] pnpm create-yorkie-app build:copy-assets
```

---------

Co-authored-by: Youngteac Hong <susukang98@gmail.com>
hackerwins added a commit that referenced this pull request Aug 16, 2024
Workspace:

```
examples/
- nextjs-scheduler
- profile-stack
- react-tldraw
- react-todomvc
- simultaneous-cursors
- vanilla-codemirror6
- vanilla-quill
- vuejs-kanban

packages/
- create-yorkie-app
- devtools
- sdk                  <-- previous yorkie-js-sdk package
```

Command:

```
`sdk`
- [x] pnpm sdk build
- [x] pnpm sdk build:proto
- [x] pnpm sdk build:docs
- [x] pnpm sdk build:ghpages
- [x] pnpm sdk dev
- [x] pnpm sdk test
- [x] pnpm sdk test:watch
- [x] pnpm sdk test:bench
- [x] pnpm sdk test:ci
- [x] pnpm sdk test:yorkie.dev
- [x] pnpm sdk lint
- [x] pnpm sdk prepare

`devtools`
- [x] pnpm devtools dev
- [x] pnpm devtools build
- [x] pnpm devtools test

`create-yorkie-app`
- [x] pnpm create-yorkie-app start
- [x] pnpm create-yorkie-app build
- [x] pnpm create-yorkie-app build:copy-assets
```

---------

Co-authored-by: Youngteac Hong <susukang98@gmail.com>
hackerwins added a commit that referenced this pull request Aug 16, 2024
Workspace:

```
examples/
- nextjs-scheduler
- profile-stack
- react-tldraw
- react-todomvc
- simultaneous-cursors
- vanilla-codemirror6
- vanilla-quill
- vuejs-kanban

packages/
- create-yorkie-app
- devtools
- sdk                  <-- previous yorkie-js-sdk package
```

Command:

```
`sdk`
- [x] pnpm sdk build
- [x] pnpm sdk build:proto
- [x] pnpm sdk build:docs
- [x] pnpm sdk build:ghpages
- [x] pnpm sdk dev
- [x] pnpm sdk test
- [x] pnpm sdk test:watch
- [x] pnpm sdk test:bench
- [x] pnpm sdk test:ci
- [x] pnpm sdk test:yorkie.dev
- [x] pnpm sdk lint
- [x] pnpm sdk prepare

`devtools`
- [x] pnpm devtools dev
- [x] pnpm devtools build
- [x] pnpm devtools test

`create-yorkie-app`
- [x] pnpm create-yorkie-app start
- [x] pnpm create-yorkie-app build
- [x] pnpm create-yorkie-app build:copy-assets
```

---------

Co-authored-by: Youngteac Hong <susukang98@gmail.com>
hackerwins added a commit that referenced this pull request Aug 16, 2024
Workspace:

```
examples/
- nextjs-scheduler
- profile-stack
- react-tldraw
- react-todomvc
- simultaneous-cursors
- vanilla-codemirror6
- vanilla-quill
- vuejs-kanban

packages/
- create-yorkie-app
- devtools
- sdk                  <-- previous yorkie-js-sdk package
```

Command:

```
`sdk`
- [x] pnpm sdk build
- [x] pnpm sdk build:proto
- [x] pnpm sdk build:docs
- [x] pnpm sdk build:ghpages
- [x] pnpm sdk dev
- [x] pnpm sdk test
- [x] pnpm sdk test:watch
- [x] pnpm sdk test:bench
- [x] pnpm sdk test:ci
- [x] pnpm sdk test:yorkie.dev
- [x] pnpm sdk lint
- [x] pnpm sdk prepare

`devtools`
- [x] pnpm devtools dev
- [x] pnpm devtools build
- [x] pnpm devtools test

`create-yorkie-app`
- [x] pnpm create-yorkie-app start
- [x] pnpm create-yorkie-app build
- [x] pnpm create-yorkie-app build:copy-assets
```

---------

Co-authored-by: Youngteac Hong <susukang98@gmail.com>
@krapie krapie added the enhancement 🌟 New feature or request label Oct 10, 2024
@coderabbitai coderabbitai bot mentioned this pull request Dec 19, 2024
2 tasks
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement 🌟 New feature or request
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

Introduce monorepo to manage packages
3 participants