diff options
Diffstat (limited to 'js/document/html-document.js')
-rwxr-xr-x | js/document/html-document.js | 74 |
1 files changed, 56 insertions, 18 deletions
diff --git a/js/document/html-document.js b/js/document/html-document.js index 28818774..02e9918f 100755 --- a/js/document/html-document.js +++ b/js/document/html-document.js | |||
@@ -290,15 +290,6 @@ exports.HTMLDocument = Montage.create(TextDocument, { | |||
290 | } | 290 | } |
291 | }, | 291 | }, |
292 | 292 | ||
293 | |||
294 | |||
295 | AppendElement: { | ||
296 | value: function(element, parent) { | ||
297 | this.dirtyFlag = true; | ||
298 | } | ||
299 | }, | ||
300 | |||
301 | |||
302 | /** | 293 | /** |
303 | * Return the specified inline attribute from the element. | 294 | * Return the specified inline attribute from the element. |
304 | */ | 295 | */ |
@@ -386,28 +377,29 @@ exports.HTMLDocument = Montage.create(TextDocument, { | |||
386 | value: function(event){ | 377 | value: function(event){ |
387 | //TODO: Clean up, using for prototyping save | 378 | //TODO: Clean up, using for prototyping save |
388 | this._templateDocument = {}; | 379 | this._templateDocument = {}; |
380 | this._templateDocument.html = this.iframe.contentWindow.document; | ||
389 | this._templateDocument.head = this.iframe.contentWindow.document.getElementById("userHead"); | 381 | this._templateDocument.head = this.iframe.contentWindow.document.getElementById("userHead"); |
390 | this._templateDocument.body = this.documentRoot = this.iframe.contentWindow.document.getElementById("UserContent"); | 382 | this._templateDocument.body = this.documentRoot = this.iframe.contentWindow.document.getElementById("UserContent"); |
391 | //TODO: Remove, also for prototyping | 383 | //TODO: Remove, also for prototyping |
392 | this.application.ninja.documentController._hackRootFlag = true; | 384 | this.application.ninja.documentController._hackRootFlag = true; |
393 | // | 385 | // |
394 | //this.documentRoot = this.iframe.contentWindow.document.getElementById("UserContent"); | ||
395 | this.stageBG = this.iframe.contentWindow.document.getElementById("stageBG"); | 386 | this.stageBG = this.iframe.contentWindow.document.getElementById("stageBG"); |
396 | this.stageBG.onclick = null; | 387 | this.stageBG.onclick = null; |
397 | this._document = this.iframe.contentWindow.document; | 388 | this._document = this.iframe.contentWindow.document; |
398 | this._window = this.iframe.contentWindow; | 389 | this._window = this.iframe.contentWindow; |
399 | // | 390 | // |
400 | if(!this.documentRoot.Ninja) this.documentRoot.Ninja = {}; | 391 | if(!this.documentRoot.Ninja) this.documentRoot.Ninja = {}; |
401 | // | 392 | //Inserting user's document into template |
402 | this._templateDocument.head.innerHTML = this._userDocument.content.head; | 393 | this._templateDocument.head.innerHTML = this._userDocument.content.head; |
403 | this._templateDocument.body.innerHTML = this._userDocument.content.body; | 394 | this._templateDocument.body.innerHTML = this._userDocument.content.body; |
404 | 395 | ||
405 | 396 | //Adding a handler for the main user document reel to finish loading | |
406 | 397 | this._document.body.addEventListener("userTemplateDidLoad", this.userTemplateDidLoad.bind(this), false); | |
398 | |||
407 | 399 | ||
408 | /* this.iframe.contentWindow.document.addEventListener('DOMSubtreeModified', function (e) { */ //TODO: Remove events upon loading once | 400 | /* this.iframe.contentWindow.document.addEventListener('DOMSubtreeModified', function (e) { */ //TODO: Remove events upon loading once |
409 | 401 | ||
410 | //TODO: When written, the best way to initialize the document is to listen for the DOM tree being modified | 402 | //TODO: When re-written, the best way to initialize the document is to listen for the DOM tree being modified |
411 | setTimeout(function () { | 403 | setTimeout(function () { |
412 | 404 | ||
413 | 405 | ||
@@ -416,9 +408,47 @@ exports.HTMLDocument = Montage.create(TextDocument, { | |||
416 | //////////////////////////////////////////////////////////////////////////////////////////////////////////////////// | 408 | //////////////////////////////////////////////////////////////////////////////////////////////////////////////////// |
417 | //////////////////////////////////////////////////////////////////////////////////////////////////////////////////// | 409 | //////////////////////////////////////////////////////////////////////////////////////////////////////////////////// |
418 | if(this._document.styleSheets.length > 1) { | 410 | if(this._document.styleSheets.length > 1) { |
419 | this._styles = this._document.styleSheets[this._document.styleSheets.length - 1]; | 411 | //Checking all styleSheets in document |
412 | for (var i in this._document.styleSheets) { | ||
413 | //If rules are null, assuming cross-origin issue | ||
414 | if(this._document.styleSheets[i].rules === null) { | ||
415 | //TODO: Revisit URLs and URI creation logic, very hack right now | ||
416 | var fileUri, cssUrl, cssData, tag, query; | ||
417 | if (this._document.styleSheets[i].href.indexOf('js/document/templates/montage-html') !== -1) { | ||
418 | //Getting the url of the CSS file | ||
419 | cssUrl = this._document.styleSheets[i].href.split('js/document/templates/montage-html')[1]; | ||
420 | //Creating the URI of the file (this is wrong should not be splitting cssUrl) | ||
421 | fileUri = this.application.ninja.coreIoApi.cloudData.root+this.application.ninja.documentController.documentHackReference.root.split(this.application.ninja.coreIoApi.cloudData.root)[1]+cssUrl.split('/')[1]; | ||
422 | //Loading the data from the file | ||
423 | cssData = this.application.ninja.coreIoApi.readFile({uri: fileUri}); | ||
424 | //Creating tag with file content | ||
425 | tag = this.iframe.contentWindow.document.createElement('style'); | ||
426 | tag.setAttribute('ninjauri', fileUri); | ||
427 | tag.setAttribute('ninjafileurl', cssUrl); | ||
428 | tag.innerHTML = cssData.content; | ||
429 | //Looping through DOM to insert style tag at location of link element | ||
430 | query = this._templateDocument.html.querySelectorAll(['link']); | ||
431 | for (var j in query) { | ||
432 | if (query[j].href === this._document.styleSheets[i].href) { | ||
433 | //Disabling style sheet to reload via inserting in style tag | ||
434 | query[j].setAttribute('disabled', 'true'); | ||
435 | //Inserting tag | ||
436 | this._templateDocument.head.insertBefore(tag, query[j]); | ||
437 | } | ||
438 | } | ||
439 | } | ||
440 | } | ||
441 | } | ||
442 | |||
443 | //TODO: Revisit this logic | ||
444 | this._styles = this._document.styleSheets[1]; | ||
420 | this._stylesheets = this._document.styleSheets; // Entire stlyesheets array | 445 | this._stylesheets = this._document.styleSheets; // Entire stlyesheets array |
421 | 446 | ||
447 | console.log(this._document.styleSheets); | ||
448 | |||
449 | //////////////////////////////////////////////////////////////////////////// | ||
450 | //////////////////////////////////////////////////////////////////////////// | ||
451 | |||
422 | //TODO Finish this implementation once we start caching Core Elements | 452 | //TODO Finish this implementation once we start caching Core Elements |
423 | // Assign a model to the UserContent and add the ViewPort reference to it. | 453 | // Assign a model to the UserContent and add the ViewPort reference to it. |
424 | NJUtils.makeElementModel(this.documentRoot, "Stage", "stage"); | 454 | NJUtils.makeElementModel(this.documentRoot, "Stage", "stage"); |
@@ -481,12 +511,20 @@ exports.HTMLDocument = Montage.create(TextDocument, { | |||
481 | 511 | ||
482 | } | 512 | } |
483 | }, | 513 | }, |
514 | |||
484 | //////////////////////////////////////////////////////////////////// | 515 | //////////////////////////////////////////////////////////////////// |
516 | |||
517 | // Handler for user content main reel. Gets called once the main reel of the template | ||
518 | // gets deserialized. | ||
519 | // Setting up the currentSelectedContainer to the document body. | ||
520 | userTemplateDidLoad: { | ||
521 | value: function(){ | ||
522 | this.application.ninja.currentSelectedContainer = this.documentRoot; | ||
523 | } | ||
524 | }, | ||
485 | 525 | ||
486 | 526 | ||
487 | 527 | //////////////////////////////////////////////////////////////////// | |
488 | |||
489 | |||
490 | _setSWFObjectScript: { | 528 | _setSWFObjectScript: { |
491 | value: function() { | 529 | value: function() { |
492 | if(!this._swfObject) { | 530 | if(!this._swfObject) { |