Skip to content

Latest commit

 

History

History
475 lines (332 loc) · 33.3 KB

CHANGELOG.md

File metadata and controls

475 lines (332 loc) · 33.3 KB

Changelog

All notable changes to Bridgetown will be documented in this file.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

Unreleased

.

0.21.4 - 2021-09-10

Fixed

Changed

  • Resolve postcss-focus-within to v4 #366 (ayushn21)
  • Performance refactor of the Webpack helper #382 (jaredcwhite)
  • Several documentation improvments thanks to JuanVqz and debashis-biswal

0.21.3 - 2021-08-06

Fixed

  • Resource: switch from default proc to preemptive defaults #359 (jaredcwhite)
  • Ensure there aren't double-slashes in pagination links (jaredcwhite)
  • Ensure summary content is html safe (jaredcwhite)

0.21.2 - 2021-07-21

Fixed

  • Add missing comma in package.json which broken install #354

0.21.1 - 2021-07-19

Added

Fixed

  • Unintentional overwriting of data when using the Resource content engine #343 (jaredcwhite)
  • Bug where in Liquid the next_resource method would mistakenly return the previous resource

Changed

  • Configure sites in subfolders via base_path, not baseurl #348 (jaredcwhite)
  • Swap babel for ESBuild and upgrade to Webpack 5 #334 (ayushn21)
  • Change postcss.config.js stage from 3 to 2 #349 (juhat) Read the Docs
  • Various improvements to the new Webpack config documentation

0.21.0 - 2021-06-01

Final release of 0.21.0! See below for full changelog.

Fixed

0.21.0.beta4 - 2021-05-30

Added

  • Memoization for caching templates in Bridgetown::Component #326 (jaredcwhite)
  • layout method in Resource::Base #324 (jaredcwhite)
  • Include Bridgetown version in Webpack defaults #322 (ayushn21)
  • Confirmation for overwriting postcss config in tailwindcss and bt-postcss bundled configurations #317 (ayushn21)
  • Create new config directory and move Webpack defaults into it #316 (ayushn21)

Changed

  • Fix the Bridgetown logger and other test improvements #328 (ayushn21)
    • NOTE: the Configuration file log message is now output with a debug log level instead of info. This means you will no longer see the config path in your terminal/logs unless you use the --verbose flag.

Fixed

  • Install required packages in Webpack enable postcss tool #319 (ayushn21)
  • Update Babel configuration to prevent overt warning #314 (ayushn21)
  • Resolve issue with zombie templates in Pagination/Prototype logic
  • Locale files now reload when the site regenerates

0.21.0.beta3 - 2021-05-15

Changed

  • Switch to using a Keep a Changelog format.
  • Switch plugins new command to use MiniTest from the sample plugin repo.
  • Make configure command use Thor's apply method directly #293 (ayushn21)

Fixed

  • Resources configured not to output to a destination are now transformed as expected.
  • The previous_resource method now returns the proper resource.
  • Fix warnings in plugin tests by checking if an ivar was defined #296 (ayushn21)
  • Ensure Netlify script is set to executable. #302 (ayushn21)
  • Consider the default branch from the git config when creating a new site or plugin. #294 (ayushn21)

Removed

  • A bunch of global config accessors on site (like lsi, keep_files, etc.)
  • Remove safe_yaml gem in favour of using Psych which is in the stdlib. #303 (ayushn21)

0.21.0.beta2 - 2021-05-08

  • Refactor old TODOs and deprecations
  • Remove deprecated sassify/scssify filters, add html_safe to the obfuscate_link helper
  • Fix dotfiles or multiple extension permalinks (for the resource content engine) #292 (jaredcwhite)

0.21.0.beta1 - 2021-04-25

