Skip to content

Releases: AlchemyCMS/alchemy_cms

v5.0.0

17 Jul 13:34
687b17f
Compare
Choose a tag to compare

Alchemy 5.0

This is a huge release laying the foundation for Alchemy being a API first CMS for static site generators. While we truly believe in server site rendered HTML and will always support this, we also think that statically generated sites talking via APIs to the backend (aka the "JAM Stack") can be a huge improvement for modern frontends. That's why we made major changes to the internals of Alchemy that help you to better serialize your content and remove weirdness from the code base.

Before we begin thanks for all the contributions that made this release possible:

You really help to make Alchemy better every day.

Thanks for that ❤️

Major changes

  • Removed the single root page from the page tree

Alchemy always had a single root page under which all other pages were nested. Even the layout pages were nested under hidden layout root pages. This was very confusing and prevents us from making changes to the internal structure of Alchemy for features coming in the near future.

               |
           Root Page
          /        \
Language Root     Layout Root
├ Page 1            ├ Header
| \                 └ Footer
|  ├ Page 2
|  └ Page 3
├ Page 4
└ Page 5

This has now been changed to a easier to understand page structure

     |            |        |
Language Root   Header   Footer
├ Page 1
| \
|  ├ Page 2
|  └ Page 3
├ Page 4
└ Page 5
  • #1837

  • #1817

  • #1812

  • Remove Page visible attribute

    The page visible attribute was one of the most confusing attribute in Alchemy. It did way more things than you might have expected. Did you know that it also changed how URLs got created? Probably not. And that's why removed it.

    Want to make a page appear in the navigation? Create a Menu instead and put pages into it.

    In order to help with the upgrade make sure to update to Alchemy 4.6 first and use Menus and Tags instead to re-organize your pages if your page tree does not reflect the URL hierarchy.

    A rake task to help with the migration is available.

    bin/rake alchemy:upgrade:4.6:restructure_page_tree
    
  • Always create nested urls

    With the introduction of Menus and the removal of the Page visible flag we now completely separated the page tree from generating the navigation. That's why we now always generate a nested URL. Don't want to nest a pages URL? Just move it up in the tree.

  • Configurable edit page preview per site

    This is a true benefit for all static sites running Alchemy as it's API. On a per site basis you can configure the host (and basic auth) to your static site and Alchemy will preview it in the build in page edit preview.

  • Add a @alchemy_cms/admin npm package

    Modern ES6 is everywhere. We started to work on the transition to a more modern JS stack. This is the first step.

  • Add an On-Boarding Flow

    We removed the implicit creation of the sites and default languages. We now do this via the UI instead letting admins decide what to create instead.

  • Removed element editor partials

    After being deprecated we removed the support for element editor partials. Alchemy now renders them for you. If you rely on passing custom options into element editors and the content editors please consider to use the settings hash on the contents definition of your elements or using a custom essence.

Other minor changes

Other breaking changes

This release also removes all deprecated methods and classes from 4.6. In order to be able to smoothly upgrade please make sure to update to Alchemy 4.6 and remove all deprecations from your code base, then upgrade to Alchemy 5 and run the

bin/rake alchemy:upgrade

task.

List of all changes

Have a look into the Changelog for a list of all PRs merged into this release.

v4.6.1

04 Jun 08:29
cc75d7c
Compare
Choose a tag to compare
  • Fix 4.6 upgrader

v4.6.0

04 Jun 07:54
4e3c69f
Compare
Choose a tag to compare

4.6.0 (2020-06-04)

In preparation for the 5.0 release this release adds a lot of deprecations. Fix them and you should be ready to upgrade to Alchemy 5.0 without any further ado.

v4.5.0

30 Mar 07:30
386b1b0
Compare
Choose a tag to compare

4.5.0 (2020-03-30)

v4.4.4

30 Mar 07:29
48d8f8f
Compare
Choose a tag to compare

4.4.4 (2020-02-28)

v4.4.3

30 Mar 07:29
2b95d07
Compare
Choose a tag to compare

4.4.3 (2020-02-26)

v4.4.2

25 Feb 11:50
5d6b054
Compare
Choose a tag to compare

4.4.2 (2020-02-25)

v4.4.1

08 Jan 11:42
2244519
Compare
Choose a tag to compare

4.4.1 (2020-01-08)

  • Fix updating page preview after element create/save #1710 (tvdeyen)
  • Element editor layout changes #1709 (tvdeyen)
  • Add Alchemy.user_class_primary_key setting #1708 (tvdeyen)
  • Add Element views upgrade tasks #1707 (tvdeyen)
  • Use postMessage to send messages between preview and element windows #1704 (tvdeyen)

v4.4.0

06 Jan 09:20
Compare
Choose a tag to compare

4.4.0 (2020-01-06)

A rather large release that includes a lot of deprecations for the upcoming 5.0 release.

The most notable changes are

Menus

Alchemy now has now a Menus module where you can manage multiple menus. A menu node can be just a name, a name and an url or an Alchemy::Page. The Alchemy page tree is now deprecated and will most likely be removed or replaced. A new render_menu helper has been introduced. Menus can have templates that live in app/views/alchemy/menus

A handy rake task has been introduced to help with the transition to Menus.

bin/rake alchemy:convert:page_trees:to_menus

Element editors are deprecated

Element editors (aka. app/views/alchemy/*_editor partials) have been deprecated and will be removed in Alchemy 5. If you used the editor partial to pass options into an essence editor, please move these settings either into the elements.yml content settings or if you used to pass dynamic values (to the EssenceSelect for instance) use a custom essence or for page selections use the newly introduced EssencePage.

If you put warnings and messages into the element editors, use the newly introduced warning and message keys for the element definition in the elements.yml.

Element views without suffix

Element view partials do not need the _view suffix anymore. You can safely remove them from your files. Please remember to also rename the your_element_view local variable into your_element.

Added a alchemyPageSelect jQuery function

Based on Select2 we introduced a new alchemyPageSelect jQuery function. Used in the new EssencePage editor, for the node page select and in the link dialogs.

Moved the anchor form into its own tab in the link dialog

The anchor form has been moved into its own tab for better distinction and UX of that feature.

Faster API

The API endpoints now eager load their associated records. Bye bye N+1 👋. Hello 🏎

EssencePage

For "real" element <-> page associations we introduced a new EssencePage essence.


I hope you like these changes and they help you to make Alchemy even better for you. Please consider to support my work on Open Collective

❤️ Thomas


All changes

Read more

v4.3.2

08 Nov 09:16
Compare
Choose a tag to compare

4.3.2 (2019-11-08)