<head>{include="includes"}</head>
<body>
<div id="pageheader">
- {include="page.header"}
- <div id="headerform" style="width:100%; white-space:nowrap;">
- <form method="GET" class="searchform" name="searchform" style="display:inline;"><input type="text" id="searchform_value" name="searchterm" style="width:30%" value=""> <input type="submit" value="Search" class="bigbutton"></form>
- <form method="GET" class="tagfilter" name="tagfilter" style="display:inline;margin-left:24px;"><input type="text" name="searchtags" id="tagfilter_value" style="width:10%" value=""> <input type="submit" value="Filter by tag" class="bigbutton"></form>
- </div>
+ {include="page.header"}
+ <div id="headerform" style="width:100%; white-space:nowrap;">
+ <form method="GET" class="searchform" name="searchform" style="display:inline;"><input type="text" id="searchform_value" name="searchterm" style="width:30%" value=""> <input type="submit" value="Search" class="bigbutton"></form>
+ <form method="GET" class="tagfilter" name="tagfilter" style="display:inline;margin-left:24px;"><input type="text" name="searchtags" id="tagfilter_value" style="width:10%" value=""> <input type="submit" value="Filter by tag" class="bigbutton"></form>
+ </div>
</div>
<div id="linklist">
<ul>
{loop="links"}
<li{if="$value.class"} class="{$value.class}"{/if}>
+ <a name="{$value.linkdate|smallHash}" id="{$value.linkdate|smallHash}"></a>
<div class="thumbnail">{$value.url|thumbnail}</div>
<div class="linkcontainer">
- <span class="linktitle"><a href="{$redirector}{$value.url}">{$value.title|htmlspecialchars}</a></span>
{if="isLoggedIn()"}
- <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>
- <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 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"{if condition="$search_type=='permalink'"} style="max-height:none !important;"{/if}>{$value.description}</div>{/if}
{if="!$GLOBALS['config']['HIDE_TIMESTAMPS'] || isLoggedIn()"}
{else}
<span class="linkdate" title="Short link here"><a href="?{$value.linkdate|smallHash}">permalink</a> - </span>
{/if}
- <div style="position:relative;display:inline;"><a href="http://invx.com/code/qrcode/?code={$scripturl|urlencode}%3F{$value.linkdate|smallHash}&width=200&height=200" onclick="return false;" class="qrcode"><img src="images/qrcode.png#" width="13" height="13" title="QR-Code"></a></div> -
+ <div style="position:relative;display:inline;"><a href="http://qrfree.kaywa.com/?l=1&s=8&d={$scripturl|urlencode}%3F{$value.linkdate|smallHash}"
+ onclick="showQrCode(this); return false;" class="qrcode" data-permalink="{$scripturl}?{$value.linkdate|smallHash}"><img src="images/qrcode.png#" width="13" height="13" title="QR-Code"></a></div> -
<span class="linkurl" title="Short link">{$value.url|htmlspecialchars}</span><br>
{if="$value.tags"}
<div class="linktaglist">
</div>
- {include="page.footer"}
-<script>
-$(document).ready(function() {
- $('a.qrcode').click(function(){
- hide_qrcode();
- var link = $(this).attr('href');
- $(this).after('<div class="qrcode" onclick="hide_qrcode();return false;"><img src="'+link+'#" width="200" height="200"><br>click to close</div>');
- });
-});
-function hide_qrcode() { $('div.qrcode').remove(); }
+ {include="page.footer"}
+
+<script language="JavaScript">
+// Remove any displayed QR-Code
+function remove_qrcode()
+{
+ var elem = document.getElementById("permalinkQrcode");
+ if (elem) elem.parentNode.removeChild(elem);
+ return false;
+}
+
+// Show the QR-Code of a permalink (when the QR-Code icon is clicked).
+function showQrCode(caller,loading=false)
+{
+ // 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.
+ {
+ 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:
+ if ( element.attachEvent ){ element.attachEvent('onclick', 'this.parentNode.removeChild(this);' ); } // Damn IE
+ else { element.setAttribute('onclick', 'this.parentNode.removeChild(this);' ); }
+
+ // Build the QR-Code:
+ var image = qr.image({size: 8,value: caller.dataset.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>
\ No newline at end of file
+</html>