|
|
|
class app.Settings
|
|
|
|
PREFERENCE_KEYS = [
|
|
|
|
'hideDisabled'
|
|
|
|
'hideIntro'
|
|
|
|
'manualUpdate'
|
|
|
|
'fastScroll'
|
|
|
|
'arrowScroll'
|
|
|
|
'docs'
|
|
|
|
'dark'
|
|
|
|
'layout'
|
|
|
|
'size'
|
|
|
|
'tips'
|
|
|
|
]
|
|
|
|
|
|
|
|
INTERNAL_KEYS = [
|
|
|
|
'count'
|
|
|
|
'schema'
|
|
|
|
'version'
|
|
|
|
'news'
|
|
|
|
]
|
|
|
|
|
|
|
|
LAYOUTS: ['_max-width', '_sidebar-hidden', '_native-scrollbars']
|
|
|
|
SIDEBAR_HIDDEN_LAYOUT = '_sidebar-hidden'
|
|
|
|
|
|
|
|
@defaults:
|
|
|
|
count: 0
|
|
|
|
hideDisabled: false
|
|
|
|
hideIntro: false
|
|
|
|
news: 0
|
|
|
|
manualUpdate: false
|
|
|
|
schema: 1
|
|
|
|
|
|
|
|
constructor: ->
|
|
|
|
@store = new CookieStore
|
|
|
|
@cache = {}
|
|
|
|
|
|
|
|
get: (key) ->
|
|
|
|
return @cache[key] if @cache.hasOwnProperty(key)
|
|
|
|
@cache[key] = @store.get(key) ? @constructor.defaults[key]
|
|
|
|
|
|
|
|
set: (key, value) ->
|
|
|
|
@store.set(key, value)
|
|
|
|
delete @cache[key]
|
|
|
|
@toggleDark(value) if key == 'dark'
|
|
|
|
return
|
|
|
|
|
|
|
|
del: (key) ->
|
|
|
|
@store.del(key)
|
|
|
|
delete @cache[key]
|
|
|
|
return
|
|
|
|
|
|
|
|
hasDocs: ->
|
|
|
|
try !!@store.get('docs')
|
|
|
|
|
|
|
|
getDocs: ->
|
|
|
|
@store.get('docs')?.split('/') or app.config.default_docs
|
|
|
|
|
|
|
|
setDocs: (docs) ->
|
|
|
|
@set 'docs', docs.join('/')
|
|
|
|
return
|
|
|
|
|
|
|
|
getTips: ->
|
|
|
|
@store.get('tips')?.split('/') or []
|
|
|
|
|
|
|
|
setTips: (tips) ->
|
|
|
|
@set 'tips', tips.join('/')
|
|
|
|
return
|
|
|
|
|
|
|
|
setLayout: (name, enable) ->
|
|
|
|
@toggleLayout(name, enable)
|
|
|
|
|
|
|
|
layout = (@store.get('layout') || '').split(' ')
|
|
|
|
$.arrayDelete(layout, '')
|
|
|
|
|
|
|
|
if enable
|
|
|
|
layout.push(name) if layout.indexOf(name) is -1
|
|
|
|
else
|
|
|
|
$.arrayDelete(layout, name)
|
|
|
|
|
|
|
|
if layout.length > 0
|
|
|
|
@set 'layout', layout.join(' ')
|
|
|
|
else
|
|
|
|
@del 'layout'
|
|
|
|
return
|
|
|
|
|
|
|
|
hasLayout: (name) ->
|
|
|
|
layout = (@store.get('layout') || '').split(' ')
|
|
|
|
layout.indexOf(name) isnt -1
|
|
|
|
|
|
|
|
setSize: (value) ->
|
|
|
|
@set 'size', value
|
|
|
|
return
|
|
|
|
|
|
|
|
dump: ->
|
|
|
|
@store.dump()
|
|
|
|
|
|
|
|
export: ->
|
|
|
|
data = @dump()
|
|
|
|
delete data[key] for key in INTERNAL_KEYS
|
|
|
|
data
|
|
|
|
|
|
|
|
import: (data) ->
|
|
|
|
for key, value of @export()
|
|
|
|
@del key unless data.hasOwnProperty(key)
|
|
|
|
for key, value of data
|
|
|
|
@set key, value if PREFERENCE_KEYS.indexOf(key) isnt -1
|
|
|
|
return
|
|
|
|
|
|
|
|
reset: ->
|
|
|
|
@store.reset()
|
|
|
|
@cache = {}
|
|
|
|
return
|
|
|
|
|
|
|
|
initLayout: ->
|
|
|
|
@toggleDark(@get('dark'))
|
|
|
|
@toggleLayout(layout, @hasLayout(layout)) for layout in @LAYOUTS
|
|
|
|
@addResizerCSS()
|
|
|
|
|
|
|
|
toggleDark: (enable) ->
|
|
|
|
classList = document.documentElement.classList
|
|
|
|
classList[if enable then 'remove' else 'add']('_theme-default')
|
|
|
|
classList[if enable then 'add' else 'remove']('_theme-dark')
|
|
|
|
|
|
|
|
toggleLayout: (layout, enable) ->
|
|
|
|
classList = document.body.classList
|
|
|
|
classList[if enable then 'add' else 'remove'](layout) unless layout is SIDEBAR_HIDDEN_LAYOUT
|
|
|
|
classList[if $.overlayScrollbarsEnabled() then 'add' else 'remove']('_overlay-scrollbars')
|
|
|
|
|
|
|
|
addResizerCSS: ->
|
|
|
|
size = @get('size')
|
|
|
|
size = if size then size + 'px' else '20rem'
|
|
|
|
|
|
|
|
css = """
|
|
|
|
._container { margin-left: #{size}; }
|
|
|
|
._header, ._list { width: #{size}; }
|
|
|
|
._list-hover.clone { min-width: #{size}; }
|
|
|
|
._notice, ._path, ._resizer { left: #{size}; }
|
|
|
|
"""
|
|
|
|
|
|
|
|
style = document.createElement('style')
|
|
|
|
style.type = 'text/css'
|
|
|
|
style.appendChild(document.createTextNode(css))
|
|
|
|
style.setAttribute('data-size', size)
|
|
|
|
style.setAttribute('data-resizer', '')
|
|
|
|
|
|
|
|
document.head.appendChild(style)
|
|
|
|
return
|