Tsdx: Add a monorepo template?

Created on 30 May 2019  路  7Comments  路  Source: formium/tsdx

Current Behavior

Currently, users can scaffold out a monorepo manually, then add tsdx as a dependency at the root of the project.

Desired Behavior

Users should be able to scaffold out a monorepo project using npx tsdx create. Just like the current templates, users could pass a flag or select from the interactive prompt.

Suggested Solution

Create two new templates, monorepo-basic and monorepo-react. In both cases, the only additional dependency would be lerna. The root package.json scripts would use lerna run command and any packages would use tsdx command.

1) Add these options directly to the create template prompt and add CLI flags for each.

2) Add an additional prompt to the create command which allows you to select a project structure (basic or monorepo?) and add a 鈥攎onorepo CLI flag which will automatically resolve the monorepo templates.

Who does this impact? Who is this for?

This feature would be very beneficial for anyone managing a larger project who wishes to leverage both tsdx and lerna.

Describe alternatives you've considered

If this use case seems out of scope, improving the documentation around integrating with lerna would be helpful to guide users through manual setup.

As a possible alternative, tsdx could become monorepo-aware so that running npx tsdx create mylib from within a monorepo could scaffold out a new package in the packages/ (or configured in lerna.json) directory.

Additional context

I have created a minimal tsdx-monorepo example project.

I would be happy to contribute to this feature, but I want to collect feedback and hash out the preferred approach before starting.

feature templates monorepo

Most helpful comment

Update: I just moved formik into a monorepo powered by tsdx (with both React native and react packages). Should be a good test bed. We DEF want to bake this in because it was huge pain to setup with VSCode.

All 7 comments

Update: I just moved formik into a monorepo powered by tsdx (with both React native and react packages). Should be a good test bed. We DEF want to bake this in because it was huge pain to setup with VSCode.

what were the VSCode specific pain points?

@jaredpalmer Is that something you can blog about?

@jaredpalmer - any updates on the baked-in monorepo setup? Interested to see what you encountered... Thanks.

Update: I just moved formik into a monorepo powered by tsdx (with both React native and react packages). Should be a good test bed. We DEF want to bake this in because it was huge pain to setup with VSCode.

In the meantime, we can look at the formik repo as a reference https://github.com/formik/formik

Looks like #778 should cover it and I'm also using TSDX in a lerna monorepo with yarn workspaces here.

@kylemh since #778 doesn't actually add the full workflow with tsdx create and replacing naming etc, I wouldn't say this is resolved until then. #778 probably resolves the lesser #275 however.

Was this page helpful?
0 / 5 - 0 ratings

Related issues

bastibuck picture bastibuck  路  5Comments

MarceloAlves picture MarceloAlves  路  4Comments

SeedyROM picture SeedyROM  路  5Comments

xaviergonz picture xaviergonz  路  3Comments

vberlier picture vberlier  路  5Comments