mirror of https://github.com/freeCodeCamp/devdocs
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
66 lines
1.5 KiB
66 lines
1.5 KiB
class app.views.OfflinePage extends app.View
|
|
@className: '_static'
|
|
|
|
@events:
|
|
click: 'onClick'
|
|
|
|
deactivate: ->
|
|
if super
|
|
@empty()
|
|
return
|
|
|
|
render: ->
|
|
app.docs.getInstallStatuses (statuses) =>
|
|
return unless @activated
|
|
if statuses is false
|
|
@html @tmpl('offlineError')
|
|
else
|
|
html = ''
|
|
html += @renderDoc(doc, statuses[doc.slug]) for doc in app.docs.all()
|
|
@html @tmpl('offlinePage', html)
|
|
return
|
|
return
|
|
|
|
renderDoc: (doc, status) ->
|
|
app.templates.render('offlineDoc', doc, status)
|
|
|
|
getTitle: ->
|
|
'Offline'
|
|
|
|
docByEl: (el) ->
|
|
el = el.parentNode until slug = el.getAttribute('data-slug')
|
|
app.docs.findBy('slug', slug)
|
|
|
|
docEl: (doc) ->
|
|
@find("[data-slug='#{doc.slug}']")
|
|
|
|
onRoute: ->
|
|
@render()
|
|
return
|
|
|
|
onClick: (event) =>
|
|
link = event.target
|
|
|
|
if link.hasAttribute('data-dl')
|
|
action = 'install'
|
|
else if link.hasAttribute('data-del')
|
|
action = 'uninstall'
|
|
|
|
if action
|
|
$.stopEvent(event)
|
|
doc = @docByEl(link)
|
|
doc[action](@onInstallSuccess.bind(@, doc), @onInstallError.bind(@, doc))
|
|
link.parentNode.innerHTML = "#{link.textContent.replace(/e$/, '')}ing…"
|
|
return
|
|
|
|
onInstallSuccess: (doc) ->
|
|
doc.getInstallStatus (status) =>
|
|
@docEl(doc).outerHTML = @renderDoc(doc, status)
|
|
$.highlight @docEl(doc), className: '_highlight'
|
|
return
|
|
|
|
onInstallError: (doc) ->
|
|
el = @docEl(doc)
|
|
el.lastElementChild.textContent = 'Error'
|
|
return
|