Socket
Socket
Sign inDemoInstall

collective.carousel

Package Overview
Dependencies
Maintainers
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

collective.carousel

Add-on for having Collections' results presented as a nice carousel


Maintainers
2

Overview.

collective.carousel is the package that lets you add "carousels" of items in your Plone site. More than one carousels on one page are supported.

collective.carousel is based on Scrollable__ plugin for JQuery Tools library__.

.. |---| unicode:: U+2014 .. em dash .. __: http://flowplayer.org/tools/scrollable.html .. __: http://flowplayer.org/tools/index.html

Work of carousel is based on one assumption |---| you already have a collection that returns results for showing in the carousel.

Carousel can be added in 2 ways:

* as a viewlet above page's title (content carousel);
* as a portlet to any portlet manager in your site.
* Go to ``Edit`` tab on a page where you want to add a carousel;
* go to ``Settings``;
* add a collection that will provide content for carousel to ``Carousel
  object`` field;
* if you want to add more than one carousel, add more collections to the
  same field;
* after saving your page, you should see the carousel(s) above your page's
  title if the collection(s) you chose for the carousel(s) returns any
  elements.
* On a page where you want to add a carousel click ``Manage portlets`` in
  one of the columns of your site;
* choose ``Carousel portlet`` from ``Add portlet...`` menu;
* collection portlet is a derivative from standard collection portlet in
  Plone, hence the same fields are available for this type of portlets as
  well;
* fill out the fields in the form specifying a collection that will
  provide content for the carousel portlet.

NOTE content carousels are not inheritable while carousel portlet is inheritable as any other portlet in a Plone site. This means that when you add a content carousel to a folder, the same carousel will not be shown on any object within that folder. At the same time if you add a carousel portlet on a folder, that portlet will be shown for all objects within the folder that don't explicitly block parent portlets.

Tips

Content carousel is defined with a regular viewlet. This lets you to move that viewlet to any place in your site the same way you would do with any other viewlet. Read Moving a viewlet from a viewlet manager to another one__ for more info on how to move viewlets from one viewlet manager to another.

.. __: http://plone.org/documentation/tutorial/customizing-main-template-viewlets/moving-a-viewlet/

How do I customize carousel's view?

collective.carousel provides a flexible way of customizing the look of items, shown in a carousel based on a content type of the item. collective.carousel comes with 2 bundled views that are available for items, rendered in a carousel:

  • browser/templates/news_item_tile.pt |---| defines how News Items should be rendered in a carousel;
  • browser/templates/default_tile.pt |---| how all the rest content types should be rendered in a carousel.

If you need to either override one of the existing views or define a new view for any content type you can do this from your package using ZCML registartion. Please take a look at browser/configure.zcml and testing.zcml for examples of such registrations. Note that there are pages with 2 different names:

  • carousel-view |---| defines a view for a content type in content carousel;
  • carousel-portlet-view |---| the view for a content type when shown in a carousel portlet.

So if you need to override/register a view for any specific content type for content carousel, your <browser:page /> has to have carousel-view name. In case you want to override/register a view for carousel portlet, name should be carousel-portlet-view.

The simplest use-case |---| you have some content carousels placed in a row side by side. Most probably your carousels have different heights and that doesn't look nice when they are placed side by side. So you want to equalize the heights of these carousels with Javascript so that your carousels have the same height. Since collective.carousel already binds load() event to each carousel (resizing the carousel to fit all of it's content) you can not bind one more load() event to a carousel because due to the nature of load() event it might be fired too early when not all content of a carousel is loaded.

For the cases like this collective.carousel provides custom Javascript event resized.carousel that you can attach your special handlers to. Moreover each carousel returns it's height that can be accessed in resized.carousel event.

Here is a simple code snippet of how to adjust the heights of carousels with JQuery::

$("#my-container .carousel").bind('resized.carousel', function(event, newheight) {
    $("#my-container .carousel").each(function() {
        if ($(this).height() < newheight) $(this).height(newheight);
    });
});

Developed by Jarn AS |---| http://www.jarn.com

Development sponsored by the Bergen Public Library |---| http://www.nettbiblioteket.no

Dexterity

collective.carouselbehaviour_ provides Dexterity-based (plone.app.dexterity) content types support.

.. |---| unicode:: U+2014 .. em dash .. _collective.carouselbehaviour: http://pypi.python.org/pypi/collective.carouselbehaviour

Changelog

1.7 (2014-04-30)

  • Edited the css/html/js so that carousel uses the .collective.carousel selector. Fixes this issue: https://github.com/collective/collective.carousel/issues/13 [pigeonflight]

  • Play/Autoscroll the carousel again, when the mouse leaves the carousel. [thet]

  • Remove skins layer and register css and js browser resources. Don't use dtml css anymore but let integrators overload styles via own css. Optimize javascript and CSS. [thet]

  • Added description for dexterity support [bogdangi]

1.6.2 - August 28, 2013

  • Allow configuring of image_scales in portlets. [thet]

  • Added MANIFEST.in to prevent issues with packaging. [bogdangi]

1.6.1 - May 2, 2013

  • Remove stale pdb statement. [thet]

1.6 - April 11, 2013

  • Depend on plone.app.jquerytools and include the scrollable plugins. Include an Upgrade step for it (Upgrade 1 to 2). [thet]

1.5 - March 2, 2013

  • Support for new-style Collection type keeping backwards-compatibility support for the old-style Topic [mishunov, ableeb]

  • Don't base the carousel portlet on the collection one since it brings quite some unnecessary fileds that don't make sense in this context. [mishunov]

  • Reduced the default rotation time for a carousel to 10 seconds. [mishunov]

  • Replace '$' with 'jQuery' in the javascript to avoid unnecessary integration conflicts. [mishunov]

  • We use plain CSS instead of the images for the arrows. [mishunov]

  • Updated bundled jQueryTools to 1.2.5 and removed 'scrollable' module from the local copy. [mishunov]

  • Complete revert of djay's changes to the javascript. [mishunov]

  • Add French translation. [toutpt]

1.4 - January 27, 2011

  • Spanish translation. [hvelarde]

  • Czech translation. [lzdych]

  • More settings for carousel portlet. [djay]

  • Pause carousel on :hover. [djay]

  • Leadimage tile. [djay]

  • Danish translation [stonor]

  • Portuguese translation [davilima6]

1.3 - July 6, 2010

  • Fixed norwegian translation [sh]

  • Actual russian translation missing in previous release [spliter]

1.2 - June 30, 2010

  • Russian translation [spliter]

1.1 - June 30, 2010

  • Norwegian translation [sh, ggozad]

  • Brazilian-Portuguese translation [davilima6]

  • Added i18n support [stonor]

  • Fixed the height of the carousel for cases when items are shorter than the carousel's height declared in CSS. [spliter]

1.0 - April 15, 2010

  • Added information about 'resized.carousel' event to README.txt [spliter]

  • Custom 'resized.carousel' event for being able to bind custom handlers to the moment when a carousel is re-sized. [spliter]

  • Limit number of items returned by a carousel to 7. [spliter]

  • Adjusted slightly to work on Plone 4. [hannosch]

  • Initial release [spliter]

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc