add chat
This commit is contained in:
		
							parent
							
								
									0815dce4c1
								
							
						
					
					
						commit
						3768cb4723
					
				| @ -2772,7 +2772,7 @@ html.a .opbox { | |||||||
| 	margin: 1.5em 0 0 0; | 	margin: 1.5em 0 0 0; | ||||||
| } | } | ||||||
| html.dz .opview input.i { | html.dz .opview input.i { | ||||||
| 	width: calc(100% - 17em); | 	width: calc(100% - 18em); | ||||||
| } | } | ||||||
| html.c #tree, | html.c #tree, | ||||||
| html.c #treeh, | html.c #treeh, | ||||||
|  | |||||||
| @ -3634,7 +3634,7 @@ var fileman = (function () { | |||||||
| 
 | 
 | ||||||
| 			if (!f.length) { | 			if (!f.length) { | ||||||
| 				toast.ok(2, 'rename OK'); | 				toast.ok(2, 'rename OK'); | ||||||
| 				treectl.goto(get_evpath()); | 				treectl.goto(); | ||||||
| 				return rn_cancel(); | 				return rn_cancel(); | ||||||
| 			} | 			} | ||||||
| 
 | 
 | ||||||
| @ -3681,7 +3681,7 @@ var fileman = (function () { | |||||||
| 				if (err !== 'xbd') | 				if (err !== 'xbd') | ||||||
| 					toast.ok(2, L.fd_ok); | 					toast.ok(2, L.fd_ok); | ||||||
| 
 | 
 | ||||||
| 				treectl.goto(get_evpath()); | 				treectl.goto(); | ||||||
| 				return; | 				return; | ||||||
| 			} | 			} | ||||||
| 			toast.show('inf r', 0, esc(L.fd_busy.format(vps.length + 1, vp)), 'r'); | 			toast.show('inf r', 0, esc(L.fd_busy.format(vps.length + 1, vp)), 'r'); | ||||||
| @ -3799,7 +3799,7 @@ var fileman = (function () { | |||||||
| 
 | 
 | ||||||
| 			if (!vp) { | 			if (!vp) { | ||||||
| 				toast.ok(2, L.fp_ok); | 				toast.ok(2, L.fp_ok); | ||||||
| 				treectl.goto(get_evpath()); | 				treectl.goto(); | ||||||
| 				r.tx(srcdir); | 				r.tx(srcdir); | ||||||
| 				return; | 				return; | ||||||
| 			} | 			} | ||||||
| @ -5283,6 +5283,7 @@ onresize100.add(filecolwidth, true); | |||||||
| var treectl = (function () { | var treectl = (function () { | ||||||
| 	var r = { | 	var r = { | ||||||
| 		"hidden": true, | 		"hidden": true, | ||||||
|  | 		"sb_msg": false, | ||||||
| 		"ls_cb": null, | 		"ls_cb": null, | ||||||
| 		"dir_cb": tree_scrollto, | 		"dir_cb": tree_scrollto, | ||||||
| 		"pdir": [] | 		"pdir": [] | ||||||
| @ -5299,7 +5300,7 @@ var treectl = (function () { | |||||||
| 	bcfg_bind(r, 'dyn', 'dyntree', true, onresize); | 	bcfg_bind(r, 'dyn', 'dyntree', true, onresize); | ||||||
| 	bcfg_bind(r, 'csel', 'csel', false); | 	bcfg_bind(r, 'csel', 'csel', false); | ||||||
| 	bcfg_bind(r, 'dots', 'dotfiles', false, function (v) { | 	bcfg_bind(r, 'dots', 'dotfiles', false, function (v) { | ||||||
| 		r.goto(get_evpath()); | 		r.goto(); | ||||||
| 		var xhr = new XHR(); | 		var xhr = new XHR(); | ||||||
| 		xhr.open('GET', SR + '/?setck=dots=' + (v ? 'y' : ''), true); | 		xhr.open('GET', SR + '/?setck=dots=' + (v ? 'y' : ''), true); | ||||||
| 		xhr.send(); | 		xhr.send(); | ||||||
| @ -5524,6 +5525,9 @@ var treectl = (function () { | |||||||
| 	}; | 	}; | ||||||
| 
 | 
 | ||||||
| 	r.goto = function (url, push, back) { | 	r.goto = function (url, push, back) { | ||||||
|  | 		if (!url || !url.startsWith('/')) | ||||||
|  | 			url = get_evpath() + (url || ''); | ||||||
|  | 
 | ||||||
| 		get_tree("", url, true); | 		get_tree("", url, true); | ||||||
| 		r.reqls(url, push, back); | 		r.reqls(url, push, back); | ||||||
| 	}; | 	}; | ||||||
| @ -5721,6 +5725,7 @@ var treectl = (function () { | |||||||
| 		xhr.send(); | 		xhr.send(); | ||||||
| 
 | 
 | ||||||
| 		r.nvis = r.lim; | 		r.nvis = r.lim; | ||||||
|  | 		r.sb_msg = false; | ||||||
| 		r.nextdir = xhr.top; | 		r.nextdir = xhr.top; | ||||||
| 		enspin('#tree'); | 		enspin('#tree'); | ||||||
| 		enspin(thegrid.en ? '#gfiles' : '#files'); | 		enspin(thegrid.en ? '#gfiles' : '#files'); | ||||||
| @ -5747,7 +5752,9 @@ var treectl = (function () { | |||||||
| 			return; | 			return; | ||||||
| 
 | 
 | ||||||
| 		r.nextdir = null; | 		r.nextdir = null; | ||||||
| 		var cur = ebi('files').getAttribute('ts'); | 		var cdir = get_evpath(), | ||||||
|  | 			cur = ebi('files').getAttribute('ts'); | ||||||
|  | 
 | ||||||
| 		if (cur && parseInt(cur) > this.ts) { | 		if (cur && parseInt(cur) > this.ts) { | ||||||
| 			console.log("reject ls"); | 			console.log("reject ls"); | ||||||
| 			return; | 			return; | ||||||
| @ -5791,12 +5798,19 @@ var treectl = (function () { | |||||||
| 		despin('#files'); | 		despin('#files'); | ||||||
| 		despin('#gfiles'); | 		despin('#gfiles'); | ||||||
| 
 | 
 | ||||||
| 		sandbox(ebi('pro'), sb_lg, '', res.logues ? res.logues[0] || "" : ""); | 		var lg0 = res.logues ? res.logues[0] || "" : "", | ||||||
| 		sandbox(ebi('epi'), sb_lg, '', res.logues ? res.logues[1] || "" : ""); | 			lg1 = res.logues ? res.logues[1] || "" : "", | ||||||
|  | 			dirchg = get_evpath() != cdir; | ||||||
|  | 
 | ||||||
|  | 		sandbox(ebi('pro'), sb_lg, '', lg0); | ||||||
|  | 		if (dirchg) | ||||||
|  | 			sandbox(ebi('epi'), sb_lg, '', lg1); | ||||||
| 
 | 
 | ||||||
| 		clmod(ebi('epi'), 'mdo'); | 		clmod(ebi('epi'), 'mdo'); | ||||||
| 		if (res.readme) | 		if (res.readme && treectl.ireadme) | ||||||
| 			show_readme(res.readme); | 			show_readme(res.readme); | ||||||
|  | 		else if (!dirchg) | ||||||
|  | 			sandbox(ebi('epi'), sb_lg, '', lg1); | ||||||
| 
 | 
 | ||||||
| 		if (this.hpush && !this.back) { | 		if (this.hpush && !this.back) { | ||||||
| 			var ofs = ebi('wrap').offsetTop; | 			var ofs = ebi('wrap').offsetTop; | ||||||
| @ -7057,7 +7071,7 @@ var msel = (function () { | |||||||
| 		clmod(sf, 'vis'); | 		clmod(sf, 'vis'); | ||||||
| 		sf.textContent = 'sent: "' + this.msg + '"'; | 		sf.textContent = 'sent: "' + this.msg + '"'; | ||||||
| 		setTimeout(function () { | 		setTimeout(function () { | ||||||
| 			treectl.goto(get_evpath()); | 			treectl.goto(); | ||||||
| 		}, 100); | 		}, 100); | ||||||
| 	} | 	} | ||||||
| })(); | })(); | ||||||
| @ -7259,6 +7273,7 @@ function sandbox(tgt, rules, cls, html) { | |||||||
| 		'};f();' + | 		'};f();' + | ||||||
| 		'window.onfocus=function(){say("igot #' + tid + '")};' + | 		'window.onfocus=function(){say("igot #' + tid + '")};' + | ||||||
| 		'window.onblur=function(){say("ilost #' + tid + '")};' + | 		'window.onblur=function(){say("ilost #' + tid + '")};' + | ||||||
|  | 		'window.treectl={"goto":function(a){say("goto #' + tid + ' "+(a||""))}};' + | ||||||
| 		'var el="' + want + '"&&ebi("' + want + '");' + | 		'var el="' + want + '"&&ebi("' + want + '");' + | ||||||
| 		'if(el)say("iscroll #' + tid + ' "+el.offsetTop);' + | 		'if(el)say("iscroll #' + tid + ' "+el.offsetTop);' + | ||||||
| 		'md_th_set();' + | 		'md_th_set();' + | ||||||
| @ -7272,16 +7287,24 @@ function sandbox(tgt, rules, cls, html) { | |||||||
| 	fr.setAttribute('title', 'folder ' + tid + 'logue'); | 	fr.setAttribute('title', 'folder ' + tid + 'logue'); | ||||||
| 	fr.setAttribute('sandbox', rules ? 'allow-' + rules.replace(/ /g, ' allow-') : ''); | 	fr.setAttribute('sandbox', rules ? 'allow-' + rules.replace(/ /g, ' allow-') : ''); | ||||||
| 	fr.setAttribute('srcdoc', html); | 	fr.setAttribute('srcdoc', html); | ||||||
| 	tgt.innerHTML = ''; |  | ||||||
| 	tgt.appendChild(fr); | 	tgt.appendChild(fr); | ||||||
|  | 	treectl.sb_msg = true; | ||||||
| 	return true; | 	return true; | ||||||
| } | } | ||||||
| window.addEventListener("message", function (e) { | window.addEventListener("message", function (e) { | ||||||
|  | 	if (!treectl.sb_msg) | ||||||
|  | 		return; | ||||||
|  | 
 | ||||||
| 	try { | 	try { | ||||||
| 		console.log('msg:' + e.data); | 		console.log('msg:' + e.data); | ||||||
| 		var t = e.data.split(/ /g); | 		var t = e.data.split(/ /g); | ||||||
| 		if (t[0] == 'iheight') { | 		if (t[0] == 'iheight') { | ||||||
| 			var el = QS(t[1] + '>iframe'); | 			var el = QSA(t[1] + '>iframe'); | ||||||
|  | 			el = el[el.length - 1]; | ||||||
|  | 			if (wfp_debounce.n) | ||||||
|  | 				while (el.previousSibling) | ||||||
|  | 					el.parentNode.removeChild(el.previousSibling); | ||||||
|  | 
 | ||||||
| 			el.style.height = (parseInt(t[2]) + SBH) + 'px'; | 			el.style.height = (parseInt(t[2]) + SBH) + 'px'; | ||||||
| 			el.style.visibility = 'unset'; | 			el.style.visibility = 'unset'; | ||||||
| 			wfp_debounce.show(); | 			wfp_debounce.show(); | ||||||
| @ -7298,6 +7321,10 @@ window.addEventListener("message", function (e) { | |||||||
| 		else if (t[0] == 'imshow') { | 		else if (t[0] == 'imshow') { | ||||||
| 			thegrid.imshow(e.data.slice(7)); | 			thegrid.imshow(e.data.slice(7)); | ||||||
| 		} | 		} | ||||||
|  | 		else if (t[0] == 'goto') { | ||||||
|  | 			var t = e.data.replace(/^[^ ]+ [^ ]+ /, '').split(/[?&]/)[0]; | ||||||
|  | 			treectl.goto(t, !!t); | ||||||
|  | 		} | ||||||
| 	} catch (ex) { | 	} catch (ex) { | ||||||
| 		console.log('msg-err: ' + ex); | 		console.log('msg-err: ' + ex); | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -1688,7 +1688,7 @@ function up2k_init(subtle) { | |||||||
|                     is_busy = st.todo.handshake.length; |                     is_busy = st.todo.handshake.length; | ||||||
|                     try { |                     try { | ||||||
|                         if (!is_busy && !uc.fsearch && !msel.getsel().length && (!mp.au || mp.au.paused)) |                         if (!is_busy && !uc.fsearch && !msel.getsel().length && (!mp.au || mp.au.paused)) | ||||||
|                             treectl.goto(get_evpath()); |                             treectl.goto(); | ||||||
|                     } |                     } | ||||||
|                     catch (ex) { } |                     catch (ex) { } | ||||||
|                 } |                 } | ||||||
|  | |||||||
| @ -1712,7 +1712,7 @@ function load_md_plug(md_text, plug_type, defer) { | |||||||
|         return md_text; |         return md_text; | ||||||
| 
 | 
 | ||||||
|     var find = '\n```copyparty_' + plug_type + '\n', |     var find = '\n```copyparty_' + plug_type + '\n', | ||||||
|         md = md_text.replace(/\r/g, ''), |         md = '\n' + md_text.replace(/\r/g, '') + '\n', | ||||||
|         ofs = md.indexOf(find), |         ofs = md.indexOf(find), | ||||||
|         ofs2 = md.indexOf('\n```', ofs + 1); |         ofs2 = md.indexOf('\n```', ofs + 1); | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										18
									
								
								srv/chat.md
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								srv/chat.md
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,18 @@ | |||||||
|  | ## chattyparty | ||||||
|  | 
 | ||||||
|  | this file, combined with the [msg-log](https://github.com/9001/copyparty/blob/hovudstraum/bin/hooks/msg-log.py) hook, turns copyparty into a makeshift instant-messaging / chat service | ||||||
|  | 
 | ||||||
|  | name this file `README.md` and run copyparty as such: | ||||||
|  | ```bash | ||||||
|  | python copyparty-sfx.py -emp --xm j,bin/hooks/msg-log.py | ||||||
|  | ``` | ||||||
|  | 
 | ||||||
|  | only the stuff below is important; delete everything from this line up | ||||||
|  | 
 | ||||||
|  | ```copyparty_post | ||||||
|  | render2(dom) { | ||||||
|  |  if (/[?&]edit/.test(location)) return; | ||||||
|  |  setTimeout(function() { treectl.goto(); }, 1000); | ||||||
|  |  // if you wanna go to another folder: treectl.goto('foo <bar> baz/', true); | ||||||
|  | } | ||||||
|  | ``` | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 ed
						ed