navpane mode-toggle button and hotkey
This commit is contained in:
		
							parent
							
								
									f083acd46d
								
							
						
					
					
						commit
						33bea1b663
					
				| @ -205,6 +205,9 @@ a, #files tbody div a:last-child { | |||||||
| 	padding: .33em; | 	padding: .33em; | ||||||
| } | } | ||||||
| #files a.doc { | #files a.doc { | ||||||
|  | 	color: #666; | ||||||
|  | } | ||||||
|  | #files a.doc.bri { | ||||||
| 	color: #f5a; | 	color: #f5a; | ||||||
| } | } | ||||||
| #files tbody a.play { | #files tbody a.play { | ||||||
| @ -1004,7 +1007,7 @@ html.light #rui { | |||||||
| } | } | ||||||
| #docul li.bn { | #docul li.bn { | ||||||
| 	text-align: center; | 	text-align: center; | ||||||
| 	padding: .5em 0; | 	padding: .5em; | ||||||
| } | } | ||||||
| #doc.prism { | #doc.prism { | ||||||
| 	padding-left: 3em; | 	padding-left: 3em; | ||||||
| @ -1266,6 +1269,9 @@ html.light #files tbody a.play.act { | |||||||
| 	color: #90c; | 	color: #90c; | ||||||
| } | } | ||||||
| html.light #files a.doc { | html.light #files a.doc { | ||||||
|  | 	color: #bbb; | ||||||
|  | } | ||||||
|  | html.light #files a.doc.bri { | ||||||
| 	color: #d38; | 	color: #d38; | ||||||
| } | } | ||||||
| html.light #files tr.play td { | html.light #files tr.play td { | ||||||
|  | |||||||
| @ -194,10 +194,12 @@ ebi('tree').innerHTML = ( | |||||||
| 	'	<a href="#" class="btn" step="2" id="twobytwo" tt="Hotkey: D">+</a>\n' + | 	'	<a href="#" class="btn" step="2" id="twobytwo" tt="Hotkey: D">+</a>\n' + | ||||||
| 	'	<a href="#" class="btn" step="-2" id="twig" tt="Hotkey: A">–</a>\n' + | 	'	<a href="#" class="btn" step="-2" id="twig" tt="Hotkey: A">–</a>\n' + | ||||||
| 	'	<a href="#" class="btn" id="visdir" tt="scroll to selected folder">🎯</a>\n' + | 	'	<a href="#" class="btn" id="visdir" tt="scroll to selected folder">🎯</a>\n' + | ||||||
|  | 	'	<a href="#" class="tgl btn" id="filetree" tt="toggle folder-tree / textfiles$NHotkey: V">📜</a>\n' + | ||||||
| 	'	<a href="#" class="tgl btn" id="dyntree" tt="autogrow as tree expands">a</a>\n' + | 	'	<a href="#" class="tgl btn" id="dyntree" tt="autogrow as tree expands">a</a>\n' + | ||||||
| 	'	<a href="#" class="tgl btn" id="wraptree" tt="word wrap">↵</a>\n' + | 	'	<a href="#" class="tgl btn" id="wraptree" tt="word wrap">↵</a>\n' + | ||||||
| 	'	<a href="#" class="tgl btn" id="hovertree" tt="reveal overflowing lines on hover$N( breaks scrolling unless mouse $N  cursor is in the left gutter )">👀</a>\n' + | 	'	<a href="#" class="tgl btn" id="hovertree" tt="reveal overflowing lines on hover$N( breaks scrolling unless mouse $N  cursor is in the left gutter )">👀</a>\n' + | ||||||
| 	'</div>\n' + | 	'</div>\n' + | ||||||
|  | 	'<ul id="docul"></ul>\n' + | ||||||
| 	'<ul id="treeul"></ul>\n' + | 	'<ul id="treeul"></ul>\n' + | ||||||
| 	'<div id="thx_ff"> </div>' | 	'<div id="thx_ff"> </div>' | ||||||
| ); | ); | ||||||
| @ -2370,12 +2372,14 @@ var showfile = (function () { | |||||||
| 
 | 
 | ||||||
| 			r.files.push({ 'id': link.id, 'name': fn }); | 			r.files.push({ 'id': link.id, 'name': fn }); | ||||||
| 
 | 
 | ||||||
| 			if (lang == 'md') | 			var td = ebi(link.id).closest('tr').getElementsByTagName('td')[0]; | ||||||
|  | 
 | ||||||
|  | 			if (lang == 'md' && td.textContent != '-') | ||||||
| 				continue; | 				continue; | ||||||
| 
 | 
 | ||||||
| 			ebi(link.id).closest('tr').getElementsByTagName('td')[0].innerHTML = | 			td.innerHTML = '<a href="#" class="doc bri" hl="' + link.id + '">-txt-</a>'; | ||||||
| 				'<a href="#" class="doc" hl="' + link.id + '">-txt-</a>'; |  | ||||||
| 		} | 		} | ||||||
|  | 		r.mktree(); | ||||||
| 		if (em) { | 		if (em) { | ||||||
| 			render(em); | 			render(em); | ||||||
| 			em = null; | 			em = null; | ||||||
| @ -2417,11 +2421,9 @@ var showfile = (function () { | |||||||
| 		ebi('dldoc').setAttribute('href', url); | 		ebi('dldoc').setAttribute('href', url); | ||||||
| 
 | 
 | ||||||
| 		var wr = ebi('bdoc'), | 		var wr = ebi('bdoc'), | ||||||
| 			nav = ebi('treeul'), |  | ||||||
| 			defer = !Prism.highlightElement; | 			defer = !Prism.highlightElement; | ||||||
| 
 | 
 | ||||||
| 		var fun = function (el) { | 		var fun = function (el) { | ||||||
| 			console.log('fun fun fun fun'); |  | ||||||
| 			try { | 			try { | ||||||
| 				if (lnh.slice(0, 5) == '#doc.') | 				if (lnh.slice(0, 5) == '#doc.') | ||||||
| 					sethash(lnh.slice(1)); | 					sethash(lnh.slice(1)); | ||||||
| @ -2456,47 +2458,50 @@ var showfile = (function () { | |||||||
| 		document.documentElement.scrollTop = 0; | 		document.documentElement.scrollTop = 0; | ||||||
| 		var hfun = no_push ? hist_replace : hist_push; | 		var hfun = no_push ? hist_replace : hist_push; | ||||||
| 		hfun(get_evpath() + '?doc=' + url.split('/').pop()); | 		hfun(get_evpath() + '?doc=' + url.split('/').pop()); | ||||||
| 		tree_scrollto(); |  | ||||||
| 
 | 
 | ||||||
| 		qsr('#docul'); |  | ||||||
| 		qsr('#docname'); | 		qsr('#docname'); | ||||||
| 		el = mknod('span'); | 		el = mknod('span'); | ||||||
| 		el.textContent = name; | 		el.textContent = name; | ||||||
| 		el.setAttribute('id', 'docname'); | 		el.setAttribute('id', 'docname'); | ||||||
| 		ebi('path').appendChild(el); | 		ebi('path').appendChild(el); | ||||||
| 
 | 
 | ||||||
| 		if (!nav) | 		r.updtree(); | ||||||
| 			return; | 		treectl.textmode(true); | ||||||
|  | 		tree_scrollto(); | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
|  | 	r.mktree = function () { | ||||||
| 		var html = ['<li class="bn">list of textfiles in<br />' + esc(get_vpath()) + '</li>']; | 		var html = ['<li class="bn">list of textfiles in<br />' + esc(get_vpath()) + '</li>']; | ||||||
| 		for (var a = 0; a < r.files.length; a++) { | 		for (var a = 0; a < r.files.length; a++) { | ||||||
| 			var file = r.files[a]; | 			var file = r.files[a]; | ||||||
| 			html.push('<li><a href="#" hl="' + file.id + | 			html.push('<li><a href="#" hl="' + file.id + | ||||||
| 				(file.name == name ? '" class="hl' : '') + |  | ||||||
| 				'">' + esc(uricom_dec(file.name)[0]) + '</a>'); | 				'">' + esc(uricom_dec(file.name)[0]) + '</a>'); | ||||||
| 		} | 		} | ||||||
|  | 		ebi('docul').innerHTML = html.join('\n'); | ||||||
|  | 	}; | ||||||
| 
 | 
 | ||||||
| 		el = mknod('ul'); | 	r.updtree = function () { | ||||||
| 		el.innerHTML = html.join('\n'); | 		var fn = QS('#path span:last-child'), | ||||||
| 		el.setAttribute('id', 'docul'); | 			lis = QSA('#docul li a'); | ||||||
| 		nav.style.display = 'none'; | 
 | ||||||
| 		nav.parentNode.insertBefore(el, nav); | 		fn = fn ? fn.textContent : ''; | ||||||
| 		el.onclick = ebi('files').onclick; | 		for (var a = 0, aa = lis.length; a < aa; a++) | ||||||
| 	} | 			clmod(lis[a], 'hl', lis[a].textContent == fn); | ||||||
|  | 	}; | ||||||
| 
 | 
 | ||||||
| 	var bdoc = ebi('bdoc'); | 	var bdoc = ebi('bdoc'); | ||||||
| 	bdoc.setAttribute('class', 'line-numbers'); | 	bdoc.setAttribute('class', 'line-numbers'); | ||||||
| 	bdoc.innerHTML = ( | 	bdoc.innerHTML = ( | ||||||
| 		'<div id="hdoc" class="ghead">\n' + | 		'<div id="hdoc" class="ghead">\n' + | ||||||
| 		'<a href="#" class="btn" id="xdoc">close</a>\n' + | 		'<a href="#" class="btn" id="xdoc" tt="return to folder view">close</a>\n' + | ||||||
| 		'<a href="#" class="btn" id="dldoc">download</a>\n' + | 		'<a href="#" class="btn" id="dldoc" tt="download this file">download</a>\n' + | ||||||
| 		'<a href="#" class="btn" id="prevdoc">prev</a>\n' + | 		'<a href="#" class="btn" id="prevdoc" tt="show previous document$NHotkey: i">prev</a>\n' + | ||||||
| 		'<a href="#" class="btn" id="nextdoc">next</a>\n' + | 		'<a href="#" class="btn" id="nextdoc" tt="show next document$NHotkey: K">next</a>\n' + | ||||||
| 		'</div>' | 		'</div>' | ||||||
| 	); | 	); | ||||||
| 	ebi('xdoc').onclick = function () { | 	ebi('xdoc').onclick = function () { | ||||||
| 		thegrid.setvis(true); | 		thegrid.setvis(true); | ||||||
| 	} | 	}; | ||||||
| 	ebi('dldoc').setAttribute('download', ''); | 	ebi('dldoc').setAttribute('download', ''); | ||||||
| 	ebi('prevdoc').onclick = function () { tree_neigh(-1); }; | 	ebi('prevdoc').onclick = function () { tree_neigh(-1); }; | ||||||
| 	ebi('nextdoc').onclick = function () { tree_neigh(1); }; | 	ebi('nextdoc').onclick = function () { tree_neigh(1); }; | ||||||
| @ -2575,7 +2580,7 @@ var thegrid = (function () { | |||||||
| 		ebi('bdoc').style.display = 'none'; | 		ebi('bdoc').style.display = 'none'; | ||||||
| 		clmod(ebi('wrap'), 'doc'); | 		clmod(ebi('wrap'), 'doc'); | ||||||
| 		qsr('#docname'); | 		qsr('#docname'); | ||||||
| 		qsr('#docul'); | 		treectl.textmode(false); | ||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	r.setdirty = function () { | 	r.setdirty = function () { | ||||||
| @ -2984,6 +2989,9 @@ document.onkeydown = function (e) { | |||||||
| 	if (k == 'KeyT') | 	if (k == 'KeyT') | ||||||
| 		return ebi('thumbs').click(); | 		return ebi('thumbs').click(); | ||||||
| 
 | 
 | ||||||
|  | 	if (k == 'KeyV') | ||||||
|  | 		return ebi('filetree').click(); | ||||||
|  | 
 | ||||||
| 	if (k == 'F2') | 	if (k == 'F2') | ||||||
| 		return fileman.rename(); | 		return fileman.rename(); | ||||||
| 
 | 
 | ||||||
| @ -3352,6 +3360,18 @@ var treectl = (function () { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	treectl.textmode = function (ya) { | ||||||
|  | 		treectl.texts = ya; | ||||||
|  | 		ebi('docul').style.display = ya ? '' : 'none'; | ||||||
|  | 		ebi('treeul').style.display = ya ? 'none' : ''; | ||||||
|  | 		clmod(ebi('filetree'), 'on', ya); | ||||||
|  | 	}; | ||||||
|  | 	ebi('filetree').onclick = function (e) { | ||||||
|  | 		ev(e); | ||||||
|  | 		treectl.textmode(!treectl.texts); | ||||||
|  | 	}; | ||||||
|  | 	treectl.textmode(false); | ||||||
|  | 
 | ||||||
| 	function onscroll() { | 	function onscroll() { | ||||||
| 		unmenter(); | 		unmenter(); | ||||||
| 		onscroll2(); | 		onscroll2(); | ||||||
| @ -3528,7 +3548,6 @@ var treectl = (function () { | |||||||
| 			links[a].onclick = treegrow; | 			links[a].onclick = treegrow; | ||||||
| 		} | 		} | ||||||
| 		ebi('tree').onscroll = nowrap ? unmenter : null; | 		ebi('tree').onscroll = nowrap ? unmenter : null; | ||||||
| 		tree_scrollto(); |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	function menter(e) { | 	function menter(e) { | ||||||
| @ -3558,6 +3577,8 @@ var treectl = (function () { | |||||||
| 			return; | 			return; | ||||||
| 		} | 		} | ||||||
| 		reqls(this.getAttribute('href'), true); | 		reqls(this.getAttribute('href'), true); | ||||||
|  | 		treectl.dir_cb = tree_scrollto; | ||||||
|  | 		thegrid.setvis(true); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	function reqls(url, hpush, no_tree) { | 	function reqls(url, hpush, no_tree) { | ||||||
| @ -3628,13 +3649,15 @@ var treectl = (function () { | |||||||
| 				fname = uricom_dec(bhref)[0], | 				fname = uricom_dec(bhref)[0], | ||||||
| 				hname = esc(fname), | 				hname = esc(fname), | ||||||
| 				sortv = (bhref.slice(-1) == '/' ? '\t' : '') + hname, | 				sortv = (bhref.slice(-1) == '/' ? '\t' : '') + hname, | ||||||
| 				id = 'f-' + ('00000000' + crc32(fname)).slice(-8); | 				id = 'f-' + ('00000000' + crc32(fname)).slice(-8), | ||||||
|  | 				lang = showfile.getlang(fname); | ||||||
| 
 | 
 | ||||||
| 			if (showfile.getlang(fname)) { | 			if (lang) | ||||||
| 				showfile.files.push({ 'id': id, 'name': fname }); | 				showfile.files.push({ 'id': id, 'name': fname }); | ||||||
| 				if (r.lead == '-') | 
 | ||||||
| 					r.lead = '<a href="#" class="doc" hl="' + id + '" name="' + hname + '">-txt-</a>'; | 			if (r.lead == '-') | ||||||
| 			} | 				r.lead = '<a href="#" class="doc' + (lang ? ' bri' : '') + | ||||||
|  | 					'" hl="' + id + '" name="' + hname + '">-txt-</a>'; | ||||||
| 
 | 
 | ||||||
| 			var ln = ['<tr><td>' + r.lead + '</td><td sortv="' + sortv + | 			var ln = ['<tr><td>' + r.lead + '</td><td sortv="' + sortv + | ||||||
| 				'"><a href="' + top + r.href + '" id="' + id + '">' + hname + '</a>', r.sz]; | 				'"><a href="' + top + r.href + '" id="' + id + '">' + hname + '</a>', r.sz]; | ||||||
| @ -3675,9 +3698,11 @@ var treectl = (function () { | |||||||
| 		document.title = '⇆🎉 ' + uricom_dec(document.location.pathname.slice(1, -1))[0]; | 		document.title = '⇆🎉 ' + uricom_dec(document.location.pathname.slice(1, -1))[0]; | ||||||
| 
 | 
 | ||||||
| 		filecols.set_style(); | 		filecols.set_style(); | ||||||
|  | 		showfile.mktree(); | ||||||
| 		mukey.render(); | 		mukey.render(); | ||||||
| 		reload_tree(); | 		reload_tree(); | ||||||
| 		reload_browser(); | 		reload_browser(); | ||||||
|  | 		tree_scrollto(); | ||||||
| 
 | 
 | ||||||
| 		var fun = treectl.ls_cb; | 		var fun = treectl.ls_cb; | ||||||
| 		if (fun) { | 		if (fun) { | ||||||
| @ -4702,7 +4727,7 @@ function goto_unpost(e) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| ebi('files').onclick = function (e) { | ebi('files').onclick = ebi('docul').onclick = function (e) { | ||||||
| 	var tgt = e.target.closest('a[id]'); | 	var tgt = e.target.closest('a[id]'); | ||||||
| 	if (tgt && tgt.getAttribute('id').indexOf('f-') === 0 && tgt.textContent.endsWith('/')) { | 	if (tgt && tgt.getAttribute('id').indexOf('f-') === 0 && tgt.textContent.endsWith('/')) { | ||||||
| 		var el = treectl.find(tgt.textContent.slice(0, -1)); | 		var el = treectl.find(tgt.textContent.slice(0, -1)); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 ed
						ed