logo of awesome-posthtml repository

Awesome PostHTML

A curated list of awesome things related to PostHTML

Awesome

TEXT

NameStatusDescription
posthtml-mdnpmEasily use context-sensitive markdown within HTML
posthtml-tocnpmTable of contents
posthtml-loremnpmAdd lorem ipsum placeholder text to any document
posthtml-retextnpmExtensible system for analysing and manipulating natural language
prevent-widowsnpmPrevent widows from appearing at the end of paragraphs
posthtml-richtyponpmProcess HTML node text with Richtypo

HTML

NameStatusDescription
posthtml-doctypenpmSet !DOCTYPE
posthtml-head-elementsnpmInclude head elements from JSON file
posthtml-includenpmInclude HTML
posthtml-modulesnpmInclude and process HTML
posthtml-extendnpmExtend Layout (Pug-like)
posthtml-extend-attrsnpmExtend Attrs
posthtml-expressionsnpmTemplate Expressions
posthtml-inline-assetsnpmInline external scripts, styles, and images
posthtml-static-reactnpmRender custom elements as static React components
posthtml-custom-elementsnpmUse custom elements
posthtml-web-componentnpmWeb Component server-side rendering, Component as a Service (CaaS)
posthtml-spacelessnpmRemove whitespace between HTML tags
posthtml-cachenpmAdd a nanoid to links in your tags
posthtml-highlightnpmSyntax highlight code elements
posthtml-pseudonpmAdd pseudo selector class names to elements
posthtml-noopenernpmAdd rel="noopener noreferrer" to links that open in new tab
posthtml-noscriptnpmInsert noscript content when JavaScript is disabled
posthtml-hashnpmHash static CSS/JS assets
posthtml-insert-atnpmAppend/prepend HTML to a selector
posthtml-plugin-remove-duplicatesnpmRemove duplicated tags
posthtml-plugin-link-preloadnpmAdd preload/prefetch tags (or return equivalent headers)
posthtml-prismnpmCode syntax highlighting with Prism
posthtml-url-parametersnpmAdd parameters to URLs
posthtml-safe-class-namesnpmReplace escaped characters in class names and CSS selectors
posthtml-fetchnpmFetch and render remote content
posthtml-msonpmMakes it easy to write Outlook conditionals in HTML emails
posthtml-postcss-merge-longhandnpmMerge longhand inline CSS into shorthand
posthtml-markdownitnpmTransform Markdown using markdown-it
posthtml-extra-attributesnpmAdd new attributes to elements in your HTML
posthtml-srinpmAdds subresource integrity (SRI) attributes.

CSS

NameStatusDescription
posthtml-bemnpmSupport BEM naming in html structure
posthtml-postcssnpmUse PostCSS in HTML document
posthtml-px2remnpmChange px to rem in Inline CSS
posthtml-css-modulesnpmUse CSS modules in HTML
posthtml-postcss-modulesnpmCSS Modules in html
posthtml-classesnpmGet a list of classes from HTML
posthtml-prefix-classnpmPrefix class names
posthtml-modular-cssnpmMake CSS modular
posthtml-inline-cssnpmCSS Inliner
posthtml-collect-stylesnpmCollect styles from html and put it in the head
posthtml-collect-inline-stylesnpmCollect inline styles and insert to head tag
posthtml-style-expantionnpmPostHTML plugin expand link rel="stylesheet".
posthtml-style-to-filenpmSave HTML style nodes and attributes to CSS file
posthtml-color-shorthand-hex-to-six-digitnpmEnforce all hex color codes to be 6-char long
posthtml-minify-classnamesnpmRewrites classnames and ids inside of html and css files to reduce file size.

IMG & SVG

NameStatusDescription
posthtml-img-autosizenpmAuto setting the width and height of <img>
posthtml-to-svg-tagsnpmConvert html tags to svg equivalents
posthtml-webpnpmAdd WebP support for images
posthtml-faviconsnpmGenerate Favicons and add related tags
posthtml-inline-svgnpmInline svg icons in HTML
posthtml-inline-faviconnpmInline favicons in HTML

Accessibility

NameStatusDescription
posthtml-aria-tabsnpmWrite accessible tabs with minimal markup
posthtml-alt-alwaysnpmAlways add alt attribute for images that don't have it
posthtml-schemasnpmAdd microdata to your HTML

Optimization

NameStatusDescription
posthtml-shortennpmShorten URLs in HTML
posthtml-uglifynpmShorten CSS in HTML
posthtml-minifiernpmMinify HTML
posthtml-remove-attributesnpmRemove attributes unconditionally or with content match
posthtml-remove-tagsnpmRemove tags with content match
posthtml-remove-duplicatesnpmRemove duplicate elements from your html
posthtml-transformernpmProcess HTML by directives in node attrs, such as inline scripts and styles, remove useless tags, concat scripts and styles etc.
htmlnanonpmHTML Minifier
posthtml-link-noreferrernpmAdd rel="noopener" and rel="noreferrer" to all links that contain the attribute target="_blank"
posthtml-lazyloadnpmAdd native lazyload attribute
posthtml-postcss-treeshakernpmTree shake styles for classes and ids in style tag
posthtml-external-linknpmAdd rel="external noopenner nofollow" and target="_blank" to all external links

Workflow

NameStatusDescription
posthtml-load-pluginsnpmAutoload Plugins
posthtml-load-optionsnpmAutoload Options (Parser && Render)
posthtml-load-confignpmAutoload Config (Plugins && Options)
posthtml-w3cnpmValidate HTML with W3C Validation
posthtml-hintnpmLint HTML with HTML Hint
posthtml-tidynpmSanitize HTML with HTML Tidy

Middleware

NameStatusDescription
koa-posthtmlnpmKoa Middleware
hapi-posthtmlnpmHapi Plugin
express-posthtmlnpmExpress Middleware
electron-posthtmlnpmElectron Plugin
metalsmith-posthtmlnpmMetalsmith Plugin