antosdk-apps/Booklet/coffees/common.coffee

193 lines
5.7 KiB
CoffeeScript
Raw Normal View History

2019-11-24 20:33:14 +01:00
class BookletEntry
2019-11-26 22:35:25 +01:00
constructor: () ->
2019-11-28 18:35:55 +01:00
@name = "Untitled"
2019-11-24 20:33:14 +01:00
save: () ->
remove: () ->
toc: () ->
2019-11-28 18:35:55 +01:00
2019-11-26 22:35:25 +01:00
2019-11-28 18:35:55 +01:00
updateName:() ->
return @name unless @descFile.dirty
2019-11-28 23:11:46 +01:00
t = (new RegExp "^\s*#+(.*)\n", "g").exec @descFile.cache
2019-11-28 18:35:55 +01:00
return @name unless t and t.length is 2
@name = t[1].trim()
2019-11-28 23:11:46 +01:00
remove: () ->
me = @
return new Promise (r, e) ->
f = me.path.asFileHandler()
f.meta (d) ->
if d.error
return r() unless me.parent
return me.parent.removeChild(me).then () ->
r()
.catch (msg) -> e msg
else
f.remove (ret) ->
return e ret.error if ret.error
return r() unless me.parent
me.parent.removeChild(me).then () ->
r()
.catch (msg) -> e msg
2019-11-24 20:33:14 +01:00
class BookletFolder extends BookletEntry
2019-11-28 18:35:55 +01:00
constructor: (@type, @path, @hasMeta) ->
2019-11-26 22:35:25 +01:00
super()
2019-11-28 23:11:46 +01:00
@cnt = 0
2019-11-28 18:35:55 +01:00
@nodes = []
@metaFile = "#{@path}/meta.json".asFileHandler() if @hasMeta
2019-11-28 23:11:46 +01:00
@descFile = "#{@path}/INTRO.md".asFileHandler()
2019-11-24 20:33:14 +01:00
2019-11-28 18:35:55 +01:00
add: (chap) ->
chap.parent = @
@nodes.push chap
2019-11-28 23:11:46 +01:00
@metaFile.dirty = true if @hasMeta and @metaFile
chap.metaFile.dirty = true if chap.metaFile and chap.hasMeta
@cnt = @cnt + 1
removeChild: (child) ->
me = @
#v.treepath = v.path for v in @nodes if @nodes
return new Promise (r, e) ->
me.nodes.splice (me.nodes.indexOf child), 1
#if me.nodes.includes child
return r() unless me.hasMeta and me.metaFile
me.metaFile.dirty = true
me.updateMeta().then () ->
r()
.catch (msg) ->
e msg
2019-11-24 20:33:14 +01:00
size: () ->
2019-11-28 18:35:55 +01:00
return @nodes.length
2019-11-26 20:23:28 +01:00
2019-11-28 18:35:55 +01:00
mkdir: () ->
2019-11-26 20:23:28 +01:00
me = @
2019-11-28 18:35:55 +01:00
return new Promise (r, e) ->
dir = me.path.asFileHandler()
dir.meta (d) ->
return r() unless d.error
bname = dir.basename
dir = dir.parent().asFileHandler()
dir.mk bname, (result) ->
e __("Error when create directory: {0}", result.error) if result.error
r()
mkdirs: () ->
me = @
return new Promise (r, e) ->
list = []
2019-11-28 23:11:46 +01:00
list[i] = v for v, i in me.nodes if me.type isnt 'section'
2019-11-28 18:35:55 +01:00
me.mkdir().then () ->
fn = (l) ->
return r() if l.length is 0
el = (l.splice 0, 1)[0]
el.mkdirs().then () ->
fn l
2019-11-28 23:11:46 +01:00
.catch (msg) -> e msg
2019-11-28 18:35:55 +01:00
return fn list
2019-11-28 23:11:46 +01:00
.catch (msg) -> e msg
2019-11-28 18:35:55 +01:00
2019-11-28 23:11:46 +01:00
updateMeta: () ->
me = @
return new Promise (r, e) ->
return r() unless me.metaFile.dirty
entries = []
entries[i] = v.path for v,i in me.nodes
me.metaFile.cache = entries
me.metaFile.write "object", (d) ->
return e d.error if d.error
me.metaFile.dirty = false
console.log "saved " + me.metaFile.path
r()
update: () ->
me = @
return new Promise (r, e) ->
me.updateMeta().then () ->
return r() unless me.descFile.dirty
me.descFile.write "text/plain", (d) ->
return e d.error if d.error
me.descFile.dirty = false
console.log "saved " + me.descFile.path
r()
.catch (msg) -> e msg
updateAll: () ->
me = @
return new Promise (r, e) ->
list = []
list[i] = v for v, i in me.nodes
me.update().then () ->
fn = (l) ->
return r() if l.length is 0
el = (l.splice 0, 1)[0]
el.updateAll().then () ->
fn l
.catch (msg) -> e msg
return fn list
.catch (msg) -> e msg
2019-11-24 20:33:14 +01:00
toc: () ->
2019-11-28 18:35:55 +01:00
@updateName()
v.toc() for v in @nodes
@
2019-11-24 20:33:14 +01:00
2019-11-28 18:35:55 +01:00
class Book extends BookletFolder
constructor: (path) ->
super 'book', path, true
2019-11-28 23:11:46 +01:00
save:() ->
me = @
return new Promise (r, e) ->
me.mkdirs().then () ->
me.updateAll().then () ->
r()
.catch (msg) -> e msg
. catch (msg) -> e msg
2019-11-28 18:35:55 +01:00
class BookletChapter extends BookletFolder
constructor: (book) ->
2019-11-28 23:11:46 +01:00
path = "#{book.path}/c_#{book.cnt}"
2019-11-28 18:35:55 +01:00
super 'chapter', path, true
book.add @
2019-11-26 22:35:25 +01:00
2019-11-24 20:33:14 +01:00
class BookletSection extends BookletFolder
2019-11-28 18:35:55 +01:00
constructor: (chapter) ->
2019-11-28 23:11:46 +01:00
path = "#{chapter.path}/s_#{chapter.cnt}"
super "section", path, true
2019-11-28 18:35:55 +01:00
chapter.add @
2019-11-24 20:33:14 +01:00
class BookletFile extends BookletEntry
constructor: (@section) ->
2019-11-26 22:35:25 +01:00
super()
2019-11-28 23:11:46 +01:00
@hasMeta = false
@type = "file"
@path = "#{@section.path}/f_#{@section.cnt}.md"
2019-11-26 22:35:25 +01:00
@descFile = @path.asFileHandler()
2019-11-28 23:11:46 +01:00
@section.add @
2019-11-24 20:33:14 +01:00
2019-11-28 23:11:46 +01:00
updateAll: ()->
2019-11-26 22:35:25 +01:00
me = @
2019-11-28 23:11:46 +01:00
return new Promise (r, e) ->
return r() unless me.descFile.dirty
me.descFile.write "text/plain", (d) ->
return e d.error if d.error
me.descFile.dirty = false
console.log "saved" + me.descFile.path
r()
2019-11-24 20:33:14 +01:00
toc: () ->
2019-11-28 18:35:55 +01:00
@updateName()
@