Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/deeleman/polymer-carousel

A reusable Polymer component for rendering responsive image slideshows
https://github.com/deeleman/polymer-carousel

Last synced: 28 days ago
JSON representation

A reusable Polymer component for rendering responsive image slideshows

Awesome Lists containing this project

README

        

# polymer-carousel
A reusable Polymer component for rendering (still not responsive) image slideshows

### A. Documentation in progress
The current project lacks from a decent documentation yet. In the meantime, refer to the code in order to understand its functionality and follow the instructions below to setup a working environment for it, building or even packaging the component.

**Please note:** This is a humble research project. In order to better test and benchmark the differences between building components on Polymer and using plain vanilla JavaScript, a [branch with a plain vanilla Javascript implementation](https://github.com/deeleman/polymer-carousel/tree/plain-vanilla-carousel) has been added to this project.

### B. Yet to be done
The following is a list of stuff still required before going gold:

* The component should expose public `width`and `height` properties and honor them where defined. Resizing itself on a fluid way otherwise.
* Images should adapt themselves to the container and not all the way around.
* Add a unit testing layer based on the Mocha test runner and the Chai assertion library according to the [vendor guidelines](https://www.polymer-project.org/0.5/articles/unit-testing-elements.html).
* Replace the *fade in* transition by horizontal/vertical sliding
* Polyfill transitions with jQuery animate (or any other CSS transitions polifyll library) for MSIE9
* Support for mobile gestures such as `swipeLeft` and `swipeRight`.

### C. Installation and deployment

#### C.1. Installing dependencies

All dependencies are managed by means of NPM, except for the basic platform files for building Polymer applications. These are managed by means of Bower using Gulp as a friednly interface.

Please open a terminal window and proceed with installation by means of the following command:

````
$ npm install
`````

##### C.2. Working against the component

In order to ease the development tasks for maintaining the component you can run the dev tools provided:

```
$ gulp dev
````

Basically all Polymer dependencies will be downloaded through Bower and the JavaScript and SCSS files will be build and watched for changes.

##### C.3. Building the component

In a similar fashion as we did previously, you just need to execute the following and... Profit! The component and its subcomponents can be then consumed form the `/components/carousel-slideshow` folder.

```
$ gulp build
````

##### C.4. Packaging the component

The component and all its dependencies can be bundled in a single file to ease its distribution. For doing so, make sure a convenient gulp task will build and package the component for you by executing the following command:

```
$ gulp package
````

The component and all its dependencies including the files required for bootstrapping the component will be bundled into a single file for your convenience, located at `/components/packaged/polymer-carousel.html`. If you want to check the component live a demo has been added for your convenience, and can be viewed at `/demo/index.html`. Feel free to take a look into it by spawning a web server of your choice at the root folder. Eg

```
$ git clone https://github.com/deeleman/polymer-carousel.git
$ cd polymer-carousel
$ npm install
$ gulp package
$ python -m SimpleHTTPServer 8080
```

The contents will be available for your viewing pleasure at [http://localhost:8080](http://localhost:8080) then.

###### Please note: This a very early work in progress and is not meant for release.

### License

Copyright (C) 2015, Paul Deeleman
Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted, provided that the above copyright notice and this permission notice appear in all copies.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.