forked from zot/Leisure
-
Notifications
You must be signed in to change notification settings - Fork 0
/
meteor.coffee
71 lines (67 loc) · 3.12 KB
/
meteor.coffee
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
start = ->
if !Element.prototype.createShadowRoot && !Element.prototype.webkitCreateShadowRoot
document.body.style = "background: url(images/steampunk_background-faded.jpg); background-size: 100%; text-align: center"
document.body.innerHTML = "<h1 style='margin-top: 64px'>Leisure won't work in this browser :(</h1><br>The Leisure environment uses Shadow Dom and this browser doesn't support it, so Leisure won't work!<br><h2>Recent versions of Chrome should work.</h2><br><br><img src='images/steampunk_leisure_button.png'>"
else
$("#load_file").click -> $("#internal_load_file").click()
div = $('[maindoc]')
window.ORG_TEXT = div.html().replace(/^\s*<!--+/, '').replace(new RegExp('-->\s*\n*','m'), '').trim()
$('#loading').remove()
$('body').removeClass 'loading'
$('#panel').css 'display', ''
Leisure.initOrg '[maindoc]', '#source'
$('#name').focus()
$('#loginForm').submit (e)->
e.preventDefault()
$("#local").hide()
$("#github_loader").removeAttr 'style'
$("#github").prop 'value', "Please hold..."
Leisure.connectStorage()
#Bubba = new Meteor.Collection 'bubba'
#processChanges = (items)-> console.log "Bubba added: #{JSON.stringify items, ' '}"
if Meteor.isServer
console.log "MAIN"
console.log "FRED ", Fred ? 'null'
console.log "TestTunnel ", TestTunnel ? 'null'
global.GlobalAssets = Assets
if Meteor.isClient
#window.Bubba = Bubba
#Bubba.find().observe
# added: (el)-> addBatch 'changes', {added: el}, processChanges
# removed: (el)-> addBatch 'changes', {removed: el}, processChanges
# changed: (el)-> addBatch 'changes', {changed: el}, processChanges
Meteor.startup ->
window.setTimeout (->
uri = new window.URI(document.location.href)
console.log "URI: #{uri}"
oldParams = uri.getSearchParams()
params = uri.getSearchParams()
if params.state
uri.appendFragment uri.search.substring(1)
uri.search = null
{load,state} = uri.getFragParams()
if state then document.querySelector('[maindoc]').innerHTML = "<h1>LOADING Google Drive file... </h1>"
else if load then document.querySelector('[maindoc]').innerHTML = "<h1>LOADING #{load}... </h1>"
body = document.body
# Gotta be able to stuff extra hidden things in the body
# so if it's a code container, copy it into a child
if 'code' == body.getAttribute 'leisureNode'
pre = document.createElement 'pre'
pre.setAttribute 'leisureNode', 'code'
pre.setAttribute 'contentEditable', 'true'
pre.innerHTML = body.innerHTML
while body.firstChild
body.removeChild body.firstChild
body.appendChild pre
body.removeAttribute 'leisureNode'
{load,state} = uri.getFragParams()
if state then window.GdriveStorage.openFromGdrive -> start()
else if load
console.log "LOAD: load"
setTimeout (->
window.Leisure.readFile load, (err, data)->
if err
if data then $('[maindoc]').html data
else $('[maindoc]').html "<h1>ERROR LOADING #{load}: #{err}</h1>"
else start()), 1
else start()), 1