| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412 | 
var m = require('mithril');// https://github.com/markdown-it/markdown-itvar markdown =  require('markdown-it')()                  .use(require('markdown-it-footnote'));var _dbs = require('./dbs');var _Header = require('./header');var _Footer = require('./footer');var _Ui = require('./ui.js');//     ____        __//    / __ \____  / /_//   / / / / __ \/ __///  / /_/ / /_/ / /_// /_____/\____/\__/var _Dot = {  id:null,  dottype:null,  type:'',  title:'',  breadcrumb:'',  text:'',  summary:'',  active:true,  opened:0,  nested:false,  links:null,  parents:[],  lang:_dbs.lang,  setupTitle(vn){    this.title = vn.attrs.title;    if(!this.title) this.title = this.type;    if(this.title)      this.title = markdown.renderInline(this.title);  },  setuptext(vn){    // console.log('setuptext', vn);    // construct text    this.text = vn.attrs.text || '';    this.rendered_text = markdown.render(this.text);    if(this.dottype == "preface"){      this.summary = this.rendered_text;    }else{      // construct summary      // TODO: summary needs more work (strip tags, markdown render)      // remove img      this.summary = this.text.replace(/!\[[^\]]+\]\([^\)]+\)/g, "");      // get portion of text      this.summary = this.summary.match('([^ ]*[ ]{0,1}){1,6}')[0];      // end underscores (italic) splited by summarizing      this.summary = this.summary.trim().replace(/_([^_]+)$/g, "_$1_");      // remove brackets (links) splited by summarizing      this.summary = this.summary.replace(/\[([^\]]+)$/g, "$1");      // render the markdown      this.summary = markdown.renderInline(this.summary) + " …";    }  },  oninit(vn){    this.id = vn.attrs.id;    this.type = vn.attrs.type;    this.dottype = vn.attrs.dottype;    this.breadcrumb = vn.attrs.breadcrumb;    // console.log(`${this.id} -> ${this.dottype}`);    if(typeof vn.attrs.active !== 'undefined')      this.active = vn.attrs.active;    // links    this.links = _dbs.data_strct[this.id];    // parents memorize where do we come from to avoid duplicates and looping nav    if(vn.attrs.parents){      this.parents = this.parents.concat(vn.attrs.parents);      // console.log('_Dot init '+this.id+' parents :',this.parents);    }    this.nested = this.parents.length ? true : false;    // if(this.nested) console.log(`oninit ${this.id}`);    this.setupTitle(vn);    this.setuptext(vn);  },  oncreate(vn){    if(this.active){      vn.dom.classList.remove('disabled');    }else{      vn.dom.classList.add('disabled');    }  },  onbeforeupdate(vn){    // if(this.opened) console.log(`onbeforeupdate ${this.id} : vn`,vn);    if(this.lang != _dbs.lang){      this.lang = _dbs.lang;      this.breadcrumb = vn.attrs.breadcrumb;      this.setuptext(vn);      this.setupTitle(vn);    }    // this.opened = 0;  },  onupdate(vn){    // if(this.nested) console.log(`onupdate ${this.id}`);    if(this.active){      if (this.opened){        vn.dom.classList.add('opened');        if(this.links.to.length)          vn.dom.classList.add('to-links');        if(this.links.from.length)          vn.dom.classList.add('from-links');      }else{        vn.dom.classList.remove('opened');      }    }  },  setupLinks(vn, c, links){    return m('nav', {'class':`links ${c}`}, links.map(id => {        // console.log(id);        if(typeof _dbs.data_byid[_dbs.lang][id] !== 'undefined'){          var obj = _dbs.data_byid[_dbs.lang][id];          // console.log('link to : obj', obj);          return m(_Dot, {            "id":id,            'title':obj.title,            'breadcrumb':obj.breadcrumb,            'text':obj.text,            'dottype':obj.dottype,            'type':obj.type,            // passe the memory of crossed dots plus the current one            'parents':vn.state.parents.concat([vn.state.id]),            // activate link only if not in parents (already went through it)            'active':vn.state.parents.indexOf(id) == -1 ? true:false,            // 'nested':true,          });        }      })    );  },  viewOpenedContent(vn){    // if(this.nested) console.log(`viewOpenedContent ${this.id} : vn`, vn);    // if(this.nested) console.log(`viewOpenedContent ${this.id} : this`, this);    return m('div', {        'uid':this.id,        'class':`dot ${this.dottype}${this.nested ? ' nested':''}`},      [        // links to        this.links.to.length          ? this.setupLinks(vn, 'to', this.links.to)          : null, // if no links to, add nothing        // close btn        m('div', {            'class':'close-link-btn',            onclick(e){              vn.state.opened = 0;            }          }, m('span', m.trust("🗙"))        ),        // Title        m('span', {'class':'title'}, m.trust(this.nested ? this.breadcrumb : this.title)),        // full text        m('section', {            'class':'text',            onmouseover(e){              e.preventDefault();              if(e.target.nodeName == "A" ){                let id = e.target.getAttribute("href");                // add highlight class                vn.dom.querySelector(`nav.links>div[uid="${id}"]`).classList.add('highlight');              }else{                // remove all hilight class                for (link of vn.dom.querySelectorAll('nav.links>div.dot')) {                  link.classList.remove('highlight');                }              }            },            onclick(e){              e.preventDefault();              if(e.target.nodeName == "A" ){                let id = e.target.getAttribute("href");                vn.dom.querySelector(`nav.links>div[uid="${id}"]>.title`).click();              }            }          }, m.trust(this.rendered_text)        ),        // links from        this.links.from.length          ? this.setupLinks(vn, 'from', this.links.from)          : null, // if no links from, add nothing      ]    );  },  viewPreviewContent(vn){    // if(this.nested) console.log(`viewPreviewContent ${this.id} : vn`, vn);    // if(this.nested) console.log(`viewPreviewContent ${this.id} : this`, this);    return m('div', {        'uid':this.id,        'class':`dot ${this.dottype}${this.nested ? ' nested':''}`      },      [        // bullet        m('div', {'class':'bullet'}, m('span', m.trust('⚫'))),        m('span', {          'class':'title',          onclick(e){            if(!vn.state.opened) vn.state.opened = 1;          }        }, m.trust(this.nested ? this.breadcrumb : this.title)),        m('p', {'class':'summary'}, m.trust(this.summary))      ]    );  },  view(vn){    // if (this.nested) console.log(`view ${this.id}`);    // if (this.opened) console.log(`view ${this.id} : vn`,vn);    // if (this.nested) console.log(`view ${this.id} : this`,this);    return this.active && vn.state.opened      ? this.viewOpenedContent(vn)  // full view of dot with linked dots      : this.viewPreviewContent(vn); // preview dot  }}/*full list of black dotlikes from unicode● - ● - Black Circle⏺ - ⏺ - Black Circle for Record⚫ - ⚫ - Medium Black Circle⬤ - ⬤ - Black Large Circle⧭ - ⧭ - Black Circle with Down Arrow🞄 - 🞄 - Black Slightly Small Circle• - • - Bullet∙ - ∙ - Bullet Operator⋅ - ⋅ - Dot Operator🌑 - 🌑 - New Moon Symbol*///   _______   _ __   __//  / ___/ /  (_) /__/ /// / /__/ _ \/ / / _  /// \___/_//_/_/_/\_,_/var _Child = {  // id:null,  // part:null,  // type:null,  // dottype:null,  // // nested:false,  // text:'',  oninit(vn){    // // console.log('vn.attrs', vn.attrs);    // this.id = vn.attrs.id;    // this.type = vn.attrs.type;    // // vn.state.part = vn.state.slug.match(/^(\d)(.+)/)[1];    // this.text = vn.attrs.text;    // // this.nested = vn.attrs.nested || false;    // this.dottype = vn.attrs.dottype;  },  onbeforeupdate(vn, old){    // // this.nested = vn.attrs.nested || false;    // this.type = vn.attrs.type;    // this.text = vn.attrs.text;  },  view(vn){    // return m(_Dot, {"id":this.id, 'text':this.text, 'type':this.type, 'dottype':this.dottype});    return m(_Dot, vn.attrs);  }};//     ______//    / ____/___  ____  ____  ________//   / __/ / __ \/ __ \/ __ \/ ___/ _ \//  / /___/ / / / /_/ / / / / /__/  __/// /_____/_/ /_/\____/_/ /_/\___/\___/var _Enonce = {  partid:null,  id:null,  title:null,  text:null,  dottype:null,  // nested:false,  childs:[],  oninit(vn){  // //   // console.log('Enonce on init', vn);  //   this.partid = vn.attrs.partid;  //   this.id = vn.attrs.id;  //   this.title = vn.attrs.title || "";  //   this.text = vn.attrs.text;  //   this.childs = vn.attrs.childs || [];  //   // this.nested = vn.attrs.nested || false;  //   this.dottype = vn.attrs.dottype;  },  onbeforeupdate(vn, old) {    // // console.log(vn.attrs.childs);    // this.title = vn.attrs.title || "";    // this.text = vn.attrs.text;    // this.childs = vn.attrs.childs || [];    // // this.nested = vn.attrs.nested || false;    // // if(vn.attrs.id == '1d1') console.log('_Enonce UPDATE, text :', vn.attrs.text);    // this.dottype = vn.attrs.dottype;  },  view(vn){    // if(vn.attrs.id == '1d1') console.log('_Enonce VIEW, text :', vn.attrs.text);    return [      // create dot      // m(_Dot, {      //   'id':this.id      //   'text':this.text      //   'type':this.title      //   'dottype':this.dottype      // }),      m(_Dot, vn.attrs),      // addd children      vn.attrs.childs.map(c => { return m(_Child, c); })    ]  }}//     ____             __//    / __ \____ ______/ /_//   / /_/ / __ `/ ___/ __///  / ____/ /_/ / /  / /_// /_/    \__,_/_/   \__/var _Part = {  oninit(vn){    this.id = vn.attrs.id;    this.title = vn.attrs.title || "";    this.enonces = vn.attrs.enonces;  },  onbeforeupdate(vn, old){    // console.log('_Part, onbeforeupdate old',old);    this.title = vn.attrs.title || "";    this.enonces = vn.attrs.enonces;  },  view(vn){    // console.log(vn.attrs.enonces);    return m("section", {        'id'    :this.id,        'class' :'part'      },      [        // create title node        m("h1", {'class':'part-title', 'part':this.id}, m.trust(markdown.renderInline(this.title))),        // create text node        this.enonces.map(e => {          // console.log(e.text);          // return m(_Enonce, Object.assign({"partid":this.id},e))          switch (e.type) {            case "title":              // handle titles              return m("h2", {'class':'title'}, m.trust(markdown.renderInline(e.title)));              break;            case "filet":              // handle filets              return m("h4", {'class':'filet'}, m.trust(markdown.renderInline(e.title)));              break;            default:              // or build structure              return m(_Enonce, Object.assign({"partid":this.id},e));          }        })      ]    )  }}//     ____      __//    /  _/___  / /__________//    / // __ \/ __/ ___/ __ \//  _/ // / / / /_/ /  / /_/ /// /___/_/ /_/\__/_/   \____/var _Intro = {  oninit(vn){    console.log('_Intro : oninit : vn', vn);    this.id = vn.attrs.id;    this.text = vn.attrs.text || '';  },  onbeforeupdate(vn, old){    this.id = vn.attrs.id;    this.text = vn.attrs.text || '';  },  view(vn){    return m("section", {'class':'intro'}, m("p",m.trust(markdown.renderInline(this.text))));  }}//    ______                            __  _//   / ____/___  ____  ____  ___  _____/ /_(_)___  ____  _____//  / /   / __ \/ __ \/ __ \/ _ \/ ___/ __/ / __ \/ __ \/ ___/// / /___/ /_/ / / / / / / /  __/ /__/ /_/ / /_/ / / / (__  )// \____/\____/_/ /_/_/ /_/\___/\___/\__/_/\____/_/ /_/____/module.exports = {  oncreate(vn){    document.body.classList.add('mode-connections');    _Ui.init();  },  view(vn){    // console.log('_ModeConnections view', vn.attrs.lang);    return m('main', {id:"content", 'class':'mode-connections'}, _dbs.data[vn.attrs.lang].map(p => {        if(p.id == 'intro'){          return m(_Intro,p);        }else{          return m(_Part,p);        }      })    );  }}
 |