guide.coffee 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. #
  2. # Config
  3. #
  4. HOUR_WIDTH = 200
  5. SCROLL_MULTIPLIER = HOUR_WIDTH
  6. CHANNELS =
  7. '1': name: 'Nederland 1'
  8. '2': name: 'Nederland 2'
  9. '3': name: 'Nederland 3'
  10. '4': name: 'RTL 4'
  11. '5': name: 'Eén'
  12. '6': name: 'Canvas'
  13. '18': name: 'NGC'
  14. '24': name: 'Film 1 Premium'
  15. '29': name: 'Discovery'
  16. '31': name: 'RTL 5'
  17. '34': name: 'Veronica'
  18. '36': name: 'SBS6'
  19. '37': name: 'NET 5'
  20. '46': name: 'RTL 7'
  21. '91': name: 'Comedy Central'
  22. '92': name: 'RTL 8'
  23. '435': name: '24 Kitchen'
  24. '438': name: 'TLC'
  25. '440': name: 'FOX'
  26. #
  27. # Utils
  28. #
  29. tosecs = (date) -> date.getHours() * 60 + date.getSeconds()
  30. now = -> tosecs(new Date())
  31. time2px = (seconds) -> HOUR_WIDTH / 3600 * seconds
  32. #
  33. # Models & collections
  34. #
  35. Channel = Backbone.Model.extend(
  36. defaults: ->
  37. id: null
  38. name: 'Some channel'
  39. visible: true
  40. initialize: (attrs, options) ->
  41. @programs = []
  42. )
  43. Progam = Backbone.Model.extend(
  44. defaults: ->
  45. title: 'Some program'
  46. start: null
  47. end: null
  48. )
  49. ChannelList = Backbone.Collection.extend(
  50. model: Channel
  51. comparator: 'id'
  52. initialize: (models, options) ->
  53. _.each(CHANNELS, (props, id) => @add(_.extend({id: id}, props)))
  54. @fetchVisible()
  55. #@loadPrograms(0)
  56. fetchVisible: ->
  57. visible = if localStorage.hasOwnProperty('channels') \
  58. then localStorage.getItem('channels').split(',') else @pluck('id')
  59. @setVisible(visible)
  60. saveVisible: ->
  61. selected = (c.id for c in @channels if c.visible)
  62. localStorage.setItem('channels', selected.join(','))
  63. setVisible: (visible, save=false) ->
  64. for id in visible
  65. @findWhere(id: id).set(visible: true)
  66. for id in _.difference(@pluck('id'), visible)
  67. @findWhere(id: id).set(visible: false)
  68. @saveVisible() if save
  69. loadPrograms: (day, callback) ->
  70. $.get(
  71. 'http://www.tvgids.nl/json/lists/programs.php'
  72. channels: @pluck('id').join(','), day: day
  73. (channels) ->
  74. _.each channels, (id, programs) ->
  75. channel = Channels.findWhere(id: id)
  76. channel.programs = (new Program(p) for p in programs)
  77. callback() if callback
  78. 'json'
  79. )
  80. )
  81. #
  82. # Views
  83. #
  84. ChannelView = Backbone.View.extend(
  85. tagName: 'div'
  86. className: 'channel'
  87. #template: _.template($('#channel-template').html())
  88. initialize: ->
  89. $el.text(@model.title)
  90. render: ->
  91. $el.toggle(@model.visible)
  92. )
  93. ProgramView = Backbone.View.extend(
  94. tagName: 'div'
  95. className: 'program'
  96. initialize: ->
  97. $el.text(@model.title)
  98. render: ->
  99. # TODO: set highlight to past/present/future
  100. )
  101. AppView = Backbone.View.extend(
  102. el: $('#guide')
  103. initialize: ->
  104. @listenTo(Channels, 'add', @addChannel)
  105. @listenTo(Channels, 'reset', => Channels.each(@addChannel, @))
  106. @listenTo(Channels, 'all', @render)
  107. @setDay(0, => @updateIndicator())
  108. #setInterval(=> @updateIndicator(), 3600000 / HOUR_WIDTH)
  109. setDay: (day, callback) ->
  110. Channels.loadPrograms(@day = day, callback)
  111. addChannel: (channel) ->
  112. view = new ChannelView(model: channel)
  113. @$('.channels').append(view.render().el)
  114. updateIndicator: ->
  115. @$('.indicator').css('left', time2px(now()) + 'px')
  116. render: ->
  117. hidden
  118. @$('.channel')
  119. )
  120. #
  121. # Main
  122. #
  123. Channels = new ChannelList()
  124. App = new AppView()