really basic but working base

This commit is contained in:
Mathieu PATUREL
2017-01-04 19:46:06 +11:00
parent 6ad9e79926
commit 28a7274b05
3 changed files with 85 additions and 285 deletions

View File

@ -11,15 +11,33 @@ from .functions import *
class MarkdownLivePreviewListener(sublime_plugin.EventListener):
def on_activated(self, view):
# if view is md_view and has no preview
# -> create preview
window = view.window()
vsettings = view.settings()
if vsettings.get(PREVIEW_ENABLED):
id = vsettings.get(PREVIEW_ID)
if id is None or get_view_from_id(window, id) is None:
preview = create_preview(view)
return
# if view is preview
# -> do nothing
if vsettings.get(IS_PREVIEW):
return
# if view is not the md_view or the preview
# remove preview if any
for view, settings in find_preview(window):
settings.set(IS_HIDDEN, True)
view.close()
class MarkdownLivePreviewListener_:
def __init__(self, *args, **kwargs):
super(MarkdownLivePreviewListener, *args, **kwargs)
self.last_deactivated_view = None
def on_load(self, view):
if not is_markdown_view(view):
return
vsettings = view.settings()
def on_modified(self, md_view):
if not is_markdown_view(md_view):
return
@ -32,14 +50,18 @@ class MarkdownLivePreviewListener(sublime_plugin.EventListener):
MarkdownLivePreviewListener.md_view = md_view
create_preview(md_view)
MarkdownLivePreviewListener.has_preview = True
window.focus_view(md_view)
# window.focus_view(md_view)
return
if True:
pass
else:
preview = get_view_from_id(window, id)
if preview is None:
raise ValueError('Getting preview from id: got None')
raise ValueError('Glastetting preview from id: got None')
show_html(md_view, preview)
def on_pre_close(self, view):
return
vsettings = view.settings()
window = view.window()
if vsettings.get(IS_PREVIEW) is True:
@ -63,7 +85,9 @@ class MarkdownLivePreviewListener(sublime_plugin.EventListener):
sublime.set_timeout(lambda: preview.close(), 250)
def on_deactivated(self, view):
self.last_deactivated_view = view
settings = view.settings()
if settings.get(IS_PREVIEW) or settings.get(PREVIEW_ENABLED):
self.last_deactivated_view = view
def on_activated(self, view):
vsettings = view.settings()
@ -76,7 +100,13 @@ class MarkdownLivePreviewListener(sublime_plugin.EventListener):
return
if id is not None:
return
return create_preview(view)
create_preview(view)
# view.window().focus_view(view)
return
if self.last_deactivated_view:
window = view.window()
focused_view = window.active_view()
hide_preview(self.last_deactivated_view)
window.focus_view(focused_view)