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.
devdocs/assets/javascripts/views/sidebar/doc_picker.coffee

125 lines
3.5 KiB

class app.views.DocPicker extends app.View
@className: '_list _list-picker'
@attributes:
role: 'form'
@elements:
saveLink: '._sidebar-footer-save'
@events:
click: 'onClick'
mousedown: 'onMouseDown'
@shortcuts:
enter: 'onEnter'
init: ->
@addSubview @listFold = new app.views.ListFold(@el)
return
activate: ->
if super
@render()
app.appCache?.on 'progress', @onAppCacheProgress
$.on @el, 'focus', @onDOMFocus, true
return
deactivate: ->
if super
@empty()
app.appCache?.off 'progress', @onAppCacheProgress
$.off @el, 'focus', @onDOMFocus, true
@focusEl = null
return
render: ->
html = ''
docs = app.docs.all().concat(app.disabledDocs.all()...)
while doc = docs.shift()
if doc.version?
[docs, versions] = @extractVersions(docs, doc)
html += @tmpl('sidebarVersionedDoc', doc, @renderVersions(versions), open: app.docs.contains(doc))
else
html += @tmpl('sidebarLabel', doc, checked: app.docs.contains(doc))
@html html + @tmpl('sidebarPickerNote') + @tmpl('sidebarSave')
@refreshElements()
$.requestAnimationFrame =>
@addClass '_in'
@findByTag('input')?.focus()
return
renderVersions: (docs) ->
html = ''
html += @tmpl('sidebarLabel', doc, checked: app.docs.contains(doc)) for doc in docs
html
extractVersions: (originalDocs, version) ->
docs = []
versions = [version]
for doc in originalDocs
(if doc.name is version.name then versions else docs).push(doc)
[docs, versions]
empty: ->
@resetClass()
super
return
save: ->
unless @saving
@saving = true
docs = @getSelectedDocs()
app.settings.setDocs(docs)
@saveLink.textContent = if app.appCache then 'Downloading\u2026' else 'Saving\u2026'
disabledDocs = new app.collections.Docs(doc for doc in app.docs.all() when docs.indexOf(doc.slug) is -1)
disabledDocs.uninstall ->
app.db.migrate()
app.reload()
return
getSelectedDocs: ->
for input in @findAllByTag 'input' when input?.checked
input.name
onClick: (event) =>
return if event.which isnt 1
if event.target is @saveLink
$.stopEvent(event)
@save()
return
onMouseDown: =>
@mouseDown = Date.now()
onDOMFocus: (event) =>
target = event.target
if target.tagName is 'INPUT'
$.scrollTo target.parentNode, null, 'continuous', bottomGap: 2
else if target.classList.contains(app.views.ListFold.targetClass)
target.blur()
unless @mouseDown and @mouseDown > Date.now() - 100
if @focusEl is $('input', target.nextElementSibling)
@listFold.close(target) if target.classList.contains(app.views.ListFold.activeClass)
prev = target.previousElementSibling
prev = prev.previousElementSibling until prev.tagName is 'LABEL' or prev.classList.contains(app.views.ListFold.targetClass)
prev = $.makeArray($$('input', prev.nextElementSibling)).pop() if prev.classList.contains(app.views.ListFold.activeClass)
@delay -> prev.focus()
else
@listFold.open(target) unless target.classList.contains(app.views.ListFold.activeClass)
@delay -> $('input', target.nextElementSibling).focus()
@focusEl = target
return
onEnter: =>
@save()
return
onAppCacheProgress: (event) =>
if event.lengthComputable
percentage = Math.round event.loaded * 100 / event.total
@saveLink.textContent = "Downloading\u2026 (#{percentage}%)"
return