Make myShaarli theme for Shaarli 0.9.2
This commit is contained in:
parent
22ee4c71a3
commit
8ead0f9219
26 changed files with 1670 additions and 2187 deletions
|
@ -1 +0,0 @@
|
||||||
1.1.6
|
|
|
@ -4,12 +4,18 @@
|
||||||
{include="includes"}
|
{include="includes"}
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
{include="page.header"}
|
||||||
<div id="headerform">
|
<div class="pure-g">
|
||||||
<form method="get" name="addform" class="addform">
|
<div class="pure-u-lg-1-3 pure-u-1-24"></div>
|
||||||
<input type="text" name="post" autofocus>
|
<div id="addlink-form" class="page-form page-form-light pure-u-lg-1-3 pure-u-22-24">
|
||||||
<input type="submit" value="Add link" class="bigbutton">
|
<h2 class="window-title">{"Shaare a new link"|t}</h2>
|
||||||
|
<form method="GET" action="#" name="addform" class="addform">
|
||||||
|
<div>
|
||||||
|
<input type="text" name="post" placeholder="{'URL or leave empty to post a note'|t}" class="autofocus">
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<input type="submit" value="{'Add link'|t}">
|
||||||
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -4,23 +4,25 @@
|
||||||
{include="includes"}
|
{include="includes"}
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
{include="page.header"}
|
||||||
<form method="post" name="changepasswordform" id="changepasswordform">
|
<div class="pure-g">
|
||||||
<p>
|
<div class="pure-u-lg-1-3 pure-u-1-24"></div>
|
||||||
<label for="oldpassword">Old password:</label>
|
<div id="addlink-form" class="page-form page-form-light pure-u-lg-1-3 pure-u-22-24">
|
||||||
<input type="password" name="oldpassword" id="oldpassword" autofocus/>
|
<h2 class="window-title">{"Change password"|t}</h2>
|
||||||
</p>
|
<form method="POST" action="#" name="changepasswordform" id="changepasswordform">
|
||||||
<p>
|
<div>
|
||||||
<label for="setpassword">New password:</label>
|
<input type="password" name="oldpassword" placeholder="{'Current password'|t}" class="autofocus">
|
||||||
<input type="password" name="setpassword" id="setpassword">
|
</div>
|
||||||
</p>
|
<div>
|
||||||
<p>
|
<input type="password" name="setpassword" placeholder="{'New password'|t}">
|
||||||
|
</div>
|
||||||
<input type="hidden" name="token" value="{$token}">
|
<input type="hidden" name="token" value="{$token}">
|
||||||
<input type="submit" name="Save" value="Save password" class="bigbutton">
|
<div>
|
||||||
</p>
|
<input type="submit" value="{'Change'|t}">
|
||||||
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
{include="page.footer"}
|
{include="page.footer"}
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
|
@ -2,66 +2,39 @@
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
{include="includes"}
|
{include="includes"}
|
||||||
{if="empty($GLOBALS['disablejquery'])"}
|
|
||||||
<script src="inc/jquery.min.js#"></script>
|
|
||||||
<script src="inc/jquery-ui.min.js#"></script>
|
|
||||||
{/if}
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
{include="page.header"}
|
||||||
<form method="post" name="changetag" id="editlinkform">
|
<div class="pure-g">
|
||||||
<fieldset>
|
<div class="pure-u-lg-1-3 pure-u-1-24"></div>
|
||||||
<legend>
|
<div id="addlink-form" class="page-form page-form-light pure-u-lg-1-3 pure-u-22-24">
|
||||||
Rename tag
|
<h2 class="window-title">{"Manage tags"|t}</h2>
|
||||||
</legend>
|
<form method="POST" action="#" name="changetag" id="changetag">
|
||||||
<p>
|
<div>
|
||||||
<label for="">Old tag :</label>
|
<input type="text" name="fromtag" placeholder="{'Tag'|t}" value="{$fromtag}"
|
||||||
<input type="text" name="fromtag" class="fromtag" autofocus>
|
list="tagsList" autocomplete="off" class="awesomplete autofocus" data-minChars="1">
|
||||||
(Case sensitive)
|
<datalist id="tagsList">
|
||||||
</p>
|
{loop="$tags"}<option>{$key}</option>{/loop}
|
||||||
<p>
|
</datalist>
|
||||||
<label>New tag :</label>
|
</div>
|
||||||
<input type="text" name="totag" class="fromtag">
|
<div>
|
||||||
</p>
|
<input type="text" name="totag" placeholder="{'New name'|t}"
|
||||||
<p class="submitButton">
|
list="toTagsList" autocomplete="off" class="awesomplete" data-minChars="1">
|
||||||
<input type="submit" name="renametag" value="Rename tag" class="bigbutton">
|
<datalist id="toTagsList">
|
||||||
</p>
|
{loop="$tags"}<option>{$key}</option>{/loop}
|
||||||
</fieldset>
|
</datalist>
|
||||||
<fieldset>
|
</div>
|
||||||
<legend>
|
<div><i class="fa fa-info-circle"></i> {'Case sensitive'|t}</div>
|
||||||
Delete tag
|
|
||||||
</legend>
|
|
||||||
<p>
|
|
||||||
<label for="">Tag :</label>
|
|
||||||
<input type="text" name="tagToDelete" class="fromtag">
|
|
||||||
(Case sensitive)
|
|
||||||
</p>
|
|
||||||
<p class="submitButton">
|
|
||||||
<input type="hidden" name="token" value="{$token}">
|
<input type="hidden" name="token" value="{$token}">
|
||||||
<input type="submit" name="deletetag" value="Delete tag" class="bigbutton" onClick="return confirmDeleteTag();">
|
<div>
|
||||||
</p>
|
<input type="submit" value="{'Rename'|t}" name="renametag">
|
||||||
</fieldset>
|
<input type="submit" value="{'Delete'|t}" name="deletetag" class="button button-red confirm-delete">
|
||||||
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
|
||||||
|
<p>{'You can also edit tags in the'|t} <a href="?do=taglist&sort=usage">{'tag list'|t}</a>.</p>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{include="page.footer"}
|
{include="page.footer"}
|
||||||
{if="($GLOBALS['config']['OPEN_SHAARLI'] || isLoggedIn()) && empty($GLOBALS['disablejquery'])"}
|
|
||||||
<script>
|
|
||||||
$(document).ready(function() {
|
|
||||||
$('.fromtag').autocomplete({
|
|
||||||
source : '{$source}?ws=singletag',
|
|
||||||
minLength : 1
|
|
||||||
});
|
|
||||||
function confirmDeleteTag() {
|
|
||||||
var agree = confirm("Are you sure you want to delete this tag from all links ?");
|
|
||||||
if (agree) {
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
{/if}
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
|
@ -1,146 +1,256 @@
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
|
|
||||||
<head>
|
<head>
|
||||||
{include="includes"}
|
{include="includes"}
|
||||||
<link type="text/css" rel="stylesheet" href="myShaarli.css?version={$version|urlencode}" />
|
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body>
|
<body>
|
||||||
<div id="pageheader">
|
{include="page.header"}
|
||||||
{include="page.header"} {$timezone_js}
|
|
||||||
|
{$ratioLabel='5-12'}
|
||||||
|
{$ratioLabelMobile='7-8'}
|
||||||
|
{$ratioInput='7-12'}
|
||||||
|
{$ratioInputMobile='1-8'}
|
||||||
|
|
||||||
|
<form method="POST" action="#" name="configform" id="configform">
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-1-8 pure-u-1-24"></div>
|
||||||
|
<div class="pure-u-lg-3-4 pure-u-22-24 page-form page-form-complete">
|
||||||
|
<h2 class="window-title">{'Configure'|t}</h2>
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="title">
|
||||||
|
<span class="label-name">Shaarli {'title'|t}</span>
|
||||||
|
</label>
|
||||||
</div>
|
</div>
|
||||||
<div>
|
|
||||||
<form method="post" action="" name="configform" id="configform">
|
|
||||||
<ul class="tabs">
|
|
||||||
<li>
|
|
||||||
<input type="radio" checked name="tabs" id="tab1">
|
|
||||||
<label class="tabsLabel" for="tab1">► General</label>
|
|
||||||
<div id="tab-content1" class="tab-content">
|
|
||||||
<p>
|
|
||||||
<label for="title">Page title :</label>
|
|
||||||
<input type="text" name="title" id="title" value="{$title}" autofocus>
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="titleLink">Title link :</label>
|
|
||||||
<input type="text" name="titleLink" id="titleLink" value="{$titleLink}">
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="contactLink">Contact link in footer: </label>
|
|
||||||
<input type="text" name="contactLink" id="contactLink" value="{$GLOBALS['config']['contactLink']}" />
|
|
||||||
<span>Example : http://example.com/contact.php or mailo:contact@example.com</span>
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label>Timezone : </label>
|
|
||||||
{$timezone_form}
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="redirector">Redirector : </label>
|
|
||||||
<input type="text" name="redirector" id="redirector" value="{$redirector}"> (e.g. <i>http://anonym.to/?</i> will mask the HTTP_REFERER)
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="enableCache">Enable local cache : </label>
|
|
||||||
<input type="checkbox" name="enableCache" id="enableCache" {if="!empty($GLOBALS['config']['ENABLE_LOCALCACHE'])"}checked{/if}/>
|
|
||||||
</p>
|
|
||||||
</div>
|
</div>
|
||||||
</li>
|
<div class="pure-u-lg-7-12 pure-u-1">
|
||||||
<li>
|
<div class="form-input">
|
||||||
<input type="radio" name="tabs" id="tab2">
|
<input type="text" name="title" id="title" size="50" value="{$title}">
|
||||||
<label class="tabsLabel" for="tab2">► Security</label>
|
|
||||||
<div id="tab-content2" class="tab-content">
|
|
||||||
<p>
|
|
||||||
<label for="disablesessionprotection">Security :</label>
|
|
||||||
<input type="checkbox" name="disablesessionprotection" id="disablesessionprotection" {if="!empty($GLOBALS['disablesessionprotection'])"}checked{/if}>
|
|
||||||
<label for="disablesessionprotection"> Disable session cookie hijacking protection (Check this if you get disconnected often or if your IP address changes often.)</label>
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="banAfter">Ban after : </label>
|
|
||||||
<input type="text" name="banAfter" id="banAfter" value="{$GLOBALS['config']['BAN_AFTER']}" />
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="banDuration">Ban time : </label>
|
|
||||||
<input type="text" name="banDuration" id="banDuration" value="{$GLOBALS['config']['BAN_DURATION']}" /> in second
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="updateCheck">Update :</label>
|
|
||||||
<input type="checkbox" name="updateCheck" id="updateCheck" {if="!empty($GLOBALS['config']['ENABLE_UPDATECHECK'])"}checked{/if}/>
|
|
||||||
<label for="updateCheck"> Notify me when a new release is ready</label>
|
|
||||||
</p>
|
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</div>
|
||||||
<li>
|
</div>
|
||||||
<input type="radio" name="tabs" id="tab3">
|
<div class="pure-g">
|
||||||
<label class="tabsLabel" for="tab3">► Display</label>
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1">
|
||||||
<div id="tab-content3" class="tab-content">
|
<div class="form-label">
|
||||||
<p>
|
<label for="titleLink">
|
||||||
<label for="theme">Theme : </label>
|
<span class="label-name">{'Home link'|t}</span><br>
|
||||||
<select name="theme" id="theme">
|
<span class="label-desc">{'Default value'|t}: ?</span>
|
||||||
{loop="themes"}
|
</label>
|
||||||
<option {if="$GLOBALS['config']['THEME']==$value"}selected{/if} value="{$value}">{$value|ucfirst}</option>
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-1">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="text" name="titleLink" id="titleLink" size="50" value="{$titleLink}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="titleLink">
|
||||||
|
<span class="label-name">{'Theme'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-1">
|
||||||
|
<div class="form-input">
|
||||||
|
<select name="theme" id="theme" class="align">
|
||||||
|
{loop="$theme_available"}
|
||||||
|
<option value="{$value}"
|
||||||
|
{if="$value===$theme"}
|
||||||
|
selected="selected"
|
||||||
|
{/if}
|
||||||
|
>
|
||||||
|
{$value|ucfirst}
|
||||||
|
</option>
|
||||||
{/loop}
|
{/loop}
|
||||||
</select>
|
</select>
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="linkPerPage">Link per page : </label>
|
|
||||||
<input type="text" name="linkPerPage" id="linkPerPage" value="{$GLOBALS['config']['LINKS_PER_PAGE']}" />
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="hideTimestamps">Hide timestamps : </label>
|
|
||||||
<input type="checkbox" name="hideTimestamps" id="hideTimestamps" {if="!empty($GLOBALS['config']['HIDE_TIMESTAMPS'])"}checked{/if}/>
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="dateFormat">Date Format : </label>
|
|
||||||
<input type="text" name="dateFormat" id="dateFormat" value="{$GLOBALS['config']['DATE_FORMAT']}" />
|
|
||||||
<label>See <a href="http://php.net/manual/en/function.strftime.php">PHP documentation</a></label>
|
|
||||||
</p>
|
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</div>
|
||||||
<li>
|
</div>
|
||||||
<input type="radio" name="tabs" id="tab4">
|
<div class="pure-g">
|
||||||
<label class="tabsLabel" for="tab4">► Extra</label>
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1">
|
||||||
<div id="tab-content4" class="tab-content">
|
<div class="form-label">
|
||||||
<p>
|
<label for="language">
|
||||||
<label for="privateLinkByDefault">New link:</label>
|
<span class="label-name">{'Language'|t}</span>
|
||||||
<input type="checkbox" name="privateLinkByDefault" id="privateLinkByDefault" {if="!empty($GLOBALS['privateLinkByDefault'])"}checked{/if}/>
|
</label>
|
||||||
<label for="privateLinkByDefault"> All new link are private by default</label>
|
</div>
|
||||||
</p>
|
</div>
|
||||||
<p>
|
<div class="pure-u-lg-{$ratioInput} pure-u-1">
|
||||||
<label for="enableMarkdown">Enable Markdown : </label>
|
<div class="form-input">
|
||||||
<input type="checkbox" name="enableMarkdown" id="enableMarkdown" {if="!empty($GLOBALS['config']['ENABLE_MARKDOWN'])"}checked{/if}/>
|
<select name="language" id="language" class="align">
|
||||||
</p>
|
{loop="$languages"}
|
||||||
<p>
|
<option value="{$key}"
|
||||||
<label for="enableThumbnails">Enable thumbnail : </label>
|
{if="$key===$language"}
|
||||||
<input type="checkbox" name="enableThumbnails" id="enableThumbnails" {if="!empty($GLOBALS['config']['ENABLE_THUMBNAILS'])"}checked{/if}/>
|
selected="selected"
|
||||||
</p>
|
{/if}
|
||||||
<p>
|
>
|
||||||
<label for="externalThumbshot">External thumbnailer : </label>
|
{$value}
|
||||||
<input type="text" name="externalThumbshot" id="externalThumbshot" value="{$GLOBALS['config']['externalThumbshot']}">
|
</option>
|
||||||
</p>
|
{/loop}
|
||||||
<p>
|
|
||||||
<label for="enableFavicon">Enable favicon : </label>
|
|
||||||
<input type="checkbox" name="enableFavicon" id="enableFavicon" {if="!empty($GLOBALS['config']['ENABLE_FAVICON'])"}checked{/if}/>
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="wallabagUrl">Wallabag URL : </label>
|
|
||||||
<input type="text" name="wallabagUrl" id="wallabagUrl" value="{$GLOBALS['config']['WALLABAG_URL']}">
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label for="wallabagVersion">Wallabag version : </label>
|
|
||||||
<select name="wallabagVersion" id="wallabagVersion">
|
|
||||||
<option {if="$GLOBALS['config']['WALLABAG_VERSION']===1"}selected{/if} value="1">v1</option>
|
|
||||||
<option {if="$GLOBALS['config']['WALLABAG_VERSION']===2"}selected{/if} value="2">v2</option>
|
|
||||||
</select>
|
</select>
|
||||||
</p>
|
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</div>
|
||||||
</ul>
|
</div>
|
||||||
<p>
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1 ">
|
||||||
|
<div class="form-label">
|
||||||
|
<label>
|
||||||
|
<span class="label-name">{'Timezone'|t}</span><br>
|
||||||
|
<span class="label-desc">{'Continent'|t} · {'City'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-1 ">
|
||||||
|
<div class="form-input">
|
||||||
|
<div class="timezone">
|
||||||
|
<select id="continent" name="continent">
|
||||||
|
{loop="$continents"}
|
||||||
|
{if="$key !== 'selected'"}
|
||||||
|
<option value="{$value}" {if="$continents.selected === $value"}selected{/if}>
|
||||||
|
{$value}
|
||||||
|
</option>
|
||||||
|
{/if}
|
||||||
|
{/loop}
|
||||||
|
</select>
|
||||||
|
<select id="city" name="city">
|
||||||
|
{loop="$cities"}
|
||||||
|
{if="$key !== 'selected'"}
|
||||||
|
<option value="{$value.city}"
|
||||||
|
{if="$cities.selected === $value.city"}selected{/if}
|
||||||
|
data-continent="{$value.continent}">
|
||||||
|
{$value.city}
|
||||||
|
</option>
|
||||||
|
{/if}
|
||||||
|
{/loop}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="clear"></div>
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-{$ratioLabelMobile} ">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="disablesessionprotection">
|
||||||
|
<span class="label-name">{'Disable session cookie hijacking protection'|t}</span><br>
|
||||||
|
<span class="label-desc">
|
||||||
|
{'Check this if you get disconnected or if your IP address changes often'|t}
|
||||||
|
</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-{$ratioInputMobile} ">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="checkbox" name="disablesessionprotection" id="disablesessionprotection"
|
||||||
|
{if="$session_protection_disabled"}checked{/if}>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-{$ratioLabelMobile} ">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="privateLinkByDefault">
|
||||||
|
<span class="label-name">{'Private links by default'|t}</span><br>
|
||||||
|
<span class="label-desc">{'All new links are private by default'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-{$ratioInputMobile} ">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="checkbox" name="privateLinkByDefault" id="privateLinkByDefault"
|
||||||
|
{if="$private_links_default"}checked{/if}/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-{$ratioLabelMobile} ">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="enableRssPermalinks">
|
||||||
|
<span class="label-name">{'RSS direct links'|t}</span><br>
|
||||||
|
<span class="label-desc">{'Check this to use direct URL instead of permalink in feeds'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-{$ratioInputMobile} ">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="checkbox" name="enableRssPermalinks" id="enableRssPermalinks"
|
||||||
|
{if="$enable_rss_permalinks"}checked{/if}/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-{$ratioLabelMobile}">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="hidePublicLinks">
|
||||||
|
<span class="label-name">{'Hide public links'|t}</span><br>
|
||||||
|
<span class="label-desc">{'Do not show any links if the user is not logged in'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-{$ratioInputMobile}">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="checkbox" name="hidePublicLinks" id="hidePublicLinks"
|
||||||
|
{if="$hide_public_links"}checked{/if}/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-{$ratioLabelMobile}">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="hidePublicLinks">
|
||||||
|
<span class="label-name">{'Check updates'|t}</span><br>
|
||||||
|
<span class="label-desc">{'Notify me when a new release is ready'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-{$ratioInputMobile}">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="checkbox" name="updateCheck" id="updateCheck"
|
||||||
|
{if="$enable_update_check"}checked{/if}/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-{$ratioLabelMobile}">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="enableApi">
|
||||||
|
<span class="label-name">{'Enable REST API'|t}</span><br>
|
||||||
|
<span class="label-desc">{'Allow third party software to use Shaarli such as mobile application'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-{$ratioInputMobile}">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="checkbox" name="enableApi" id="enableApi"
|
||||||
|
{if="$api_enabled"}checked{/if}/>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="apiSecret">
|
||||||
|
<span class="label-name">{'API secret'|t}</span><br>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="text" name="apiSecret" id="apiSecret" size="50" value="{$api_secret}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="center">
|
||||||
|
<input type="submit" value="{'Save'|t}" name="save">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
<input type="hidden" name="token" value="{$token}">
|
<input type="hidden" name="token" value="{$token}">
|
||||||
<input type="submit" name="Save" value="Save config" class="bigbutton">
|
|
||||||
</p>
|
|
||||||
</form>
|
</form>
|
||||||
</div>
|
|
||||||
{include="page.footer"}
|
{include="page.footer"}
|
||||||
</body>
|
</body>
|
||||||
|
|
||||||
</html>
|
</html>
|
||||||
|
|
||||||
|
|
|
@ -1,63 +1,113 @@
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>{include="includes"}</head>
|
<head>
|
||||||
|
{include="includes"}
|
||||||
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="pageheader">{include="page.header"}</div>
|
{include="page.header"}
|
||||||
<div class="daily">
|
|
||||||
<div class="dailyAbout">
|
<div class="pure-g">
|
||||||
All links of one day<br>in a single page.<br>
|
<div class="pure-u-lg-1-6 pure-u-1-24"></div>
|
||||||
{if="$previousday"} <a href="?do=daily&day={$previousday}"><b><</b>Previous day</a>{else}<b><</b>Previous day{/if}
|
<div class="pure-u-lg-2-3 pure-u-22-24 page-form page-visitor" id="daily">
|
||||||
-
|
<h2 class="window-title">
|
||||||
{if="$nextday"}<a href="?do=daily&day={$nextday}">Next day<b>></b></a>{else}Next day<b>></b>{/if}
|
{'The Daily Shaarli'|t}
|
||||||
<br><br>
|
<a href="?do=dailyrss" title="{'1 RSS entry per day'|t}"><i class="fa fa-rss"></i></a>
|
||||||
<a href="?do=dailyrss" title="1 RSS entry per day"><img src="images/feed-icon-14x14.png#" width="14" height="14" style="position:relative;top:3px; margin-right:4px;">Daily RSS Feed</a>
|
</h2>
|
||||||
|
|
||||||
|
<div id="plugin_zone_start_daily" class="plugin_zone">
|
||||||
|
{loop="$plugin_start_zone"}
|
||||||
|
{$value}
|
||||||
|
{/loop}
|
||||||
</div>
|
</div>
|
||||||
<div class="dailyTitle"><img src="images/floral_left.png#" width="51" height="50" class="nomobile"> The Daily Shaarli <img src="images/floral_right.png#" width="51" height="50" class="nomobile"></div>
|
|
||||||
<div class="dailyDate"><span class="nomobile">———————————</span> {$day} <span class="nomobile">———————————</span></div>
|
<div class="daily-about">
|
||||||
<div style="clear:both;"></div>
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-1-3 pure-u-1 center">
|
||||||
|
{if="$previousday"}
|
||||||
|
<a href="?do=daily&day={$previousday}">
|
||||||
|
<i class="fa fa-arrow-left"></i>
|
||||||
|
{'Previous day'|t}
|
||||||
|
</a>
|
||||||
|
{/if}
|
||||||
|
</div>
|
||||||
|
<div class="daily-desc pure-u-lg-1-3 pure-u-1 center">
|
||||||
|
{'All links of one day in a single page.'|t}
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-1-3 pure-u-1 center">
|
||||||
|
{if="$nextday"}
|
||||||
|
<a href="?do=daily&day={$nextday}">
|
||||||
|
{'Next day'|t}
|
||||||
|
<i class="fa fa-arrow-right"></i>
|
||||||
|
</a>
|
||||||
|
{/if}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<h3 class="window-subtitle">{function="format_date($dayDate, false)"}</h3>
|
||||||
|
|
||||||
|
<div id="plugin_zone_about_daily" class="plugin_zone">
|
||||||
|
{loop="$daily_about_plugin"}
|
||||||
|
{$value}
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
{if="$linksToDisplay"}
|
{if="$linksToDisplay"}
|
||||||
<div id="daily_col1">
|
<div class="pure-g">
|
||||||
{loop="col1"}
|
{loop="$cols"}
|
||||||
<div class="dailyEntry">
|
{if="isset($value[0])"}
|
||||||
<div style="float:right;position:relative;top:-1px;"><a href="?{$value.linkdate|smallHash}"><img src="images/squiggle2.png#" width="25" height="26" title="permalink" alt="permalink"></a></div>
|
<div class="pure-u-lg-1-3 pure-u-1">
|
||||||
{if="$value.tags"}<div class="dailyEntryTags">{loop="value.taglist"}{$value|htmlspecialchars} - {/loop}</div>{/if}
|
{loop="value"}
|
||||||
<div class="dailyEntryTitle"><a href="{$value.url}">{$value.title|htmlspecialchars}</a></div>
|
{$link=$value}
|
||||||
{if="$value.thumbnail"}<div class="dailyEntryThumbnail">{$value.thumbnail}</div>{/if}
|
<div class="daily-entry">
|
||||||
<div class="dailyEntryDescription">{$value.formatedDescription}</div>
|
<div class="daily-entry-title center">
|
||||||
|
<a href="?{$link.shorturl}" title="{'Permalink'|t}">
|
||||||
|
<i class="fa fa-link"></i>
|
||||||
|
</a>
|
||||||
|
<a href="{$link.real_url}">{$link.title}</a>
|
||||||
|
</div>
|
||||||
|
{$thumb=thumbnail($value.url)}
|
||||||
|
{if="$thumb!=false"}
|
||||||
|
<div class="daily-entry-thumbnail">{$thumb}</div>
|
||||||
|
{/if}
|
||||||
|
<div class="daily-entry-description">{$link.formatedDescription}</div>
|
||||||
|
{if="$link.tags"}
|
||||||
|
<div class="daily-entry-tags center">
|
||||||
|
{loop="link.taglist"}
|
||||||
|
<span class="label label-tag" title="Add tag">
|
||||||
|
{$value}
|
||||||
|
</span>
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
<div class="dailyEntryFooter">
|
||||||
|
{loop="$link.link_plugin"}
|
||||||
|
{$value}
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{/loop}
|
{/loop}
|
||||||
</div>
|
</div>
|
||||||
|
{/if}
|
||||||
<div id="daily_col2">
|
|
||||||
{loop="col2"}
|
|
||||||
<div class="dailyEntry">
|
|
||||||
<div style="float:right;position:relative;top:-1px;"><a href="?{$value.linkdate|smallHash}"><img src="images/squiggle2.png#" width="25" height="26" title="permalink" alt="permalink"></a></div>
|
|
||||||
{if="$value.tags"}<div class="dailyEntryTags">{loop="value.taglist"}{$value|htmlspecialchars} - {/loop}</div>{/if}
|
|
||||||
<div class="dailyEntryTitle"><a href="{$value.url}">{$value.title|htmlspecialchars}</a></div>
|
|
||||||
{if="$value.thumbnail"}<div class="dailyEntryThumbnail">{$value.thumbnail}</div>{/if}
|
|
||||||
<div class="dailyEntryDescription">{$value.formatedDescription}</div>
|
|
||||||
</div>
|
|
||||||
{/loop}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="daily_col3">
|
|
||||||
{loop="col3"}
|
|
||||||
<div class="dailyEntry">
|
|
||||||
<div style="float:right;position:relative;top:-1px;"><a href="?{$value.linkdate|smallHash}"><img src="images/squiggle2.png#" width="25" height="26" title="permalink" alt="permalink"></a></div>
|
|
||||||
{if="$value.tags"}<div class="dailyEntryTags">{loop="value.taglist"}{$value|htmlspecialchars} - {/loop}</div>{/if}
|
|
||||||
<div class="dailyEntryTitle"><a href="{$value.url}">{$value.title|htmlspecialchars}</a></div>
|
|
||||||
{if="$value.thumbnail"}<div class="dailyEntryThumbnail">{$value.thumbnail}</div>{/if}
|
|
||||||
<div class="dailyEntryDescription">{$value.formatedDescription}</div>
|
|
||||||
</div>
|
|
||||||
{/loop}
|
{/loop}
|
||||||
</div>
|
</div>
|
||||||
{else}
|
{else}
|
||||||
<div style="text-align:center; padding:40px 0px 90px 0px;">No articles on this day.</div>
|
<div class="dailyNoEntry">No articles on this day.</div>
|
||||||
{/if}
|
{/if}
|
||||||
<div style="clear:both;"></div>
|
|
||||||
<div style="text-align:center; padding-bottom:20px;"><img src="images/squiggle_closing.png#" width="66" height="61" alt="-"></div>
|
<div class="clear"></div>
|
||||||
|
|
||||||
|
<div id="plugin_zone_end_picwall" class="plugin_zone">
|
||||||
|
{loop="$plugin_end_zone"}
|
||||||
|
{$value}
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
{include="page.footer"}
|
{include="page.footer"}
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,16 @@
|
||||||
|
<item>
|
||||||
|
<title>{$title} - {function="strftime('%A %e %B %Y', $daydate)"}</title>
|
||||||
|
<guid>{$absurl}</guid>
|
||||||
|
<link>{$absurl}</link>
|
||||||
|
<pubDate>{$rssdate}</pubDate>
|
||||||
|
<description><![CDATA[
|
||||||
{loop="links"}
|
{loop="links"}
|
||||||
<h3><a href="{$value.url}">{$value.title|htmlspecialchars}</a></h3>
|
<h3><a href="{$value.url}">{$value.title}</a></h3>
|
||||||
<small>{if="!$GLOBALS['config']['HIDE_TIMESTAMPS']"}{$value.localdate|htmlspecialchars} - {/if}{if="$value.tags"}{$value.tags|htmlspecialchars}{/if}<br>
|
<small>{if="!$hide_timestamps"}{function="strftime('%c', $value.timestamp)"} - {/if}{if="$value.tags"}{$value.tags}{/if}<br>
|
||||||
{$value.url|htmlspecialchars}</small><br>
|
{$value.url}</small><br>
|
||||||
{if="$value.thumbnail"}{$value.thumbnail}{/if}<br>
|
{if="$value.thumbnail"}{$value.thumbnail}{/if}<br>
|
||||||
{if="$value.description"}{$value.formatedDescription}{/if}
|
{if="$value.description"}{$value.formatedDescription}{/if}
|
||||||
<br><br><hr>
|
<br><br><hr>
|
||||||
{/loop}
|
{/loop}
|
||||||
|
]]></description>
|
||||||
|
</item>
|
||||||
|
|
|
@ -2,83 +2,79 @@
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
{include="includes"}
|
{include="includes"}
|
||||||
{if="empty($GLOBALS['disablejquery'])"}
|
|
||||||
<script src="inc/jquery.min.js#"></script>
|
|
||||||
<script src="inc/jquery-ui.min.js#"></script>
|
|
||||||
{/if}
|
|
||||||
</head>
|
</head>
|
||||||
<body
|
<body>
|
||||||
{if condition="$link.title==''"}onload="document.linkform.lf_title.focus();"
|
|
||||||
{elseif condition="$link.description==''"}onload="document.linkform.lf_description.focus();"
|
|
||||||
{else}onload="document.linkform.lf_tags.focus();"{/if} >
|
|
||||||
<div id="pageheader">
|
|
||||||
{if="$source !== 'firefoxsocialapi'"}
|
|
||||||
{include="page.header"}
|
{include="page.header"}
|
||||||
|
<div id="editlinkform" class="pure-g">
|
||||||
|
<div class="pure-u-lg-1-5 pure-u-1-24"></div>
|
||||||
|
<form method="post" name="linkform" class="page-form pure-u-lg-3-5 pure-u-22-24 page-form page-form-light">
|
||||||
|
<h2 class="window-title">
|
||||||
|
{if="!$link_is_new"}{'Edit'|t}{/if}
|
||||||
|
{'Shaare'|t}
|
||||||
|
</h2>
|
||||||
|
<input type="hidden" name="lf_linkdate" value="{$link.linkdate}">
|
||||||
|
{if="isset($link.id)"}
|
||||||
|
<input type="hidden" name="lf_id" value="{$link.id}">
|
||||||
{/if}
|
{/if}
|
||||||
<div id="editlinkform">
|
{if="!$link_is_new"}<div class="created-date">{'Created:'|t} {$link.created|format_date}</div>{/if}
|
||||||
<form method="post" name="linkform">
|
<div>
|
||||||
<p>
|
<label for="lf_url">{'URL'|t}</label>
|
||||||
<label for="lf_url">URL</label>
|
</div>
|
||||||
<input type="text" id="lf_url" name="lf_url" value="{$link.url|htmlspecialchars}">
|
<div>
|
||||||
</p>
|
<input type="text" name="lf_url" id="lf_url" value="{$link.url}" class="lf_input autofocus">
|
||||||
<p>
|
</div>
|
||||||
<label for="lf_title">Title</label>
|
<div>
|
||||||
<input type="text" id="lf_title" name="lf_title" value="{$link.title|htmlspecialchars}">
|
<label for="lf_title">{'Title'|t}</label>
|
||||||
</p>
|
</div>
|
||||||
<p>
|
<div>
|
||||||
<label for="lf_description">Description</label><a href="doc/markdown.php" id="help"><img src="images/help_icon.png#" alt="help icon"/></a>
|
<input type="text" name="lf_title" id="lf_title" value="{$link.title}" class="lf_input autofocus">
|
||||||
<textarea id="lf_description" name="lf_description" rows="4" cols="25">{$link.description|htmlspecialchars}</textarea>
|
</div>
|
||||||
</p>
|
<div>
|
||||||
<p>
|
<label for="lf_description">{'Description'|t}</label>
|
||||||
<label for="lf_tags">Tags</label>
|
</div>
|
||||||
<input type="text" id="lf_tags" name="lf_tags" value="{$link.tags|htmlspecialchars}">
|
<div>
|
||||||
</p>
|
<textarea name="lf_description" id="lf_description" class="autofocus">{$link.description}</textarea>
|
||||||
<p>
|
</div>
|
||||||
<label for="lf_via">Origine</label>
|
<div>
|
||||||
<input type="text" id="lf_via" name="lf_via" value="{$link.via|htmlspecialchars}">
|
<label for="lf_tags">{'Tags'|t}</label>
|
||||||
</p>
|
</div>
|
||||||
{if condition="($link_is_new && $GLOBALS['privateLinkByDefault']==true) || $link.private == true"}
|
<div>
|
||||||
<p>
|
<input type="text" name="lf_tags" id="lf_tags" value="{$link.tags}" class="lf_input autofocus"
|
||||||
<input type="checkbox" checked="checked" name="lf_private" id="lf_private">
|
data-list="{loop="$tags"}{$key}, {/loop}" data-multiple data-autofirst autocomplete="off" >
|
||||||
<label for="lf_private">Private</label>
|
</div>
|
||||||
</p>
|
|
||||||
{else}
|
<div>
|
||||||
<p>
|
<input type="checkbox" name="lf_private" id="lf_private"
|
||||||
<input type="checkbox" name="lf_private" id="lf_private">
|
{if="($link_is_new && $default_private_links || $link.private == true)"}
|
||||||
<label for="lf_private">Private</label>
|
checked="checked"
|
||||||
</p>
|
{/if}>
|
||||||
{/if}
|
<label for="lf_private">{'Private'|t}</label>
|
||||||
<p class="submitButton">
|
</div>
|
||||||
<input type="hidden" id="lf_linkdate" name="lf_linkdate" value="{$link.linkdate}">
|
|
||||||
<input type="submit" value="Save" name="save_edit" class="bigbutton">
|
<div id="editlink-plugins">
|
||||||
<input type="submit" value="Cancel" name="cancel_edit" class="bigbutton">
|
{loop="$edit_link_plugin"}
|
||||||
{if condition="!$link_is_new"}
|
{$value}
|
||||||
<input type="submit" value="Delete" name="delete_link" class="bigbutton" onClick="return confirmDeleteLink();">
|
{/loop}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="submit-buttons center">
|
||||||
|
<input type="submit" name="save_edit" class="" id="button-save-edit"
|
||||||
|
value="{if="$link_is_new"}{'Save'|t}{else}{'Apply Changes'|t}{/if}">
|
||||||
|
{if="!$link_is_new"}
|
||||||
|
<a href="?delete_link&lf_linkdate={$link.id}&token={$token}"
|
||||||
|
title="" name="delete_link" class="button button-red confirm-delete">
|
||||||
|
{'Delete'|t}
|
||||||
|
</a>
|
||||||
{/if}
|
{/if}
|
||||||
|
</div>
|
||||||
|
|
||||||
<input type="hidden" name="token" value="{$token}">
|
<input type="hidden" name="token" value="{$token}">
|
||||||
{if condition="$http_referer"}
|
{if="$http_referer"}
|
||||||
<input type="hidden" name="returnurl" value="{$http_referer|htmlspecialchars}">
|
<input type="hidden" name="returnurl" value="{$http_referer}">
|
||||||
{/if}
|
{/if}
|
||||||
</p>
|
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
{if="$source !== 'firefoxsocialapi'"}
|
|
||||||
{include="page.footer"}
|
{include="page.footer"}
|
||||||
{/if}
|
|
||||||
{if="($GLOBALS['config']['OPEN_SHAARLI'] || isLoggedIn()) && empty($GLOBALS['disablejquery'])"}
|
|
||||||
<script>
|
|
||||||
$(document).ready(function() {
|
|
||||||
$('#lf_tags').autocomplete({
|
|
||||||
source : '{$source}?ws=tags',
|
|
||||||
minLength : 1
|
|
||||||
});
|
|
||||||
$("#help").click(function() {
|
|
||||||
window.open("doc/markdown.php", "myWindow","scrollbars=1, width=400, height=400");
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
{/if}
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
|
@ -4,25 +4,65 @@
|
||||||
{include="includes"}
|
{include="includes"}
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
{include="page.header"}
|
||||||
<div id="toolsdiv">
|
|
||||||
<ul>
|
<form method="GET" action="#" name="exportform" id="exportform">
|
||||||
<li>
|
<div class="pure-g">
|
||||||
<a href="?do=export&what=all">Export all <span>: Export all links</span></a>
|
<div class="pure-u-lg-1-4 pure-u-1-24"></div>
|
||||||
</li>
|
<div class="pure-u-lg-1-2 pure-u-22-24 page-form page-form-complete">
|
||||||
<li>
|
<div>
|
||||||
<a href="?do=export&what=public">Export public <span>: Export public links only</span></a>
|
<h2 class="window-title">{"Export Database"|t}</h2>
|
||||||
</li>
|
</div>
|
||||||
<li>
|
<input type="hidden" name="do" value="export">
|
||||||
<a href="?do=export&what=private">Export private <span>: Export private links only</span></a>
|
<input type="hidden" name="token" value="{$token}">
|
||||||
</li>
|
|
||||||
</ul>
|
<div class="pure-g">
|
||||||
<div class="clearFix">
|
<div class="pure-u-lg-1-2 pure-u-1">
|
||||||
|
<div class="form-label">
|
||||||
|
<label><span class="label-name">{'Selection'|t}</span></label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-1-2 pure-u-1">
|
||||||
|
<div class="radio-buttons">
|
||||||
|
<div>
|
||||||
|
<input type="radio" name="selection" value="all" checked="checked">
|
||||||
|
{'All'|t}
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<input type="radio" name="selection" value="private">
|
||||||
|
{'Private'|t}
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<input type="radio" name="selection" value="public">
|
||||||
|
{'Public'|t}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-1-2 pure-u-7-8">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="prepend_note_url">
|
||||||
|
<span class="label-name">{'Prepend note permalinks with this Shaarli instance\'s URL'|t}</span><br>
|
||||||
|
<span class="label-desc">{'Useful to import bookmarks in a web browser'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-1-2 pure-u-1-8">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="checkbox" name="prepend_note_url" id="prepend_note_url">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="center">
|
||||||
|
<input type="submit" value="{'Export'|t}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
|
||||||
{include="page.footer"}
|
{include="page.footer"}
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
|
@ -3,31 +3,84 @@
|
||||||
<head>
|
<head>
|
||||||
{include="includes"}
|
{include="includes"}
|
||||||
</head>
|
</head>
|
||||||
<body onload="document.uploadform.filetoupload.focus();">
|
<body>
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
{include="page.header"}
|
||||||
<div id="uploaddiv">
|
|
||||||
Import Netscape html bookmarks (as exported from Firefox/Chrome/Opera/delicious/diigo...) (Max: {$maxfilesize|htmlspecialchars} bytes).
|
<form method="POST" action="?do=import" enctype="multipart/form-data" name="uploadform" id="uploadform">
|
||||||
<form method="post" action="?do=upload" enctype="multipart/form-data" name="uploadform" id="uploadform">
|
<div class="pure-g">
|
||||||
<p>
|
<div class="pure-u-lg-1-4 pure-u-1-24"></div>
|
||||||
<input type="file" name="filetoupload" size="80">
|
<div class="pure-u-lg-1-2 pure-u-22-24 page-form page-form-complete">
|
||||||
</p>
|
<div>
|
||||||
<p>
|
<h2 class="window-title">{"Import Database"|t}</h2>
|
||||||
<input type="checkbox" name="private" id="private">
|
</div>
|
||||||
<label for="private"> Import all links as private</label>
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<input type="checkbox" name="overwrite" id="overwrite">
|
|
||||||
<label for="overwrite"> Overwrite existing links</label>
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<input type="hidden" name="MAX_FILE_SIZE" value="{$maxfilesize|htmlspecialchars}">
|
|
||||||
<input type="hidden" name="token" value="{$token}">
|
<input type="hidden" name="token" value="{$token}">
|
||||||
<input type="submit" name="import_file" value="Import" class="bigbutton">
|
<div class="center" id="import-field">
|
||||||
</p>
|
<input type="hidden" name="MAX_FILE_SIZE" value="{$maxfilesize}">
|
||||||
|
<input type="file" name="filetoupload">
|
||||||
|
<p><br>{'Maximum size allowed:'|t} <strong>{$maxfilesizeHuman}</strong></p>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-1-3 pure-u-1">
|
||||||
|
<div class="form-label">
|
||||||
|
<label><span class="label-name">{'Visibility'|t}</span></label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-2-3 pure-u-1">
|
||||||
|
<div class="radio-buttons">
|
||||||
|
<div>
|
||||||
|
<input type="radio" name="privacy" value="default" checked="checked">
|
||||||
|
{'Use values from the imported file, default to public'|t}
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<input type="radio" name="privacy" value="private">
|
||||||
|
{'Import all bookmarks as private'|t}
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<input type="radio" name="privacy" value="public">
|
||||||
|
{'Import all bookmarks as public'|t}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-1-3 pure-u-7-8">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="overwrite">
|
||||||
|
<span class="label-name">{'Overwrite existing bookmarks'|t}</span><br>
|
||||||
|
<span class="label-desc">{'Duplicates based on URL'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-2-3 pure-u-1-8">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="checkbox" name="overwrite" id="overwrite">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-1-3 pure-u-1">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="default_tags"><span class="label-name">{'Add default tags'|t}</span></label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-2-3 pure-u-1">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="text" name="default_tags" id="default_tags" placeholder="{'Tag'|t}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="center">
|
||||||
|
<input type="submit" name="import_file" value="{'Import'|t}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{include="page.footer"}
|
{include="page.footer"}
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
|
@ -1,13 +1,22 @@
|
||||||
<title>{$pagetitle}</title>
|
<title>{$pagetitle}</title>
|
||||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
||||||
<meta name="format-detection" content="telephone=no" />
|
<meta name="format-detection" content="telephone=no" />
|
||||||
<meta name="viewport" content="width=device-width,initial-scale=1.0" />
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||||
<link rel="alternate" type="application/rss+xml" href="{$feedurl}?do=rss{$searchcrits}#" title="RSS Feed" />
|
|
||||||
<link rel="alternate" type="application/atom+xml" href="{$feedurl}?do=atom{$searchcrits}#" title="ATOM Feed" />
|
<link rel="alternate" type="application/atom+xml" href="{$feedurl}?do=atom{$searchcrits}#" title="ATOM Feed" />
|
||||||
<!--<link href="images/favicon.ico#" rel="shortcut icon" type="image/x-icon" />-->
|
<link rel="alternate" type="application/rss+xml" href="{$feedurl}?do=rss{$searchcrits}#" title="RSS Feed" />
|
||||||
<link rel="icon" type="image/png" sizes="128x128" href="images/favicon_128.png#" />
|
<link href="img/favicon.png" rel="shortcut icon" type="image/png" />
|
||||||
<link rel="icon" type="image/png" sizes="64x64" href="images/favicon_64.png#" />
|
<link href="img/apple-touch-icon.png" rel="apple-touch-icon" sizes="180x180" />
|
||||||
<link rel="icon" type="image/png" sizes="32x32" href="images/favicon_32.png#" />
|
<link type="text/css" rel="stylesheet" href="css/pure.min.css?v={$version_hash}" />
|
||||||
<link rel="icon" type="image/png" sizes="16x16" href="images/favicon_16.png#" />
|
<link type="text/css" rel="stylesheet" href="css/grids-responsive.min.css?v={$version_hash}">
|
||||||
<link type="text/css" rel="stylesheet" href="myShaarli.css?version={$version|urlencode}" />
|
<link type="text/css" rel="stylesheet" href="css/pure-extras.css?v={$version_hash}">
|
||||||
<link rel="search" type="application/opensearchdescription+xml" href="?do=opensearch#" title="Shaarli search - {$shaarlititle|htmlspecialchars}" />
|
<link type="text/css" rel="stylesheet" href="css/font-awesome.min.css?v={$version_hash}" />
|
||||||
|
<link type="text/css" rel="stylesheet" href="inc/awesomplete.css?v={$version_hash}#" />
|
||||||
|
<!--<link type="text/css" rel="stylesheet" href="css/shaarli.css?v={$version_hash}" />-->
|
||||||
|
<link type="text/css" rel="stylesheet" href="css/myShaarli.css?v={$version_hash}" />
|
||||||
|
{if="is_file('data/user.css')"}
|
||||||
|
<link type="text/css" rel="stylesheet" href="data/user.css#" />
|
||||||
|
{/if}
|
||||||
|
{loop="$plugins_includes.css_files"}
|
||||||
|
<link type="text/css" rel="stylesheet" href="{$value}?v={$version_hash}#"/>
|
||||||
|
{/loop}
|
||||||
|
<link rel="search" type="application/opensearchdescription+xml" href="?do=opensearch#" title="Shaarli search - {$shaarlititle}"/>
|
||||||
|
|
|
@ -1,43 +1,168 @@
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
{include="includes"}{$timezone_js}
|
{include="includes"}
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="logo" title="Share your links !"></div>
|
|
||||||
<div id="pageheader">
|
{$ratioLabel='1-4'}
|
||||||
<form method="post" action="?" name="installform" id="configform">
|
{$ratioInput='3-4'}
|
||||||
<p>
|
{$ratioLabelMobile='7-8'}
|
||||||
<h3>It looks like it's the first time you run Shaarli. Please configure it:</h3>
|
{$ratioInputMobile='1-8'}
|
||||||
</p>
|
|
||||||
<p>
|
<form method="POST" action="#" name="installform" id="installform">
|
||||||
<label>Login : </label>
|
<div class="pure-g">
|
||||||
<input type="text" name="setlogin" autofocus="autofocus"/>
|
<div class="pure-u-lg-1-6 pure-u-1-24"></div>
|
||||||
</p>
|
<div class="pure-u-lg-2-3 pure-u-22-24 page-form page-form-complete">
|
||||||
<p>
|
<h2 class="window-title">{'Install Shaarli'|t}</h2>
|
||||||
<label>Password : </label>
|
|
||||||
<input type="password" name="setpassword"/>
|
<div class="center">
|
||||||
</p>
|
{'It looks like it\'s the first time you run Shaarli. Please configure it.'|t}
|
||||||
<p>
|
|
||||||
{$timezone_html}
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label>Page title : </label>
|
|
||||||
<input type="text" name="title" />
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<label>Update : </label>
|
|
||||||
<input type="checkbox" name="updateCheck" id="updateCheck" checked="checked"/>
|
|
||||||
<label for="updateCheck"> Notify me when a new release is ready</label>
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
More option avaible in my Shaarli configuration page.
|
|
||||||
</p>
|
|
||||||
<p>
|
|
||||||
<input type="submit" name="Save" value="Save config" class="bigbutton">
|
|
||||||
</p>
|
|
||||||
</form>
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="username">
|
||||||
|
<span class="label-name">{'Username'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-1">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="text" name="setlogin" id="username">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="password">
|
||||||
|
<span class="label-name">{'Password'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-1">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="password" name="setpassword" id="password">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="title">
|
||||||
|
<span class="label-name">{'Shaarli title'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-1">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="text" name="title" id="title" placeholder="{'My links'|t}">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="language">
|
||||||
|
<span class="label-name">{'Language'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-1">
|
||||||
|
<div class="form-input">
|
||||||
|
<select name="language" id="language" class="align">
|
||||||
|
{loop="$languages"}
|
||||||
|
<option value="{$key}">
|
||||||
|
{$value}
|
||||||
|
</option>
|
||||||
|
{/loop}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-1">
|
||||||
|
<div class="form-label">
|
||||||
|
<label>
|
||||||
|
<span class="label-name">{'Timezone'|t}</span><br>
|
||||||
|
<span class="label-desc">{'Continent'|t} · {'City'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-1">
|
||||||
|
<div class="form-input">
|
||||||
|
<div class="timezone">
|
||||||
|
<select id="continent" name="continent">
|
||||||
|
{loop="$continents"}
|
||||||
|
{if="$key !== 'selected'"}
|
||||||
|
<option value="{$value}" {if="$continents.selected === $value"}selected{/if}>
|
||||||
|
{$value}
|
||||||
|
</option>
|
||||||
|
{/if}
|
||||||
|
{/loop}
|
||||||
|
</select>
|
||||||
|
<select id="city" name="city">
|
||||||
|
{loop="$cities"}
|
||||||
|
{if="$key !== 'selected'"}
|
||||||
|
<option value="{$value.city}"
|
||||||
|
{if="$cities.selected === $value.city"}selected{/if}
|
||||||
|
data-continent="{$value.continent}">
|
||||||
|
{$value.city}
|
||||||
|
</option>
|
||||||
|
{/if}
|
||||||
|
{/loop}
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-7-8">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="update">
|
||||||
|
<span class="label-name">{'Check updates'|t}</span><br>
|
||||||
|
<span class="label-desc">
|
||||||
|
{'Notify me when a new release is ready'|t}
|
||||||
|
</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-1-8">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="checkbox" name="updateCheck" id="update" checked="checked">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-{$ratioLabel} pure-u-{$ratioLabelMobile}">
|
||||||
|
<div class="form-label">
|
||||||
|
<label for="enableApi">
|
||||||
|
<span class="label-name">{'Enable REST API'|t}</span><br>
|
||||||
|
<span class="label-desc">{'Allow third party software to use Shaarli such as mobile application'|t}</span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-{$ratioInput} pure-u-{$ratioInputMobile}">
|
||||||
|
<div class="form-input">
|
||||||
|
<input type="checkbox" name="enableApi" id="enableApi" checked />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="center">
|
||||||
|
<input type="submit" value="{'Install'|t}" name="Save">
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
{include="page.footer"}
|
{include="page.footer"}
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
|
@ -2,161 +2,272 @@
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
{include="includes"}
|
{include="includes"}
|
||||||
{if="empty($GLOBALS['disablejquery'])"}
|
|
||||||
<script src="inc/jquery.min.js#"></script>
|
|
||||||
<script src="inc/jquery-ui.min.js#"></script>
|
|
||||||
{/if}
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
{include="page.header"}
|
||||||
<div id="headerform">
|
|
||||||
<form method="get" class="searchform" name="searchform">
|
<div class="linkcount pure-u-0 pure-u-lg-visible">
|
||||||
<input type="text" id="searchform_value" name="searchterm" value="" placeholder="Search text"/>
|
{if="!empty($linkcount)"}
|
||||||
<input type="submit" value="Search" class="bigbutton"/>
|
<span class="strong">{$linkcount}</span> {function="t('shaare', 'shaares', $linkcount)"}
|
||||||
</form>
|
{if="$privateLinkcount>0"}
|
||||||
<form method="get" class="tagfilter" name="tagfilter">
|
<br><span class="strong">{$privateLinkcount}</span> {function="t('private link', 'private links', $privateLinkcount)"}
|
||||||
<input type="text" name="searchtags" id="tagfilter_value" value="{loop="search_crits"}{$value|htmlspecialchars} {/loop}" placeholder="Filter by tag"/>
|
|
||||||
<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" class="tags">
|
|
||||||
Nothing found.
|
|
||||||
</div>
|
|
||||||
{else}
|
|
||||||
{if="$search_type=='fulltext'"}
|
|
||||||
<div id="searchcriteria" class="tags">
|
|
||||||
{$result_count} results for <i>{$search_crits}</i>
|
|
||||||
</div>
|
|
||||||
{/if}
|
|
||||||
{if="$search_type=='tags'"}
|
|
||||||
<div id="searchcriteria" class="tags">
|
|
||||||
{$result_count} results for tags <i> {loop="search_crits"} <a href="?removetag={$value|htmlspecialchars}">{$value|htmlspecialchars} <span class="removeTag">x</span></a> {/loop}</i>
|
|
||||||
</div>
|
|
||||||
{/if}
|
{/if}
|
||||||
{/if}
|
{/if}
|
||||||
<ul class="linkList">
|
|
||||||
{loop="links"}
|
|
||||||
<li {if="$value.class"} class="{$value.class}"{/if} >
|
|
||||||
<!--<a name="{$value.linkdate|smallHash}" id="{$value.linkdate|smallHash}"></a>-->
|
|
||||||
{if="$GLOBALS['config']['ENABLE_THUMBNAILS']"}
|
|
||||||
<div class="thumbnail">
|
|
||||||
{$value.url|thumbnail}
|
|
||||||
</div>
|
</div>
|
||||||
{/if}
|
|
||||||
<div class="linkcontainer {if="$GLOBALS['config']['ENABLE_THUMBNAILS']"}linkcontainerThumb{/if}">
|
|
||||||
{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="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();">
|
<div id="search-linklist">
|
||||||
|
|
||||||
|
<form method="GET" class="pure-form searchform" name="searchform">
|
||||||
|
<input type="text" tabindex="1" name="searchterm" class="searchterm" placeholder="{'Search text'|t}"
|
||||||
|
{if="!empty($search_term)"}
|
||||||
|
value="{$search_term}"
|
||||||
|
{/if}
|
||||||
|
>
|
||||||
|
<input type="text" tabindex="2" name="searchtags" class="searchtags" placeholder="{'Filter by tag'|t}"
|
||||||
|
{if="!empty($search_tags)"}
|
||||||
|
value="{$search_tags}"
|
||||||
|
{/if}
|
||||||
|
autocomplete="off" data-multiple data-autofirst data-minChars="1"
|
||||||
|
data-list="{loop="$tags"}{$key}, {/loop}"
|
||||||
|
>
|
||||||
|
<button type="submit" class="search-button"><i class="fa fa-search"></i></button>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
{loop="$plugins_header.fields_toolbar"}
|
||||||
|
<form
|
||||||
|
{loop="$value.attr"}
|
||||||
|
{$key}="{$value}"
|
||||||
|
{/loop}>
|
||||||
|
<div class="toolbar-plugin pure-u-lg-1">
|
||||||
|
{loop="$value.inputs"}
|
||||||
|
<input
|
||||||
|
{loop="$value"}
|
||||||
|
{$key}="{$value}"
|
||||||
|
{/loop}>
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
{/loop}
|
||||||
|
|
||||||
|
<div id="linklist">
|
||||||
|
<div id="link-count-block" class="pure-g">
|
||||||
|
<div class="pure-u-lg-2-24 pure-u-1-24"></div>
|
||||||
|
<div id="link-count-content" class="pure-u-lg-20-24 pure-u-22-24">
|
||||||
|
<div class="linkcount pure-u-lg-0 center">
|
||||||
|
{if="!empty($linkcount)"}
|
||||||
|
<span class="strong">{$linkcount}</span> {function="t('shaare', 'shaares', $linkcount)"}
|
||||||
|
{if="$privateLinkcount>0"}
|
||||||
|
· <span class="strong">{$privateLinkcount}</span> {function="t('private link', 'private links', $privateLinkcount)"}
|
||||||
{/if}
|
{/if}
|
||||||
<h3 class="linktitle">{function="returnFavicon($value.url)"}<a href="{$redirector}{$value.url|htmlspecialchars}">{$value.title|htmlspecialchars}</a></h3>
|
{/if}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{include="linklist.paging"}
|
||||||
|
|
||||||
|
<div id="plugin_zone_start_linklist" class="plugin_zone">
|
||||||
|
{loop="$plugin_start_zone"}
|
||||||
|
{$value}
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{if="count($links)==0"}
|
||||||
|
<div id="search-result-block" class="pure-g pure-alert pure-alert-error search-result">
|
||||||
|
<div class="pure-u-2-24"></div>
|
||||||
|
<div id="search-result-content" class="pure-u-20-24">
|
||||||
|
<div id="searchcriteria">{'Nothing found.'|t}</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{elseif="!empty($search_term) or $search_tags !== '' or !empty($visibility) or $untaggedonly"}
|
||||||
|
<div id="search-result-block" class="pure-g pure-alert pure-alert-success search-result">
|
||||||
|
<div class="pure-u-2-24"></div>
|
||||||
|
<div id="search-result-content" class="pure-u-20-24 search-result-main">
|
||||||
|
{function="sprintf(t('%s result', '%s results', $result_count), $result_count)"}
|
||||||
|
{if="!empty($search_term)"}
|
||||||
|
{'for'|t} <em><strong>{$search_term}</strong></em>
|
||||||
|
{/if}
|
||||||
|
{if="!empty($search_tags)"}
|
||||||
|
{$exploded_tags=explode(' ', $search_tags)}
|
||||||
|
{'tagged'|t}
|
||||||
|
{loop="$exploded_tags"}
|
||||||
|
<span class="label label-tag" title="{'Remove tag'|t}">
|
||||||
|
<a href="?removetag={function="urlencode($value)"}">{$value}<span class="remove"><i class="fa fa-times"></i></span></a>
|
||||||
|
</span>
|
||||||
|
{/loop}
|
||||||
|
{/if}
|
||||||
|
{if="!empty($visibility)"}
|
||||||
|
{'with status'|t}
|
||||||
|
<span class="label label-private">
|
||||||
|
{$visibility|t}
|
||||||
|
</span>
|
||||||
|
{/if}
|
||||||
|
{if="$untaggedonly"}
|
||||||
|
<span class="label label-private">
|
||||||
|
{'without any tag'|t}
|
||||||
|
</span>
|
||||||
|
{/if}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
<div id="linklist-loop-block" class="pure-g">
|
||||||
|
<div class="pure-u-lg-2-24 pure-u-1-24"></div>
|
||||||
|
<div id="linklist-loop-content" class="pure-u-lg-20-24 pure-u-22-24">
|
||||||
|
{ignore}Set translation here, for performances{/ignore}
|
||||||
|
{$strPrivate=t('Private')}
|
||||||
|
{$strEdit=t('Edit')}
|
||||||
|
{$strDelete=t('Delete')}
|
||||||
|
{$strFold=t('Fold')}
|
||||||
|
{$strEdited=t('Edited: ')}
|
||||||
|
{$strPermalink=t('Permalink')}
|
||||||
|
{$strPermalinkLc=t('permalink')}
|
||||||
|
{$strAddTag=t('Add tag')}
|
||||||
|
{ignore}End of translations{/ignore}
|
||||||
|
{loop="links"}
|
||||||
|
<div class="anchor" id="{$value.shorturl}"></div>
|
||||||
|
|
||||||
|
<div class="linklist-item linklist-item{if="$value.class"} {$value.class}{/if}" data-id="{$value.id}">
|
||||||
|
<div class="linklist-item-title">
|
||||||
|
{$thumb=thumbnail($value.url)}
|
||||||
|
{if="$thumb!=false"}
|
||||||
|
<div class="linklist-item-thumbnail">{$thumb}</div>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
{if="isLoggedIn()"}
|
||||||
|
<div class="linklist-item-editbuttons">
|
||||||
|
{if="$value.private"}
|
||||||
|
<span class="label label-private">{$strPrivate}</span>
|
||||||
|
{/if}
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
<h2>
|
||||||
|
<a href="{$value.real_url}">
|
||||||
|
{if="strpos($value.url, $value.shorturl) === false"}
|
||||||
|
<i class="fa fa-external-link"></i>
|
||||||
|
{else}
|
||||||
|
<i class="fa fa-sticky-note"></i>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
<span class="linklist-link">{$value.title}</span>
|
||||||
|
</a>
|
||||||
|
</h2>
|
||||||
|
</div>
|
||||||
|
|
||||||
{if="$value.description"}
|
{if="$value.description"}
|
||||||
<div class="linkdescription" {if condition="$search_type=='permalink'"}{/if}>
|
<div class="linklist-item-description">
|
||||||
{$value.description}
|
{$value.description}
|
||||||
</div>
|
</div>
|
||||||
{/if}
|
{/if}
|
||||||
{if condition="isset($value.via) && !empty($value.via)"}
|
|
||||||
<div>
|
<div class="linklist-item-infos clear">
|
||||||
<a href="{$value.via}">Origine => {$value.via|getJustDomain}</a>
|
|
||||||
</div>{/if}
|
|
||||||
{if="!$GLOBALS['config']['HIDE_TIMESTAMPS'] || isLoggedIn()"}
|
|
||||||
<span class="linkdate linkBottom" title="Permalink"><a href="?{$value.linkdate|smallHash}">{function="ucfirst(htmlspecialchars($value.localdate))"} - permalink</a> - </span>
|
|
||||||
{else}
|
|
||||||
<span class="linkdate linkBottom" title="Short link here"><a href="?{$value.linkdate|smallHash}">permalink</a> - </span>
|
|
||||||
{/if}
|
|
||||||
<span class="linkarchive linkBottom"><a href="https://web.archive.org/web/{$value.url|htmlspecialchars}">Archive.org</a> - </span>
|
|
||||||
{if="$GLOBALS['config']['WALLABAG_URL'] && isLoggedIn() && $GLOBALS['config']['WALLABAG_VERSION']===1"}
|
|
||||||
<span class="linkWallabag linkBottom"><a href="{$GLOBALS['config']['WALLABAG_URL']}/?plainurl={$value.url|htmlspecialchars}">Save to Wallabag</a> - </span>
|
|
||||||
{/if}
|
|
||||||
{if="$GLOBALS['config']['WALLABAG_URL'] && isLoggedIn() && $GLOBALS['config']['WALLABAG_VERSION']===2"}
|
|
||||||
<span class="linkWallabag linkBottom"><a href="{$GLOBALS['config']['WALLABAG_URL']}/bookmarklet?url={$value.url|htmlspecialchars}">Save to Wallabag</a> - </span>
|
|
||||||
{/if}
|
|
||||||
<span><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#" title="QR-Code" alt="qrcode logo"></a></span> - <span class="linkurl" title="Short link">{$value.url|htmlspecialchars}</span>
|
|
||||||
<br>
|
|
||||||
{if="$value.tags"}
|
{if="$value.tags"}
|
||||||
<div class="tags">
|
<div class="linklist-item-tags">
|
||||||
{loop="value.taglist"}<a href="?addtag={$value|urlencode}">{$value|htmlspecialchars}</a> {/loop}
|
<i class="fa fa-tags"></i>
|
||||||
|
{$tag_counter=count($value.taglist)}
|
||||||
|
{loop="value.taglist"}
|
||||||
|
<span class="label label-tag" title="{$strAddTag}">
|
||||||
|
<a href="?addtag={$value|urlencode}">{$value}</a>
|
||||||
|
</span>
|
||||||
|
{if="$tag_counter - 1 != $counter"}·{/if}
|
||||||
|
{/loop}
|
||||||
</div>
|
</div>
|
||||||
{/if}
|
{/if}
|
||||||
|
|
||||||
|
<div class="linklist-item-infos-date-url-block pure-g">
|
||||||
|
<div class="linklist-item-infos-dateblock pure-u-lg-7-12 pure-u-1">
|
||||||
|
{if="isLoggedIn()"}
|
||||||
|
<div class="linklist-item-infos-controls-group pure-u-0 pure-u-lg-visible">
|
||||||
|
<span class="linklist-item-infos-controls-item ctrl-checkbox">
|
||||||
|
<input type="checkbox" class="delete-checkbox" value="{$value.id}">
|
||||||
|
</span>
|
||||||
|
<span class="linklist-item-infos-controls-item ctrl-edit">
|
||||||
|
<a href="?edit_link={$value.id}" title="{$strEdit}"><i class="fa fa-pencil-square-o edit-link"></i></a>
|
||||||
|
</span>
|
||||||
|
<span class="linklist-item-infos-controls-item ctrl-delete">
|
||||||
|
<a href="?delete_link&lf_linkdate={$value.id}&token={$token}"
|
||||||
|
title="{$strDelete}" class="delete-link pure-u-0 pure-u-lg-visible confirm-delete">
|
||||||
|
<i class="fa fa-trash"></i>
|
||||||
|
</a>
|
||||||
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<span class="clearFix"> </span>
|
{/if}
|
||||||
</li>
|
<a href="?{$value.shorturl}" title="{$strPermalink}">
|
||||||
|
{if="!$hide_timestamps || isLoggedIn()"}
|
||||||
|
{$updated=$value.updated_timestamp ? $strEdited. format_date($value.updated) : $strPermalink}
|
||||||
|
<span class="linkdate" title="{$updated}">
|
||||||
|
<i class="fa fa-clock-o"></i>
|
||||||
|
{$value.created|format_date}
|
||||||
|
{if="$value.updated_timestamp"}*{/if}
|
||||||
|
·
|
||||||
|
</span>
|
||||||
|
{/if}
|
||||||
|
{$strPermalinkLc}
|
||||||
|
</a>
|
||||||
|
|
||||||
|
<div class="pure-u-0 pure-u-lg-visible">
|
||||||
|
{if="isset($value.link_plugin)"}
|
||||||
|
·
|
||||||
|
{$link_plugin_counter=count($value.link_plugin)}
|
||||||
|
{loop="$value.link_plugin"}
|
||||||
|
{$value}
|
||||||
|
{if="$link_plugin_counter - 1 != $counter"}·{/if}
|
||||||
{/loop}
|
{/loop}
|
||||||
</ul>
|
{/if}
|
||||||
|
</div>
|
||||||
|
</div><div
|
||||||
|
{ignore}do not add space or line break between these div - Firefox issue{/ignore}
|
||||||
|
class="linklist-item-infos-url pure-u-lg-5-12 pure-u-1">
|
||||||
|
<a href="{$value.real_url}" title="{$value.title}">
|
||||||
|
<i class="fa fa-link"></i> {$value.url}
|
||||||
|
</a>
|
||||||
|
<div class="linklist-item-buttons pure-u-0 pure-u-lg-visible">
|
||||||
|
<a href="#" title="{$strFold}" class="fold-button"><i class="fa fa-chevron-up"></i></a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="mobile-buttons pure-u-1 pure-u-lg-0">
|
||||||
|
{if="isset($value.link_plugin)"}
|
||||||
|
{$link_plugin_counter=count($value.link_plugin)}
|
||||||
|
{loop="$value.link_plugin"}
|
||||||
|
{$value}
|
||||||
|
{if="$link_plugin_counter - 1 != $counter"}·{/if}
|
||||||
|
{/loop}
|
||||||
|
{/if}
|
||||||
|
{if="isLoggedIn()"}
|
||||||
|
·
|
||||||
|
<a href="?delete_link&lf_linkdate={$value.id}&token={$token}"
|
||||||
|
title="{$strDelete}" class="delete-link confirm-delete">
|
||||||
|
<i class="fa fa-trash"></i>
|
||||||
|
</a>
|
||||||
|
·
|
||||||
|
<a href="?edit_link={$value.id}" title="{$strEdit}"><i class="fa fa-pencil-square-o edit-link"></i></a>
|
||||||
|
{/if}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="plugin_zone_end_linklist" class="plugin_zone">
|
||||||
|
{loop="$plugin_end_zone"}
|
||||||
|
{$value}
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="linklist-paging-bottom-block" class="pure-g">
|
||||||
|
<div class="pure-u-lg-2-24 pure-u-1-24"></div>
|
||||||
|
<div id="linklist-paging-bottom-content" class="pure-u-lg-20-24 pure-u-22-24">
|
||||||
{include="linklist.paging"}
|
{include="linklist.paging"}
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
{include="page.footer"}
|
{include="page.footer"}
|
||||||
<script>
|
|
||||||
$('#tagfilter_value').autocomplete({
|
|
||||||
source : '{$source}?ws=tags',
|
|
||||||
minLength : 1
|
|
||||||
});
|
|
||||||
// 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>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
|
@ -1,24 +1,61 @@
|
||||||
<div class="paging">
|
<div class="linklist-paging">
|
||||||
|
<div class="paging pure-g">
|
||||||
|
<div class="linklist-filters pure-u-1-3">
|
||||||
|
{if="isLoggedIn() or !empty($action_plugin)"}
|
||||||
|
<span class="linklist-filters-text pure-u-0 pure-u-lg-visible">
|
||||||
|
{'Filters'|t}
|
||||||
|
</span>
|
||||||
{if="isLoggedIn()"}
|
{if="isLoggedIn()"}
|
||||||
<div class="paging_privatelinks">
|
<a href="?privateonly" title="{'Filter private links'|t}"
|
||||||
<a href="?privateonly"> {if="$privateonly"} <img src="images/private_16x16_active.png#" width="16" height="16" title="Click to see all links" alt="Click to see all links"> {else} <img src="images/private_16x16.png#" width="16" height="16" title="Click to see only private links" alt="Click to see only private links"> {/if} </a>
|
class={if="$privateonly"}"filter-on"{else}"filter-off"{/if}
|
||||||
</div>
|
><i class="fa fa-key"></i></a>
|
||||||
{/if}
|
{/if}
|
||||||
<div class="paging_linksperpage">
|
<a href="?untaggedonly" title="{'Filter untagged links'|t}"
|
||||||
Links per page: <a href="?linksperpage=20">20</a><a href="?linksperpage=50">50</a><a href="?linksperpage=100">100</a>
|
class={if="$untaggedonly"}"filter-on"{else}"filter-off"{/if}
|
||||||
<form method="GET" class="linksperpage">
|
><i class="fa fa-tag"></i></a>
|
||||||
<input type="text" name="linksperpage">
|
<a href="#" class="filter-off fold-all pure-u-lg-0" title="{'Fold all'|t}">
|
||||||
</form>
|
<i class="fa fa-chevron-up"></i>
|
||||||
</div>
|
</a>
|
||||||
<div class="paginNavigation">
|
{loop="$action_plugin"}
|
||||||
{if="$previous_page_url"}
|
{$value.attr.class=isset($value.attr.class) ? $value.attr.class : ''}
|
||||||
<a href="{$previous_page_url}" class="paging_older">◄Older</a>
|
{$value.attr.class=!empty($value.on) ? $value.attr.class .' filter-on' : $value.attr.class .' filter-off'}
|
||||||
|
<a
|
||||||
|
{loop="$value.attr"}
|
||||||
|
{$key}="{$value}"
|
||||||
|
{/loop}>
|
||||||
|
{$value.html}
|
||||||
|
</a>
|
||||||
|
{/loop}
|
||||||
{/if}
|
{/if}
|
||||||
<div class="paging_current">
|
|
||||||
page {$page_current} / {$page_max}
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
|
<div class="linklist-pages pure-u-1-3">
|
||||||
{if="$next_page_url"}
|
{if="$next_page_url"}
|
||||||
<a href="{$next_page_url}" class="paging_newer">Newer►</a>
|
<a href="{$next_page_url}" class="paging_newer">
|
||||||
|
<i class="fa fa-arrow-circle-left"></i>
|
||||||
|
</a>
|
||||||
{/if}
|
{/if}
|
||||||
|
{if="$page_max>1"}<span class="strong">{$page_current} / {$page_max}</span>{/if}
|
||||||
|
{if="$previous_page_url"}
|
||||||
|
<a href="{$previous_page_url}" class="paging_older">
|
||||||
|
<i class="fa fa-arrow-circle-right"></i>
|
||||||
|
</a>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="linksperpage pure-u-1-3">
|
||||||
|
<div class="pure-u-0 pure-u-lg-visible">{'Links per page'|t}</div>
|
||||||
|
<a href="?linksperpage=20">20</a>
|
||||||
|
<a href="?linksperpage=50">50</a>
|
||||||
|
<a href="?linksperpage=100">100</a>
|
||||||
|
<form method="GET" class="pure-u-0 pure-u-lg-visible">
|
||||||
|
<input type="text" name="linksperpage" placeholder="133">
|
||||||
|
</form>
|
||||||
|
<a href="#" class="filter-off fold-all pure-u-0 pure-u-lg-visible" title="{'Fold all'|t}">
|
||||||
|
<i class="fa fa-chevron-up"></i>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
|
@ -4,34 +4,48 @@
|
||||||
{include="includes"}
|
{include="includes"}
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
{include="page.header"}
|
||||||
<div id="headerform">
|
{if="!ban_canLogin($conf)"}
|
||||||
{if="!ban_canLogin()"}
|
<div class="pure-g pure-alert pure-alert-error pure-alert-closable center">
|
||||||
You have been banned from login after too many failed attempts. Try later.
|
<div class="pure-u-2-24"></div>
|
||||||
|
<div class="pure-u-20-24">
|
||||||
|
{'You have been banned after too many failed login attempts. Try again later.'|t}
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-2-24">
|
||||||
|
<i class="fa fa-times pure-alert-close"></i>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
{else}
|
{else}
|
||||||
<form method="post" id="configform" class="configform">
|
<div class="pure-g">
|
||||||
<p>
|
<div class="pure-u-lg-1-3 pure-u-1-24"></div>
|
||||||
<label for="login">Login :</label>
|
<div id="login-form" class="page-form page-form-light pure-u-lg-1-3 pure-u-22-24">
|
||||||
<input type="text" name="login" id="login" tabindex="1" autofocus />
|
<form method="post" name="loginform">
|
||||||
<label for="password">Password :</label>
|
<h2 class="window-title">{'Login'|t}</h2>
|
||||||
<input type="password" name="password" id="password" tabindex="2">
|
<div>
|
||||||
</p>
|
<input type="text" name="login" placeholder="{'Username'|t}"
|
||||||
<p>
|
{if="!empty($username)"}value="{$username}"{/if} class="autofocus" tabindex="20">
|
||||||
<input type="checkbox" name="longlastingsession" id="longlastingsession" tabindex="3">
|
</div>
|
||||||
<label for="longlastingsession"> Stay signed in (Do not check on public computers)</label>
|
<div>
|
||||||
</p>
|
<input type="password" name="password" placeholder="{'Password'|t}" class="autofocus" tabindex="21">
|
||||||
<p>
|
</div>
|
||||||
{if="$returnurl"}
|
<div class="remember-me">
|
||||||
<input type="hidden" name="returnurl" value="{$returnurl|htmlspecialchars}">
|
<input type="checkbox" name="longlastingsession" id="longlastingsessionform"
|
||||||
{/if}
|
{if="$remember_user_default"}checked="checked"{/if}
|
||||||
|
tabindex="22">
|
||||||
|
<label for="longlastingsessionform">{'Remember me'|t}</label>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<input type="submit" value="{'Login'|t}" class="bigbutton" tabindex="23">
|
||||||
|
</div>
|
||||||
<input type="hidden" name="token" value="{$token}">
|
<input type="hidden" name="token" value="{$token}">
|
||||||
<input type="submit" value="Login" class="bigbutton" tabindex="4" />
|
{if="$returnurl"}<input type="hidden" name="returnurl" value="{$returnurl}">{/if}
|
||||||
</p>
|
|
||||||
</form>
|
</form>
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-lg-1-3 pure-u-1-8"></div>
|
||||||
|
</div>
|
||||||
{/if}
|
{/if}
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{include="page.footer"}
|
{include="page.footer"}
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load diff
|
@ -1,15 +1,45 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<OpenSearchDescription xmlns="http://a9.com/-/spec/opensearch/1.1/">
|
<OpenSearchDescription xmlns="http://a9.com/-/spec/opensearch/1.1/">
|
||||||
<ShortName>myShaarli search - {$pagetitle}</ShortName>
|
<ShortName>Shaarli search - {$pagetitle}</ShortName>
|
||||||
<Description>myShaarli search - {$pagetitle}</Description>
|
<Description>Shaarli search - {$pagetitle}</Description>
|
||||||
<Url type="text/html" template="{$serverurl}?searchterm={searchTerms}" />
|
<Url type="text/html" template="{$serverurl}?searchterm={searchTerms}" />
|
||||||
<Url type="application/atom+xml" template="{$serverurl}?do=atom&searchterm={searchTerms}"/>
|
<Url type="application/atom+xml" template="{$serverurl}?do=atom&searchterm={searchTerms}"/>
|
||||||
<Url type="application/rss+xml" template="{$serverurl}?do=rss&searchterm={searchTerms}"/>
|
<Url type="application/rss+xml" template="{$serverurl}?do=rss&searchterm={searchTerms}"/>
|
||||||
<InputEncoding>UTF-8</InputEncoding>
|
<InputEncoding>UTF-8</InputEncoding>
|
||||||
<Developer>Knah Tsaeb myShaarly - https://github.com/Knah-Tsaeb/myShaarli</Developer>
|
<Developer>Shaarli Community - https://github.com/shaarli/Shaarli/</Developer>
|
||||||
<Image width="16" height="16">data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAABGdBTUEAALGPC/xhBQAAAAlwSFlz AAALEwAACxMBAJqcGAAAAAd0SU1FB98HEA4tDZmAhI0AAAAdaVRYdENvbW1lbnQAAAAAAENyZWF0 ZWQgd2l0aCBHSU1QZC5lBwAAAhJJREFUOMuVUz1oU1EYPcm90iTNnxCTtImtD6VdoghShzq0xPLy
|
<Image width="16" height="16">data:image/x-icon;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAABmJLR0QA/wD/AP+gvaeTAAAHRklE
|
||||||
DEpEcdAuoUgVC4JDHERx6ioU0UVQC3VyU4dAMKb+pNI6qBTaQqnSxpBgan6qTZq89z6HWIkhofEs l3s45/B99/suQxPcuOdnWeOXEedBPnjsRNfcQjxH+B8cuqC7c3OG0+05ToeH+d1mOlZPDF62tZv3 KwMOQb7e0c2t7QaOHylFMLh2RdLzSqper6m9HBk2C66e0kL/kK7NuZfh8+wW7J0cboFj6VMZ0Wel 6Lv78vGmFVh6lNMXr1rPfk8QZqIlzL4uIrEiY3VJRt9RI8xWJih606O1j5v5bY+2NsBmND1/+vBn
|
QVRIx5WWaWxU5xWG3++7986dfYYZb+MN2xiMDRiDFePUiQsNoiwpUNpAmhInJVEqpa0oQUlbJVKq
|
||||||
4cA+Pc6f2wOPx4BOZxsujXZgIwPEX21Oxx9nVms9/wS8ncyu5xaFqXJei5eRAkJj3RgbcSPyYgOn BhxYz6hf69+A1xMqK71ZXt66EjzjxuSTFIp5DySfgm9rMlTSZHacQmIxO6/+6r3W5RrV6fP92K32 Qi73YXz8fcLuEE6ufEjuvA+iKBIRkd/vp2AwSEREXq+3oVHbkNRW6UKhoBaLRQCA3W6HJEmmlgL+ LolGo2Ws2uWfk7UUUKlUqmO12WCxWAAARI1b541IWZYT6XTaHQgEwDkHESGZTCIWi+Va+kiSJN0K
|
olaiqpLKUtOKhAJRm1BKRVWctuykpFjAgPcFx/uMl5mxPTOeuXPv3O3rjyiV0lIpfX+dc36c55xf
|
||||||
hUK0jYmJCRJFcaphm81CfD7fg0qlEmSMcQDTjLGhcDgs1+t+Ay6pzgTLZnNuAAAAAElFTkSuQmCC
|
70vwP9TZ2fFpSQCwT5u6unX4f0QeNLx27RoMQwfRveTd11T23M+8S9w+Z3NRma1W4Hk6/nEimFpM
|
||||||
|
Xnun9Xpmz1MPY+feOhBi/fwAAOjq7iJEqmQqCZf5i7NvyNZ/bJPYgAjCiJc2Zmhyw68SM/T1+NlK
|
||||||
|
uf61BPoH+tHU1PT5ACMjI8RXvACvpZ5NT0+fmrG+2TKqtDLV0BgA2AUfXS3+UtfDX2ixCf73E+oA
|
||||||
|
rat92CTkv9fRBwEkSaLDt/JZR/v0Q7qjb8dQ5hjSqmYSOCkzBbogL+ij2RN8bik9wK88Al9tH4tG
|
||||||
|
ow88lvb19yEyPwfGGLq6OungYD9fUlosrqwoQVVVUeOU8qE/mU0ZTq6KNvreNort+5hugkayQUgY
|
||||||
|
qQld/u6qnVRhkciscOdOkNy5E0RnZ+e/AbwsZxAaHyORZA+prW01CTlnGppOqAcwUnCmlDAkAyin
|
||||||
|
Dapb2t7lNeRijpwvTGlJROXugoKS+upz/S19Kj9lJjxXGY1VU49tGevt7WOCSMHTeAXclePsQts9
|
||||||
|
Jq9oLR7rPVkHxpUYkK2c07ZDiieRNcAx3ZlNphcnsxbiMuEsXFSTZpabp+VVS17UNSV/8n7+gN75
|
||||||
|
+C1DM6VEjkgatiz/5IOCAheiUdeyr+198keKZXLzTKYjMDk/ZzGJhkV9AiPSdWaYIAY4U7TYNJMR
|
||||||
|
pugMqgHcXTiJqDK8ycMv2+TPWyWtKFw3KEdtJxNz8u8+/PNYIqeUgY/Oz+Z7q5X3gtqvG7qip8yM
|
||||||
|
HqdZg5kGgwGACoQQQkEMQ2DMIFnGE04xCRQTZFaexUT6jEEImJ2njjxx9fr13hfqfULTQ4apHept
|
||||||
|
lxf4mrqS3Tek0w1toTc1K6WcXfAwnyWH8kSkIueEhdhNrzUAv16fSCUzNwR3vr/G2lKWojMqbxF4
|
||||||
|
FWlLPDvBR+RBNpTsNqfkV7htuUe/UVq456qdzzvFh2KjdSH0I6ODs1ps9NHcw2jMfRYcEQyOCiox
|
||||||
|
aWR0fOQWVLFNUuOnrXJxfIPnpXLRKzocLpsJanhUU/bfjJ4gfwm/ys3JGX1cuS3UBvauLa/MBe9z
|
||||||
|
5c/xGRdSKpiVmhhN98JK/w4DGgg4uLh8u1NfPhWbmzszeH3G1rxv3dL7+qXyGaXHJi46s4QQophp
|
||||||
|
TKSDkHWGlAqmGCbAGAUA3sY5LlRZv3w44Dhnm0iFzbnsGfJR5E+EEsppTBVXuBptL5b8YQMlwnO+
|
||||||
|
Z2wtea4cl8Rc3KXJ4zShRm0CFaCaGhSDwGSMlbtLhSr7FnVhKhscC4+AO3L0x5PSFBdfE9i40SE6
|
||||||
|
xLSWRCIbJ6phIqEysqvk+2aJ0vhB1NK353zyaL3GS76NgRbVYykkt2OXuaQqMwuxkk0FT+OJpS+z
|
||||||
|
piXPRP1KzRvz4dRvO68PaWCMEQAIDcbqFiLJtyaSA/Ef3NnMGttgvHS7mUUWw7cTMemtY/cPsw3n
|
||||||
|
oe2+4mGXpt7VGWPJ6zOn1V2Xfaz5AxgvBzexodmeGWmCbWWTDOGpSZIIqeAe2/IYvnXgWbomUj2T
|
||||||
|
lNlwUP7bV64lzuRIeoodqDxi1OKRs/e0i08dH/6JPWtk6KKaZd3xj2jAXkY3BvZGK1xrhZvRNktP
|
||||||
|
fNA0ubQrxyxV4jHpSkWoXJPKYqBetxeRpgsMWwE5b/bxaYxUDSWmzCLbStqQuy02LY4/cWLsqH8i
|
||||||
|
HYNbyEeJczkJSzH2855DwsXp932F9hXEKQSQ1UHa568iRAa3uFyeNVolMBmeIrzT4cTXm37KMuvA
|
||||||
|
xb8XXTqiDELRgKg8h/dGWwP9iSDaIzcYJSCbA/uNR3N2sNahV/hbsSA70vEdW66tCOOpj8FRkIgU
|
||||||
|
Q5ybLUopiTzeTpFWUoTXdR3knwQMzLANOyQX50fWhDktLeAX3UcIA2EEQHPgi6TBsrWzaLGm7emC
|
||||||
|
H7bY+GPlV6YumiEpDhslxGBgROApz+yyhROzduIEzwngDh48iD3jO0nBRAUUXtHcoq+ZWbI5EWWa
|
||||||
|
WTieFjoKsaVoN92T88J4vlz+asXqpb+hEcdotbdueZ47vyiqhpA2UoRQwpoLtpNHxR0382jR8RzT
|
||||||
|
k8xYMyCMMfR33Uc8rxdrA9tpuHPyS7pPOTRPZ1arepa4rUsybiWnnU9a39ZXxdur+XoGAGMdoXLi
|
||||||
|
M789axnfNxDr8omiDcvF1f3OhPf18efjF/nfz6PGvv6zlrlwWwYBgcBZbKH4WKHODLHEURDxbHDF
|
||||||
|
QWGePftHUlZWjsy8guYnH2EgwORfZ5cuavEqgGhLnL6+sycvRP1Fbux/fheIn3wCCN4N/qdPMwA4
|
||||||
|
2fYOeoe7kc6kcfCbh8n+r7YwAOjs6QCl9DNx5t7dew+MOf8CcuqqoLxlhwgAAAAASUVORK5CYII=
|
||||||
</Image>
|
</Image>
|
||||||
</OpenSearchDescription>
|
</OpenSearchDescription>
|
||||||
|
|
|
@ -1,21 +1,43 @@
|
||||||
<div id="footer">
|
|
||||||
<a href="https://forge.leslibres.org/Knah-Tsaeb/MyShaarli">myShaarli are made by Knah Tsaeb</a> is based on <b><a href="http://sebsauvage.net/wiki/doku.php?id=php:shaarli">Shaarli 0.0.41 beta</a></b> - The personal, minimalist, super-fast, no-database
|
|
||||||
delicious clone. By <a href="http://sebsauvage.net" target="_blank">sebsauvage.net</a>.
|
|
||||||
<br/> Original theme by <a href="http://blog.idleman.fr" target="_blank">idleman.fr</a>.
|
|
||||||
<br/> {if="$GLOBALS['config']['contactLink']"} For contact me <a href="{$GLOBALS['config']['contactLink']}">use this link.</a>{/if}
|
|
||||||
</div>
|
</div>
|
||||||
{if="$newversion"}
|
|
||||||
<div id="newversion">
|
<div class="pure-g">
|
||||||
●<a href="{$GLOBALS['config']['UPDATECHECK_DOWNLOAD']}">{$newversion|htmlspecialchars}</a>
|
<div class="pure-u-2-24"></div>
|
||||||
</div>
|
<div id="footer" class="pure-u-20-24">
|
||||||
{/if} {if="isLoggedIn()"}
|
<strong><a href="https://github.com/shaarli/Shaarli">Shaarli</a></strong>
|
||||||
<script>
|
{if="isLoggedIn()===true"}
|
||||||
function confirmDeleteLink() {
|
{$version}
|
||||||
var agree = confirm("Are you sure you want to delete this link ?");
|
|
||||||
if (agree)
|
|
||||||
return true;
|
|
||||||
else
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
</script>
|
|
||||||
{/if}
|
{/if}
|
||||||
|
·
|
||||||
|
{'The personal, minimalist, super-fast, database free, bookmarking service'|t} {'by the Shaarli community'|t} ·
|
||||||
|
<a href="doc/html/index.html" rel="nofollow">{'Documentation'|t}</a>
|
||||||
|
{loop="$plugins_footer.text"}
|
||||||
|
{$value}
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-2-24"></div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<input type="hidden" name="token" value="{$token}" id="token" />
|
||||||
|
|
||||||
|
{loop="$plugins_footer.endofpage"}
|
||||||
|
{$value}
|
||||||
|
{/loop}
|
||||||
|
|
||||||
|
{loop="$plugins_footer.js_files"}
|
||||||
|
<script src="{$value}#"></script>
|
||||||
|
{/loop}
|
||||||
|
|
||||||
|
<div id="js-translations" class="hidden">
|
||||||
|
<span id="translation-fold">{'Fold'|t}</span>
|
||||||
|
<span id="translation-fold-all">{'Fold all'|t}</span>
|
||||||
|
<span id="translation-expand">{'Expand'|t}</span>
|
||||||
|
<span id="translation-expand-all">{'Expand all'|t}</span>
|
||||||
|
<span id="translation-delete-link">{'Are you sure you want to delete this link?'|t}</span>
|
||||||
|
<span id="translation-shaarli-desc">
|
||||||
|
{'The personal, minimalist, super-fast, database free, bookmarking service'|t} {'by the Shaarli community'|t}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<script src="js/shaarli.js?v={$version_hash}"></script>
|
||||||
|
<script src="inc/awesomplete.js?v={$version_hash}#"></script>
|
||||||
|
<script src="inc/awesomplete-multiple-tags.js?v={$version_hash}#"></script>
|
||||||
|
|
|
@ -1,24 +1,172 @@
|
||||||
<div id="logo" title="Share your links !" onclick="document.location='?';"></div>
|
<div class="shaarli-menu pure-g" id="shaarli-menu">
|
||||||
<div id="linkcount" class="nomobile">
|
<div class="pure-u-lg-0 pure-u-1">
|
||||||
Shaare
|
<div class="pure-menu">
|
||||||
{if="!empty($linkcount)"}{$linkcount}{/if} links
|
<a href="{$titleLink}" class="pure-menu-link">
|
||||||
|
<img src="img/icon.png" width="16" height="16" class="head-logo" alt="logo" />
|
||||||
|
{$shaarlititle}
|
||||||
|
</a>
|
||||||
|
<a href="#" class="menu-toggle" id="menu-toggle"><s class="bar"></s><s class="bar"></s></a>
|
||||||
</div>
|
</div>
|
||||||
<span id="shaarli_title"><a href="{$titleLink}">{$shaarlititle|htmlspecialchars}</a></span>
|
</div>
|
||||||
{if="!empty($_GET['source']) && $_GET['source']=='bookmarklet'"}
|
<div class="pure-u-1">
|
||||||
{ignore} When called as a popup from bookmarklet, do not display menu. {/ignore}
|
<div class="pure-menu menu-transform pure-menu-horizontal pure-g">
|
||||||
{else}
|
<ul class="pure-menu-list pure-u-lg-5-6 pure-u-1">
|
||||||
<a href="?" class="nomobile">Home</a>
|
<li class="pure-menu-item pure-u-0 pure-u-lg-visible">
|
||||||
|
<a href="{$titleLink}" class="pure-menu-link">
|
||||||
|
<img src="img/icon.png" width="16" height="16" class="head-logo" alt="logo" />
|
||||||
|
{$shaarlititle}
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
{if="isLoggedIn() || $openshaarli"}
|
||||||
|
<li class="pure-menu-item">
|
||||||
|
<a href="?do=addlink" class="pure-menu-link">
|
||||||
|
<i class="fa fa-plus" ></i> {'Shaare'|t}
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="pure-menu-item">
|
||||||
|
<a href="?do=tools" class="pure-menu-link">{'Tools'|t}</a>
|
||||||
|
</li>
|
||||||
|
{/if}
|
||||||
|
<li class="pure-menu-item">
|
||||||
|
<a href="?do=tagcloud" class="pure-menu-link">{'Tag cloud'|t}</a>
|
||||||
|
</li>
|
||||||
|
<li class="pure-menu-item">
|
||||||
|
<a href="?do=picwall{$searchcrits}" class="pure-menu-link">{'Picture wall'|t}</a>
|
||||||
|
</li>
|
||||||
|
<li class="pure-menu-item">
|
||||||
|
<a href="?do=daily" class="pure-menu-link">{'Daily'|t}</a>
|
||||||
|
</li>
|
||||||
|
{loop="$plugins_header.buttons_toolbar"}
|
||||||
|
<li class="pure-menu-item">
|
||||||
|
<a
|
||||||
|
{$value.attr.class=isset($value.class) ? $value.attr.class . ' pure-menu-link' : 'pure-menu-link'}
|
||||||
|
{loop="$value.attr"}
|
||||||
|
{$key}="{$value}"
|
||||||
|
{/loop}>
|
||||||
|
{$value.html}
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
{/loop}
|
||||||
|
<li class="pure-menu-item pure-u-lg-0">
|
||||||
|
<a href="?do={$feed_type}{$searchcrits}" class="pure-menu-link">{'RSS Feed'|t}</a>
|
||||||
|
</li>
|
||||||
{if="isLoggedIn()"}
|
{if="isLoggedIn()"}
|
||||||
<a href="?do=logout">Logout</a><a href="?do=tools">Tools</a><a href="?do=addlink"><b>Add link</b></a>
|
<li class="pure-menu-item pure-u-lg-0">
|
||||||
{elseif="$GLOBALS['config']['OPEN_SHAARLI']"}
|
<a href="?do=logout" class="pure-menu-link">{'Logout'|t}</a>
|
||||||
<a href="?do=tools">Tools</a><a href="?do=addlink"><b>Add link</b></a>
|
</li>
|
||||||
{else}
|
{else}
|
||||||
<a href="?do=login">Login</a>
|
<li class="pure-menu-item pure-u-lg-0">
|
||||||
|
<a href="?do=login" class="pure-menu-link">{'Login'|t}</a>
|
||||||
|
</li>
|
||||||
{/if}
|
{/if}
|
||||||
<a href="{$feedurl}?do=rss{$searchcrits}" class="nomobile">RSS Feed</a>
|
</ul>
|
||||||
<a href="{$feedurl}?do=atom{$searchcrits}" style="padding-left:10px;" class="nomobile">ATOM Feed</a>
|
<div class="header-buttons pure-u-lg-1-6 pure-u-0 pure-u-lg-visible">
|
||||||
<a href="?do=tagcloud">Tag cloud</a>
|
<ul class="pure-menu-list">
|
||||||
<a href="?do=picwall{$searchcrits}">Picture wall</a>
|
<li class="pure-menu-item">
|
||||||
<a href="?do=daily">Daily</a>
|
<a href="#" class="pure-menu-link subheader-opener"
|
||||||
|
data-open-id="search"
|
||||||
|
id="search-button" title="{'Search'|t}">
|
||||||
|
<i class="fa fa-search"></i>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
<li class="pure-menu-item">
|
||||||
|
<a href="?do={$feed_type}{$searchcrits}" class="pure-menu-link" title="{'RSS Feed'|t}">
|
||||||
|
<i class="fa fa-rss"></i>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
{if="!isLoggedIn()"}
|
||||||
|
<li class="pure-menu-item">
|
||||||
|
<a href="?do=login" class="pure-menu-link"
|
||||||
|
data-open-id="header-login-form"
|
||||||
|
id="login-button" title="{'Login'|t}">
|
||||||
|
<i class="fa fa-user"></i>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
|
{else}
|
||||||
|
<li class="pure-menu-item">
|
||||||
|
<a href="?do=logout" class="pure-menu-link" title="{'Logout'|t}">
|
||||||
|
<i class="fa fa-sign-out"></i>
|
||||||
|
</a>
|
||||||
|
</li>
|
||||||
{/if}
|
{/if}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="content">
|
||||||
|
<div id="search" class="subheader-form">
|
||||||
|
<form method="GET" class="pure-form searchform" name="searchform">
|
||||||
|
<input type="text" tabindex="1" id="searchform_value" name="searchterm" placeholder="{'Search text'|t}"
|
||||||
|
{if="!empty($search_term)"}
|
||||||
|
value="{$search_term}"
|
||||||
|
{/if}
|
||||||
|
>
|
||||||
|
<input type="text" tabindex="2" name="searchtags" id="tagfilter_value" placeholder="{'Filter by tag'|t}"
|
||||||
|
{if="!empty($search_tags)"}
|
||||||
|
value="{$search_tags}"
|
||||||
|
{/if}
|
||||||
|
autocomplete="off" data-multiple data-autofirst data-minChars="1"
|
||||||
|
data-list="{loop="$tags"}{$key}, {/loop}"
|
||||||
|
>
|
||||||
|
<button type="submit" class="search-button"><i class="fa fa-search"></i></button>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
<div id="actions" class="subheader-form">
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-1">
|
||||||
|
<a href="" id="actions-delete" class="button">Delete</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{if="!isLoggedIn()"}
|
||||||
|
<form method="post" name="loginform">
|
||||||
|
<div class="subheader-form" id="header-login-form">
|
||||||
|
<input type="text" name="login" placeholder="{'Username'|t}" tabindex="3">
|
||||||
|
<input type="password" name="password" placeholder="{'Password'|t}" tabindex="5">
|
||||||
|
<div class="remember-me">
|
||||||
|
<input type="checkbox" name="longlastingsession" id="longlastingsession" tabindex="6" checked>
|
||||||
|
<label for="longlastingsession">{'Remember me'|t}</label>
|
||||||
|
</div>
|
||||||
|
<input type="hidden" name="token" value="{$token}">
|
||||||
|
<input type="hidden" name="returnurl">
|
||||||
|
<input type="submit" value="Login" tabindex="7">
|
||||||
|
</div>
|
||||||
|
</form>
|
||||||
|
{/if}
|
||||||
|
{if="!empty($newVersion) || !empty($versionError)"}
|
||||||
|
<div class="pure-g new-version-message pure-alert pure-alert-warning pure-alert-closable">
|
||||||
|
<div class="pure-u-2-24"></div>
|
||||||
|
{if="$newVersion"}
|
||||||
|
<div class="pure-u-20-24">
|
||||||
|
Shaarli {$newVersion}
|
||||||
|
<a href="https://github.com/shaarli/Shaarli/releases">{'is available'|t}</a>.
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
{if="$versionError"}
|
||||||
|
<div class="pure-u-20-24">
|
||||||
|
{'Error'|t}: {$versionError}
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
<div class="pure-u-2-24">
|
||||||
|
<i id="new-version-dismiss" class="fa fa-times pure-alert-close"></i>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
{if="!empty($plugin_errors) && isLoggedIn()"}
|
||||||
|
<div class="pure-g new-version-message pure-alert pure-alert-error pure-alert-closable">
|
||||||
|
<div class="pure-u-2-24"></div>
|
||||||
|
<div class="pure-u-20-24">
|
||||||
|
{loop="plugin_errors"}
|
||||||
|
<p>{$value}</p>
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
|
<div class="pure-u-2-24">
|
||||||
|
<i class="fa fa-times pure-alert-close"></i>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
|
||||||
<div class="clear"></div>
|
<div class="clear"></div>
|
|
@ -1,13 +0,0 @@
|
||||||
<!DOCTYPE html>
|
|
||||||
<html>
|
|
||||||
<head>
|
|
||||||
{include="includes"}
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
|
||||||
</div>
|
|
||||||
You body goes here...
|
|
||||||
{include="page.footer"}
|
|
||||||
</body>
|
|
||||||
</html>
|
|
|
@ -2,30 +2,44 @@
|
||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
{include="includes"}
|
{include="includes"}
|
||||||
{if="empty($GLOBALS['disablejquery'])"}
|
|
||||||
<script src="inc/jquery.min.js#"></script>
|
|
||||||
<script src="inc/jquery-ui.min.js#"></script>
|
|
||||||
<script src="inc/jquery.lazyload.min.js#"></script>
|
|
||||||
{/if}
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
{include="page.header"}
|
||||||
</div>
|
|
||||||
<div class="picwall_container">
|
<div class="pure-g">
|
||||||
{loop="linksToDisplay"}
|
<div class="pure-u-lg-1-6 pure-u-1-24"></div>
|
||||||
<div class="picwall_pictureframe">
|
<div class="pure-u-lg-2-3 pure-u-22-24 page-form page-visitor">
|
||||||
{$value.thumbnail}<a href="{$value.permalink}"><span class="info">{$value.title|htmlspecialchars}</span></a>
|
{$countPics=count($linksToDisplay)}
|
||||||
</div>
|
<h2 class="window-title">{'Picture Wall'|t} - {$countPics} {'pics'|t}</h2>
|
||||||
|
|
||||||
|
<div id="plugin_zone_start_picwall" class="plugin_zone">
|
||||||
|
{loop="$plugin_start_zone"}
|
||||||
|
{$value}
|
||||||
{/loop}
|
{/loop}
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div id="picwall_container">
|
||||||
|
{loop="$linksToDisplay"}
|
||||||
|
<div class="picwall_pictureframe">
|
||||||
|
{$value.thumbnail}<a href="{$value.real_url}"><span class="info">{$value.title}</span></a>
|
||||||
|
{loop="$value.picwall_plugin"}
|
||||||
|
{$value}
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
|
{/loop}
|
||||||
|
<div class="clear"></div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="plugin_zone_end_picwall" class="plugin_zone">
|
||||||
|
{loop="$plugin_end_zone"}
|
||||||
|
{$value}
|
||||||
|
{/loop}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
{include="page.footer"}
|
{include="page.footer"}
|
||||||
{if="empty($GLOBALS['disablejquery'])"}
|
<script src="inc/blazy-1.3.1.min.js#"></script>
|
||||||
<script>
|
|
||||||
$(document).ready(function() {
|
|
||||||
$(".b-lazy").show().lazyload();
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
{/if}
|
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
||||||
|
|
|
@ -1,19 +0,0 @@
|
||||||
<!DOCTYPE html>
|
|
||||||
<html>
|
|
||||||
<head>{include="includes"}</head>
|
|
||||||
<body>
|
|
||||||
<div id="pageheader">{include="page.header"}</div>
|
|
||||||
<div style="background-color:#003;">
|
|
||||||
{loop="linksToDisplay"}
|
|
||||||
<div style="float:left;width:48%;border-right:2px solid white;height:120px;overflow:hide;">
|
|
||||||
<div style="float:left;width:120px;text-align:center">{$value.thumbnail}</div>
|
|
||||||
<a href="{$value.permalink}" style="color:yellow;font-weight:bold;text-decoration:none;">{$value.title|htmlspecialchars}</a><br>
|
|
||||||
<span style="font-size:8pt;color:#eee;">{$value.description|htmlspecialchars}</span>
|
|
||||||
<div style="clear:both;"></div>
|
|
||||||
</div><br>
|
|
||||||
{/loop}
|
|
||||||
</div>
|
|
||||||
|
|
||||||
{include="page.footer"}
|
|
||||||
</body>
|
|
||||||
</html>
|
|
|
@ -1,42 +0,0 @@
|
||||||
===== Shaarli template organisation =====
|
|
||||||
|
|
||||||
Any Shaarli page should conform to this RainTPL template:
|
|
||||||
|
|
||||||
-----------------------------------------------------
|
|
||||||
<html>
|
|
||||||
<head>{include="includes"}</head>
|
|
||||||
<body>
|
|
||||||
<div id="pageheader">{include="page.header"}</div>
|
|
||||||
You body goes here...
|
|
||||||
{include="page.footer"}
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
-----------------------------------------------------
|
|
||||||
|
|
||||||
If you want to also add something in the page header (in the dark area), do it here:
|
|
||||||
|
|
||||||
<div id="pageheader">{include="page.header"}My menu goes here...</div>
|
|
||||||
|
|
||||||
|
|
||||||
Example: "Add new link" form:
|
|
||||||
-----------------------------------------------------
|
|
||||||
<html>
|
|
||||||
<head>{include="includes"}</head>
|
|
||||||
<body onload="document.addform.post.focus();">
|
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
|
||||||
<div id="headerform">
|
|
||||||
<form method="GET" action="" name="addform" class="addform">
|
|
||||||
<input type="text" name="post" style="width:50%;">
|
|
||||||
<input type="submit" value="Add link" class="bigbutton">
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
{include="page.footer"}
|
|
||||||
</body>
|
|
||||||
</html>
|
|
||||||
-----------------------------------------------------
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,17 +0,0 @@
|
||||||
<!DOCTYPE html>
|
|
||||||
<html>
|
|
||||||
<head>
|
|
||||||
{include="includes"}
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
|
||||||
</div>
|
|
||||||
<div id="cloudtag">
|
|
||||||
{loop="tags"}
|
|
||||||
<span>{$value.count}</span><a href="?searchtags={$key|htmlspecialchars}" style="font-size:{$value.size}em;">{$key|htmlspecialchars}</a>
|
|
||||||
{/loop}
|
|
||||||
</div>
|
|
||||||
{include="page.footer"}
|
|
||||||
</body>
|
|
||||||
</html>
|
|
|
@ -4,68 +4,163 @@
|
||||||
{include="includes"}
|
{include="includes"}
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<div id="pageheader">
|
|
||||||
{include="page.header"}
|
{include="page.header"}
|
||||||
<div id="toolsdiv">
|
|
||||||
<ul>
|
<div class="pure-g">
|
||||||
<li>
|
<div class="pure-u-lg-1-3 pure-u-1-24"></div>
|
||||||
<a href="{$GLOBALS['config']['UPDATECHECK_DOWNLOAD']}">Version : <span>myshaarli {#myShaarli_version#}</span></a>
|
<div class="pure-u-lg-1-3 pure-u-22-24 page-form page-form-light">
|
||||||
</li>
|
<h2 class="window-title">{'Settings'|t}</h2>
|
||||||
{if="!$GLOBALS['config']['OPEN_SHAARLI']"}
|
<div class="tools-item">
|
||||||
<li>
|
<a href="?do=configure" title="{'Change Shaarli settings: title, timezone, etc.'|t}">
|
||||||
<a href="?do=changepasswd">Change password : <span>Change your password.</span></a>
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">{'Configure your Shaarli'|t}</span>
|
||||||
</li>
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="tools-item">
|
||||||
|
<a href="?do=pluginadmin" title="{'Enable, disable and configure plugins'|t}">
|
||||||
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">{'Plugin administration'|t}</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
{if="!$openshaarli"}
|
||||||
|
<div class="tools-item">
|
||||||
|
<a href="?do=changepasswd" title="{'Change your password'|t}">
|
||||||
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">{'Change password'|t}</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
{/if}
|
{/if}
|
||||||
<li>
|
<div class="tools-item">
|
||||||
<a href="?do=configure">Configure your Shaarli : <span>Change Title, timezone...</span></a>
|
<a href="?do=changetag" title="{'Rename or delete a tag in all links'|t}">
|
||||||
</li>
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">{'Manage tags'|t}</span>
|
||||||
<li>
|
</a>
|
||||||
<a href="?do=changetag">Rename/delete tags : <span>Rename or delete a tag in all links</span></a>
|
</div>
|
||||||
</li>
|
<div class="tools-item">
|
||||||
<li>
|
<a href="?do=import"
|
||||||
<a href="?do=import">Import : <span>Import Netscape html bookmarks (as exported from Firefox, Chrome, Opera, delicious...)</span></a>
|
title="{'Import Netscape HTML bookmarks (as exported from Firefox, Chrome, Opera, delicious...)'|t}">
|
||||||
</li>
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">{'Import links'|t}</span>
|
||||||
<li>
|
</a>
|
||||||
<a href="?do=export">Export : <span>Export Netscape html bookmarks (which can be imported in Firefox, Chrome, Opera, delicious...)</span></a>
|
</div>
|
||||||
</li>
|
<div class="tools-item">
|
||||||
<li>
|
<a href="?do=export"
|
||||||
<a class="smallbutton" onclick="alert('Drag this link to your bookmarks toolbar, or right-click it and choose Bookmark This Link...');return false;" href="javascript:javascript:(function(){var%20url%20=%20location.href;var%20title%20=%20document.title%20||%20url;window.open('{$pageabsaddr}?post='%20+%20encodeURIComponent(url)+'&title='%20+%20encodeURIComponent(title)+'&description='%20+%20encodeURIComponent(document.getSelection())+'&source=bookmarklet','_blank','menubar=no,height=450,width=600,toolbar=no,scrollbars=no,status=no,dialog=1');})();">✚Shaare link</a><a href="#" style="clear:none;"><span>⇐ Drag this link to your bookmarks toolbar (or right-click it and choose Bookmark This Link....).
|
title="{'Export Netscape HTML bookmarks (which can be imported in Firefox, Chrome, Opera, delicious...)'|t}">
|
||||||
<br>
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">{'Export database'|t}</span>
|
||||||
Then click "✚Shaare link" button in any page you want to share.</span></a>
|
</a>
|
||||||
</li>
|
</div>
|
||||||
<li>
|
|
||||||
<a class="smallbutton" onclick="alert('Drag this link to your bookmarks toolbar, or right-click it and choose Bookmark This Link...');return false;" href="?private=1&post=">✚Add Note</a><a href="#" style="clear:none;"><span>⇐ Drag this link to your bookmarks toolbar (or right-click it and choose Bookmark This Link....).
|
{loop="$tools_plugin"}
|
||||||
<br>
|
<div class="tools-item">
|
||||||
Then click "✚Add Note" button anytime to start composing a (default private) Note (text post) to your Shaarli.</span></a>
|
{$value}
|
||||||
</li>
|
</div>
|
||||||
<li>
|
{/loop}
|
||||||
<a class="smallbutton" onclick="activateFirefoxSocial(this)">✚Add to Firefox social</a><a href="#" style="clear:none;"><span>⇐ Click on this button to add Shaarli to the "Share this page" button in Firefox.</span></a>
|
</div>
|
||||||
</li>
|
|
||||||
</ul>
|
|
||||||
<div class="clear"></div>
|
<div class="clear"></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
|
||||||
{include="page.footer"}
|
<div class="pure-g">
|
||||||
<script>
|
<div class="pure-u-lg-1-3 pure-u-1-24"></div>
|
||||||
function activateFirefoxSocial(node) {
|
<div class="pure-u-lg-1-3 pure-u-22-24 page-form page-form-light">
|
||||||
var loc = location.href;
|
<h2 class="window-title">Bookmarklets</h2>
|
||||||
var baseURL = loc.substring(0, loc.lastIndexOf("/"));
|
<p>
|
||||||
// Keeping the data separated (ie. not in the DOM) so that it's maintainable and diffable.
|
{'Drag one of these button to your bookmarks toolbar or right-click it and "Bookmark This Link"'|t},
|
||||||
var data = {
|
{'then click on the bookmarklet in any page you want to share.'|t}
|
||||||
name : "{$shaarlititle}",
|
</p>
|
||||||
description : "The personal, minimalist, super-fast, no-database delicious clone.",
|
<div class="tools-item">
|
||||||
author : "Shaarli",
|
<a title="{'Drag this link to your bookmarks toolbar or right-click it and Bookmark This Link'|t},
|
||||||
version : "1.0.0",
|
{'then click ✚Shaare link button in any page you want to share'|t}"
|
||||||
iconURL : baseURL + "/images/favicon.ico",
|
class="bookmarklet-link"
|
||||||
icon32URL : baseURL + "/images/favicon.ico",
|
href="javascript:(
|
||||||
icon64URL : baseURL + "/images/favicon.ico",
|
function(){
|
||||||
shareURL : baseURL + "{noparse}?post=%{url}&title=%{title}&description=%{description}&source=firefoxsocialapi{/noparse}",
|
var%20url%20=%20location.href;
|
||||||
homepageURL : baseURL
|
var%20title%20=%20document.title%20||%20url;
|
||||||
};
|
var%20desc=document.getSelection().toString();
|
||||||
node.setAttribute("data-service", JSON.stringify(data));
|
if(desc.length>4000){
|
||||||
var activate = new CustomEvent("ActivateSocialFeature");
|
desc=desc.substr(0,4000)+'...';
|
||||||
node.dispatchEvent(activate);
|
alert('{function="str_replace(' ', '%20', t('The selected text is too long, it will be truncated.'))"}');
|
||||||
}
|
}
|
||||||
</script>
|
window.open(
|
||||||
|
'{$pageabsaddr}?post='%20+%20encodeURIComponent(url)+
|
||||||
|
'&title='%20+%20encodeURIComponent(title)+
|
||||||
|
'&description='%20+%20encodeURIComponent(desc)+
|
||||||
|
'&source=bookmarklet','_blank','menubar=no,height=800,width=600,toolbar=no,scrollbars=yes,status=no,dialog=1'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
)();">
|
||||||
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">✚ {'Shaare link'|t}</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="tools-item">
|
||||||
|
<a title="{'Drag this link to your bookmarks toolbar or right-click it and Bookmark This Link'|t},
|
||||||
|
{'Then click ✚Add Note button anytime to start composing a private Note (text post) to your Shaarli'|t}"
|
||||||
|
class="bookmarklet-link"
|
||||||
|
href="javascript:(
|
||||||
|
function(){
|
||||||
|
var%20desc=document.getSelection().toString();
|
||||||
|
if(desc.length>4000){
|
||||||
|
desc=desc.substr(0,4000)+'...';
|
||||||
|
alert('{function="str_replace(' ', '%20', t('The selected text is too long, it will be truncated.'))"}');
|
||||||
|
}
|
||||||
|
window.open(
|
||||||
|
'{$pageabsaddr}?private=1&post='+
|
||||||
|
'&description='%20+%20encodeURIComponent(desc)+
|
||||||
|
'&source=bookmarklet','_blank','menubar=no,height=800,width=600,toolbar=no,scrollbars=yes,status=no,dialog=1'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
)();">
|
||||||
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">✚ {'Add Note'|t}</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{if="$sslenabled"}
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-1-3 pure-u-1-24"></div>
|
||||||
|
<div class="pure-u-lg-1-3 pure-u-22-24 page-form page-form-light">
|
||||||
|
<h2 class="window-title">Firefox Social API</h2>
|
||||||
|
<p>{'You need to browse your Shaarli over <strong>HTTPS</strong> to use this functionality.'|t}</p>
|
||||||
|
|
||||||
|
<div class="tools-item">
|
||||||
|
<a title="{'Click on this button to add Shaarli to the 'Share this page' button in Firefox"
|
||||||
|
id="ff-social-button">
|
||||||
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">✚ {'Add to'|t} Firefox Social</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{/if}
|
||||||
|
|
||||||
|
<div class="pure-g">
|
||||||
|
<div class="pure-u-lg-1-3 pure-u-1-24"></div>
|
||||||
|
<div class="pure-u-lg-1-3 pure-u-22-24 page-form page-form-light">
|
||||||
|
<h2 class="window-title">{'3rd party'|t}</h2>
|
||||||
|
<div class="tools-item">
|
||||||
|
<a href="https://addons.mozilla.org/fr/firefox/addon/shaarli/" title="Firefox {'Plugin'|t}">
|
||||||
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">Firefox {'plugin'|t}</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="tools-item">
|
||||||
|
<a href="https://chrome.google.com/webstore/detail/shiny-shaarli/hajdfkmbdmadjmmpkkbbcnllepomekin"
|
||||||
|
title="Chrome {'Plugin'|t}">
|
||||||
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">Chrome {'plugin'|t}</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="tools-item">
|
||||||
|
<a href="https://play.google.com/store/apps/details?id=com.dimtion.shaarlier&hl=fr"
|
||||||
|
title="Android">
|
||||||
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">Android</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<div class="tools-item">
|
||||||
|
<a href="https://itunes.apple.com/app/ShaarliOS/id1027441388?mt=8"
|
||||||
|
title="iOS">
|
||||||
|
<span class="pure-button pure-u-lg-2-3 pure-u-3-4">iOS</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
{include="page.footer"}
|
||||||
|
<input type="hidden" id="bookmarklet-alert"
|
||||||
|
value="{'Drag this link to your bookmarks toolbar, or right-click it and choose Bookmark This Link'|t}">
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
Loading…
Reference in a new issue