diff --git a/lib/atom-nyancat-view.coffee b/lib/atom-nyancat-view.coffee index 29c0fae..ecc3d07 100644 --- a/lib/atom-nyancat-view.coffee +++ b/lib/atom-nyancat-view.coffee @@ -1,10 +1,30 @@ module.exports = class AtomNyancatView + + catHeadSize = 18 + catArseSize = 9 + catSize = catArseSize + catHeadSize + constructor: (serializedState) -> # Create root element @element = document.createElement('div') @element.classList.add('inline-block', 'atom-nyancat') + @catTrail = document.createElement('span') + @catTrail.classList.add('atom-nyancat-trail') + @catTrail.style.minWidth = catArseSize + "px"; + + catHead = document.createElement('span') + catHead.classList.add('atom-nyancat-head') + + catArse = document.createElement('span') + catArse.classList.add('atom-nyancat-arse') + + @catTrail.appendChild(catArse) + @element.appendChild(@catTrail) + @element.appendChild(catHead) + + # Returns an object that can be retrieved when package is activated serialize: -> @@ -29,28 +49,10 @@ class AtomNyancatView # percentage should be number between 0 and 1 updateScroll: (progress) -> - # round percentage up - if progress + .000001 > 1 - progress = 1 - percentage = 100 * parseFloat(progress) - - catHeadSize = 18 - catArseSize = 9 - catSize = catArseSize + catHeadSize - maxWidth = 200 - trailSize = (maxWidth - catHeadSize) * progress + catArseSize - @element.style.width = maxWidth + "px" - - catTrail = document.createElement('span') - catTrail.classList.add('atom-nyancat-trail') - catTrail.style.width = Math.min(trailSize, maxWidth - catHeadSize) + "px" - - catHead = document.createElement('span') - catHead.classList.add('atom-nyancat-head') + progress = Math.min(progress * 100, 100); + @catTrail.style.width = "calc(" + progress + "% - " + catHeadSize + "px)" - catArse = document.createElement('span') - catArse.classList.add('atom-nyancat-arse') - - catTrail.appendChild(catArse) - @element.appendChild(catTrail) - @element.appendChild(catHead) + hide: -> + @element.classList.add('hide') + unhide: -> + @element.classList.remove('hide') diff --git a/lib/atom-nyancat.coffee b/lib/atom-nyancat.coffee index 24db07d..deccf0c 100644 --- a/lib/atom-nyancat.coffee +++ b/lib/atom-nyancat.coffee @@ -2,9 +2,6 @@ AtomNyancatView = require './atom-nyancat-view' {CompositeDisposable} = require 'atom' module.exports = AtomNyancat = - atomNyancatView: null - modalPanel: null - subscriptions: null activate: (state) -> console.log "nyancat enabled" @@ -12,14 +9,23 @@ module.exports = AtomNyancat = @view = new AtomNyancatView() @subs = new CompositeDisposable - @subs.add atom.workspace.observeActivePaneItem => - @unsubLastActive() - @subActive() + @subs.add atom.workspace.onDidChangeActiveTextEditor => + @attachToActiveTextEditor() + @attachToActiveTextEditor() + + attachToActiveTextEditor: -> + @scrollBind?.dispose() + editor = atom.workspace.getActiveTextEditor() + @scrollBind = editor?.element.onDidChangeScrollTop(@update.bind(this)) + if editor? + @view.unhide() @update() + else + @view.hide() deactivate: -> - @unsubLastActive() @subs.dispose() + @scrollBind?.dispose() @view.destroy() @statusBar = null @@ -28,28 +34,12 @@ module.exports = AtomNyancat = priority = 500 @view.mount(@statusBar, priority) - subActive: -> - editor = atom.workspace.getActiveTextEditor() - if not editor? - return - editorElement = editor.getElement() - @editor_subs = new CompositeDisposable - @editor_subs.add editorElement.onDidChangeScrollTop (top) => - @update() - @update() # update once regardles - - unsubLastActive: -> - if @editor_subs? - @editor_subs.dispose() - @editor_subs = null - update: -> editor = atom.workspace.getActiveTextEditor() - @view.clear() - if editor? - lastVisibleRow = editor.firstVisibleScreenRow - lastScreenLine = editor.getLineCount() - editor.rowsPerPage - percent = lastVisibleRow/parseFloat(lastScreenLine) + + maxScrollTop = editor?.element.getMaxScrollTop() + if maxScrollTop > 0 + percent = editor.element.getScrollTop() / maxScrollTop else - precent = 1 + percent = 1 @view.updateScroll(percent) diff --git a/styles/atom-nyancat.less b/styles/atom-nyancat.less index 86dc904..2e16394 100644 --- a/styles/atom-nyancat.less +++ b/styles/atom-nyancat.less @@ -4,36 +4,43 @@ // for a full listing of what's available. @import "ui-variables"; -.atom-nyancat { - background-color: @app-background-color; - height: 23px; - padding: 3px 0 3px 0; -} +.status-bar .status-bar-left { + display: flex; + flex-direction: row; -.atom-nyancat-trail { - position: relative; - display: inline-block; - width: 9px; - background-image: url(); - background-repeat: repeat-x; - height: 17px; -} + .atom-nyancat { + background-color: @app-background-color; + height: 23px; + padding: 3px 0 3px 0; + max-width: none; + flex: 1; + } -.atom-nyancat-arse { - position: absolute; - top: 0; - right: 0; - width: 11px; - height: 17px; - background-image: url(); - background-repeat: no-repeat; -} + .atom-nyancat-trail { + position: relative; + display: inline-block; + width: 9px; + background-image: url(); + background-repeat: repeat-x; + height: 17px; + } + + .atom-nyancat-arse { + position: absolute; + top: 0; + right: 0; + width: 11px; + height: 17px; + background-image: url(); + background-repeat: no-repeat; + } -.atom-nyancat-head { - position: relative; - display: inline-block; - width: 18px; - height: 17px; - background-image: url(); - background-repeat: no-repeat; + .atom-nyancat-head { + position: relative; + display: inline-block; + width: 18px; + height: 17px; + background-image: url(); + background-repeat: no-repeat; + } }