/*
This file contains proprietary software owned by Motorola Mobility, Inc.
No rights, expressed or implied, whatsoever to this software are provided by Motorola Mobility, Inc. hereunder.
(c) Copyright 2011 Motorola Mobility, Inc. All Rights Reserved.
*/
////////////////////////////////////////////////////////////////////////
//
var Montage = require("montage/core/core").Montage,
Component = require("montage/ui/component").Component,
FileIo = require("js/io/system/fileio").FileIo,
ProjectIo = require("js/io/system/projectio").ProjectIo,
TemplateCreator = require("node_modules/tools/template-creator").TemplateCreator;
////////////////////////////////////////////////////////////////////////
//
exports.IoMediator = Montage.create(Component, {
////////////////////////////////////////////////////////////////////
//
hasTemplate: {
enumerable: false,
value: false
},
////////////////////////////////////////////////////////////////////
//
deserializedFromTemplate: {
enumerable: false,
value: function () {
//
}
},
////////////////////////////////////////////////////////////////////
//
fio: {
enumerable: false,
value: FileIo
},
////////////////////////////////////////////////////////////////////
//
pio: {
enumerable: false,
value: ProjectIo
},
////////////////////////////////////////////////////////////////////
//
getAppTemplatesUrlRegEx: {
enumerable: false,
value: function () {
var regex = new RegExp(chrome.extension.getURL('js/document/templates/montage-html').replace(/\//gi, '\\\/'), 'gi');
return regex;
}
},
////////////////////////////////////////////////////////////////////
//
fileNew: {
enumerable: false,
value: function (file, template, callback) {
//Loading template from template URL
var xhr = new XMLHttpRequest(), result;
xhr.open("GET", template, false);
xhr.send();
if (xhr.readyState === 4) {
//Making call to create file, checking for return code
switch (this.fio.newFile({uri: file, contents: xhr.response})) {
case 201:
result = {status: 201, success: true, uri: file};
break;
case 204:
result = {status: 204, success: false, uri: file};
break;
case 400:
result = {status: 400, success: false, uri: file};
break;
default:
result = {status: 500, success: false, uri: file};
break;
}
} else {
result = {status: 500, success: false, uri: file};
}
//Sending result to callback if requested for handling
if (callback) callback(result);
//Codes
// 204: File exists | 400: File exists
// 201: File succesfully created | 500: Unknown (Probably cloud API not running)
}
},
////////////////////////////////////////////////////////////////////
//
fileOpen: {
enumerable: false,
value: function (file, callback) {
//Reading file (Ninja doesn't really open a file, all in browser memory)
var read = this.fio.readFile({uri: file}), result;
//Checking for status
switch(read.status) {
case 204:
//Creating and formatting result object for callbak
result = read.file.details;
result.root = read.file.details.uri.replace(read.file.details.name, "");
//Checking for type of content to returns
if (result.extension !== 'html' && result.extension !== 'htm') {
//Simple string
result.content = read.file.content;
} else {
//Object to be used by Ninja Template
result.content = this.parseHtmlToNinjaTemplate(read.file.content);
}
//Status of call
result.status = read.status;
//Calling back with result
if (callback) callback(result);
break;
case 404:
//File does not exists
if (callback) callback({status: read.status});
break;
default:
//Unknown
if (callback) callback({status: 500});
break;
}
/*
////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////
//Return Object Description
Object.status (Always presents for handling)
204: File exists (Success)
404: File does not exists (Failure)
500: Unknown (Probably cloud API not running)
(Below only present if succesfull 204)
Object.content
Object.extension
Object.name
Object.uri
Object.creationDate
Object.modifiedDate
Object.readOnly
Object.size
////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////
*/
}
},
////////////////////////////////////////////////////////////////////
//
fileSave: {
enumerable: false,
value: function (file, callback) {
//
var contents, save;
//
switch (file.mode) {
case 'html':
//TODO: Add check for Monatage library to copy
//Getting content from function to properly handle saving assets (as in external if flagged)
contents = this.parseNinjaTemplateToHtml(file);
break;
default:
contents = file.content;
break;
}
//Making call to save file
save = this.fio.saveFile({uri: file.document.uri, contents: contents});
//Checking for callback
if (callback) callback(save);
}
},
////////////////////////////////////////////////////////////////////
//
fileSaveAs: {
enumerable: false,
value: function (copyTo, copyFrom, callback) {
//TODO: Implement Save As functionality
}
},
////////////////////////////////////////////////////////////////////
//
fileDelete: {
enumerable: false,
value: function (file, callback) {
//TODO: Implement Delete functionality
}
},
////////////////////////////////////////////////////////////////////
//
parseHtmlToNinjaTemplate: {
enumerable: false,
value: function (html) {
//Creating temp object to mimic HTML
var doc = window.document.implementation.createHTMLDocument(), template;
//Setting content to temp
doc.getElementsByTagName('html')[0].innerHTML = html;
//Creating return object
return {head: doc.head.innerHTML, body: doc.body.innerHTML, document: doc};
}
},
////////////////////////////////////////////////////////////////////
//TODO: Expand to allow more templates, clean up variables
parseNinjaTemplateToHtml: {
enumerable: false,
value: function (template) {
var regexRootUrl, rootUrl = this.application.ninja.coreIoApi.rootUrl+escape((this.application.ninja.documentController.documentHackReference.root.split(this.application.ninja.coreIoApi.cloudData.root)[1]));
regexRootUrl = new RegExp(rootUrl.replace(/\//gi, '\\\/'), 'gi');
//Injecting head and body into old document
template.document.content.document.head.innerHTML = template.head.replace(regexRootUrl, '');
template.document.content.document.body.innerHTML = template.body.replace(regexRootUrl, '');
//Getting all CSS (style or link) tags
var styletags = template.document.content.document.getElementsByTagName('style'),
linktags = template.document.content.document.getElementsByTagName('link'),
toremovetags = [];
//Getting styles tags to be removed from document
if (styletags.length) {
for (var j=0; j only | css =