0.20.0 - 2021-03-15

  • EXPERIMENTAL (and opt-in): the Great Resource Content Engine PR has been merged. 135 files changed. Holy guacamole! #243 (jaredcwhite) Read the Docs
  • Further improved Webpack integration by allowing multiple entry points and loading any manifest item with webpack_path helper #247 (jaredcwhite) Docs
  • Exclude current post from LSI-powered related posts #253 (katafrakt)
  • The inspect string for Bridgetown::Site is now lean and clean.
  • The history bug with the bridgetown console has been fixed! Now pressing your up arrow after entering the console will pull up all previous commands entered. Up, up, and away!
  • Support added for upcoming gem bridgetown-mdjs which will allow inline JS code blocks in Markdown similar in purpose to MDX (but for web components and other HTML-native solutions). Stay tuned!

0.19.3 - 2021-02-11

0.19.2 - 2021-02-05

  • Introducing bundled configurations! Now some popular automations, including enhanced PostCSS and Tailwind CSS setups, are available directly through the Bridgetown CLI rather than being in a separate automations repo. Documentation here. Thanks Ayush
  • Upgrade to Liquid 5.0 and remove previous backported render tag #224 (jaredcwhite)
    • Breaking Change: when using the where filter, the literals ""``, blank, and empty` are now all equivalent.
  • New plugin generator now prefers main over master for default branch name #225 (ayushn21)
  • Use ActiveSupport::DescendantsTracker for managing class hierarchies of plugins (converters, builders, and generators) #218 (jaredcwhite)
  • Lots of documentation improvements — thanks Juan, Taha, and Ayush.

0.19.1 - 2020-12-26

  • Website: Fix a grammar error in the Jamstack.md page on Bridgetown website (taha)

  • Fix for issue #73 (less likely to hit ActiveSupport error when bridgetown command is run without bundle exec prefixed)

0.19.0 - 2020-12-22

  • Improve our active ActiveSupport support =) #215 (jaredcwhite)
  • Add filters_scope option to liquid_filter DSL #214 (jaredcwhite)
  • Deprecate PageWithoutAFile class. It will be removed in v0.20.
  • Specify Webrick as a gem dependency now that it's no longer in the stdlib in Ruby 3
  • Website: documentation on how to install Bridgetown in Fedora (bkmgit)
  • Add modules resolve paths to default webpack config #206 (ayushn21)
  • Add an empty PostCSS configuration option to the "new" command #190 (ayushn21)
  • Fix obfuscate link syntax #203 julianrubisch)
  • Website: Fix class declaration keyword in liquid tags and helpers docs #198 (ayushn21)
  • Website: The Great Unification (removing all div-ision-s) #191 (jaredcwhite)
  • Website: Fix typo in generators page in docs #195 (ayushn21)
  • Add mailto:--tag to generated footer #192 (pascalwengerter)
  • Change the name attribute of the default package.json to be inferred from the path passed to bridgetown new #188 (ayushn21)

0.18.6 - 2020-11-12

  • Change the logging level for "Executing inline Ruby…" messages to the debug level #184 (ianbayne)
  • Add yarn clean script to package.json #182 (andrewmcodes)
  • Fix dash obfuscation in obfuscate filter #181 julianrubisch)
  • Ensure HashWithDotAccess converts to Hash for Liquid templates

0.18.5 - 2020-11-09

  • Bugfix: use HashWithDotAccess when parsing JSON in the HTTP Builder DSL

0.18.4 - 2020-11-05

  • Bugfix: reset payload for each Liquid template conversion
  • Change site.layouts hash to dot access

0.18.3 - 2020-11-01

  • Bugfix: For template engine converters, set template_engine frontmatter automatically #177 (jaredcwhite)

0.18.2 - 2020-10-30

  • Bugfix: Resolve bug in converter error notifications

0.18.1 - 2020-10-29

0.18.0 - 2020-10-29

  • Configurable template engines on a per-site or per-document basis #157 (jaredcwhite)
    • Set a template_engine key in your config file. The default is assumed to be liquid, but you can change it to erb (or other things in the future as this gets rolled out). Once that is set, you don't even have to name all your ERB files with an .erb extension—it will process even .html., .md, .json, etc. It also means Liquid won't try to "preprocess" any ERB files, etc.
    • Regardless of what is configured site-wide, you can also set the template_engine in front matter (whether that's in an individual file or using front matter defaults), allowing you to swap out template engines wherever it's needed.
    • Front matter defaults support setting template_engine to none or anything else for a part of the source tree.
    • Liquid pages/layouts with a .liquid extension are processed as Liquid even if the configured engine is something else.
    • Breaking change: previously it was possible in Liquid for a child layout to set a front matter variable and a parent layout to access the child layout's variable value, aka {{ layout.variable_from_child_layout }}. That's no longer the case now…each layout has access to only its own front matter data.
    • Breaking change: a few pre-render hooks were provided access to Liquid's global payload hash. That meant they could alter the hash and thus the data being fed to Liquid templates. The problem is that there was no visibility into those changes from any other part of the system. Plugins accessing actual page/layout/site/etc. data wouldn't pick up those changes, nor would other template engines like ERB. Now if a hook needs to alter data, it needs to alter actual Ruby model data, and Liquid's payload should always reflect that model data.
  • Add render method for Ruby templates #169 (jaredcwhite)
    • Add Zeitwerk loaders for component folders (any *.rb file will now be accessible from Ruby templates). Note: Zeitwerk will not load classes from plugins if they're already present in the source folder, so if you want a component to "reopen" a class from a plugin, you'll need to require the plugin class explicitly in your local component.
    • Allow ERB capture to pass object argument to its block.
    • Breaking change: the previous <%|= output_block do %>…<%| end %> block style is out in favor of: <%= output_block do %>…<% end %>, so you don't have to change a thing coming from Rails. Note: if you're coming from Middleman where blocks output by default without <%=, you'll need to switch to Rails-style block expressions.
    • Breaking change: the markdownify helper in ERB now just returns a string rather than directly outputting to the template, so use <%= markdownify do %>…<% end %>.
  • Site documents array should exclude static files #168 (jaredcwhite)
  • Obfuscate link filter #167 (julianrubisch)
  • Add link/url_for and link_to helpers #164 (jaredcwhite)
  • False value in front matter is now supported to ensure no layout is rendered #163 (jaredcwhite)
  • Support per-document locale permalinks and config #162 (jaredcwhite)
    • This isn't yet documented because an even more comprehensive i18n solution and announcement is forthcoming.
  • Add blank src/images folder #172 (jaredcwhite)
  • chore: Prototype pages optimizations and improvements to YARD docs #171 (jaredcwhite)

0.17.1 - 2020-10-02

0.17.0 "Mount Scott" - 2020-09-17

Website updates

0.16.0 "Crystal Springs" - 2020-07-28

  • Final release of 0.16! Yipee yay! Keep reading for what's new since 0.15.

0.16.0.beta2 - 2020-07-24

(0-16-stable branch)

  • Fix the "add_yarn_for_gem" action #114 (jaredcwhite)
  • Call GitHub API to determine default branch name #115 (jaredcwhite)
  • Add capture helper to ERB templates
  • Switch to Erubi for ERB template parsing
  • Move webpack parsing code to the Utils module and enable for ERB templates #105 (jaredcwhite)

0.16.0.beta1 - 2020-07-16

(0-16-stable branch)

  • Improve handling of Webpack manifest errors #96 (ParamagicDev)
  • Add a class_map Liquid tag #99 (ParamagicDev)
  • Update pagination documentation #98 (andrewmcodes)
  • Add ERB template support (with Slim/Haml coming as additional plugins) #79 (jaredcwhite)
  • Add/update Yard documentation for Site concerns #85 (ParamagicDev)
  • Resolve deprecation warnings for Ruby 2.7 #92 (jaredcwhite)
  • Switched the default branch from master to main
  • Remove the Convertible concern and refactor into additional concerns #80 (jaredcwhite)
  • Reducing animation for users who prefer reduced motion #84 (MikeRogers0)

0.15.0 "Overlook" - 2020-06-18

  • Final release of 0.15! Woo hoo! Keep reading for what's new since 0.14

0.15.0.beta4 - 2020-06-15

(0-15-stable branch)

0.15.0.beta3 - 2020-06-05

(0-15-stable branch)

  • New documentation on plugin development (including bridgetown plugins new), themes, automations, Liquid components, etc. now on beta website. Beta site also showcases the upcoming quick search plugin which will be made available to all site devs.
  • Optimizations made internally to the Bridgetown test suite.
  • Bridgetown website experiment with test suite #69 (jaredcwhite)
  • Fix for GitHub branch URLs in automations #66 (ParamagicDev)
  • Migrate CLI from Mercenery to Thor and Enable Automations #56 (jaredcwhite)
  • First implementation of Liquid Components as well as a preview tool on the Bridgetown website #26 (jaredcwhite)
  • Deprecate the include tag and standardize around the render tag #46 (jaredcwhite)

0.14.1 - 2020-05-23

  • Patch to fix PluginManager yarn add bug when there is no dependencies key in package.json

0.14.0 "Hazelwood" - 2020-05-17

  • Use liquid-render-tag backport gem and remove references to temporary GitHub fork of Liquid #52 (jaredcwhite)
  • Refactor Bridgetown::Site into multiple Concerns #51 (jaredcwhite)
  • Fix for start.js to eliminate junk terminal characters (jaredcwhite)
  • New Unified Plugins API with Builders, Source Manifests, and Autoreload #41 (jaredcwhite)
  • Add a Posts page to the new site template #39 (andrewmcodes)
  • Add titleize Liquid filter and improve slugify filter description #38 (jaredcwhite)
  • Add Bundler cache to the build GH action to improve test speed #40 (andrewmcodes)
  • Bump minimum Node requirement to 10.13 (jaredcwhite)

0.13.0 "Klickitat" - 2020-05-05

  • Configurable setting to allow executable Ruby code in Front Matter #9
  • Honor the configured site encoding when loading Liquid components #33
  • Allow configuration file as well as site metadata file to pull YAML options out of an environment specific block #34
  • Add Faraday to the default set of gems that get installed with Bridgetown #30
  • Add blank favicon.ico file to prevent error when generating a new site for the first time #32 (jaredmoody)

0.12.1 - 2020-05-01

  • Update the minimum Ruby version requirement to 2.5

0.12.0 "Lovejoy" - 2020-04-27

  • Add Concurrently and Browsersync for live reload, plus add new Yarn scripts #21
  • Add some color to terminal output
  • Add code name for minor SemVer version updates

0.11.2 - 2020-04-24

  • Add components source folder to sass-loader include paths
  • Include missing commit from PR #14

0.11.1 - 2020-04-24

  • Add a git init step to bridgetown new command #18
  • Update sass-loader webpack config to support .sass #14 (jaredmoody)
  • Add customizable permalinks to Prototype Pages (aka /path/to/:term/and/beyond). Use hooks and in-memory caching to speed up Pagination. Inspired by use cases like this #12

0.11.0 - 2020-04-21

Prototype Pages

You can now create a page, say categories/category.html, and add a prototype config to the Front Matter:

layout: default
title: Posts in category :prototype-term
prototype:
  term: category

And then all the site's different categories will have archives pages at this location (e.g. categories/awesome-movies, categories/my-cool-vacation, etc.) It enables pagination automatically, so you'd just use paginator.documents to loop through the posts. See the docs here.

#11

0.10.2 - 2020-04-19

Automatic Yarn Step for New Plugins

Now with Gem-based plugins for Bridgetown, all you need to do is add yarn-add metadata matching the NPM package name and keep the version the same as the Gem version. For example:

  spec.metadata = { "yarn-add" => "my-awesome-plugin@#{MyAwesomePlugin::VERSION}" }

With that bit of metadata, Bridgetown will know always to look for that package in the users' package.json file when they load Bridgetown, and it will trigger a yarn add command if the package and exact version number isn't present.

0.10.1 - 2020-04-18

Add {% webpack_path [js|css] } tag which pulls in the Webpack manifest and finds the hashed output bundles. Also works in concert with the Watcher so every time Webpack rebuilds the bundles, Bridgetown regenerates the site.

#6

0.10.0 - 2020-04-17

Switch gears on experimental component functionality.

Going with a new rendercontent tag instead of component. It is based on Shopify's new Render tag which recently got introduced to Liquid. Note that the feature hasn't been officially released via the Liquid gem, so we need to use the master branch that's been forked on GitHub with a higher version number).

#5

0.9.0 - 2020-04-16

  • Update table styling in Documentation
  • Now showing the plugins_dir in log output if it's present
  • With the Posts Reader changes, now you can add a Front Matter Default of _posts/drafts having published: false, put a bunch of draft posts in _posts/drafts and you're done!
  • New -U flag makes it easier to specify generating published: false docs.
  • The Posts Reader has been reworked so that files with valid front matter can be read in even if there's no YYYY-MM-DD- at the beginning. In addition, static files are also supported, which means if you can create a folder (inlinefiles), drop a post in along with a bunch of images, and use ![alt](some-image.jpg) relative paths, it'll work! Big improvement to Markdown authoring. (You'll need to use a permalink in a specific manner though, e.g. permalink: /inlinefiles/:title:output_ext) If you need a static file not to get copied to the destination, just add an _ at the beginning and it'll get ignored.
  • Collections no longer allow displaying a full server file path via Liquid.
  • {{ page.collection }} now returns a CollectionDrop, not the label of the collection. Using the jsonify filter on a document however still returns just the label for the collection key.
  • Add favicon to website
  • Add mobile improvements to website
  • Add back working feature tests for basic pagination
  • Convert to Ruby 1.9+ symbol: value hash syntax
  • Add Swup to website for some slick transitions
  • Add "where_query" feature to Paginate. For example. specify where_query: [author, sandy] in the pagination YAML to filter by that front matter key.
  • Update the Jamstack page in the docs.

0.8.1 - 2020-04-14

  • Fix bug where paginator wouldn't properly convert Markdown templates

0.8.0 - 2020-04-14

  • Add Bridgetown::Paginate gem to monorepo
  • Add CI build workflow via GitHub actions
  • Clean up Rake tasks
  • Add documentation around gem releases and contributing PRs

0.7.0 - 2020-04-12

  • Moved the default plugins folder from src/_plugins to simply plugins
  • Remove gems and plugins keys from configuration
  • Move the cache and metadata folders to the root dir
  • Define a default data file for site metadata: src/_data/site_metdata.yml that's accessible via {{ site.metadata.title }} (for example)
  • Add relevant changes to site template for bridgetown new
  • Continue work on repo cleanup and documentation

0.6.0 - 2020-04-09

  • Add bridgetown console command to invoke IRB with the current site (similar to the Rails console command). Plugins, gems, will be loaded, etc.

0.5.0 - 2020-04-07

  • Remove em-websocket dependency.
  • Change _config.yml to bridgetown.config.yml (but _config.yml will still work for compatibility purposes).
  • New Bridgetown logo and further Bridgetown URL updates.
  • Many new and improved docs.

0.4.0 - 2020-04-05

  • Added a component Liquid tag which extends the functionality of include tags.
  • Added a new bridgetown-website project to the repo, which of course is a Bridgetown site and will house the homepage, documentation, etc.

0.3.0 - 2020-04-05

  • Moved all Bridgetown code to bridgetown-core, the idea being this will now be a monorepo housing Core plus a few other official gems/projects as time goes on. Users will install the bridgetown gem which in turns installs bridgetown-core as a dependency.

0.2.0 - 2020-04-04

  • Completed comprehensive code audio and changed or removed features no longer required for the project. Fixed and successfully ran test suite accordingly.

0.1.0 - 2020-04-02

  • First version after fork from pre-released Jekyll 4.1