This is the monorepo of the JW Player plugins that @hahow is using.
powered by:
- Turborepo — High-performance build system for Monorepos
- Storybook — UI component environment powered by Vite
- Tsup — TypeScript bundler powered by esbuild
- Changesets - for managing versioning and changelogs
- GitHub Actions - for fully automated package publishing
As well as a few others tools preconfigured:
- TypeScript for static type checking
- ESLint for code linting
- Prettier for code formatting
This turborepo uses npm as a package manager. It includes the following packages/apps:
apps/docs
: a Storybook apppackages/jwplayer-plugins-full-viewport
: a JW Player plugin that allows users to switch the video player to full-viewport size modepackages/jwplayer-plugins-screenshot
: a JW Player plugin that allows users to capture the current frame and download it as a PNG imagepackages/jwplayer-plugins-track-notes
: a JW Player plugin that allows users to mark notes on the player's timelinepackages/jwplayer-plugins-watermark
: a JW Player plugin that allows to display watermarks on the video playerpackages/eslint-config-custom
:eslint
configurations (includeseslint-config-prettier
)packages/tsconfig
:tsconfig.json
s used throughout the monorepo
Please refer to the Documentation
- Clone the repo
git clone [email protected]:hahow/jwplayer-plugins.git
- Install NPM packages
npm install
npm run build
- Build all packages including the Storybook sitenpm run dev
- Run all packages locally and preview with Storybooknpm run lint
- Lint all packagesnpm run clean
- Clean up all node_modules and dist folders (runs each package's clean script)npm run changeset
- Generate a changeset
Turborepo enables us to "hoist" dependencies that are shared between packages to the root package.json
. This means smaller node_modules
folders and a better local dev experience. To install a dependency for the entire monorepo, use the -w
workspaces flag with npm install
:
# Install npm package only for apps/docs
npm install some-package -w=docs
# Install npm package only for packages/jwplayer-plugin-watermark
npm install some-package -w=packages/jwplayer-plugin-watermark
# Linting apps/docs
npm run lint -w=docs
# Build the specified package
npm run build -w=packages/jwplayer-plugin-watermark
This repository uses Changesets to manage versions, create changelogs, and publish to npm. It's preconfigured so you can start publishing packages immediately.
To generate your changelog, run npm run changeset
locally:
- Which packages would you like to include? – This shows which packages and changed and which have remained the same. By default, no packages are included. Press
space
to select the packages you want to include in thechangeset
. - Which packages should have a major bump? – Press
space
to select the packages you want to bump versions for. - If doing the first major version, confirm you want to release.
- Write a summary for the changes.
- Confirm the changeset looks as expected.
- A new Markdown file will be created in the
changeset
folder with the summary and a list of the packages included.
When you merge your code to GitHub, the GitHub Action will run the release
script defined in the root package.json
.