Skip to main content

A block approach for Plone 6 Classic

Project description

collective.contentsections

PyPI Python Version License Status Stars

This product offers a block approach for Plone 6 Classic based entirely on Dexterity content types. It is largely based on the code that was developed in the imio.smartweb.core product for the Walloon municipalities.

The approach in this product can be seen as a generalisation of the Full content view available in Plone on Folder content type.

The Plone site is seen as a folder hierarchy that contains pages. A page is a folderish content type composed of sections. A section can contain elements of the same type (File, Image, Link, Location, Contact). Folders, pages, sections, and elements are all Dexterity content types.

The section view redirects to its position in its parent page view. Section content types are hidden from research, but their contents are indexed in the SearchableText index of their parent page.

Images and files are seen as elements. Images are only available in image sections and as the lead image in all content types. Files are only available in file sections. Links are sometimes seen as elements of the links section and sometimes as redirect pages.

Here is a picture of the model.

Archimate Model

Compatibility

  • Releases 1.x of collective.contentsections are for Plone 6.0
  • Releases 2.x of collective.contentsections are for Plone 6.1

Features

This product provides:

  • Basic schema and class for section content types
  • LeadIcon vocabulary and behavior based on plone.icons registry records
  • collective.taxonomy.section_css_classes taxonomy for available section CSS classes
  • TextSection which contains a simplified TinyMCE field and the behavior LeadImage. A TextSection contains only the lead image. No more image in TinyMCE text field.
  • HTMLSection to integrate iframe from YouTube, Google Maps, and other iframe providers. No more video or iframe in TinyMCE text field.
  • CollectionSection to link a section with a collection.
  • SelectionSection to link a section to other pages. The SelectionSection replaces the Related items behavior.
  • CardsSection content type based on a collective.z3cform.datagridfield field to make nice information blocks/links on a page.
  • ImagesSection, LinksSection, FilesSection, LocationsSection, ContactsSection folderish section content types to keep the site structured and facilitate the cut and paste of sections between pages.
  • A Page view for folderish content types.
  • BasicPage, EventPage, and NewsPage page content types to replace default Plone content types.

This product fits Plone with:

  • A new default page name index.
  • LeadImage on File and Link content types.
  • A profile to simplify the TinyMCE interface.

Demo Content

The collective.contentsections product adds a plone.distribution "Plone Site (Content Sections)" with some demo pages.

Choices/Beliefs

  • We want a KISS solution.
  • We want a solution for junior integrators.
  • We believe that Plone Classic can be used to create beautiful sites in less than a day.

Possibilities

  • If you activate workflow on sections, you can restrict access to certain sections of a page.
  • As sections are Dexterity content types, you can create a collection/faceted navigation of sections.

Dependencies

This product depends on the following products: collective.taxonomy, collective.z3cform.datagridfield, collective.geolocationbehavior

Installation

Install collective.contentsections by adding it to your buildout:

[buildout]
...

eggs =
    collective.contentsections

and then run bin/buildout.

Development

Prerequisites

uv

See installation guide )

Environment initialization

git clone git@github.com:collective/collective.contentsections.git
cd collective.contentsections
make install
make start

Tests

Tests are located inside tests folder. They can be run with tox.

make test
make coverage
make lint

Internationalization

This product has been translated into:

  • English
  • French

To add a new language, you need a "PO file" inside the locales folder.

For example, to add German locales:

mkdir -p src/collective/collective.contentsections/locales/de/LC_MESSAGES
touch src/collective/collective.contentsections/locales/de/LC_MESSAGES/collective.contentsections.po

After that, you can update the file with:

make i18n

You will need to change Language-Code and Language-Name directives in the file.

Credits

Most ideas developed in this product come from people who worked at iMio on the imio.smartweb product family during the year 2021. This team was composed of:

  • Christophe BOULANGER
  • Elisabeth DONNAY
  • Thomas LAMBERT
  • Laurent LASUDRY
  • Olivier SNICKERS
  • Sébastien VERBOIS

Previews

Preview 1

Preview 2

Contributors

Changelog

2.0.0a4 (2025-06-21)

  • Add pre-commit to development environment. [remdub]
  • Increase test coverage to 100%. [remdub]
  • Use Select2FieldWidget instead of SelectFieldWidget in ICard. [sverbois]
  • Fix ZCML includes [ale-rt]
  • Fix TinyMCE plone.menu registry setting. TinyMCE plone.menu is not longer a list, it's now a text. Plone 6.1.2 is now the minimal version for collective.contentsections. [sverbois]

2.0.0a3 (2025-04-30)

  • Fix typos in card.pt and macros.pt template. [remdub]
  • Enable i18ndude pre-commit checks. [remdub]

2.0.0a2 (2025-04-29)

  • Implement UV for managing Python environment and dependencies. [remdub]
  • Introduce pytest as the testing framework. [remdub]
  • Add plone/meta for GitHub Actions CI/CD integration. [remdub]
  • Configure Tox to launch tests across multiple environments. [remdub]
  • Integrate i18n/locales support for improved internationalization and localization. [remdub]

2.0.0a1 (2025-03-19)

  • Use Plone 6.1 and Python 3.12 in development buildout. [sverbois]
  • Remove portal_properties access. [sverbois]
  • Add a plone.distribution with demo content. [sverbois]
  • Update TinyMCE registry profile to TinyMCE 7. [sverbois]
  • Remove import deprecation warning. [sverbois]
  • Use h-100 class on cards section. [sverbois]
  • Disable AjaxSelectFieldWidget on relation_uid field of cards section (Not working on Plone 6.1). [sverbois]

