123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412 |
- var m = require('mithril');
- // https://github.com/markdown-it/markdown-it
- var 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);
- }
- })
- );
- }
- }
|