[PATCH v3 6/6] line-range-highlight: copy URL to clipboard on click
John Keeping
john at keeping.me.uk
Sun Jun 24 13:42:33 CEST 2018
On Sun, Jun 24, 2018 at 10:44:54AM +0800, Andy Green wrote:
> Since the only reason to click on the line number links
> is to get the corresponding #URL to share, this patch
> makes that process more convenient by copying the
> highlit area, be it a single line or a range, to the
> clipboard on each click of the line number links.
As a user, I'd find this surprising and probably quite annoying.
I strongly prefer that software not overwrite the clipboard contents
without an explicit request to do so. A quick survey suggests none of
GitHub, Gitlab or repo.or.cz (GitWeb) behave in this way.
> Signed-off-by: Andy Green <andy at warmcat.com>
> ---
> cgit.js | 36 ++++++++++++++++++++++++++++++++----
> 1 file changed, 32 insertions(+), 4 deletions(-)
>
> diff --git a/cgit.js b/cgit.js
> index 2cfad29..e2c3799 100644
> --- a/cgit.js
> +++ b/cgit.js
> @@ -89,8 +89,29 @@ function cgit_line_range_highlight()
> e.scrollIntoView(true);
> }
>
> +function cgit_copy_clipboard(value)
> +{
> + var inp = document.createElement("textarea");
> + var e = document.getElementById("linenumber_td");
> +
> + inp.type = "text";
> + inp.value = value;
> + /* hidden style stops it working for clipboard */
> + inp.setAttribute('readonly', '');
> + inp.style.position = "absolute";
> + inp.style.left = "-1000px";
> +
> + e.appendChild(inp);
> +
> + inp.select();
> +
> + document.execCommand("copy");
> +
> + inp.remove();
> +}
> +
> function cgit_line_range_click(e) {
> - var t = e.target.id;
> + var t = e.target.id, cp;
>
> cgit_line_range_override = null;
>
> @@ -101,13 +122,13 @@ function cgit_line_range_click(e) {
> * is called, and override it there.
> */
>
> - if (window.location.hash && window.location.hash.indexOf("-") < 0)
> + if (window.location.hash && window.location.hash.indexOf("-") < 0) {
> if (parseInt(window.location.hash.substring(2)) <
> parseInt(t.substring(1))) /* forwards */
> - cgit_line_range_override =
> + cp = cgit_line_range_override =
> window.location + '-' + t.substring(1);
> else /* backwards */
> - cgit_line_range_override =
> + cp = cgit_line_range_override =
> window.location.href.substring(0,
> window.location.href.length -
> window.location.hash.length) +
> @@ -115,6 +136,13 @@ function cgit_line_range_click(e) {
> window.location.href.substring(
> window.location.href.length -
> window.location.hash.length + 2);
> + } else
> + cp = window.location.href.substring(0,
> + window.location.href.length -
> + window.location.hash.length) +
> + '#n' + t.substring(1);
> +
> + cgit_copy_clipboard(cp);
> }
>
> /* line range highlight */
>
> _______________________________________________
> CGit mailing list
> CGit at lists.zx2c4.com
> https://lists.zx2c4.com/mailman/listinfo/cgit
More information about the CGit
mailing list