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.
85 lines
2.2 KiB
85 lines
2.2 KiB
class app.views.OfflinePage extends app.View
|
|
@className: '_static'
|
|
|
|
@events:
|
|
click: 'onClick'
|
|
change: 'onChange'
|
|
|
|
deactivate: ->
|
|
if super
|
|
@empty()
|
|
return
|
|
|
|
render: ->
|
|
app.docs.getInstallStatuses (statuses) =>
|
|
return unless @activated
|
|
if statuses is false
|
|
@html @tmpl('offlineError', app.db.reason)
|
|
else
|
|
html = ''
|
|
html += @renderDoc(doc, statuses[doc.slug]) for doc in app.docs.all()
|
|
@html @tmpl('offlinePage', html)
|
|
@refreshLinks()
|
|
return
|
|
return
|
|
|
|
renderDoc: (doc, status) ->
|
|
app.templates.render('offlineDoc', doc, status)
|
|
|
|
getTitle: ->
|
|
'Offline'
|
|
|
|
refreshLinks: ->
|
|
for action in ['install', 'update', 'uninstall']
|
|
@find("a[data-action-all='#{action}']").classList[if @find("a[data-action='#{action}']") then 'add' else 'remove']('_show')
|
|
return
|
|
|
|
docByEl: (el) ->
|
|
el = el.parentNode until slug = el.getAttribute('data-slug')
|
|
app.docs.findBy('slug', slug)
|
|
|
|
docEl: (doc) ->
|
|
@find("[data-slug='#{doc.slug}']")
|
|
|
|
onRoute: (route) ->
|
|
if app.isSingleDoc()
|
|
window.location = "/#/#{route.path}"
|
|
else
|
|
@render()
|
|
return
|
|
|
|
onClick: (event) =>
|
|
return unless link = $.closestLink(event.target)
|
|
if action = link.getAttribute('data-action')
|
|
$.stopEvent(event)
|
|
doc = @docByEl(link)
|
|
action = 'install' if action is 'update'
|
|
doc[action](@onInstallSuccess.bind(@, doc), @onInstallError.bind(@, doc))
|
|
link.parentNode.innerHTML = "#{link.textContent.replace(/e$/, '')}ing…"
|
|
else if action = link.getAttribute('data-action-all')
|
|
$.stopEvent(event)
|
|
el.click() for el in @findAll("a[data-action='#{action}']")
|
|
return
|
|
|
|
onInstallSuccess: (doc) ->
|
|
return unless @activated
|
|
doc.getInstallStatus (status) =>
|
|
return unless @activated
|
|
if el = @docEl(doc)
|
|
el.outerHTML = @renderDoc(doc, status)
|
|
$.highlight el, className: '_highlight'
|
|
@refreshLinks()
|
|
return
|
|
return
|
|
|
|
onInstallError: (doc) ->
|
|
return unless @activated
|
|
if el = @docEl(doc)
|
|
el.lastElementChild.textContent = 'Error'
|
|
return
|
|
|
|
onChange: (event) ->
|
|
if event.target.name is 'autoUpdate'
|
|
app.settings.set 'autoUpdate', !!event.target.checked
|
|
return
|