fe16b01edb
* make QRCode JS works with IE : * behave as a normal link if canvas aren't supported (<=IE8) * default parameter values in JS aren't widely supported (see: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/Default_parameters ), use this method instead: http://stackoverflow.com/a/148918/1484919 * dataset isn't supported in IE9 use getAttribute instead * addEventListener works with IE9+ and other browsers
132 lines
5.8 KiB
HTML
132 lines
5.8 KiB
HTML
<!DOCTYPE html>
|
|
<html>
|
|
<head>{include="includes"}</head>
|
|
<body>
|
|
<div id="pageheader">
|
|
{include="page.header"}
|
|
<div id="headerform" class="search">
|
|
<form method="GET" class="searchform" name="searchform"><input type="text" id="searchform_value" name="searchterm" value=""> <input type="submit" value="Search" class="bigbutton"></form>
|
|
<form method="GET" class="tagfilter" name="tagfilter"><input type="text" name="searchtags" id="tagfilter_value" value=""> <input type="submit" value="Filter by tag" class="bigbutton"></form>
|
|
</div>
|
|
</div>
|
|
|
|
<div id="linklist">
|
|
|
|
{include="linklist.paging"}
|
|
|
|
{if="count($links)==0"}
|
|
<div id="searchcriteria">Nothing found.</i></div>
|
|
{else}
|
|
{if="$search_type=='fulltext'"}
|
|
<div id="searchcriteria">{$result_count} results for <i>{$search_crits}</i></div>
|
|
{/if}
|
|
{if="$search_type=='tags'"}
|
|
<div id="searchcriteria">{$result_count} results for tags <i>
|
|
{loop="search_crits"}
|
|
<span class="linktag" title="Remove tag"><a href="?removetag={$value|htmlspecialchars}">{$value|htmlspecialchars} <span class="remove">x</span></a></span>
|
|
{/loop}</i></div>
|
|
{/if}
|
|
{/if}
|
|
<ul>
|
|
{loop="links"}
|
|
<li{if="$value.class"} class="{$value.class}"{/if}>
|
|
<a id="{$value.linkdate|smallHash}"></a>
|
|
<div class="thumbnail">{$value.url|thumbnail}</div>
|
|
<div class="linkcontainer">
|
|
{if="isLoggedIn()"}
|
|
<div class="linkeditbuttons">
|
|
<form method="GET" class="buttoneditform"><input type="hidden" name="edit_link" value="{$value.linkdate}"><input type="image" alt="Edit" src="images/edit_icon.png#" title="Edit" class="button_edit"></form><br>
|
|
<form method="POST" class="buttoneditform"><input type="hidden" name="lf_linkdate" value="{$value.linkdate}">
|
|
<input type="hidden" name="token" value="{$token}"><input type="hidden" name="delete_link"><input type="image" alt="Delete" src="images/delete_icon.png#" title="Delete" class="button_delete" onClick="return confirmDeleteLink();"></form>
|
|
</div>
|
|
{/if}
|
|
<span class="linktitle"><a href="{$redirector}{$value.url|htmlspecialchars}">{$value.title|htmlspecialchars}</a></span>
|
|
<br>
|
|
{if="$value.description"}<div class="linkdescription">{$value.description}</div>{/if}
|
|
{if="!$GLOBALS['config']['HIDE_TIMESTAMPS'] || isLoggedIn()"}
|
|
<span class="linkdate" title="Permalink"><a href="?{$value.linkdate|smallHash}">{$value.localdate|htmlspecialchars} - permalink</a> - </span>
|
|
{else}
|
|
<span class="linkdate" title="Short link here"><a href="?{$value.linkdate|smallHash}">permalink</a> - </span>
|
|
{/if}
|
|
{if="$GLOBALS['config']['ARCHIVE_ORG']"}
|
|
<span class="linkarchive"><a href="https://web.archive.org/web/{$value.url|htmlspecialchars}">archive</a> - </span>
|
|
{/if}
|
|
<div class="linkqrcode"><a href="http://qrfree.kaywa.com/?l=1&s=8&d={$scripturl|urlencode}%3F{$value.linkdate|smallHash}"
|
|
onclick="return showQrCode(this);" class="qrcode" data-permalink="{$scripturl}?{$value.linkdate|smallHash}"><img src="images/qrcode.png#" title="QR-Code"></a></div> -
|
|
<a href="{$value.url|htmlspecialchars}"><span class="linkurl" title="Short link">{$value.url|htmlspecialchars}</span></a><br>
|
|
{if="$value.tags"}
|
|
<div class="linktaglist">
|
|
{loop="value.taglist"}<span class="linktag" title="Add tag"><a href="?addtag={$value|urlencode}">{$value|htmlspecialchars}</a></span> {/loop}
|
|
</div>
|
|
{/if}
|
|
</div>
|
|
</li>
|
|
{/loop}
|
|
</ul>
|
|
|
|
{include="linklist.paging"}
|
|
|
|
</div>
|
|
|
|
{include="page.footer"}
|
|
|
|
<script>
|
|
// Remove any displayed QR-Code
|
|
function remove_qrcode()
|
|
{
|
|
var elem = document.getElementById("permalinkQrcode");
|
|
if (elem) elem.parentNode.removeChild(elem);
|
|
return false;
|
|
}
|
|
|
|
function isCanvasSupported(){
|
|
var elem = document.createElement('canvas');
|
|
return !!(elem.getContext && elem.getContext('2d'));
|
|
}
|
|
|
|
// Show the QR-Code of a permalink (when the QR-Code icon is clicked).
|
|
function showQrCode(caller,loading)
|
|
{
|
|
if( !isCanvasSupported() ) return true;
|
|
|
|
// Dynamic javascript lib loading: We only load qr.js if the QR code icon is clicked:
|
|
if (typeof(qr)=='undefined') // Load qr.js only if not present.
|
|
{
|
|
loading = typeof loading !== 'undefined' ? loading : false;
|
|
if (!loading) // If javascript lib is still loading, do not append script to body.
|
|
{
|
|
var element = document.createElement("script");
|
|
element.src = "inc/qr.min.js";
|
|
document.body.appendChild(element);
|
|
}
|
|
setTimeout(function() { showQrCode(caller,true);}, 200); // Retry in 200 milliseconds.
|
|
return false;
|
|
}
|
|
|
|
// Remove previous qrcode if present.
|
|
remove_qrcode();
|
|
|
|
// Build the div which contains the QR-Code:
|
|
var element = document.createElement('div');
|
|
element.id="permalinkQrcode";
|
|
|
|
// Make QR-Code div commit sepuku when clicked:
|
|
element.addEventListener('click', remove_qrcode ); // Works on every canvas supported browser
|
|
|
|
// Build the QR-Code:
|
|
var image = qr.image({size: 8,value: caller.getAttribute('data-permalink')});
|
|
if (image)
|
|
{
|
|
element.appendChild(image);
|
|
element.innerHTML+= "<br>Click to close";
|
|
caller.parentNode.appendChild(element);
|
|
}
|
|
else
|
|
{
|
|
element.innerHTML="Your browser does not seem to be HTML5 compatible.";
|
|
}
|
|
return false;
|
|
}
|
|
</script>
|
|
</body>
|
|
</html>
|