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.
188 lines
4.6 KiB
188 lines
4.6 KiB
class app.views.DocList extends app.View
|
|
@className: '_list'
|
|
@attributes:
|
|
role: 'navigation'
|
|
|
|
@events:
|
|
open: 'onOpen'
|
|
close: 'onClose'
|
|
click: 'onClick'
|
|
|
|
@routes:
|
|
after: 'afterRoute'
|
|
|
|
@elements:
|
|
disabledTitle: '._list-title'
|
|
disabledList: '._disabled-list'
|
|
|
|
init: ->
|
|
@lists = {}
|
|
|
|
@addSubview @listFocus = new app.views.ListFocus @el
|
|
@addSubview @listFold = new app.views.ListFold @el
|
|
@addSubview @listSelect = new app.views.ListSelect @el
|
|
|
|
app.on 'ready', @render
|
|
return
|
|
|
|
activate: ->
|
|
if super
|
|
list.activate() for slug, list of @lists
|
|
@listSelect.selectCurrent()
|
|
return
|
|
|
|
deactivate: ->
|
|
if super
|
|
list.deactivate() for slug, list of @lists
|
|
return
|
|
|
|
render: =>
|
|
html = ''
|
|
for doc in app.docs.all()
|
|
html += @tmpl('sidebarDoc', doc, fullName: app.docs.countAllBy('name', doc.name) > 1)
|
|
@html html
|
|
@renderDisabled() unless app.isSingleDoc() or app.disabledDocs.size() is 0
|
|
return
|
|
|
|
renderDisabled: ->
|
|
@append @tmpl('sidebarDisabled', count: app.disabledDocs.size())
|
|
@refreshElements()
|
|
@renderDisabledList()
|
|
return
|
|
|
|
renderDisabledList: ->
|
|
if app.settings.get('hideDisabled')
|
|
@removeDisabledList()
|
|
else
|
|
@appendDisabledList()
|
|
return
|
|
|
|
appendDisabledList: ->
|
|
html = ''
|
|
docs = [].concat(app.disabledDocs.all()...)
|
|
|
|
while doc = docs.shift()
|
|
if doc.version?
|
|
versions = ''
|
|
loop
|
|
versions += @tmpl('sidebarDoc', doc, disabled: true)
|
|
break if docs[0]?.name isnt doc.name
|
|
doc = docs.shift()
|
|
html += @tmpl('sidebarDisabledVersionedDoc', doc, versions)
|
|
else
|
|
html += @tmpl('sidebarDoc', doc, disabled: true)
|
|
|
|
@append @tmpl('sidebarDisabledList', html)
|
|
@disabledTitle.classList.add('open-title')
|
|
@refreshElements()
|
|
return
|
|
|
|
removeDisabledList: ->
|
|
$.remove @disabledList if @disabledList
|
|
@disabledTitle.classList.remove('open-title')
|
|
@refreshElements()
|
|
return
|
|
|
|
reset: (options = {}) ->
|
|
@listSelect.deselect()
|
|
@listFocus?.blur()
|
|
@listFold.reset()
|
|
@revealCurrent() if options.revealCurrent || app.isSingleDoc()
|
|
return
|
|
|
|
onOpen: (event) =>
|
|
$.stopEvent(event)
|
|
doc = app.docs.findBy 'slug', event.target.getAttribute('data-slug')
|
|
|
|
if doc and not @lists[doc.slug]
|
|
@lists[doc.slug] = if doc.types.isEmpty()
|
|
new app.views.EntryList doc.entries.all()
|
|
else
|
|
new app.views.TypeList doc
|
|
$.after event.target, @lists[doc.slug].el
|
|
return
|
|
|
|
onClose: (event) =>
|
|
$.stopEvent(event)
|
|
doc = app.docs.findBy 'slug', event.target.getAttribute('data-slug')
|
|
|
|
if doc and @lists[doc.slug]
|
|
@lists[doc.slug].detach()
|
|
delete @lists[doc.slug]
|
|
return
|
|
|
|
select: (model) ->
|
|
@listSelect.selectByHref model?.fullPath()
|
|
return
|
|
|
|
reveal: (model) ->
|
|
@openDoc model.doc
|
|
@openType model.getType() if model.type
|
|
@focus model
|
|
@paginateTo model
|
|
@scrollTo model
|
|
return
|
|
|
|
focus: (model) ->
|
|
@listFocus?.focus @find("a[href='#{model.fullPath()}']")
|
|
return
|
|
|
|
revealCurrent: ->
|
|
if model = app.router.context.type or app.router.context.entry
|
|
@reveal model
|
|
@select model
|
|
return
|
|
|
|
openDoc: (doc) ->
|
|
@listFold.open @find("[data-slug='#{doc.slug_without_version}']") if app.disabledDocs.contains(doc) and doc.version
|
|
@listFold.open @find("[data-slug='#{doc.slug}']")
|
|
return
|
|
|
|
closeDoc: (doc) ->
|
|
@listFold.close @find("[data-slug='#{doc.slug}']")
|
|
return
|
|
|
|
openType: (type) ->
|
|
@listFold.open @lists[type.doc.slug].find("[data-slug='#{type.slug}']")
|
|
return
|
|
|
|
paginateTo: (model) ->
|
|
@lists[model.doc.slug]?.paginateTo(model)
|
|
return
|
|
|
|
scrollTo: (model) ->
|
|
$.scrollTo @find("a[href='#{model.fullPath()}']"), null, 'top', margin: if app.isMobile() then 48 else 0
|
|
return
|
|
|
|
toggleDisabled: ->
|
|
if @disabledTitle.classList.contains('open-title')
|
|
@removeDisabledList()
|
|
app.settings.set 'hideDisabled', true
|
|
else
|
|
@appendDisabledList()
|
|
app.settings.set 'hideDisabled', false
|
|
return
|
|
|
|
onClick: (event) =>
|
|
target = $.eventTarget(event)
|
|
if @disabledTitle and $.hasChild(@disabledTitle, target) and target.tagName isnt 'A'
|
|
$.stopEvent(event)
|
|
@toggleDisabled()
|
|
else if slug = target.getAttribute('data-enable')
|
|
$.stopEvent(event)
|
|
doc = app.disabledDocs.findBy('slug', slug)
|
|
app.enableDoc(doc, @onEnabled, @onEnabled) if doc
|
|
return
|
|
|
|
onEnabled: =>
|
|
@reset()
|
|
@render()
|
|
return
|
|
|
|
afterRoute: (route, context) =>
|
|
if context.init
|
|
@reset revealCurrent: true if @activated
|
|
else
|
|
@select context.type or context.entry
|
|
return
|