# @cjsx React.DOM $ = require('jquery') React = require('react') CardCollection = require('../models/cards') config = require('../config') helpers = require('../helpers') classnames = require('classnames') markdownIt = require('markdown-it')(linkify: true) DropdownButton = require('react-bootstrap').DropdownButton MenuItem = require('react-bootstrap').MenuItem ButtonGroup = require('react-bootstrap').ButtonGroup Button = require('react-bootstrap').Button #window.onerror = (error, url, line) -> alert error Flash = React.createClass componentDidMount: -> console.log '[views/flash] componentDidMount', @props $(document).on 'keydown', @onKeyDown @setState currCards: @props.cards if @props.cards.at(0) @setState currCard: @props.cards.at(0), => @loadNextCards() @loadPrevCards() @forceUpdate.bind(@, null) else @props.cards.on 'sync', => @setState currCard: @props.cards.at(0), => @loadNextCards() @loadPrevCards() @forceUpdate.bind(@, null) componentWillUnmount: -> $(document).off 'keydown', @onKeyDown onKeyDown: (event)-> switch event.keyCode when 27 then @props.router.navigate(@closeLink()) when 37 then @onClickPrev() when 39 then @onClickNext() getInitialState: -> currCard: null currCards: null nextCards: null prevCards: null hiding: true showTools: false menuOpen: false prevCard: -> _prevCard = @state.currCards.at(@currCardIndex() - 1) console.log '[views/slideshow] prevCard', _prevCard _prevCard nextCard: -> _nextCard = @state.currCards.at(@currCardIndex() + 1) console.log '[views/slideshow] nextCard', _nextCard _nextCard currCardIndex: -> _currCardIndex = @state.currCards.indexOf(@state.currCard) console.log '[views/slideshow] currCardIndex, @state.currCard', @state.currCard console.log '[views/slideshow] currCardIndex', _currCardIndex _currCardIndex currPage: -> _currPage = @state.currCards.pagination.current_page console.log '[views/slideshow] currPage', _currPage _currPage totalPages: -> @state.currCards.pagination.total_pages nextPage: -> _nextPage = if @currPage() < @totalPages() then @currPage() + 1 else 1 console.log '[views/slideshow] nextPage', _nextPage _nextPage prevPage: -> _prevPage = if @currPage() > 1 then @currPage() - 1 else @totalPages() console.log '[views/slideshow] prevPage', _prevPage _prevPage loadNextCards: -> console.log '[views/slideshow] loadNextCards' nextCards = new CardCollection() nextCards.query = $.extend {}, @state.currCards.query, {page: @nextPage()} nextCards.fetching = true nextCards.fetch success: ()-> nextCards.fetching = false @setState nextCards: nextCards loadPrevCards: -> console.log '[views/slideshow] loadPrevCards' prevCards = new CardCollection() prevCards.query = $.extend {}, @state.currCards.query, {page: @prevPage()} prevCards.fetching = true prevCards.fetch success: ()-> prevCards.fetching = false @setState prevCards: prevCards onTouchStart: (event)-> @touchStartX = event.changedTouches[0].pageX onTouchEnd: (event)-> touchEndX = event.changedTouches[0].pageX distance = touchEndX - @touchStartX if Math.abs(distance) > 100 if distance > 0 @onClickNext() else @onClickPrev() onClickNext: -> if @props.cards.query.hide != 'none' && @state.hiding @setState hiding: false else @setState hiding: true if nextCard = @nextCard() @setState currCard: nextCard else return if @state.nextCards.fetching @setState currCards: @state.nextCards, prevCards: @state.currCards, ()=> @setState currCard: @state.currCards.at(0), ()=> @loadNextCards() onClickPrev: -> if @props.cards.query.hide != 'none' && @state.hiding @setState hiding: false else @setState hiding: true if prevCard = @prevCard() @setState currCard: prevCard else return if @state.prevCards.fetching @setState currCards: @state.prevCards, nextCards: @state.currCards, ()=> @setState currCard: @state.currCards.at(@state.currCards.length - 1), ()=> @loadPrevCards() closeLink: -> params = $.extend {}, @props.cards.query delete params.mode delete params.auto delete params.hide '#/?' + $.param(params) onChangeHide: (event)-> @setState hideValue: event.target.value onMouseOverTools: ()-> @setState showTools: true onMouseLeaveTools: ()-> @setState showTools: false onClick: -> @setState showTools: !@state.showTools queryParam: (query)-> query = $.extend {}, @props.cards.query, query $.param(query) render: ->
flash = React.createFactory Flash module.exports = React.createClass displayName: 'FlashWrapper' componentDidMount: -> console.log '[views/slideshow] componentDidMount' @node = document.createElement('div') @node.className = 'carte-slideshow' document.body.appendChild(@node) @renderSlideshow() componentWillReceiveProps: (nextProps)-> console.log '[views/slideshow] componentWillReceiveProps', nextProps document.body.removeChild(@node) if @node @node = document.createElement('div') @node.className = 'carte-slideshow' document.body.appendChild(@node) React.render(flash(nextProps), @node) componentWillUnmount: -> console.log '[views/slideshow] componentWillUnmount' document.body.removeChild(@node) renderSlideshow: -> React.render(flash(@props), @node) render: -> null