codecombat/app/views/courses/mock1/CourseEnrollView.coffee
2015-09-10 10:39:21 -07:00

63 lines
1.7 KiB
CoffeeScript

app = require 'core/application'
RootView = require 'views/core/RootView'
template = require 'templates/courses/mock1/course-enroll'
module.exports = class CourseEnrollView extends RootView
id: 'course-enroll-mock-view'
template: template
events:
'click .btn-buy': 'onClickBuy'
'change .course-select': 'onChangeCourse'
'change .input-quantity': 'onQuantityChange'
constructor: (options, @courseID=0) ->
super options
@initData()
getRenderData: ->
context = super()
context.courses = @courses ? {}
context.courseID = @courseID
context.price = @price ? 0
context.quantity = @quantity
context.selectedCourseTitle = @selectedCourseTitle
context
afterRender: ->
super()
@$el.find('.course-select').val(@selectedCourseTitle)
initData: ->
mockData = require 'views/courses/mock1/CoursesMockData'
@courses = mockData.courses
@selectedCourseTitle = @courses[@courseID]?.title
@quantity = 20
@updatePrice()
onClickBuy: (e) ->
if @selectedCourseTitle is 'All Courses'
app.router.navigate "/courses/mock1/0"
else
for course, i in @courses when course.title is @selectedCourseTitle
app.router.navigate "/courses/mock1/#{i}"
break
window.location.reload()
onChangeCourse: (e) ->
@selectedCourseTitle = $(e.target).val()
@updatePrice()
@render?()
onQuantityChange: (e) ->
@quantity = $(e.target).val() ? 20
@updatePrice()
@render?()
updatePrice: ->
if @selectedCourseTitle is 'All Courses'
@price = (@courses.length - 1) * @quantity * 2
else if @selectedCourseTitle is 'Introduction to Computer Science'
@price = 0
else
@price = @quantity * 4