1.0.0a22 (2024-02-06)

  • Remove bootstrap carousel ride. [sverbois]
  • Use h-100 class on card macro. [sverbois]
  • Add Section primary/secondary/black items to section_css_classes taxonomy. [sverbois]
  • Change element view view to redirect to parent folder_contents view. [sverbois]

1.0.0a21 (2023-12-31)

  • Fix date isoformat in collection section. [sverbois]

1.0.0a20 (2023-12-31)

  • Fix end_date field in selection view. [sverbois]
  • Improve Bootstrap card component with bigger titles, publication date and event dates. [sverbois]
  • Improve section ordering drag and drop. [sverbois]

1.0.0a19 (2023-12-25)

  • Add content type icons. [sverbois]
  • Sort sections by position in parent. [sverbois]
  • Hide Plone toolbar on Spotlight.js view. [sverbois]

1.0.0a18 (2023-08-23)

  • Disable workflow on ContactsSection and Contact content type. [sverbois]
  • Fix empty Locations section with zoom value. [sverbois]

1.0.0a17 (2023-08-19)

  • Add Contacts section and Contact content type. [sverbois]

1.0.0a16 (2023-08-19)

  • Add Locations section and Location element base on pat-leaflet. [sverbois]
  • Modify content type names to avoid confusion with Plone's default content types. [sverbois]
  • Add plone.formwidget.geolocation >= 3.0.5 dependency. [sverbois]
  • Add a Javascript workaround to fix "Add item to default page". [sverbois]
  • Use Python 3.11 and Plone 6.0.6 in development buildout. [sverbois]
  • Add NewsPage content type. [sverbois]

1.0.0a15 (2023-01-01)

  • Use Plone 6 final in development buildout. [sverbois]
  • Transform internal (resolveuid) links before rendering LinksSection. [sverbois]

1.0.0a14 (2022-12-11)

  • Set load_defer key to True for resource bundles. [sverbois]
  • Use Plone 6 beta 3 in development buildout. [sverbois]
  • Update TinyMCE registry profile to TinyMCE 5. [sverbois]
  • Add a shortcut in actions menu to add content in sections. [sverbois]
  • Use "Card view" as default view for "Images section". [sverbois]
  • Move "group_size" field to "default" fieldset. [sverbois]

1.0.0a13 (2022-08-21)

  • Add a CSS class on each section with the section view template id. [sverbois]
  • Add a hide_item_titles field on links sections. [sverbois]
  • Allow "Group size" of 6 items. [sverbois]
  • Add control buttons and optional title section on card and carousel templates. [sverbois]

1.0.0a12 (2022-08-16)

  • Remove customized plone.allowed_sizes and plone.toolbar_position configurations. [sverbois]
  • Set boolean fields required option to False. [sverbois]
  • Require version 3 of collective.taxonomy and collective.z3cform.datagridfield. [sverbois]
  • Improve CSS for section full-width management and card section edition. [sverbois]

1.0.0a11 (2022-03-26)

  • Add hide_title field on IPage. [sverbois]

1.0.0a10 (2022-03-26)

  • Allow BasicPage as default page type. [sverbois]
  • Remove layout name in item_lead_image_scale method. [sverbois]

1.0.0a9 (2021-12-30)

  • Allow Python 3.7 as Plone 6. [sverbois]
  • Use Plone 6 alpha 2 in development buildout. [sverbois]

1.0.0a8 (2021-12-22)

  • Use a collective.taxonomy to manage the available section CSS classes. [sverbois]

1.0.0a7 (2021-12-22)

  • Add model Archimate view. [sverbois]
  • Remove remote_url field on CardsSection. We can use the relation_uid field with a Link content. [sverbois]
  • Add a Card carousel view on sections. [sverbois]
  • Add container width option on sections. [sverbois]

1.0.0a6 (2021-12-20)

  • Use pat-sortable pattern to reorder sections in a page using drag and drop. [sverbois]

1.0.0a5 (2021-12-19)

  • Remove the use of accordion in edit forms. [sverbois]
  • Remove the row prototype. We want a KISS product. [sverbois]

1.0.0a4 (2021-12-19)

  • Add tags information in section view which contains context subjects field value. [sverbois]
  • Clean up the list of behaviours on content types. [sverbois]
  • Don't hide contentleadimage viewlet. [sverbois]

1.0.0a3 (2021-12-18)

  • Add a demo.json export of collective.exportimport with demo pages. [sverbois]
  • Clean use of default and missing_value field attributes. [sverbois]

1.0.0a2 (2021-12-17)

  • Add Event Page portal type. [sverbois]

1.0.0a1 (2021-12-17)

  • Initial release [sverbois]

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

collective_contentsections-2.0.0a4.tar.gz (5.5 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

collective_contentsections-2.0.0a4-py3-none-any.whl (5.5 MB view details)

Uploaded Python 3

File details

Details for the file collective_contentsections-2.0.0a4.tar.gz.

File metadata

File hashes

Hashes for collective_contentsections-2.0.0a4.tar.gz
Algorithm Hash digest
SHA256 8c5eca31de468f31d0a3ece11413ded89e583bd5029b67830822affcf6588da7
MD5 e0d85a029f989f2c118b159470969493
BLAKE2b-256 8c483fc74691c44e99b70e2fb98301f98ece2b8108656107b2b63488d25ae53d

See more details on using hashes here.

File details

Details for the file collective_contentsections-2.0.0a4-py3-none-any.whl.

File metadata

File hashes

Hashes for collective_contentsections-2.0.0a4-py3-none-any.whl
Algorithm Hash digest
SHA256 3683f642eec14c2ab0bbe49bb2538f5a4e1a4d5927bad4a65044239ecd5c591a
MD5 4e737be51a1c305cb6d53d2c6c8c45ab
BLAKE2b-256 e2fdb3751413123589181460caec48c95a389bc7aeb23b16388749711a7027bb

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page