# @cjsx React.DOM
$ = require('jquery')
React = require('react')
List = require('./list')
Tags = require('./tags')
Slideshow = require('./slideshow')
CardCollection = require('../models/cards')
CardHistoryCollection = require('../models/card_histories')
CardModel = require('../models/card')
TagCollection = require('../models/tags')
String = require('string')
config = require('../config')
module.exports = React.createClass
displayName: 'Content'
componentWillMount: ->
console.log '[views/content] component will mount'
@callback = ()=> @forceUpdate()
@props.router.on "route", @callback
componentWillUnmount: ->
console.log '[views/content] component will unmount'
@props.router.off "route", @callback
render: ->
console.log '[views/content] render'
{
switch @props.router.current
when "list"
console.log '[views/content] list', @props
cards = new CardCollection()
cards.query = $.extend {}, config.default_query, @props.router.query
cards.fetching = true
cards.fetch success: ()-> cards.fetching = false
if cards.query.mode == 'flash'
cards.query.auto = 'off' if !cards.query.auto
cards.query.hide = 'none' if !cards.query.hide
document.title = config.title + '、フラッシュ'
else
document.title = config.title
when "show"
cards = new CardCollection()
cards.fetching = true
card = new CardModel(title: @props.router.title)
card.query = $.extend {}, {context: 'updated_at'}, @props.router.query
card.fetching = true
card.fetch
success: (card)->
card.fetching = false
for left in card.get("lefts")
cardModel = new CardModel(left)
cardModel.set 'focused', false
cards.add cardModel
card.set 'focused', true
cards.add card
for right in card.get("rights")
cardModel = new CardModel(right)
cardModel.set 'focused', false
cards.add cardModel
cards.fetching = false
error: (card, response)=>
cards.fetching = false
document.title = config.title + '、' + card.get('title')
when "history"
console.log '[views/content] history', @props
cards = new CardHistoryCollection()
console.log cards
cards.title = @props.router.title
cards.fetching = true
cards.fetch success: ()-> cards.fetching = false
document.title = config.title + '、ヒストリー'
when "tags"
console.log '[views/content] tags', @props
tags = new TagCollection()
tags.fetching = true
tags.fetch success: ()-> tags.fetching = false
document.title = config.title + '、タグ一覧'
else
null
}