Update 21-11-2018: As documented on the pnpm FAQs, a simpler way to use pnpm is to use the “–shamefully-flatten” flag. This will create a flat node_modules structure similar to npm and yarn.
The instructions below are relevant if you do not want to use the “–shamefully-flatten”, but be aware that you will end up modifying the package.json file.
UPDATE: Unfortunately all images for this post were lost when I had to migrate the content of the blog. Hope you still find this post useful
Original Post
About 2 weeks ago, I published a blog post on how to use pnpm with SPFx 1.6.0 and the required steps to have a working solution.
Today, I was reviewing the comments and noticed someone was having issues with SPFx 1.7.0, so decided to give it a go.
Disclaimer: tested on Windows 10 only, using SPFx 1.7.0.
When you scaffold a new SPFx 1.7.0 project using pnpm, you will get the following error when trying to build it
data:image/s3,"s3://crabby-images/7e164/7e164810f64ee2bdc5cfdfddef5f94f6e2545ab4" alt=""
Inspecting the tslint.json file made it clear that there was some changes between SPFx 1.6.0 and 1.7.0:
SPFx 1.6.0
data:image/s3,"s3://crabby-images/3fbb6/3fbb6109760a8f6493aa1b97b3a2f47b888eba5f" alt=""
SPFx 1.7.0
data:image/s3,"s3://crabby-images/01933/01933f329f9529d1352dd2408e96a8de4355627f" alt=""
Opening the base-tslint.json file referenced, we can see tslint-microsoft-contrib under rulesDirectory.
Taking the same approach as per the article for SPFx 1.6.0, I installed the following modules
pnpm i tslint-microsoft-contrib@5.2.1 -DE
pnpm i tslint@5.9.1 -DE
pnpm i typescript@2.4.2 -DE
And voilà, the project is now building without errors
data:image/s3,"s3://crabby-images/81867/81867d7855cc6bf65ef4bd2b12f22e06900acf7d" alt=""
Have you looked at the Office 365 CLI for upgrade steps? I find it very helpful.
M.
In which context? Related to pnpm usage?
I did use it a few times in the past and I agree, it’s very useful 🙂 I have a PR pending for both PnP reusable controls projects to upgrade to SPFx 1.6.0 and the CLI was a major help as the projects were 1.2.0 and 1.3.0 – aka lot’s of required changes 🙂
I’d consider instead using the “–shamefully-flatten” flag when using PNPM as that’s the more correct way to address things. Eventually, when the dependencies aren’t screwed up, this can be dropped, but you won’t have a dirtied up package.json with unnecessary references.
Thanks for the feedback AC. I should have made it clear that the instructions are only for when the –shamefully-flatten flag is not used and also add a note regarding the “dirty” package.json file. Will update the post when I get a few minutes