adding-quill-to-your-build-pipeline.mdx 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. ---
  2. title: Adding Quill to Your Build Pipeline
  3. ---
  4. Each version of Quill is built and ready to use from a variety of sources, including [NPM](https://www.npmjs.com/package/quill) or its [CDN](/docs/download/). However there may be use cases where you would like to build Quill from source, as part of your application's build pipeline. If this desire has not occurred to you, don't sweat it! Using pre-built versions is the easiest way to use Quill.
  5. Quill is built using [Webpack](https://webpack.js.org/concepts/) and this guide is mostly targeted towards Webpack users. However some principles may translate to other build environments.
  6. A minimal working example of everything covered in this guide can be found at [quill-webpack-example](https://github.com/quilljs/webpack-example/).
  7. ### Webpack
  8. You will need to add Webpack and appropriate loaders as development dependencies to your app. The Typescript compiler is necessary if you want to build Parchment from source as well.
  9. - Quill source code - [`babel-core`](https://www.npmjs.com/package/babel-core), [`babel-loader`](https://www.npmjs.com/package/babel-loader), [`babel-preset-es2015`](https://www.npmjs.com/package/babel-preset-es2015)
  10. - Parchment source code - [`ts-loader`](https://www.npmjs.com/package/ts-loader), [`typescript`](https://www.npmjs.com/package/typescript)
  11. Your Webpack configuration file will also need to alias Quill and Parchment to point to their respective entry source files. Without this, Webpack will use the pre-built files included in NPM, instead of building from source.
  12. ### Entry
  13. Quill is distributed with builds `quill.js` and `quill.core.js`. The purpose of the entry files for both builds, [quill.js](https://github.com/quilljs/quill/blob/master/quill.js) and [core.js](https://github.com/quilljs/quill/blob/master/core.js), is to import and register necessary dependencies. You will likely want a similar entry point in your application that includes only the formats, modules, or themes that you use.
  14. ```js
  15. import Quill from 'quill/core';
  16. import Toolbar from 'quill/modules/toolbar';
  17. import Snow from 'quill/themes/snow';
  18. import Bold from 'quill/formats/bold';
  19. import Italic from 'quill/formats/italic';
  20. import Header from 'quill/formats/header';
  21. Quill.register({
  22. 'modules/toolbar': Toolbar,
  23. 'themes/snow': Snow,
  24. 'formats/bold': Bold,
  25. 'formats/italic': Italic,
  26. 'formats/header': Header
  27. });
  28. export default Quill;
  29. ```
  30. ### Stylesheets
  31. There is not as much to benefit from building from source in the realm of stylesheets, since rules can be so easily overwritten. However, [`css-loader`](https://www.npmjs.com/package/css-loader)'s tilde prefix may be useful to include Quill styles in a your application css file.
  32. ```css
  33. @import "~quill/dist/quill.core.css"
  34. // Rest of your application CSS
  35. ```
  36. ### Example
  37. Take a look at [quill-webpack-example](https://github.com/quilljs/webpack-example/) for a minimal working example.