/*
* pettanR system.js
- * version 0.4.5
+ * version 0.4.11
*
* author:
* itozyun
TREE_ARRAY.push( _tree);
return _tree;
},
- getFileData: function( UIDorFILEorFILEDATA){
- var _access = FILE_CONTROLER.getFileDataAccess( UIDorFILEorFILEDATA);
- return _access !== null ? _access.DATA : null;
- },
- getChildren: function( UIDorFILEorFILEDATA){
- var _data = FILE_CONTROLER.getFileData( UIDorFILEorFILEDATA);
- return _data !== null ? _data.children || null : null;
- },
getFileDataAccess: function( UIDorFILEorFILEDATA){
var _uid, _data, _access;
if( _access.DATA === _data) return _access;
}
return null;
+ },
+ getFileData: function( UIDorFILEorFILEDATA){
+ var _access = FILE_CONTROLER.getFileDataAccess( UIDorFILEorFILEDATA);
+ return _access !== null ? _access.DATA : null;
+ },
+ getChildren: function( UIDorFILEorFILEDATA){
+ var _data = FILE_CONTROLER.getFileData( UIDorFILEorFILEDATA);
+ return _data !== null ? _data.children || null : null;
},
getDriver: function( _file){
var _data = FILE_CONTROLER.getFileData( _file);
return _data !== null && _data.driver ? _data.driver : FileDriverBase;
},
getUpdateFlag: function( _file, _bit){
- var _driver = FILE_CONTROLER.getFileData( _file),
+ var _driver = FILE_CONTROLER.getDriver( _file ),
_policy;
if( typeof _driver.getUpdatePolicy === 'function'){
_policy = _driver.getUpdatePolicy( _file );
}
return _policy % ( _bit * 2) >= _bit;
},
- getUID: function ( _filedata){
- var l = FILEDATA_RESITER.length;
- for( var i=0; i<l; ++i){
- if( FILEDATA_RESITER[ i] === _filedata) return i;
- }
- return -1;
- },
- getSeqentialFiles: function( _file){
- var _driver = FILE_CONTROLER.getDriver( _file);
- if( _driver !== null && typeof _driver.getSeqentialFiles === 'function'){
- _driver.getSeqentialFiles( _file);
- }
- },
- updateFileAttribute: function( _uid, key, _value, _opt_callback){
- var _data = FILE_CONTROLER.getFileDataAccess( _uid),
- _type = _data.TYPE;
-
- },
- getFileAttribute: function( _uid, KEYorKEYARRAY){
- var _fileData = FILE_CONTROLER.getFileDataAccess( _uid),
- _type = _fileData.TYPE;
- },
move: function( _prentUID, _targetfile, _newFolder, _newIndex, _opt_callback){
var _parentData = FILE_CONTROLER.getFileDataAccess( _prentUID),
_parentType = _parentData.TYPE,
},
fileEventRellay: function( _targetFile, _targetTree, _event){
var _uid = _targetTree.getUID(),
- _access = TREE_ACCESS_ARRAY[ _uid],
- l = TREE_ARRAY.length,
- _tree, _currentFile;
- _access !== undefined && _access.dispatchFileEvent( _event);
- for(var i=0; i<l; ++i){
+ _access = TREE_ACCESS_ARRAY[ _uid ],
+ _data = FILE_CONTROLER.getFileData( _targetFile ),
+ _tree;
+ _access && _access.dispatchFileEvent( _event );
+ for( var i=0, l = TREE_ARRAY.length; i<l; ++i){
if( i !== _uid){
- _tree = TREE_ARRAY[i];
- _currentFile = _tree.getCurrentFile();
- if( FILE_CONTROLER.getFileData( _currentFile) === _access.DATA){
- TREE_ACCESS_ARRAY[ _tree.getUID()].dispatchFileEvent( _event);
+ _tree = TREE_ARRAY[ i ];
+ if( FILE_CONTROLER.getFileData( _tree.getCurrentFile() ) === _data ){
+ _access = TREE_ACCESS_ARRAY[ _tree.getUID() ];
+ _access && _access.dispatchFileEvent( _event);
}
}
}
init: function(){
instance = this;
currentFile = rootFile = new FileClass( this, null, ROOTFILE_DATA);
- rootFile.init();
- FILE_CONTROLER.getSeqentialFiles( currentFile);
+ // rootFile.init();
+ currentFile.getSeqentialFiles();
delete this.init;
},
getUID: function(){ return UID},
if( typeof _index !== 'number' || _index < 0 || _index >= currentFile.getChildFileLength()) return;
PARENT_FILE_RESITER.unshift( currentFile);
currentFile = currentFile.getChildFileByIndex( _index);
- FILE_CONTROLER.getSeqentialFiles( currentFile);
+ currentFile.getSeqentialFiles();
return currentFile;
},
up: function( _index){
} else {
currentFile = PARENT_FILE_RESITER.shift();
}
- FILE_CONTROLER.getSeqentialFiles( currentFile);
+ currentFile.getSeqentialFiles();
return currentFile;
},
addTreeEventListener: function( _eventType, _callback){
*/
var FileClass = function( TREE, parentFile, data){
- if( !data.children){
- data.children = [];
- }
- var uid = FILE_CONTROLER.getUID( data),
+ var uid = pettanr.util.getIndex( FILEDATA_RESITER, data ),
instance = this;
if( uid === -1){
uid = FILEDATA_RESITER.length;
- FILEDATA_RESITER.push( data);
+ FILEDATA_RESITER.push( data );
}
FILEDATA_ACCESS.push(
}
/* grobal Methods */
- this.init = function(){
- delete this.init;
- }
+
this.getUID = function(){
return uid;
}
/*
- * ファイル構造は TRON のような ハイパーリンク方式 だが、文脈上の 親ファイルが存在する場合がある.
+ * ファイル構造は TRON のような ハイパーリンク方式 だが、文脈上の 親ファイルが存在する.その親ファイルを使う操作は.prototype に置く事ができない.
+ * 同様に TREE を使う操作も .prototype に置く事ができない.
*/
this.getChildFileByIndex = function( _index){
var _children = FILE_CONTROLER.getChildren( instance );
if( typeof _index !== 'number' || _index < 0 || typeof _children.length !== 'number' || _index >= _children.length) return null;
var _file = new FileClass( TREE, this, _children[ _index]);
- _file.init();
+ // _file.init();
return _file;
}
this.move = function( _newFolder, _newIndex, opt_callback){
delete _access.DATA, _access.updateParent, _access.dispatchFileEvent;
}
};
+
FileClass.prototype = {
isChildFile: function( _FILEorFILEDATA){
return this.getChildFileIndex( _FILEorFILEDATA) !== -1;
},
getSeqentialFiles: function(){
- FILE_CONTROLER.getSeqentialFiles( this);
+ var _driver = FILE_CONTROLER.getDriver( this );
+ if( _driver !== null && typeof _driver.getSeqentialFiles === 'function'){
+ _driver.getSeqentialFiles( this );
+ }
},
addEventListener: function( _eventType, _callback){
FILE_CONTROLER.addEventListener( this, _eventType, _callback);
},
getChildFileLength: function(){
var children = FILE_CONTROLER.getChildren( this);
- return children !== null && typeof children.length === 'number' ? children.length : 0;
+ return Type.isArray( children ) === true ? children.length : -1;
},
getChildFileIndex: function( _FILEorFILEDATA){
var children = FILE_CONTROLER.getChildren( this);
-
- if( children === null || typeof children.length !== 'number') return -1;
+ if( Type.isArray( children.length ) === false ) return -1;
var l = children.length,
_fileData = FILE_CONTROLER.getFileData( _FILEorFILEDATA);
if( _fileData === null) return -1;
write: function( _newName, _newData){
return false;
},
+ viwerApps: function(){
+
+ },
+ editorApps: function(){
+
+ },
create: function(){
},
}
}
- function getFileObject( TREE, parentFile, data){
- var _file = FILE_OBJECT_POOL.length > 0 ? FILE_OBJECT_POOL.shift() : new FileClass();
- _file.init( TREE, parentFile, data);
- return _file;
- }
-
var ROOT_FILEDATA = {
name: 'system root',
type: FILE_TYPE_IS_FOLDER,
GET_SEQENTIAL_FILES:'gotSeqentilFiles'
},
FILE_DATA_PROPERTY_RESERVED: [
- 'children', 'driver', 'state', 'type', 'name'
+ 'children', 'driver', 'state', 'type'
]
}
})();
var l = ICON_ARRAY.length;
if( i < l){
var _file = tree.getCurrentFile().getChildFileByIndex( i);
- if( _file !== null && ( _file.getChildFileLength() > 0 || _file.getType() === pettanr.file.FILE_TYPE.FOLDER)){
+ if( _file !== null && ( _file.getChildFileLength() !== -1 || _file.getType() === pettanr.file.FILE_TYPE.FOLDER)){
tree.down( i);
draw();
}
getSeqentialFiles: function( _file){
var _data = FileAPI.getFileData( _file),
_json = _data !== null ? _data.json : null;
+ if( _json === true && _data.type === pettanr.driver.FILE_TYPE.COMIC ){
+ _json = [ pettanr.CONST.PETTANR_ROOT_PATH, 'comics\/', _data.id, '.json\/play\/' ].join( '' );
+ }
if( typeof _json === 'string'){
FileAPI.getJson( _file, _json, onLoadJson, onErrorJson);
_data.state = pettanr.file.FILE_STATE.LOADING;
- delete _data.json;
+ _data.json = null;
+ return;
}
},
getName: function( _file){
var _data = FileAPI.getFileData( _file),
_type = _data !== null ? _data.type : null;
- if( _type === pettanr.driver.FILE_TYPE.PICTURE){
+ if( _type === pettanr.driver.FILE_TYPE.PICTURE ){
return [ _data.id, _data.ext ].join( '.');
} else
- if( _type === pettanr.driver.FILE_TYPE.PANEL){
- return [ _data.t, ':', _data.comic.name || _data.comic.title ].join( '');
+ if( _type === pettanr.driver.FILE_TYPE.PANEL ){
+ return [ _data.t, ':', _data.comic.title ].join( '');
} else
- if( _type === pettanr.driver.FILE_TYPE.ARTIST){
+ if( _type === pettanr.driver.FILE_TYPE.COMIC ){
+ return _data.title;
+ } else
+ if( _type === pettanr.driver.FILE_TYPE.ARTIST ){
return [ _data.id , ':', _data.name, '画伯' ].join( '');
} else
- if( _type === pettanr.driver.FILE_TYPE.AUTHOR){
+ if( _type === pettanr.driver.FILE_TYPE.AUTHOR ){
return [ _data.id , ':', _data.name, '先生' ].join( '');
}
- return _data.name || _data.title;
+ return _data.name;
},
getThumbnail: function( _file){
var _data = FileAPI.getFileData( _file);
if( _type === pettanr.driver.FILE_TYPE.PICTURE){
return { image: [ pettanr.CONST.RESOURCE_PICTURE_PATH, 'thumbnail/', _data.id, '.', _data.ext ].join( '')};
}
- if( _data === FILE_DATA_COMIC_ROOT){
+ if( _data === FILE_DATA_COMICS_ROOT){
return { className: 'file-type-cabinet'};
}
if( _type === pettanr.driver.FILE_TYPE.COMIC){
type: pettanr.file.FILE_TYPE.FOLDER,
children: []
},
- FILE_DATA_COMIC_ROOT = {
+ FILE_DATA_COMICS_ROOT = {
name: 'Comics',
type: pettanr.file.FILE_TYPE.FOLDER,
children: [],
driver: Driver,
+ json: pettanr.CONST.URL_COMICS_JSON
+ },
+ FILE_DATA_PANELS_ROOT = {
+ name: 'Panels',
+ type: pettanr.file.FILE_TYPE.FOLDER,
+ children: [],
+ driver: Driver,
json: pettanr.CONST.URL_PANELS_JSON
},
FILE_DATA_PICTURE_ROOT = {
type: pettanr.file.FILE_TYPE.FOLDER,
children: [],
driver: Driver,
- json: pettanr.CONST.URL_ORIGINAL_PICTURES_JSON
+ json: pettanr.CONST.URL_RESOURCE_PICTURES_JSON
},
FILE_DATA_MY_COMICS_ROOT = {
name: 'My Comics',
- type: pettanr.file.FILE_TYPE.FOLDER,
- children: []
+ type: pettanr.file.FILE_TYPE.AUTHOR,
+ children: [],
+ driver: Driver
},
FILE_DATA_MY_PICTURES_ROOT = {
name: 'My Pictures',
- type: pettanr.file.FILE_TYPE.FOLDER,
- children: []
+ type: pettanr.file.FILE_TYPE.ARTIST,
+ children: [],
+ driver: Driver,
+ json: pettanr.CONST.URL_ORIGINAL_PICTURES_JSON
},
FILE_DATA_AUTHOR_ROOT = {
name: 'Authors',
type: pettanr.file.FILE_TYPE.FOLDER,
children: []
},
- FILE_DATA_LICENSE_ROOT = {
- name: 'Original Licenses',
+ FILE_DATA_LISENCE_ROOT = {
+ name: 'Original Lisences',
type: pettanr.file.FILE_TYPE.FOLDER,
children: []
},
BALLOON_TEMPLETE_ARRAY = [],
ORIGINAL_LICENSE_ARRAY = [],
BASIC_LICENSES = 'cc_by,cc_nc,cc_nd,cc_sa,keep_aspect_ratio,no_convert,no_flip,no_resize'.split( ',');
- FILE_DATA_SERVICE_ROOT.children.push( FILE_DATA_COMIC_ROOT, FILE_DATA_PICTURE_ROOT, FILE_DATA_LICENSE_ROOT, FILE_DATA_BALLOON_ROOT);
- FILE_DATA_COMIC_ROOT.children.push( FILE_DATA_MY_COMICS_ROOT, FILE_DATA_AUTHOR_ROOT);
+ FILE_DATA_SERVICE_ROOT.children.push( FILE_DATA_COMICS_ROOT, FILE_DATA_PICTURE_ROOT, FILE_DATA_PANELS_ROOT, FILE_DATA_LISENCE_ROOT, FILE_DATA_BALLOON_ROOT);
+ FILE_DATA_COMICS_ROOT.children.push( FILE_DATA_MY_COMICS_ROOT, FILE_DATA_AUTHOR_ROOT);
FILE_DATA_PICTURE_ROOT.children.push( FILE_DATA_MY_PICTURES_ROOT, FILE_DATA_ARTIST_ROOT);
FileAPI.createFolderUnderRoot( FILE_DATA_SERVICE_ROOT);
-
+
function onLoadJson( _file, _json){
var _access = FileAPI.getFileDataAccess( _file),
_data = _access !== null ? _access.DATA : null,
- l = _json.length;
+ l;
if( _data === null){
onErrorJson( _file);
return;
}
_data.state = pettanr.file.FILE_STATE.OK;
- if( l === 0) return;
- for(var i=0; i<l; ++i){
- buildFileData( _json[ i], _data);
+
+ if( Type.isArray( _json ) === true ){
+ var l = _json.length;
+ if( l === 0) return;
+ for( var i=0; i<l; ++i ){
+ buildFileData( _json[ i], _data);
+ }
+ } else
+ if( _json.id ){
+ buildFileData( _json, _data );
}
_access.dispatchFileEvent( FileAPI.createFileEvent( pettanr.file.FILE_EVENT.GET_SEQENTIAL_FILES, _file, 'children', null));
}
- function onErrorJson( _file){
+ function onErrorJson( _file ){
var _data = FileAPI.getFileData( _file);
if( _data !== null){
_data.state = pettanr.file.FILE_STATE.ERROR;
}
}
- function buildFileData( _data, _parent){
- var _type, _array,
- _id = _data.id,
- i, l;
- if( _parent === FILE_DATA_COMIC_ROOT){
+ function buildFileData( _data, _parent ){
+ var _array, i, l;
+ // Panel
+ if( _parent === FILE_DATA_PANELS_ROOT ){
_data.type = pettanr.driver.FILE_TYPE.PANEL;
_array = PANEL_ARRAY;
} else
- if( _parent === FILE_DATA_PICTURE_ROOT){
+ // Comic
+ if( _parent === FILE_DATA_COMICS_ROOT ){
+ _data.type = pettanr.driver.FILE_TYPE.COMIC;
+ _array = COMIC_ARRAY;
+ } else
+ if( _parent.type === pettanr.driver.FILE_TYPE.COMIC ){
+ _array = COMIC_ARRAY;
+ } else
+ // Lisence
+ if( _parent === FILE_DATA_LISENCE_ROOT ){
+ _data.type = pettanr.driver.FILE_TYPE.LICENSE;
+ _array = ORIGINAL_LICENSE_ARRAY;
+ } else
+ // Author
+ if( _parent === FILE_DATA_AUTHOR_ROOT ){
+ _data.type = pettanr.driver.FILE_TYPE.AUTHOR;
+ _array = AUTHOR_ARRAY;
+ } else
+ // Artist
+ if( _parent === FILE_DATA_ARTIST_ROOT ){
+ _data.type = pettanr.driver.FILE_TYPE.ARTIST;
+ _array = ARTIST_ARRAY;
+ } else
+ // Picture
+ if( _parent === FILE_DATA_PICTURE_ROOT || _parent === FILE_DATA_MY_PICTURES_ROOT ){
_data.type = pettanr.driver.FILE_TYPE.PICTURE;
_array = RESOURCE_PICTURE_ARRAY;
-
// original_license を含まなければ、license object を削除して ビットデータ で保持
- // original_license なら ファイルを作る buildFileData( _license, FILE_DATA_LICENSE_ROOT)
+ // original_license なら ファイルを作る buildFileData( _license, FILE_DATA_LISENCE_ROOT)
var _license = _data.license,
_Math_pow = Math.pow,
_bits = 0;
}
_data.license = _bits;
}
- } else
- if( _parent === FILE_DATA_LICENSE_ROOT){
- _data.type = pettanr.driver.FILE_TYPE.LICENSE;
- _array = ORIGINAL_LICENSE_ARRAY;
+ } else {
+ alert( 'error' );
}
_data.driver = Driver;
// _array に _data を格納 または 上書き
- if( typeof _id === 'number'){
- var __data = _array[ _id];
- if( __data){
+ if( typeof _data.id === 'number' && _data.id > 0 ){
+ var _id = _data.id - 1,
+ __data = _array[ _id ],
+ _reserved = pettanr.file.FILE_DATA_PROPERTY_RESERVED.join( ', ' );
+ if( __data ){
for( var key in _data){
- __data[ key ] = _data[ key ];
+ if( _reserved.indexOf( key ) === -1 ){
+ __data[ key ] = _data[ key ];
+ }
}
_data = __data; // このタイミングで参照が切れるので注意!!
} else {
- _array[ _id] = _data;
+ _array[ _id ] = _data;
}
+ } else {
+ alert( 'error' );
}
-
- if( _parent === FILE_DATA_COMIC_ROOT){
- if( _data.comic && _data.author){
- var _comic = getFolderData( _data, 'comic', FILE_DATA_COMIC_ROOT),
- _comicList = getFolderData( _data, 'author', FILE_DATA_AUTHOR_ROOT);
- _comic.children.push( _data);
- pettanr.util.getIndex( _comicList.children, _comic) === -1 && _comicList.children.push( _comic);
- _comicList.id === MyAuthorID && pettanr.util.getIndex( FILE_DATA_MY_COMICS_ROOT.children, _comic) === -1 && FILE_DATA_MY_COMICS_ROOT.children.push( _comic);
- }
- // picture data をファイルに取り出し
- var _elements = _data.panel_elements || [],
- _elm;
- for(var i=0, l=_elements.length; i<l; ++i){
- _elm = _elements[ i];
- if( _elm.resource_picture){
- _elm.resource_picture = buildFileData( _elm.resource_picture, FILE_DATA_PICTURE_ROOT); // 上記参照切れに備えてここで上書き
+
+ // Author
+ // Artist
+ if( _parent === FILE_DATA_AUTHOR_ROOT || _parent === FILE_DATA_ARTIST_ROOT ){
+ addChildData( _parent, _data );
+ } else
+ // Comic + Panels
+ if( _parent.type === pettanr.driver.FILE_TYPE.COMIC || _parent === FILE_DATA_COMICS_ROOT ){
+ var _panels = _data.panels,
+ _panel;
+ if( _panels && Type.isArray( _panels ) === true ){
+
+ for( i=0, l=_panels.length; i<l; ++i){
+ _panel = buildFileData( _panels[ i ], FILE_DATA_PANELS_ROOT );
+ /*
+ * 間違い! t 順に格納
+ */
+ addChildData( _data, _panel );
}
- if( _elm.resource_picture_id && RESOURCE_PICTURE_ARRAY[ _elm.resource_picture_id]){
- _elm.resource_picture = RESOURCE_PICTURE_ARRAY[ _elm.resource_picture_id];
+ delete _data.panels;
+ } else {
+ if( _data.json !== null ){
+ _data.json = true;
}
+ if( Type.isArray( _data.children ) === false ){
+ _data.children = [];
+ }
+ }
+ var _author = _data.author || getResource( AUTHOR_ARRAY, _data.author_id );
+ if( _author ){
+ _data.author = _author = buildFileData( _author, FILE_DATA_AUTHOR_ROOT );
+ addChildData( _author, _data );
+ _author.id === MyAuthorID && addChildData( FILE_DATA_MY_COMICS_ROOT, _data );
}
} else
- if( _parent === FILE_DATA_PICTURE_ROOT){
- if( _data.artist){
- var _pictureList = getFolderData( _data, 'artist', FILE_DATA_ARTIST_ROOT);
- pettanr.util.getIndex( _pictureList.children, _data) === -1 && _pictureList.children.push( _data);
- _pictureList.id === MyArtistID && pettanr.util.getIndex( FILE_DATA_MY_PICTURES_ROOT.children, _data) === -1 && FILE_DATA_MY_PICTURES_ROOT.children.push( _data);
+ // Panel
+ if( _parent === FILE_DATA_PANELS_ROOT ){
+ _data.comic = getResource( COMIC_ARRAY, _data.comic_id ),
+ _data.author = getResource( AUTHOR_ARRAY, _data.author_id );
+
+ // picture data をファイルに取り出し
+ if( Type.isArray( _data.panel_elements ) === true ){
+ var _elements,
+ _elm, _rpic;
+ for( i=0, l=_elements.length; i<l; ++i){
+ _elm = _elements[ i];
+ if( _elm.resource_picture ){
+ _elm.resource_picture = buildFileData( _elm.resource_picture, FILE_DATA_PICTURE_ROOT); // 上記参照切れに備えてここで上書き
+ } else {
+ _elm.resource_picture = getResource( RESOURCE_PICTURE_ARRAY, _elm.resource_picture_id );
+ }
+ }
+ }
+ } else
+ // Picture
+ if( _data.type = pettanr.driver.FILE_TYPE.PICTURE ){
+ var _artist = _data.artist || getResource( ARTIST_ARRAY, _data.artist_id );
+ if( _artist){
+ _data.artist = _artist = buildFileData( _artist, FILE_DATA_ARTIST_ROOT );
+ addChildData( _artist, _data );
+ _artist.id === MyArtistID && addChildData( FILE_DATA_MY_PICTURES_ROOT, _data );
}
}
-
return _data;
}
- /**
- * folder には Artist, Author, Comic,
- */
- function getFolderData( _data, _key, _parentData){
- if( typeof _data[ _key ] !== 'object') return {children:[]};
- var _ret,
- _id = _data[ _key ].id,
- _array;
- if( typeof _id !== 'number') return {children:[]};
-
- _array = _parentData === FILE_DATA_ARTIST_ROOT ? ARTIST_ARRAY :
- _parentData === FILE_DATA_AUTHOR_ROOT ? AUTHOR_ARRAY :
- _parentData === FILE_DATA_COMIC_ROOT ? COMIC_ARRAY : []
-
- if( typeof _array[ _id] === 'object'){
- var __data = _array[ _id];
- for( var i in _data[ _key ]){
- __data[ i ] = _data[ _key ][ i ];
- }
- return _data[ _key ] = __data;// このタイミングで参照が切れるので注意!!
+ function addChildData( _parent, _child ){
+ if( Type.isArray( _parent.children ) === false){
+ _parent.children = [];
}
- // 以下は folder がなく 新規に作られる場合.
- _ret = _array[ _id ] = _data[ _key ];
- if( _ret.title){
- _ret.name = _ret.title;
- delete _ret.title;
- }
- _ret.children = [];
- _ret.driver = Driver;
-
- if( _parentData === FILE_DATA_AUTHOR_ROOT){
- _ret.type = pettanr.driver.FILE_TYPE.AUTHOR;
- } else
- if( _parentData === FILE_DATA_ARTIST_ROOT){
- _ret.type = pettanr.driver.FILE_TYPE.ARTIST;
- } else
- if( _parentData === FILE_DATA_COMIC_ROOT){
- _ret.type = pettanr.driver.FILE_TYPE.COMIC;
- return _ret;
- } else {
- _ret.type = pettanr.file.FILE_TYPE.FOLDER;
+ pettanr.util.getIndex( _parent.children, _child ) === -1 && _parent.children.push( _child );
+ }
+ function getResource( _array, _id ){
+ if( Type.isArray( _array ) === false || Type.isNumber( _id ) === false || _id < 1 ) return null;
+ var _data = _array[ _id - 1 ];
+ if( !_data ){
+ _data = _array[ _id - 1 ] = {};
}
-
- _parentData.children.push( _ret);
-
- return _ret;
+ return _data;
}
return {
createComicTree: function(){
- return pettanr.file.createTree( FILE_DATA_SERVICE_ROOT); //FILE_DATA_COMIC_ROOT);
+ return pettanr.file.createTree( FILE_DATA_SERVICE_ROOT); //FILE_DATA_COMICS_ROOT);
},
createPictureTree: function(){
return pettanr.file.createTree( FILE_DATA_PICTURE_ROOT);
pettanr.fn( pettanr.editor);
pettanr.fn( pettanr.comicConsole);
pettanr.fn( pettanr.uploadConsole);
+pettanr.fn( pettanr.panelConsole);
+pettanr.fn( pettanr.artistConsole);
pettanr.fn( pettanr.file);
pettanr.fn( pettanr.finder);