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.
95 lines
2.6 KiB
95 lines
2.6 KiB
class app.views.OfflinePage extends app.View
|
|
@className: '_static'
|
|
|
|
@events:
|
|
click: 'onClick'
|
|
change: 'onChange'
|
|
|
|
deactivate: ->
|
|
if super
|
|
@empty()
|
|
return
|
|
|
|
render: ->
|
|
if app.cookieBlocked
|
|
@html @tmpl('offlineError', 'cookie_blocked')
|
|
return
|
|
|
|
app.docs.getInstallStatuses (statuses) =>
|
|
return unless @activated
|
|
if statuses is false
|
|
@html @tmpl('offlineError', app.db.reason, app.db.error)
|
|
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("[data-action-all='#{action}']").classList[if @find("[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) =>
|
|
el = event.target
|
|
if action = el.getAttribute('data-action')
|
|
doc = @docByEl(el)
|
|
action = 'install' if action is 'update'
|
|
doc[action](@onInstallSuccess.bind(@, doc), @onInstallError.bind(@, doc), @onInstallProgress.bind(@, doc))
|
|
el.parentNode.innerHTML = "#{el.textContent.replace(/e$/, '')}ing…"
|
|
else if action = el.getAttribute('data-action-all')
|
|
app.db.migrate()
|
|
$.click(el) for el in @findAll("[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
|
|
|
|
onInstallProgress: (doc, event) ->
|
|
return unless @activated and event.lengthComputable
|
|
if el = @docEl(doc)
|
|
percentage = Math.round event.loaded * 100 / event.total
|
|
el.lastElementChild.textContent = el.lastElementChild.textContent.replace(/(\s.+)?$/, " (#{percentage}%)")
|
|
return
|
|
|
|
onChange: (event) ->
|
|
if event.target.name is 'autoUpdate'
|
|
app.settings.set 'manualUpdate', !event.target.checked
|
|
return
|