Created
July 14, 2018 06:34
-
-
Save tjmonsi/64505b908c38dd70eeae228633fc475d to your computer and use it in GitHub Desktop.
Exercise 1 for Polymer 3
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import { PolymerElement, html } from '../node_modules/@polymer/polymer/polymer-element.js'; | |
class ImageCarousel extends PolymerElement { | |
static get properties () { | |
return { | |
selected: { | |
type: Object, | |
observer: '_selectedChanged' | |
} | |
} | |
} | |
static get template () { | |
return html` | |
<style> | |
:host { | |
display: block; | |
position: relative; | |
overflow: hidden; | |
} | |
div > ::slotted(:not([selected])) { | |
display: none; | |
} | |
button { | |
position: absolute; | |
top: calc(50% - 20px); | |
padding: 0; | |
line-height: 40px; | |
border: none; | |
background: none; | |
color: #DDD; | |
font-size: 40px; | |
font-weight: bold; | |
opacity: 0.7; | |
} | |
button:hover, | |
button:focus { | |
opacity: 1; | |
} | |
#prevBtn { | |
left: 12px; | |
} | |
#nextBtn { | |
right: 12px; | |
} | |
button[disabled] { | |
opacity: 0.4; | |
} | |
</style> | |
<div> | |
<slot></slot> | |
</div> | |
<button id="prevBtn" on-click="previous">❮</button> | |
<button id="nextBtn" on-click="next">❯</button> | |
`; | |
} | |
connectedCallback() { | |
super.connectedCallback(); | |
this.shadowRoot.addEventListener('slotchange', this._resetSelected.bind(this)); | |
this._resetSelected(); | |
} | |
_selectedChanged(selected, oldSelected) { | |
if (oldSelected) oldSelected.removeAttribute('selected'); | |
if (selected) selected.setAttribute('selected', ''); | |
} | |
_resetSelected() { | |
if (!this.selected || this.selected.parentElement !== this) { | |
this.selected = this.firstElementChild; | |
} | |
} | |
previous() { | |
const elem = this.selected && this.selected.previousElementSibling; | |
if (elem) { | |
this.selected = elem; | |
} | |
} | |
next() { | |
const elem = this.selected && this.selected.nextElementSibling; | |
if (elem) { | |
this.selected = elem; | |
} | |
} | |
} | |
customElements.define('image-carousel', ImageCarousel); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment