diff --git a/CHANGELOG b/CHANGELOG index 6385d22bb..2f675fb6d 100644 --- a/CHANGELOG +++ b/CHANGELOG @@ -1,3 +1,134 @@ +Version 2018.09 (2018-09-23) + Friendica Core: + Update to the translation (CS, DE, EN-US, FI, IT, NL, PL, ZH-CN) [translation teams] + Update to the documentation [Aditoo17, annando, astifter, rebeka-catalina, fabrixxm, M-arcus, microgroove, nupplaphil, tobiasd] + Enhancements to the database structure, handling and documentation [abanink, Angristan, annando, miqrogroove, tobiasd] + Enhancements of unit testing [abanink, nupplaphil, rudloff] + Enhancements to labelling of UI elements [andyhee, tobiasd] + Enhancements to the background workers [annando, miqrogroove, rabuzarus] + Enhancements to the PHP7.2 compatibility [annando, miqrogroove, MrPetovan] + Enhancements to the content filter [MrPetovan] + Enhancements to the hooks provided for addons [abanink] + Enhancements to the interaction with public postings [annando] + Enhancements to the config storage [frabrixxm] + Enhancements to the themes (frio, quattro, smoothly, vier) [annando, astifter, hoergen, MrPetovan, rabuzarus, tobiasd] + Enhancements to the handling of locks [nupplaphil] + Enhancements to the redis integration [nupplaphil] + Enhancements to the admin panel [JeroenED, tobiasd] + Enhancements to the user import process [annando] + Enhancements to the display of invitation information [JeroenED] + Enhancements to the automatic installation process [nupplaphil] + Enhancements to the contact group UI [annando, astifter] + Enhancements to the call of JS [hypolite] + Enhancements to the storage of items in the database [annando] + Enhancements to the process of changing relationships [annando] + Enhancements to the OEmbed of data [MrPetovan] + Fixed various PHP notice occurrences [annando, MrPetovan] + Fixed a bug that could lead to the display of posts from deleted accounts on the community page for a short period [annando] + Fixed a bug that prevented email notification to be send out [annando] + Fixed a bug in database optimisation [annando] + Fixed a bug during removing contacts [annando] + Fixed a bug in the tag-cloud widget [annando] + Fixed a bug in the daemon mode of the background worker [annando] + Fixed a bug in the frio theme that contact filtering [rabuzarus] + Fixed a bug that mangled the display of some additional smileys [abanink] + Fixed a bug in generating registration mails [MrPetovan] + Fixed a bug that caused blank re-share bodies [MrPetovon] + Fixed a bug in the API handling of private mails [fabrixxm] + Fixed a bug when calling the mail() function [miqrogroove] + Fixed a bug that caused deleted accounts being displayed in the local directory [miqrogroove] + Fixed a bug when checking the domain of an email address [VVelox] + Fixed a bug that prevented re-shares from Twitter to be shown as this [annando] + Fixed a bug that caused broken profile links [miqrogroove] + Fixed a bug that caused content from unknown accounts appearing in the timeline [annando] + Fixed a bug with the ignoring and blocking of contacts [annando] + Fixed a bug with showing hidden contacts in some places [annando] + Fixed a bug that prevented the deletion of events by contacts [annando] + Fixed a bug that prevented email contacts from being added [annando] + Fixed a bug in the notification/seen API call [fabrixxm] + Fixed a bug that prevented a refresh after un-/ignoring a conversation [annando] + Fixed a bug in the handling of some language translations [anndno] + Fixed a bug in the hook handling [annando] + Fixed the handling of too long tags [annando] + Fixed a bug that prevented the unliking of dis-/likes [annando] + Fixed bugs with the handling of private nodes [annando] + Fixed a bug in the session initialisation [annando] + Fixed bugs in the execution of the background processes [annando, Quix0r] + Fixed a problem with the notification page [MrPetovan] + Fixed a bug with wrong dates in importing some Atom feeds [annando] + Fixed forum exclusive distribution of postings using the !notation [annando] + Fixed a bug that lead to empty notifications [MrPetovan] + Fixed a problem that could sometimes prevent the execution of the relocation [annando] + Fixed a bug with the handling of images in postings over the connectors [annando] + Added conversation cleanup configuration [miqrogroove] + Added support of the usage of internal diaspora links to accounts [annando] + Added the possibility for admins to block certain nicknames (e.g. role names) [tobiasd] + Added the generation of system guid [nupplaphil] + Added the possibility for admins to mark a node for explicit content [tobiasd] + Added filter by account type to the community page [annando] + Added private flag to API results [fabrixxm] + Added post update checks to the console utility [annando] + Added codecov analysis [nupplaphil] + Added access-keys to the frio theme [tobiasd] + Added the profile settings to the user settings [tobiasd] + General code refactoring and beautification work [annando, MrPetovan, Quix0r, tobiasd] + Fixation of the position on the network page when new posts arrive [rabuzarus] + Ported OpenWebAuth from Hubzilla [annando, rabuzarus] + Removed hard coded syntax highlighting from code blocks [MrPetovan] + Removed (temporarily) the possibility to add pictures to private messages [annando] + New INI style config file format in /config [MrPetovan, tobiasd] + The .htaccess file is not part of the git repository anymore [annando, Quix0r] + + Friendica Addons: + Update to the translations (CS, DE, EN-US, NL, PL, ZH-CN) [translation teams] + General update to adopt changes in core [annando, MrPetovan, Quix0r, tobiasd] + advancedcontentfilter: + Enhancement to the error handling [MrPetovan] + Honour the CSP settings [MrPetovan] + Fixed translation problems [annando] + blockem: + Enhancement of the settings [AlfredSK] + buffer: + support for app.net removed [annando] + js_upload: + Enhancement of the album name handling [rabuzarus] + Enhancement to the wording of the labels [astifter] + langfilter: + Fixed a problem with default values of the filtered languages [tobiasd] + libravatar: + The service wont shutdown, so we can keep the addon [tobiasd] + pumpio: + Fixed a problem that prevented new connections [annando] + superblock: + Fixed a bug that prevented the addon to block accounts [annando] + Enhancements of the settings [AlfredSK] + twitter: + Use rich text for quote tweets [MrPetovan] + Prevent empty quotes from being created [annando] + Fixed a problem with re-shares from remote_self contacts [annando] + Changed URL display after link expansion [MrPetovan] + Fixed a problem with EXIF handling [MrPetovan] + added addons: + mastodoncustomemojis [MrPetovan] + deprecated addons: + notimeline, retriver, remote_permissions, widgets + + Directory: + Enhancements of the health summary [andyhee] + Enhancements of the PHP7 compatibility [MrPetovan] + + Closed Issues: + 901, 1034, 1074, 1303, 1308, 1391, 1490, 1470, 1559, 2093, 2337, + 2340, 2381, 2396, 2675, 3291, 3299, 3493, 3501, 3535, 3643, 3840, + 4148, 4419, 4475, 4507, 4655, 4659, 4710, 4726, 4739, 4753, 4814, + 4830, 4868, 4889, 4923, 4971, 4950, 4985, 5066, 5099, 5137, 5148, + 5158, 5168, 5188, 5202, 5211, 5222, 5233, 5243, 5247, 5252, 5257, + 5260, 5262, 5268, 5274, 5275, 5276, 5278, 5298, 5318, 5319, 5320, + 5321, 5322, 5330, 5333, 5341, 5365, 5405, 5407, 5411, 5423, 5432, + 5434, 5436, 5443, 5455, 5464, 5467, 5469, 5486, 5496, 5497, 5514, + 5539, 5524, 5541, 5544, 5550, 5564, 5566, 5605, 5630, 5638, 5651, + 5653, 5660, 5670, 5691, 5733, 5745, 5768 + Version 2018.05 (2018-06-01) Friendica Core: Update to the translations (DE, EN-GB, EN-US, FI, IS, IT, NL, PL, RU, ZN CH) [translation teams] diff --git a/VERSION b/VERSION index 40284ee69..8033ba208 100644 --- a/VERSION +++ b/VERSION @@ -1 +1 @@ -2018.08-rc +2018.12-dev diff --git a/boot.php b/boot.php index 2236a4d5d..581bbb181 100644 --- a/boot.php +++ b/boot.php @@ -39,7 +39,7 @@ require_once 'include/text.php'; define('FRIENDICA_PLATFORM', 'Friendica'); define('FRIENDICA_CODENAME', 'The Tazmans Flax-lily'); -define('FRIENDICA_VERSION', '2018.08-rc'); +define('FRIENDICA_VERSION', '2018.12-dev'); define('DFRN_PROTOCOL_VERSION', '2.23'); define('DB_UPDATE_VERSION', 1283); define('NEW_UPDATE_ROUTINE_VERSION', 1170); diff --git a/database.sql b/database.sql index 60d4b1c88..718855804 100644 --- a/database.sql +++ b/database.sql @@ -1,5 +1,5 @@ -- ------------------------------------------ --- Friendica 2018.08-dev (The Tazmans Flax-lily) +-- Friendica 2018.12-dev (The Tazmans Flax-lily) -- DB_UPDATE_VERSION 1283 -- ------------------------------------------ diff --git a/doc/de/FAQ.md b/doc/de/FAQ.md index 6baa5c5f5..fe8a9d128 100644 --- a/doc/de/FAQ.md +++ b/doc/de/FAQ.md @@ -180,7 +180,7 @@ Hier ist eine Liste von Clients bei denen dies möglich ist, bzw. die speziell f ### Wo finde ich Hilfe? -Wenn Du Probleme mit Deiner Friendica-Seite hast, dann kannst Du die Community in der [Friendica-Support-Gruppe](https://forum.friendi.ca/profile/helpers) oder im [deutschen Friendica-Support-Forum](http://toktan.org/profile/wiki) fragen oder Dir das [deutsche Wiki](http://wiki.toktan.org/doku.php) anschauen. +Wenn Du Probleme mit Deiner Friendica-Seite hast, dann kannst Du die Community in der [Friendica-Support-Gruppe](https://forum.friendi.ca/profile/helpers) fragen oder Dir das [deutsche Wiki](https://friendica-wiki.de/) anschauen. Wenn Du Deinen Account nicht nutzen kannst, kannst Du entweder einen [Testaccount](https://tryfriendica.de) bzw. einen Account auf einer öffentlichen Seite ([Liste](https://dir.friendica.social/servers)) nutzen. Wenn du dir keinen weiteren Friendica Account einrichten willst, kannst du auch gerne über einen der folgenden alternativen Kanäle Hilfe suchen: diff --git a/doc/de/Home.md b/doc/de/Home.md index b6a07cc09..6c95476ed 100644 --- a/doc/de/Home.md +++ b/doc/de/Home.md @@ -61,7 +61,7 @@ Friendica - Dokumentation und Ressourcen **Externe Ressourcen** * [Haupt-Webseite](https://friendi.ca) -* [Deutsches Friendica-Wiki](http://wiki.toktan.org/doku.php) +* [Deutsches Friendica-Wiki](https://friendica-wiki.de) * Support Kanäle * [Friendica Support Forum](https://forum.friendi.ca/~helpers) * [Mailing Listen Archiv](http://mailman.friendi.ca/mailman/listinfo/support-friendi.ca) zum Abonnieren der Liste eine E-Mail an ``support-request(at)friendi.ca?subject=subscribe`` senden diff --git a/mod/editpost.php b/mod/editpost.php index 258585ef1..9f4aee31d 100644 --- a/mod/editpost.php +++ b/mod/editpost.php @@ -21,12 +21,18 @@ function editpost_content(App $a) } $post_id = (($a->argc > 1) ? intval($a->argv[1]) : 0); + $return_url = (($a->argc > 2) ? base64_decode($a->argv[2]) : ''); if (!$post_id) { notice(L10n::t('Item not found') . EOL); return; } + // Fallback to SESSION return_path + if (empty($return_url)) { + $return_url = $_SESSION['return_url']; + } + $fields = ['allow_cid', 'allow_gid', 'deny_cid', 'deny_gid', 'type', 'body', 'title', 'file', 'wall', 'post-type']; @@ -95,7 +101,7 @@ function editpost_content(App $a) $o .= replace_macros($tpl, [ '$is_edit' => true, - '$return_path' => $_SESSION['return_url'], + '$return_path' => $return_url, '$action' => 'item', '$share' => L10n::t('Save'), '$upload' => L10n::t('Upload photo'), diff --git a/mod/message.php b/mod/message.php index 223976ddb..d0a583967 100644 --- a/mod/message.php +++ b/mod/message.php @@ -92,7 +92,7 @@ function message_post(App $a) $a->argc = 2; $a->argv[1] = 'new'; } else { - goaway($_SESSION['return_url']); + goaway($a->cmd . '/' . $ret); } } diff --git a/src/Core/Cache/ArrayCache.php b/src/Core/Cache/ArrayCache.php index b19828714..d1302c1d6 100644 --- a/src/Core/Cache/ArrayCache.php +++ b/src/Core/Cache/ArrayCache.php @@ -53,6 +53,11 @@ class ArrayCache extends AbstractCacheDriver implements IMemoryCacheDriver */ public function clear($outdated = true) { + // Array doesn't support TTL so just don't delete something + if ($outdated) { + return true; + } + $this->cachedData = []; return true; } diff --git a/src/Core/Worker.php b/src/Core/Worker.php index 9dd973728..3400f00ae 100644 --- a/src/Core/Worker.php +++ b/src/Core/Worker.php @@ -117,12 +117,14 @@ class Worker // Count active workers and compare them with a maximum value that depends on the load if (self::tooMuchWorkers()) { logger('Active worker limit reached, quitting.', LOGGER_DEBUG); + Lock::release('worker'); return; } // Check free memory if ($a->min_memory_reached()) { logger('Memory limit reached, quitting.', LOGGER_DEBUG); + Lock::release('worker'); return; } Lock::release('worker'); diff --git a/src/Model/Item.php b/src/Model/Item.php index 2926e460a..e33cf020d 100644 --- a/src/Model/Item.php +++ b/src/Model/Item.php @@ -1936,6 +1936,7 @@ class Item extends BaseObject } else { // This shouldn't happen. logger('Could not insert activity for URI ' . $item['uri'] . ' - should not happen'); + Lock::release('item_insert_activity'); return false; } if ($locked) { diff --git a/src/Object/Post.php b/src/Object/Post.php index 39d9743b2..efd7d4dc8 100644 --- a/src/Object/Post.php +++ b/src/Object/Post.php @@ -157,7 +157,7 @@ class Post extends BaseObject if ($item["event-id"] != 0) { $edpost = ["events/event/" . $item['event-id'], L10n::t("Edit")]; } else { - $edpost = ["editpost/" . $item['id'], L10n::t("Edit")]; + $edpost = ["editpost/" . $item['id'] . "/" . base64_encode($a->cmd), L10n::t("Edit")]; } $dropping = in_array($item['uid'], [0, local_user()]); } else { diff --git a/tests/src/Core/Cache/CacheTest.php b/tests/src/Core/Cache/CacheTest.php index 105142f0b..5c56c2072 100644 --- a/tests/src/Core/Cache/CacheTest.php +++ b/tests/src/Core/Cache/CacheTest.php @@ -81,19 +81,33 @@ abstract class CacheTest extends DatabaseTest '3_value1' => $this->instance->get('3_value1'), ]); - $this->assertTrue($this->instance->clear(false)); + $this->assertTrue($this->instance->clear()); $this->assertEquals([ - '1_value1' => null, - '1_value2' => null, - '2_value1' => null, - '3_value1' => null, + '1_value1' => 'ipsum lorum1', + '1_value2' => 'ipsum lorum2', + '2_value1' => 'ipsum lorum3', + '3_value1' => 'ipsum lorum4', ], [ '1_value1' => $this->instance->get('1_value1'), '1_value2' => $this->instance->get('1_value2'), '2_value1' => $this->instance->get('2_value1'), '3_value1' => $this->instance->get('3_value1'), ]); + + $this->assertTrue($this->instance->clear(false)); + + $this->assertEquals([ + '1_value1' => null, + '1_value2' => null, + '2_value3' => null, + '3_value4' => null, + ], [ + '1_value1' => $this->instance->get('1_value1'), + '1_value2' => $this->instance->get('1_value2'), + '2_value3' => $this->instance->get('2_value3'), + '3_value4' => $this->instance->get('3_value4'), + ]); } /** diff --git a/tests/src/Core/Lock/ArrayCacheLockDriverTest.php b/tests/src/Core/Lock/ArrayCacheLockDriverTest.php index dc044f5c5..671341718 100644 --- a/tests/src/Core/Lock/ArrayCacheLockDriverTest.php +++ b/tests/src/Core/Lock/ArrayCacheLockDriverTest.php @@ -8,21 +8,9 @@ use Friendica\Core\Lock\CacheLockDriver; class ArrayCacheLockDriverTest extends LockTest { - /** - * @var \Friendica\Core\Cache\IMemoryCacheDriver - */ - private $cache; - protected function getInstance() { - $this->cache = new ArrayCache(); - return new CacheLockDriver($this->cache); - } - - public function tearDown() - { - $this->cache->clear(); - parent::tearDown(); + return new CacheLockDriver(new ArrayCache()); } public function testLockTTL() diff --git a/tests/src/Core/Lock/LockTest.php b/tests/src/Core/Lock/LockTest.php index 9698f0bde..a7bbea265 100644 --- a/tests/src/Core/Lock/LockTest.php +++ b/tests/src/Core/Lock/LockTest.php @@ -19,6 +19,7 @@ abstract class LockTest extends DatabaseTest { parent::setUp(); $this->instance = $this->getInstance(); + $this->instance->releaseAll(); // Reusable App object $this->app = BaseObject::getApp(); @@ -31,11 +32,18 @@ abstract class LockTest extends DatabaseTest Config::set('system', 'theme', 'system_theme'); } + protected function tearDown() + { + parent::tearDown(); + $this->instance->releaseAll(); + } + /** * @small */ public function testLock() { - $this->instance->acquireLock('foo', 1); + $this->assertFalse($this->instance->isLocked('foo')); + $this->assertTrue($this->instance->acquireLock('foo', 1)); $this->assertTrue($this->instance->isLocked('foo')); $this->assertFalse($this->instance->isLocked('bar')); } @@ -44,7 +52,8 @@ abstract class LockTest extends DatabaseTest * @small */ public function testDoubleLock() { - $this->instance->acquireLock('foo', 1); + $this->assertFalse($this->instance->isLocked('foo')); + $this->assertTrue($this->instance->acquireLock('foo', 1)); $this->assertTrue($this->instance->isLocked('foo')); // We already locked it $this->assertTrue($this->instance->acquireLock('foo', 1)); @@ -54,7 +63,8 @@ abstract class LockTest extends DatabaseTest * @small */ public function testReleaseLock() { - $this->instance->acquireLock('foo', 1); + $this->assertFalse($this->instance->isLocked('foo')); + $this->assertTrue($this->instance->acquireLock('foo', 1)); $this->assertTrue($this->instance->isLocked('foo')); $this->instance->releaseLock('foo'); $this->assertFalse($this->instance->isLocked('foo')); @@ -64,9 +74,9 @@ abstract class LockTest extends DatabaseTest * @small */ public function testReleaseAll() { - $this->instance->acquireLock('foo', 1); - $this->instance->acquireLock('bar', 1); - $this->instance->acquireLock('nice', 1); + $this->assertTrue($this->instance->acquireLock('foo', 1)); + $this->assertTrue($this->instance->acquireLock('bar', 1)); + $this->assertTrue($this->instance->acquireLock('nice', 1)); $this->assertTrue($this->instance->isLocked('foo')); $this->assertTrue($this->instance->isLocked('bar')); @@ -83,9 +93,12 @@ abstract class LockTest extends DatabaseTest * @small */ public function testReleaseAfterUnlock() { - $this->instance->acquireLock('foo', 1); - $this->instance->acquireLock('bar', 1); - $this->instance->acquireLock('nice', 1); + $this->assertFalse($this->instance->isLocked('foo')); + $this->assertFalse($this->instance->isLocked('bar')); + $this->assertFalse($this->instance->isLocked('nice')); + $this->assertTrue($this->instance->acquireLock('foo', 1)); + $this->assertTrue($this->instance->acquireLock('bar', 1)); + $this->assertTrue($this->instance->acquireLock('nice', 1)); $this->instance->releaseLock('foo'); @@ -103,10 +116,12 @@ abstract class LockTest extends DatabaseTest * @medium */ function testLockTTL() { + $this->assertFalse($this->instance->isLocked('foo')); + $this->assertFalse($this->instance->isLocked('bar')); // TODO [nupplaphil] - Because of the Datetime-Utils for the database, we have to wait a FULL second between the checks to invalidate the db-locks/cache - $this->instance->acquireLock('foo', 1, 1); - $this->instance->acquireLock('bar', 1, 3); + $this->assertTrue($this->instance->acquireLock('foo', 2, 1)); + $this->assertTrue($this->instance->acquireLock('bar', 2, 3)); $this->assertTrue($this->instance->isLocked('foo')); $this->assertTrue($this->instance->isLocked('bar')); diff --git a/tests/src/Core/Lock/MemcacheCacheLockDriverTest.php b/tests/src/Core/Lock/MemcacheCacheLockDriverTest.php index c54cf9c59..ca9b9b463 100644 --- a/tests/src/Core/Lock/MemcacheCacheLockDriverTest.php +++ b/tests/src/Core/Lock/MemcacheCacheLockDriverTest.php @@ -3,7 +3,6 @@ namespace Friendica\Test\src\Core\Lock; - use Friendica\Core\Cache\CacheDriverFactory; use Friendica\Core\Lock\CacheLockDriver; @@ -12,20 +11,8 @@ use Friendica\Core\Lock\CacheLockDriver; */ class MemcacheCacheLockDriverTest extends LockTest { - /** - * @var \Friendica\Core\Cache\IMemoryCacheDriver - */ - private $cache; - protected function getInstance() { - $this->cache = CacheDriverFactory::create('memcache'); - return new CacheLockDriver($this->cache); - } - - public function tearDown() - { - $this->cache->clear(); - parent::tearDown(); + return new CacheLockDriver(CacheDriverFactory::create('memcache')); } } diff --git a/tests/src/Core/Lock/MemcachedCacheLockDriverTest.php b/tests/src/Core/Lock/MemcachedCacheLockDriverTest.php index 27886261b..71311d5ba 100644 --- a/tests/src/Core/Lock/MemcachedCacheLockDriverTest.php +++ b/tests/src/Core/Lock/MemcachedCacheLockDriverTest.php @@ -3,7 +3,6 @@ namespace Friendica\Test\src\Core\Lock; - use Friendica\Core\Cache\CacheDriverFactory; use Friendica\Core\Lock\CacheLockDriver; @@ -12,20 +11,8 @@ use Friendica\Core\Lock\CacheLockDriver; */ class MemcachedCacheLockDriverTest extends LockTest { - /** - * @var \Friendica\Core\Cache\IMemoryCacheDriver - */ - private $cache; - protected function getInstance() { - $this->cache = CacheDriverFactory::create('memcached'); - return new CacheLockDriver($this->cache); - } - - public function tearDown() - { - $this->cache->clear(); - parent::tearDown(); + return new CacheLockDriver(CacheDriverFactory::create('memcached')); } } diff --git a/tests/src/Core/Lock/RedisCacheLockDriverTest.php b/tests/src/Core/Lock/RedisCacheLockDriverTest.php index eaafbf4e4..43cedb9cb 100644 --- a/tests/src/Core/Lock/RedisCacheLockDriverTest.php +++ b/tests/src/Core/Lock/RedisCacheLockDriverTest.php @@ -3,7 +3,6 @@ namespace Friendica\Test\src\Core\Lock; - use Friendica\Core\Cache\CacheDriverFactory; use Friendica\Core\Lock\CacheLockDriver; @@ -12,21 +11,9 @@ use Friendica\Core\Lock\CacheLockDriver; */ class RedisCacheLockDriverTest extends LockTest { - /** - * @var \Friendica\Core\Cache\IMemoryCacheDriver - */ - private $cache; - protected function getInstance() { - $this->cache = CacheDriverFactory::create('redis'); - return new CacheLockDriver($this->cache); + return new CacheLockDriver(CacheDriverFactory::create('redis')); } - - public function tearDown() - { - $this->cache->clear(); - parent::tearDown(); - } } diff --git a/tests/src/Core/Lock/SemaphoreLockDriverTest.php b/tests/src/Core/Lock/SemaphoreLockDriverTest.php index cd4b91573..39f0763fb 100644 --- a/tests/src/Core/Lock/SemaphoreLockDriverTest.php +++ b/tests/src/Core/Lock/SemaphoreLockDriverTest.php @@ -2,26 +2,13 @@ namespace Friendica\Test\src\Core\Lock; - use Friendica\Core\Lock\SemaphoreLockDriver; class SemaphoreLockDriverTest extends LockTest { - /** - * @var \Friendica\Core\Lock\SemaphoreLockDriver - */ - private $semaphoreLockDriver; - protected function getInstance() { - $this->semaphoreLockDriver = new SemaphoreLockDriver(); - return $this->semaphoreLockDriver; - } - - public function tearDown() - { - $this->semaphoreLockDriver->releaseAll(); - parent::tearDown(); + return new SemaphoreLockDriver(); } function testLockTTL() diff --git a/view/lang/cs/messages.po b/view/lang/cs/messages.po index 057416b7f..7b87e7d32 100644 --- a/view/lang/cs/messages.po +++ b/view/lang/cs/messages.po @@ -13,7 +13,7 @@ msgstr "" "Project-Id-Version: friendica\n" "Report-Msgid-Bugs-To: \n" "POT-Creation-Date: 2018-08-25 15:34+0000\n" -"PO-Revision-Date: 2018-09-17 14:51+0000\n" +"PO-Revision-Date: 2018-09-22 16:53+0000\n" "Last-Translator: Aditoo\n" "Language-Team: Czech (http://www.transifex.com/Friendica/friendica/language/cs/)\n" "MIME-Version: 1.0\n" @@ -214,7 +214,7 @@ msgstr "Podobné zájmy" #: view/theme/vier/theme.php:204 src/Content/Widget.php:66 msgid "Random Profile" -msgstr "Náhodný Profil" +msgstr "Náhodný profil" #: view/theme/vier/theme.php:205 src/Content/Widget.php:67 msgid "Invite Friends" @@ -1786,7 +1786,7 @@ msgstr "Databáze se již používá." #: mod/install.php:163 msgid "System check" -msgstr "Testování systému" +msgstr "Zkouška systému" #: mod/install.php:167 mod/cal.php:279 mod/events.php:394 msgid "Next" @@ -1794,7 +1794,7 @@ msgstr "Dále" #: mod/install.php:168 msgid "Check again" -msgstr "Otestovat znovu" +msgstr "Vyskoušet znovu" #: mod/install.php:187 msgid "Database connection" @@ -1804,7 +1804,7 @@ msgstr "Databázové spojení" msgid "" "In order to install Friendica we need to know how to connect to your " "database." -msgstr "Pro instalaci Friendica potřeujeme znát připojení k Vaší databázi." +msgstr "Pro instalaci Friendica potřebujeme znát připojení k Vaší databázi." #: mod/install.php:189 msgid "" @@ -1840,13 +1840,13 @@ msgstr "Jméno databáze" #: mod/install.php:198 mod/install.php:235 msgid "Site administrator email address" -msgstr "Emailová adresa administrátora webu" +msgstr "E-mailová adresa administrátora webu" #: mod/install.php:198 mod/install.php:235 msgid "" "Your account email address must match this in order to use the web admin " "panel." -msgstr "Vaše emailová adresa účtu se musí s touto shodovat, aby bylo možné využívat administrační panel ve webovém rozhraní." +msgstr "Vaše e-mailová adresa účtu se musí s touto shodovat, aby bylo možné využívat administrační panel ve webovém rozhraní." #: mod/install.php:200 mod/install.php:238 msgid "Please select a default timezone for your website" @@ -2109,7 +2109,7 @@ msgstr "Profily" #: mod/settings.php:72 mod/admin.php:190 msgid "Additional features" -msgstr "Další funkčnosti" +msgstr "Dodatečné vlastnosti" #: mod/settings.php:80 msgid "Display" @@ -2157,7 +2157,7 @@ msgstr "Nastavení e-mailu aktualizována." #: mod/settings.php:306 msgid "Features updated" -msgstr "Funkce aktualizovány" +msgstr "Vlastnosti aktualizovány" #: mod/settings.php:379 msgid "Relocate message has been send to your contacts" @@ -2230,7 +2230,7 @@ msgstr "Přidat aplikaci" #: mod/admin.php:317 mod/admin.php:1426 mod/admin.php:2074 mod/admin.php:2328 #: mod/admin.php:2403 mod/admin.php:2550 msgid "Save Settings" -msgstr "Uložit Nastavení" +msgstr "Uložit nastavení" #: mod/settings.php:678 mod/settings.php:704 msgid "Consumer Key" @@ -2290,7 +2290,7 @@ msgstr "Zap" #: mod/settings.php:780 msgid "Additional Features" -msgstr "Další funkce" +msgstr "Dodatečné vlastnosti" #: mod/settings.php:803 src/Content/ContactSelector.php:82 msgid "Diaspora" @@ -3511,19 +3511,19 @@ msgstr "Ignorovat" #: mod/notifications.php:93 src/Content/Nav.php:191 msgid "Notifications" -msgstr "Upozornění" +msgstr "Oznámení" #: mod/notifications.php:101 msgid "Network Notifications" -msgstr "Upozornění Sítě" +msgstr "Síťová oznámení" #: mod/notifications.php:106 mod/notify.php:81 msgid "System Notifications" -msgstr "Systémová upozornění" +msgstr "Systémová oznámení" #: mod/notifications.php:111 msgid "Personal Notifications" -msgstr "Osobní upozornění" +msgstr "Osobní oznámení" #: mod/notifications.php:116 msgid "Home Notifications" @@ -4328,7 +4328,7 @@ msgstr "Smazat položku" #: mod/admin.php:200 mod/admin.php:201 mod/admin.php:2402 msgid "Logs" -msgstr "Logy" +msgstr "Záznamy" #: mod/admin.php:202 mod/admin.php:2469 msgid "View Logs" @@ -4336,7 +4336,7 @@ msgstr "Zobrazit záznamy" #: mod/admin.php:204 msgid "Diagnostics" -msgstr "Diagnostica" +msgstr "Diagnostika" #: mod/admin.php:205 msgid "PHP Info" @@ -5237,7 +5237,7 @@ msgstr "Podpora OpenID pro registraci a přihlašování." #: mod/admin.php:1477 msgid "Fullname check" -msgstr "kontrola úplného jména" +msgstr "Kontrola úplného jména" #: mod/admin.php:1477 msgid "" @@ -5299,7 +5299,7 @@ msgstr "Podpora pro Diasporu nemůže být zapnuta, protože Friendica byla nain #: mod/admin.php:1485 msgid "Enable Diaspora support" -msgstr "Povolit podporu Diaspora" +msgstr "Zapnout podporu pro Diaspora" #: mod/admin.php:1485 msgid "Provide built-in Diaspora network compatibility." @@ -5773,7 +5773,7 @@ msgid "" "\n" "\t\t\tDear %1$s,\n" "\t\t\t\tthe administrator of %2$s has set up an account for you." -msgstr "\n\t\t\tVážený/á%1$s,\n\t\t\t\tadministrátor %2$s pro Vás vytvořil uživatelský účet." +msgstr "\n\t\t\tVážený/á %1$s,\n\t\t\t\tadministrátor %2$s pro Vás vytvořil uživatelský účet." #: mod/admin.php:1669 #, php-format @@ -6015,7 +6015,7 @@ msgstr "[Nepodporováno]" #: mod/admin.php:2360 msgid "Log settings updated." -msgstr "Nastavení protokolu aktualizováno." +msgstr "Nastavení záznamů aktualizována." #: mod/admin.php:2393 msgid "PHP log currently enabled." @@ -6183,7 +6183,7 @@ msgstr "Vzdálený odběr nemůže být na Vaší síti proveden. Prosím, přih #: mod/dfrn_request.php:486 msgid "Please login to confirm introduction." -msgstr "Pro ptvrzení představení se prosím přihlaste." +msgstr "Pro potvrzení představení se prosím přihlaste." #: mod/dfrn_request.php:494 msgid "" @@ -7847,13 +7847,13 @@ msgstr "Pokud nemáte na Vašem serveru nainstalovanou verzi PHP pro příkazov #: src/Core/Install.php:143 msgid "PHP executable path" -msgstr "Cesta k \"PHP executable\"" +msgstr "Cesta ke spustitelnému souboru PHP" #: src/Core/Install.php:143 msgid "" "Enter full path to php executable. You can leave this blank to continue the " "installation." -msgstr "Zadejte plnou cestu k spustitelnému souboru php. Tento údaj můžete ponechat nevyplněný a pokračovat v instalaci." +msgstr "Zadejte plnou cestu ke spustitelnému souboru PHP. Tento údaj můžete ponechat nevyplněný a pokračovat v instalaci." #: src/Core/Install.php:148 msgid "Command line PHP" diff --git a/view/lang/cs/strings.php b/view/lang/cs/strings.php index f4b53ec73..753b0e51d 100644 --- a/view/lang/cs/strings.php +++ b/view/lang/cs/strings.php @@ -45,7 +45,7 @@ $a->strings["Examples: Robert Morgenstein, Fishing"] = "Příklady: Josef Dvoř $a->strings["Find"] = "Najít"; $a->strings["Friend Suggestions"] = "Návrhy přátel"; $a->strings["Similar Interests"] = "Podobné zájmy"; -$a->strings["Random Profile"] = "Náhodný Profil"; +$a->strings["Random Profile"] = "Náhodný profil"; $a->strings["Invite Friends"] = "Pozvat přátele"; $a->strings["Global Directory"] = "Globální adresář"; $a->strings["Local Directory"] = "Místní adresář"; @@ -430,11 +430,11 @@ $a->strings["Your Friendica site database has been installed."] = "Vaše databá $a->strings["You may need to import the file \"database.sql\" manually using phpmyadmin or mysql."] = "Nejspíše budete muset manuálně importovat soubor \"database.sql\" pomocí phpMyAdmin či MySQL."; $a->strings["Please see the file \"INSTALL.txt\"."] = "Přečtěte si prosím informace v souboru \"INSTALL.txt\"."; $a->strings["Database already in use."] = "Databáze se již používá."; -$a->strings["System check"] = "Testování systému"; +$a->strings["System check"] = "Zkouška systému"; $a->strings["Next"] = "Dále"; -$a->strings["Check again"] = "Otestovat znovu"; +$a->strings["Check again"] = "Vyskoušet znovu"; $a->strings["Database connection"] = "Databázové spojení"; -$a->strings["In order to install Friendica we need to know how to connect to your database."] = "Pro instalaci Friendica potřeujeme znát připojení k Vaší databázi."; +$a->strings["In order to install Friendica we need to know how to connect to your database."] = "Pro instalaci Friendica potřebujeme znát připojení k Vaší databázi."; $a->strings["Please contact your hosting provider or site administrator if you have questions about these settings."] = "Pokud máte otázky k následujícím nastavením, obraťte se na svého poskytovatele hostingu nebo administrátora serveru."; $a->strings["The database you specify below should already exist. If it does not, please create it before continuing."] = "Databáze, kterou uvedete níže, by již měla existovat. Pokud to tak není, prosíme, vytvořte ji před pokračováním."; $a->strings["Database Server Name"] = "Jméno databázového serveru"; @@ -442,8 +442,8 @@ $a->strings["Database Login Name"] = "Přihlašovací jméno k databázi"; $a->strings["Database Login Password"] = "Heslo k databázovému účtu "; $a->strings["For security reasons the password must not be empty"] = "Z bezpečnostních důvodů nesmí být heslo prázdné."; $a->strings["Database Name"] = "Jméno databáze"; -$a->strings["Site administrator email address"] = "Emailová adresa administrátora webu"; -$a->strings["Your account email address must match this in order to use the web admin panel."] = "Vaše emailová adresa účtu se musí s touto shodovat, aby bylo možné využívat administrační panel ve webovém rozhraní."; +$a->strings["Site administrator email address"] = "E-mailová adresa administrátora webu"; +$a->strings["Your account email address must match this in order to use the web admin panel."] = "Vaše e-mailová adresa účtu se musí s touto shodovat, aby bylo možné využívat administrační panel ve webovém rozhraní."; $a->strings["Please select a default timezone for your website"] = "Prosím, vyberte výchozí časové pásmo pro váš server"; $a->strings["Site settings"] = "Nastavení webu"; $a->strings["System Language:"] = "Systémový jazyk"; @@ -501,7 +501,7 @@ $a->strings["Profile Match"] = "Shoda profilu"; $a->strings["everybody"] = "Žádost o připojení selhala nebo byla zrušena."; $a->strings["Account"] = "Účet"; $a->strings["Profiles"] = "Profily"; -$a->strings["Additional features"] = "Další funkčnosti"; +$a->strings["Additional features"] = "Dodatečné vlastnosti"; $a->strings["Display"] = "Zobrazení"; $a->strings["Social Networks"] = "Sociální sítě"; $a->strings["Addons"] = "Doplňky"; @@ -513,7 +513,7 @@ $a->strings["Missing some important data!"] = "Chybí některé důležité úda $a->strings["Update"] = "Aktualizace"; $a->strings["Failed to connect with email account using the settings provided."] = "Nepodařilo se připojit k e-mailovému účtu pomocí dodaného nastavení."; $a->strings["Email settings updated."] = "Nastavení e-mailu aktualizována."; -$a->strings["Features updated"] = "Funkce aktualizovány"; +$a->strings["Features updated"] = "Vlastnosti aktualizovány"; $a->strings["Relocate message has been send to your contacts"] = "Správa o změně umístění byla odeslána vašim kontaktům"; $a->strings["Passwords do not match. Password unchanged."] = "Hesla se neshodují. Heslo nebylo změněno."; $a->strings["Empty passwords are not allowed. Password unchanged."] = "Prázdné hesla nejsou povolena. Heslo nebylo změněno."; @@ -530,7 +530,7 @@ $a->strings["Private forum has no privacy permissions. Using default privacy gro $a->strings["Private forum has no privacy permissions and no default privacy group."] = "Soukromé fórum nemá nastaveno zabezpečení a ani žádnou defaultní výchozí skupinu."; $a->strings["Settings updated."] = "Nastavení aktualizováno."; $a->strings["Add application"] = "Přidat aplikaci"; -$a->strings["Save Settings"] = "Uložit Nastavení"; +$a->strings["Save Settings"] = "Uložit nastavení"; $a->strings["Consumer Key"] = "Consumer Key"; $a->strings["Consumer Secret"] = "Consumer Secret"; $a->strings["Redirect"] = "Přesměrování"; @@ -545,7 +545,7 @@ $a->strings["No Addon settings configured"] = "Žádná nastavení doplňků nen $a->strings["Addon Settings"] = "Nastavení doplňků"; $a->strings["Off"] = "Vyp"; $a->strings["On"] = "Zap"; -$a->strings["Additional Features"] = "Další funkce"; +$a->strings["Additional Features"] = "Dodatečné vlastnosti"; $a->strings["Diaspora"] = "Diaspora"; $a->strings["enabled"] = "povoleno"; $a->strings["disabled"] = "zakázáno"; @@ -826,10 +826,10 @@ $a->strings["Note: This node explicitly contains adult content"] = "Poznámka: T $a->strings["Invalid request identifier."] = "Neplatný identifikátor požadavku."; $a->strings["Discard"] = "Odstranit"; $a->strings["Ignore"] = "Ignorovat"; -$a->strings["Notifications"] = "Upozornění"; -$a->strings["Network Notifications"] = "Upozornění Sítě"; -$a->strings["System Notifications"] = "Systémová upozornění"; -$a->strings["Personal Notifications"] = "Osobní upozornění"; +$a->strings["Notifications"] = "Oznámení"; +$a->strings["Network Notifications"] = "Síťová oznámení"; +$a->strings["System Notifications"] = "Systémová oznámení"; +$a->strings["Personal Notifications"] = "Osobní oznámení"; $a->strings["Home Notifications"] = "Oznámení na domovské stránce"; $a->strings["Show Ignored Requests"] = "Zobrazit ignorované žádosti"; $a->strings["Hide Ignored Requests"] = "Skrýt ignorované žádosti"; @@ -1001,9 +1001,9 @@ $a->strings["Tools"] = "Nástroje"; $a->strings["Contact Blocklist"] = "Blokované kontakty"; $a->strings["Server Blocklist"] = "Blokované servery"; $a->strings["Delete Item"] = "Smazat položku"; -$a->strings["Logs"] = "Logy"; +$a->strings["Logs"] = "Záznamy"; $a->strings["View Logs"] = "Zobrazit záznamy"; -$a->strings["Diagnostics"] = "Diagnostica"; +$a->strings["Diagnostics"] = "Diagnostika"; $a->strings["PHP Info"] = "Info o PHP"; $a->strings["probe address"] = "vyzkoušet adresu"; $a->strings["check webfinger"] = "vyzkoušet webfinger"; @@ -1204,7 +1204,7 @@ $a->strings["Block multiple registrations"] = "Blokovat více registrací"; $a->strings["Disallow users to register additional accounts for use as pages."] = "Znemožnit uživatelům registraci dodatečných účtů k použití jako stránky."; $a->strings["OpenID support"] = "Podpora OpenID"; $a->strings["OpenID support for registration and logins."] = "Podpora OpenID pro registraci a přihlašování."; -$a->strings["Fullname check"] = "kontrola úplného jména"; +$a->strings["Fullname check"] = "Kontrola úplného jména"; $a->strings["Force users to register with a space between firstname and lastname in Full name, as an antispam measure"] = "Přimět uživatele k registraci s mezerou mezi jménu a příjmením v poli Celé jméno, jako antispamové opatření."; $a->strings["Community pages for visitors"] = "Komunitní stránky pro návštěvníky"; $a->strings["Which community pages should be available for visitors. Local users always see both pages."] = "Které komunitní stránky by měly být viditelné pro návštěvníky. Lokální uživatelé vždy vidí obě stránky."; @@ -1216,7 +1216,7 @@ $a->strings["Only import OStatus threads from our contacts"] = "Pouze importovat $a->strings["Normally we import every content from our OStatus contacts. With this option we only store threads that are started by a contact that is known on our system."] = "Běžně importujeme všechen obsah z našich kontaktů na OStatus. S touto volbou uchováváme vlákna počatá kontaktem, který je na našem systému známý."; $a->strings["OStatus support can only be enabled if threading is enabled."] = "Podpora pro OStatus může být zapnuta pouze, je-li povolen threading."; $a->strings["Diaspora support can't be enabled because Friendica was installed into a sub directory."] = "Podpora pro Diasporu nemůže být zapnuta, protože Friendica byla nainstalována do podadresáře."; -$a->strings["Enable Diaspora support"] = "Povolit podporu Diaspora"; +$a->strings["Enable Diaspora support"] = "Zapnout podporu pro Diaspora"; $a->strings["Provide built-in Diaspora network compatibility."] = "Poskytnout zabudovanou kompatibilitu sitě Diaspora."; $a->strings["Only allow Friendica contacts"] = "Povolit pouze kontakty z Friendica"; $a->strings["All contacts must use Friendica protocols. All other built-in communication protocols disabled."] = "Všechny kontakty musí používat Friendica protokol. Všchny jiné zabudované komunikační protokoly budou zablokované."; @@ -1313,7 +1313,7 @@ $a->strings["Failed Updates"] = "Neúspěšné aktualizace"; $a->strings["This does not include updates prior to 1139, which did not return a status."] = "To nezahrnuje aktualizace do verze 1139, které nevracejí žádný status."; $a->strings["Mark success (if update was manually applied)"] = "Označit za úspěšné (pokud byla aktualizace aplikována manuálně)"; $a->strings["Attempt to execute this update step automatically"] = "Pokusit se provést tuto aktualizaci automaticky."; -$a->strings["\n\t\t\tDear %1\$s,\n\t\t\t\tthe administrator of %2\$s has set up an account for you."] = "\n\t\t\tVážený/á%1\$s,\n\t\t\t\tadministrátor %2\$s pro Vás vytvořil uživatelský účet."; +$a->strings["\n\t\t\tDear %1\$s,\n\t\t\t\tthe administrator of %2\$s has set up an account for you."] = "\n\t\t\tVážený/á %1\$s,\n\t\t\t\tadministrátor %2\$s pro Vás vytvořil uživatelský účet."; $a->strings["\n\t\t\tThe login details are as follows:\n\n\t\t\tSite Location:\t%1\$s\n\t\t\tLogin Name:\t\t%2\$s\n\t\t\tPassword:\t\t%3\$s\n\n\t\t\tYou may change your password from your account \"Settings\" page after logging\n\t\t\tin.\n\n\t\t\tPlease take a few moments to review the other account settings on that page.\n\n\t\t\tYou may also wish to add some basic information to your default profile\n\t\t\t(on the \"Profiles\" page) so that other people can easily find you.\n\n\t\t\tWe recommend setting your full name, adding a profile photo,\n\t\t\tadding some profile \"keywords\" (very useful in making new friends) - and\n\t\t\tperhaps what country you live in; if you do not wish to be more specific\n\t\t\tthan that.\n\n\t\t\tWe fully respect your right to privacy, and none of these items are necessary.\n\t\t\tIf you are new and do not know anybody here, they may help\n\t\t\tyou to make some new and interesting friends.\n\n\t\t\tIf you ever want to delete your account, you can do so at %1\$s/removeme\n\n\t\t\tThank you and welcome to %4\$s."] = "\n\t\t\tZde jsou Vaše přihlašovací detaily:\n\n\t\t\tAdresa stránky:\t\t%1\$s\n\t\t\tPřihlašovací jméno:\t%2\$s\n\t\t\tHeslo:\t\t\t%3\$s\n\n\t\t\tSvé heslo si po přihlášení můžete změnit na stránce \"Nastavení\" vašeho\n\t\t\túčtu.\n\n\t\t\tProsím, prohlédněte si na chvilku ostatní nastavení účtu na této stránce.\n\n\t\t\tMožná byste si také přál/a přidat pár základních informací na svůj výchozí\n\t\t\tprofil (na stránce \"Profily\") aby vás další lidé mohli snadno najít.\n\t\t\tDoporučujeme nastavit si Vaše celé jméno, přidat profilovou fotku,\n\t\t\tpřidat pár \"klíčových slov\" k profilu (velmi užitečné při získávání nových\n\t\t\tpřátel) - a možná v jaké zemi žijete; pokud nechcete být konkrétnější.\n\n\t\t\tZcela respektujeme Vaše právo na soukromí a žádnou z těchto položek\n\t\t\tnení potřeba vyplňovat. Pokud jste zde nový/á a nikoho zde neznáte, mohou vám\n\t\t\tpomoci si získat nové a zajímavé přátele.\n\t\t\tPokud byste si někdy přál/a smazat účet, můžete tak učinit na stránce\n\t\t\t%1\$s/removeme.\n\n\t\t\tDěkujeme Vám a vítáme Vás na %4\$s."; $a->strings["Registration details for %s"] = "Registrační údaje pro uživatele %s"; $a->strings["%s user blocked/unblocked"] = [ @@ -1370,7 +1370,7 @@ $a->strings["Reload active themes"] = "Znovu načíst aktivní motivy"; $a->strings["No themes found on the system. They should be placed in %1\$s"] = "V systému nebyly nalezeny žádné motivy. Měly by být uloženy v %1\$s"; $a->strings["[Experimental]"] = "[Experimentální]"; $a->strings["[Unsupported]"] = "[Nepodporováno]"; -$a->strings["Log settings updated."] = "Nastavení protokolu aktualizováno."; +$a->strings["Log settings updated."] = "Nastavení záznamů aktualizována."; $a->strings["PHP log currently enabled."] = "PHP záznamy jsou aktuálně povolené."; $a->strings["PHP log currently disabled."] = "PHP záznamy jsou aktuálně zakázané."; $a->strings["Clear"] = "Vyčistit"; @@ -1411,7 +1411,7 @@ $a->strings["Disallowed profile URL."] = "Nepovolené URL profilu."; $a->strings["Failed to update contact record."] = "Nepodařilo se aktualizovat kontakt."; $a->strings["Your introduction has been sent."] = "Vaše žádost o propojení byla odeslána."; $a->strings["Remote subscription can't be done for your network. Please subscribe directly on your system."] = "Vzdálený odběr nemůže být na Vaší síti proveden. Prosím, přihlaste se k odběru přímo na Vašem systému."; -$a->strings["Please login to confirm introduction."] = "Pro ptvrzení představení se prosím přihlaste."; +$a->strings["Please login to confirm introduction."] = "Pro potvrzení představení se prosím přihlaste."; $a->strings["Incorrect identity currently logged in. Please login to this profile."] = "Jste přihlášen/a pod nesprávnou identitou. Prosím, přihlaste se do tohoto profilu."; $a->strings["Confirm"] = "Potvrdit"; $a->strings["Hide this contact"] = "Skrýt tento kontakt"; @@ -1801,8 +1801,8 @@ $a->strings["%s: Database update"] = "%s: Aktualizace databáze"; $a->strings["%s: updating %s table."] = "%s: aktualizuji tabulku %s"; $a->strings["Could not find a command line version of PHP in the web server PATH."] = "Nelze najít verzi PHP pro příkazový řádek v PATH webového serveru."; $a->strings["If you don't have a command line version of PHP installed on your server, you will not be able to run the background processing. See 'Setup the worker'"] = "Pokud nemáte na Vašem serveru nainstalovanou verzi PHP pro příkazový řádek, nebudete moci spouštět procesy v pozadí. Více na \"Nastavte pracovníka\""; -$a->strings["PHP executable path"] = "Cesta k \"PHP executable\""; -$a->strings["Enter full path to php executable. You can leave this blank to continue the installation."] = "Zadejte plnou cestu k spustitelnému souboru php. Tento údaj můžete ponechat nevyplněný a pokračovat v instalaci."; +$a->strings["PHP executable path"] = "Cesta ke spustitelnému souboru PHP"; +$a->strings["Enter full path to php executable. You can leave this blank to continue the installation."] = "Zadejte plnou cestu ke spustitelnému souboru PHP. Tento údaj můžete ponechat nevyplněný a pokračovat v instalaci."; $a->strings["Command line PHP"] = "Příkazový řádek PHP"; $a->strings["PHP executable is not the php cli binary (could be cgi-fgci version)"] = "PHP executable není php cli binary (může být verze cgi-fgci)"; $a->strings["Found PHP version: "] = "Nalezena PHP verze:"; diff --git a/view/theme/frio/js/modal.js b/view/theme/frio/js/modal.js index 9a15cab52..80694b64d 100644 --- a/view/theme/frio/js/modal.js +++ b/view/theme/frio/js/modal.js @@ -343,6 +343,8 @@ function toggleJotNav (elm) { // For some some tab panels we need to execute other js functions. if (tabpanel === "jot-preview-content") { preview_post(); + // Make Share button visivle in preview + $('#jot-preview-share').removeClass("minimize").attr("aria-hidden" ,"false"); } else if (tabpanel === "jot-fbrowser-wrapper") { $(function() { Dialog.showJot(); diff --git a/view/theme/frio/js/textedit.js b/view/theme/frio/js/textedit.js index 2079c20cd..ad5f95023 100644 --- a/view/theme/frio/js/textedit.js +++ b/view/theme/frio/js/textedit.js @@ -27,6 +27,22 @@ function insertFormatting(BBcode, id) { return true; } +function insertFormattingToPost(BBcode) { + textarea = document.getElementById("profile-jot-text"); + if (document.selection) { + textarea.focus(); + selected = document.selection.createRange(); + selected.text = "[" + BBcode + "]" + selected.text + "[/" + BBcode + "]"; + } else if (textarea.selectionStart || textarea.selectionStart == "0") { + var start = textarea.selectionStart; + var end = textarea.selectionEnd; + textarea.value = textarea.value.substring(0, start) + "[" + BBcode + "]" + textarea.value.substring(start, end) + "[/" + BBcode + "]" + textarea.value.substring(end, textarea.value.length); + } + + $(textarea).trigger('change'); + + return true; +} function showThread(id) { $("#collapsed-comments-" + id).show() diff --git a/view/theme/frio/templates/jot.tpl b/view/theme/frio/templates/jot.tpl index 423be5a5d..14f383ac8 100644 --- a/view/theme/frio/templates/jot.tpl +++ b/view/theme/frio/templates/jot.tpl @@ -93,6 +93,10 @@