Skip to content

Outline an approach to creating an reusable, extensible carousel.

Notifications You must be signed in to change notification settings

xtwest/carousel-planning

Repository files navigation

Objective

Design a light-weight, flexible carousel module that enables reusable across projects:

  • Deeply customizable options
  • Deeply extensible architecture
  • Library/framework agnostic with minimal code redundancy

Terminology

Tile: Single carousel item

Frame: Visible tiles displayed in carousel

Core Features

  • Accessible

  • Basic prev/next navigation controls

  • Minimal (and replaceable) animation

    • Basic css animation (js fallback as extension?)
    • Pluggable framework to replace default animation engine
    • expose needed elements/object/properties
  • Deep linking

  • Fluid by default (scaling)

  • Responsive by extension

  • Single tile transition

  • Previous/Next buttons

  • Tile container is specified by class so carousel is element agnostic (e.g. <ul>)

  • Default animation: single tile at a time

  • Frame tile count

  • Frame - no empty tile spaces

Options

  • Carousel DOM element (object)
  • Tiles per frame (integer)
  • Animate by frame (boolean)

Properties

Layout

  • Fixed or Responsive

    • fixed or relative units?
    • should content be ignored and left up to the developer?
  • Horizontal or Vertical

Controls

  • Prev/Next

    • Markup:
      • ul with button tags
      • nav with button tags
      • custom markup with template {token} tags
    • Placement:
      • inside/outside the mask
      • before/after mask
  • Frames

    • Markup:
      • ul with button tags
      • nav with button tags
      • custom markup with template {token} tags
    • Placement:
      • inside the navigation controls
      • inside/outside the mask
      • before/after the mask

Event Hooks

Should these should instead be events that are emitted rather than added to the options.

  • Ready
  • Before Destroy
  • After Destroy
  • Before Animation
  • After Animation
  • Before Resize
  • After Resize
  • Tiles Added
  • Tiles Removed
  • Tile Input
    • extensible, default input type would be click

API

Properties

  • State Object
    • Length Number
    • Tiles Array
    • Frames Array
    • Current Tile Index Number
    • Current Frame Index Number
    • Options Object

Methods

  • Previous
  • Next
  • Config
  • Destroy
  • Add Tiles
  • Remove Tiles
  • Subscribe to Event
    • should a subscribe method be used instead of event hooks on the options object?

Extension Ideas

The extensible architecture should support the ability to add features that integrate at the core level.

  • Support for Touch/Pointer Events

  • Modes

    • Auto Advance
    • Looping
  • Content Type Support

    • Video
      • what API would be useful?
  • Animation Engine

    • enable the animation to be replaced
  • CSS Layout Themes

Dependencies

  • GruntJS for builds

  • UMD pattern for source modularity and extension configuration. Need to research on how other libs handle this.

    • RequireJS
  • DOM libs

    • Vanilla JS for DOM manipulation?
      • Support for passing in a jQuery/Zepto collection and convert it to an array.
    • What about animation? Is there a small lib that can handle basic css animations with js fallback? Can we use only the animation aspect of jQuery?
    • Modernizr, or can we get away with minimal feature tests and require extensions to roll their own? How do other libs handle this?

Thoughts:

Initial extensions should include:

  • Responsive frame feature should be an extension
  • Loop extension
  • Pagination extension

About

Outline an approach to creating an reusable, extensible carousel.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •