@livepreso/webpack-deck

3.5.0 • Public • Published

Webpack config for LivePreso Content Development

How does it work?

Two plugins live at the heart of this project

LivePresoProjectPlugin

This reads your project.yaml file and automatically generates base index.html files in a structure the LivePreso servers expect. For example if your project.yaml has the following:

key: test_section_1
title: 'Test Section 1'
slides:
	- {key: 'test_slide_1', title: 'Test Slide 1'}
	- {key: 'test_slide_2', title: 'Test Slide 2'}

Then the output would look like the following:

sections
└── test_section_1
		├── index.html
		└── slides
				├── test_slide_1
				│   └── index.html
				└── test_slide_2
						└── index.html

This can be found in plugins/project.js and could be included manually in your webpack config like so:

const { ProjectPlugin } = require("@livepreso/webpack");

module.exports = {
	plugins: {
		new ProjectPlugin()
	}
}

Postcss Prefixer

This is a postcss plugin that is used to prevent bleeding of global styles from affecting elements outside of the presentation. Essentially it adds #slideshow to the start of most styles.

It could be manually added to your config like so:

const { LivePresoPostCSSPrefixer } = require("@livepreso/webpack-deck");

// In your webpack rules...
rules: [
	{
		test: /\.s[ac]ss/i,
		use: [
			"css-loader",
			{
				loader: "postcss-loader",
				options: {
					postcssOptions: {
						plugins: [LivePresoPostCSSPrefixer],
					},
				},
			},
			"sass-loader",
		],
	},
],

Readme

Keywords

none

Package Sidebar

Install

npm i @livepreso/webpack-deck

Weekly Downloads

11

Version

3.5.0

License

ISC

Unpacked Size

20.9 kB

Total Files

8

Last publish

Collaborators

  • ahoddinott
  • bennullgraham