1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
{
"uid": "7F1D60F1K265BA40B5SA78EEAB249F02B709",
"isLoaded": true,
"lastModificationTime": 1421095528911,
"items": {
"name": "DataManager",
"type": "game_script",
"order": 6,
"content": "# ===================================================================\n#\n# Script: DataManager\n#\n# $$COPYRIGHT$$\n#\n# ===================================================================\nclass DataManager\n ###*\n * Manages the game's data like loading documents. Documents are stored\n * in the data folder of the game in JSON format. The UID is used as the file-name.\n * A document has the following structure:<br>\n * <br>\n * UID - Unique Identifier<br>\n * Items -> An object containing all the items/fields of the document.<br>\n * Items.Type -> The type of the document<br>\n * Items.Name -> The name of the document<br>\n * <br>\n * @module gs\n * @class DataManager\n * @memberof gs\n * @constructor\n ###\n constructor: ->\n ###*\n * Stores all documents by UID.\n * @property documentsByUid\n * @type gs.Document[]\n ### \n @documentsByUid = {}\n \n ###*\n * Stores all documents.\n * @property documents\n * @type gs.Document[]\n ###\n @documents = []\n \n ###*\n * Indiciates if all requested documents are loaded.\n * @property documentsLoaded\n * @type boolean\n ###\n @documentsLoaded = true\n \n ###*\n * @property events\n * @type gs.EventEmitter\n ###\n @events = new gs.EventEmitter()\n \n\n ###*\n * Unloads all documents with a specified type.\n *\n * @method disposeDocumentsByType\n * @param {String} type - The document type.\n ### \n disposeDocumentsByType: (type) ->\n i = 0\n \n while i < @documents.length\n d = @documents[i]\n if d && d.items && d.items.type == type\n \t@documents.remove(d)\n \t@documentsByUid[d.uid] = null\n \tGS.dataCache[d.uid] = null\n \tdelete @documentsByUid[d.uid]\n \tdelete GS.dataCache[d.uid]\n \ti--;\n i++\n \n return null\n \t\t\n\t\n ###*\n * Gets all documents with a specified type.\n *\n * @method getDocumentsByType\n * @param {String} type - The document type.\n * @return {gs.Document[]} The documents.\n ### \n getDocumentsByType: (type) ->\n result = []\n \n for uid of @summaries.items\n summary = @summaries.items[uid]\n if summary.items? and summary.items.type == type\n result.push(@getDocument(uid))\n\n return result\n \n ###*\n * Gets the first document with the specified type.\n *\n * @method getDocumentByType\n * @param {String} type - The document type.\n * @return {gs.Document} The document or <b>null</b> if a document with the specified type doesn't exist.\n ### \n getDocumentByType: (type) ->\n result = null\n \n for uid of @summaries.items\n summary = @summaries.items[uid]\n if summary.items? and summary.items.type == type\n result = @getDocument(uid)\n break\n\n return result\n \n ###*\n * Gets a document by its UID.\n *\n * @method getDocument\n * @param {String} uid - The UID of the document to get.\n * @return {gs.Document} The document or <b>null</b> if a document with the specified UID doesn't exist.\n ### \n getDocument: (uid) ->\n result = @documentsByUid[uid]\n \n if not result?\n gs.Data.load(uid, (dataObject, error) =>\n if !error\n r = @documentsByUid[dataObject.uid]\n r.items = dataObject.items;\n r.loaded = true;\n )\n \n if @summaries and @summaries.items\n summary = @summaries.items[uid]\n if summary\n result = { uid: uid, items: summary.items, loaded: false }\n else\n result = { uid: uid, loaded: false }\n \n if result\n @documentsByUid[uid] = result\n @documents.push(result)\n @documentsLoaded = false\n \n if uid == \"SUMMARIES\" then @summaries = result\n \n return result\n \n \n ###*\n * Gets a document by its UID. If the document isn't already loaded this method\n * only returned document only contains summary data.\n *\n * @method getDocumentSummary\n * @param {String} uid - The UID of the document to get.\n * @return {gs.Document} The document or <b>null</b> if a document with the specified UID doesn't exist.\n ### \n getDocumentSummary: (uid) -> @summaries.items[uid]\n \n ###*\n * Updates the loading process of documents.\n *\n * @method update\n ### \n update: ->\n if not @documentsLoaded\n @documentsLoaded = true\n \n for i in [0...@documents.length]\n if not @documents[i].loaded\n @documentsLoaded = false\n break\n \n if @documentsLoaded\n @events.emit(\"loaded\", this)\n \n return null\n\nwindow.DataManager = DataManager\ngs.DataManager = DataManager",
"compiledContent": "var DataManager;\n\nDataManager = (function() {\n\n /**\n * Manages the game's data like loading documents. Documents are stored\n * in the data folder of the game in JSON format. The UID is used as the file-name.\n * A document has the following structure:<br>\n * <br>\n * UID - Unique Identifier<br>\n * Items -> An object containing all the items/fields of the document.<br>\n * Items.Type -> The type of the document<br>\n * Items.Name -> The name of the document<br>\n * <br>\n * @module gs\n * @class DataManager\n * @memberof gs\n * @constructor\n */\n function DataManager() {\n\n /**\n * Stores all documents by UID.\n * @property documentsByUid\n * @type gs.Document[]\n */\n this.documentsByUid = {};\n\n /**\n * Stores all documents.\n * @property documents\n * @type gs.Document[]\n */\n this.documents = [];\n\n /**\n * Indiciates if all requested documents are loaded.\n * @property documentsLoaded\n * @type boolean\n */\n this.documentsLoaded = true;\n\n /**\n * @property events\n * @type gs.EventEmitter\n */\n this.events = new gs.EventEmitter();\n }\n\n\n /**\n * Unloads all documents with a specified type.\n *\n * @method disposeDocumentsByType\n * @param {String} type - The document type.\n */\n\n DataManager.prototype.disposeDocumentsByType = function(type) {\n var d, i;\n i = 0;\n while (i < this.documents.length) {\n d = this.documents[i];\n if (d && d.items && d.items.type === type) {\n this.documents.remove(d);\n this.documentsByUid[d.uid] = null;\n GS.dataCache[d.uid] = null;\n delete this.documentsByUid[d.uid];\n delete GS.dataCache[d.uid];\n i--;\n }\n i++;\n }\n return null;\n };\n\n\n /**\n * Gets all documents with a specified type.\n *\n * @method getDocumentsByType\n * @param {String} type - The document type.\n * @return {gs.Document[]} The documents.\n */\n\n DataManager.prototype.getDocumentsByType = function(type) {\n var result, summary, uid;\n result = [];\n for (uid in this.summaries.items) {\n summary = this.summaries.items[uid];\n if ((summary.items != null) && summary.items.type === type) {\n result.push(this.getDocument(uid));\n }\n }\n return result;\n };\n\n\n /**\n * Gets the first document with the specified type.\n *\n * @method getDocumentByType\n * @param {String} type - The document type.\n * @return {gs.Document} The document or <b>null</b> if a document with the specified type doesn't exist.\n */\n\n DataManager.prototype.getDocumentByType = function(type) {\n var result, summary, uid;\n result = null;\n for (uid in this.summaries.items) {\n summary = this.summaries.items[uid];\n if ((summary.items != null) && summary.items.type === type) {\n result = this.getDocument(uid);\n break;\n }\n }\n return result;\n };\n\n\n /**\n * Gets a document by its UID.\n *\n * @method getDocument\n * @param {String} uid - The UID of the document to get.\n * @return {gs.Document} The document or <b>null</b> if a document with the specified UID doesn't exist.\n */\n\n DataManager.prototype.getDocument = function(uid) {\n var result, summary;\n result = this.documentsByUid[uid];\n if (result == null) {\n gs.Data.load(uid, (function(_this) {\n return function(dataObject, error) {\n var r;\n if (!error) {\n r = _this.documentsByUid[dataObject.uid];\n r.items = dataObject.items;\n return r.loaded = true;\n }\n };\n })(this));\n if (this.summaries && this.summaries.items) {\n summary = this.summaries.items[uid];\n if (summary) {\n result = {\n uid: uid,\n items: summary.items,\n loaded: false\n };\n }\n } else {\n result = {\n uid: uid,\n loaded: false\n };\n }\n if (result) {\n this.documentsByUid[uid] = result;\n this.documents.push(result);\n this.documentsLoaded = false;\n }\n if (uid === \"SUMMARIES\") {\n this.summaries = result;\n }\n }\n return result;\n };\n\n\n /**\n * Gets a document by its UID. If the document isn't already loaded this method\n * only returned document only contains summary data.\n *\n * @method getDocumentSummary\n * @param {String} uid - The UID of the document to get.\n * @return {gs.Document} The document or <b>null</b> if a document with the specified UID doesn't exist.\n */\n\n DataManager.prototype.getDocumentSummary = function(uid) {\n return this.summaries.items[uid];\n };\n\n\n /**\n * Updates the loading process of documents.\n *\n * @method update\n */\n\n DataManager.prototype.update = function() {\n var i, j, ref;\n if (!this.documentsLoaded) {\n this.documentsLoaded = true;\n for (i = j = 0, ref = this.documents.length; 0 <= ref ? j < ref : j > ref; i = 0 <= ref ? ++j : --j) {\n if (!this.documents[i].loaded) {\n this.documentsLoaded = false;\n break;\n }\n }\n if (this.documentsLoaded) {\n this.events.emit(\"loaded\", this);\n }\n }\n return null;\n };\n\n return DataManager;\n\n})();\n\nwindow.DataManager = DataManager;\n\ngs.DataManager = DataManager;\n\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"","sourceRoot":"","sources":[""],"names":[],"mappings":"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","sourcesContent":["# ===================================================================\n#\n#   Script: DataManager\n#\n#   $$COPYRIGHT$$\n#\n# ===================================================================\nclass DataManager\n    ###*\n    * Manages the game's data like loading documents. Documents are stored\n    * in the data folder of the game in JSON format. The UID is used as the file-name.\n    * A document has the following structure:<br>\n    * <br>\n    * UID - Unique Identifier<br>\n    * Items -> An object containing all the items/fields of the document.<br>\n    * Items.Type -> The type of the document<br>\n    * Items.Name -> The name of the document<br>\n    * <br>\n    * @module gs\n    * @class DataManager\n    * @memberof gs\n    * @constructor\n    ###\n    constructor: ->\n        ###*\n        * Stores all documents by UID.\n        * @property documentsByUid\n        * @type gs.Document[]\n        ### \n        @documentsByUid = {}\n        \n        ###*\n        * Stores all documents.\n        * @property documents\n        * @type gs.Document[]\n        ###\n        @documents = []\n        \n        ###*\n        * Indiciates if all requested documents are loaded.\n        * @property documentsLoaded\n        * @type boolean\n        ###\n        @documentsLoaded = true\n        \n        ###*\n        * @property events\n        * @type gs.EventEmitter\n        ###\n        @events = new gs.EventEmitter()\n        \n\n    ###*\n    * Unloads all documents with a specified type.\n    *\n    * @method disposeDocumentsByType\n    * @param {String} type - The document type.\n    ###  \n    disposeDocumentsByType: (type) ->\n        i = 0\n        \n        while i < @documents.length\n            d = @documents[i]\n            if d && d.items && d.items.type == type\n            \t@documents.remove(d)\n            \t@documentsByUid[d.uid] = null\n            \tGS.dataCache[d.uid] = null\n            \tdelete @documentsByUid[d.uid]\n            \tdelete GS.dataCache[d.uid]\n            \ti--;\n            i++\n            \n        return null\n    \t\t\n\t\n    ###*\n    * Gets all documents with a specified type.\n    *\n    * @method getDocumentsByType\n    * @param {String} type - The document type.\n    * @return {gs.Document[]} The documents.\n    ###  \n    getDocumentsByType: (type) ->\n        result = []\n        \n        for uid of @summaries.items\n            summary = @summaries.items[uid]\n            if summary.items? and summary.items.type == type\n                result.push(@getDocument(uid))\n\n        return result\n        \n    ###*\n    * Gets the first document with the specified type.\n    *\n    * @method getDocumentByType\n    * @param {String} type - The document type.\n    * @return {gs.Document} The document or <b>null</b> if a document with the specified type doesn't exist.\n    ###  \n    getDocumentByType: (type) ->\n        result = null\n        \n        for uid of @summaries.items\n            summary = @summaries.items[uid]\n            if summary.items? and summary.items.type == type\n                result = @getDocument(uid)\n                break\n\n        return result\n        \n    ###*\n    * Gets a document by its UID.\n    *\n    * @method getDocument\n    * @param {String} uid - The UID of the document to get.\n    * @return {gs.Document} The document or <b>null</b> if a document with the specified UID doesn't exist.\n    ###  \n    getDocument: (uid) ->\n        result = @documentsByUid[uid]\n    \n        if not result?\n            gs.Data.load(uid, (dataObject, error) =>\n                if !error\n                    r = @documentsByUid[dataObject.uid]\n                    r.items = dataObject.items;\n                    r.loaded = true;\n            )\n            \n            if @summaries and @summaries.items\n                summary = @summaries.items[uid]\n                if summary\n                    result = { uid: uid, items: summary.items, loaded: false }\n            else\n                result = { uid: uid, loaded: false }\n            \n            if result\n                @documentsByUid[uid] = result\n                @documents.push(result)\n                @documentsLoaded = false\n            \n            if uid == \"SUMMARIES\" then @summaries = result\n    \n        return result\n        \n    \n    ###*\n    * Gets a document by its UID. If the document isn't already loaded this method\n    * only returned document only contains summary data.\n    *\n    * @method getDocumentSummary\n    * @param {String} uid - The UID of the document to get.\n    * @return {gs.Document} The document or <b>null</b> if a document with the specified UID doesn't exist.\n    ### \n    getDocumentSummary: (uid) -> @summaries.items[uid]\n    \n    ###*\n    * Updates the loading process of documents.\n    *\n    * @method update\n    ### \n    update: ->\n        if not @documentsLoaded\n            @documentsLoaded = true\n    \n            for i in [0...@documents.length]\n                if not @documents[i].loaded\n                    @documentsLoaded = false\n                    break\n                    \n            if @documentsLoaded\n                @events.emit(\"loaded\", this)\n        \n        return null\n\nwindow.DataManager = DataManager\ngs.DataManager = DataManager"]}\n//# sourceURL=DataManager_77.js",
"parentId": "C0268943K60B3A42B7SA6F1EDDCF2F642FD7"
},
"summary": [
"name",
"type",
"order"
]
}
|