From 772bbd99bee83d17707c73a630a4d47c4b8bc807 Mon Sep 17 00:00:00 2001 From: Arthur Schiwon Date: Thu, 5 Jul 2018 00:41:59 +0200 Subject: Backend work to provide NC whats New info to users Signed-off-by: Arthur Schiwon --- apps/files/js/app.js | 2 ++ apps/updatenotification/lib/Settings/Admin.php | 33 +++++--------------------- 2 files changed, 8 insertions(+), 27 deletions(-) (limited to 'apps') diff --git a/apps/files/js/app.js b/apps/files/js/app.js index 6a21bce975b..883642b9c1c 100644 --- a/apps/files/js/app.js +++ b/apps/files/js/app.js @@ -131,6 +131,8 @@ }); this._debouncedPersistShowHiddenFilesState = _.debounce(this._persistShowHiddenFilesState, 1200); + + OCP.WhatsNew.query(); // for Nextcloud server }, /** diff --git a/apps/updatenotification/lib/Settings/Admin.php b/apps/updatenotification/lib/Settings/Admin.php index b859ca79f62..cae62ee0a9f 100644 --- a/apps/updatenotification/lib/Settings/Admin.php +++ b/apps/updatenotification/lib/Settings/Admin.php @@ -123,39 +123,18 @@ class Admin implements ISettings { return $filtered; } - $isFirstCall = true; + $iterator = $this->l10nFactory->getLanguageIterator(); do { - $lang = $this->l10nFactory->iterateLanguage($isFirstCall); - if($this->findWhatsNewTranslation($lang, $filtered, $changes['whatsNew'])) { - return $filtered; + $lang = $iterator->current(); + if(isset($changes['whatsNew'][$lang])) { + return $filtered['whatsNew'][$lang]; } - $isFirstCall = false; - } while($lang !== 'en'); + $iterator->next(); + } while($lang !== 'en' && $iterator->valid()); return $filtered; } - protected function getLangTrunk(string $lang):string { - $pos = strpos($lang, '_'); - if($pos !== false) { - $lang = substr($lang, 0, $pos); - } - return $lang; - } - - protected function findWhatsNewTranslation(string $lang, array &$result, array $whatsNew): bool { - if(isset($whatsNew[$lang])) { - $result['whatsNew'] = $whatsNew[$lang]; - return true; - } - $trunkedLang = $this->getLangTrunk($lang); - if($trunkedLang !== $lang && isset($whatsNew[$trunkedLang])) { - $result['whatsNew'] = $whatsNew[$trunkedLang]; - return true; - } - return false; - } - /** * @param array $groupIds * @return array -- cgit v1.2.3 From ca6094f3900fd463449d9973589b1d49aed28b2a Mon Sep 17 00:00:00 2001 From: Arthur Schiwon Date: Thu, 5 Jul 2018 20:29:00 +0200 Subject: wire the frontend Signed-off-by: Arthur Schiwon --- apps/files/css/merged.scss | 1 + core/Controller/WhatsNewController.php | 13 ++++- core/css/whatsnew.scss | 31 +++++++++++ core/js/public/whatsnew.js | 94 +++++++++++++++++++++++++++++++--- 4 files changed, 130 insertions(+), 9 deletions(-) create mode 100644 core/css/whatsnew.scss (limited to 'apps') diff --git a/apps/files/css/merged.scss b/apps/files/css/merged.scss index d65bac512f1..8a11e55c269 100644 --- a/apps/files/css/merged.scss +++ b/apps/files/css/merged.scss @@ -2,3 +2,4 @@ @import 'upload.scss'; @import 'mobile.scss'; @import 'detailsView.scss'; +@import '../../../core/css/whatsnew.scss'; diff --git a/core/Controller/WhatsNewController.php b/core/Controller/WhatsNewController.php index d3331651693..c3a6d28cea2 100644 --- a/core/Controller/WhatsNewController.php +++ b/core/Controller/WhatsNewController.php @@ -29,6 +29,7 @@ use OC\Updater\ChangesCheck; use OCP\AppFramework\Db\DoesNotExistException; use OCP\AppFramework\Http; use OCP\AppFramework\Http\DataResponse; +use OCP\Defaults; use OCP\IConfig; use OCP\IRequest; use OCP\IUserManager; @@ -45,6 +46,8 @@ class WhatsNewController extends OCSController { private $whatsNewService; /** @var IFactory */ private $langFactory; + /** @var Defaults */ + private $defaults; public function __construct( string $appName, @@ -55,13 +58,15 @@ class WhatsNewController extends OCSController { Manager $keyManager, IConfig $config, ChangesCheck $whatsNewService, - IFactory $langFactory + IFactory $langFactory, + Defaults $defaults ) { parent::__construct($appName, $request, $capabilitiesManager, $userSession, $userManager, $keyManager); $this->config = $config; $this->userSession = $userSession; $this->whatsNewService = $whatsNewService; $this->langFactory = $langFactory; + $this->defaults = $defaults; } /** @@ -82,7 +87,11 @@ class WhatsNewController extends OCSController { try { $iterator = $this->langFactory->getLanguageIterator(); $whatsNew = $this->whatsNewService->getChangesForVersion($currentVersion); - $resultData = ['changelogURL' => $whatsNew['changelogURL']]; + $resultData = [ + 'changelogURL' => $whatsNew['changelogURL'], + 'product' => $this->defaults->getName(), + 'version' => $currentVersion, + ]; do { $lang = $iterator->current(); if(isset($whatsNew['whatsNew'][$lang])) { diff --git a/core/css/whatsnew.scss b/core/css/whatsnew.scss new file mode 100644 index 00000000000..1c2ab08333a --- /dev/null +++ b/core/css/whatsnew.scss @@ -0,0 +1,31 @@ +/** + * @copyright Copyright (c) 2018, Arthur Schiwon + * + * @license GNU AGPL version 3 or any later version + * + */ + +.whatsNewPopover { + bottom: 35px !important; + left: 15px !important; + width: 270px; + background-color: var(--color-background-dark); +} + +.whatsNewPopover p { + width: auto !important; +} + +.whatsNewPopover .caption { + font-weight: bolder; + cursor: auto !important; +} + +.whatsNewPopover .icon-close { + position: absolute; + right: 0; +} + +.whatsNewPopover::after { + content: none; +} diff --git a/core/js/public/whatsnew.js b/core/js/public/whatsnew.js index dc5862e8572..20a871ada27 100644 --- a/core/js/public/whatsnew.js +++ b/core/js/public/whatsnew.js @@ -14,10 +14,13 @@ query: function(options) { options = options || {}; + var dismissOptions = options.dismiss || {}; $.ajax({ type: 'GET', url: options.url || OC.linkToOCS('core', 2) + 'whatsnew?format=json', - success: options.success || this._onQuerySuccess, + success: options.success || function(data, statusText, xhr) { + OCP.WhatsNew._onQuerySuccess(data, statusText, xhr, dismissOptions); + }, error: options.error || this._onQueryError }); }, @@ -31,20 +34,97 @@ success: options.success || this._onDismissSuccess, error: options.error || this._onDismissError }); + // remove element immediately + $('.whatsNewPopover').remove(); }, - _onQuerySuccess: function(data, statusText) { - console.debug('querying Whats New data was successful: ' + data || statusText); + _onQuerySuccess: function(data, statusText, xhr, dismissOptions) { + console.debug('querying Whats New data was successful: ' + statusText); console.debug(data); + + if(xhr.status !== 200) { + return; + } + + var item, menuItem, text, icon; + + var div = document.createElement('div'); + div.classList.add('popovermenu', 'open', 'whatsNewPopover', 'menu-left'); + + var list = document.createElement('ul'); + + // header + item = document.createElement('li'); + menuItem = document.createElement('span'); + menuItem.className = "menuitem"; + + text = document.createElement('span'); + text.innerText = t('core', 'New in') + ' ' + data['ocs']['data']['product']; + text.className = 'caption'; + menuItem.appendChild(text); + + icon = document.createElement('span'); + icon.className = 'icon-close'; + icon.onclick = function () { + OCP.WhatsNew.dismiss(data['ocs']['data']['version'], dismissOptions); + }; + menuItem.appendChild(icon); + + item.appendChild(menuItem); + list.appendChild(item); + + // Highlights + for (var i in data['ocs']['data']['whatsNew']['regular']) { + var whatsNewTextItem = data['ocs']['data']['whatsNew']['regular'][i]; + item = document.createElement('li'); + + menuItem = document.createElement('span'); + menuItem.className = "menuitem"; + + icon = document.createElement('span'); + icon.className = 'icon-star-dark'; + menuItem.appendChild(icon); + + text = document.createElement('p'); + text.innerHTML = _.escape(whatsNewTextItem); + menuItem.appendChild(text); + + item.appendChild(menuItem); + list.appendChild(item); + } + + // Changelog URL + if(!_.isUndefined(data['ocs']['data']['changelogURL'])) { + item = document.createElement('li'); + + menuItem = document.createElement('a'); + menuItem.href = data['ocs']['data']['changelogURL']; + menuItem.rel = 'noreferrer noopener'; + menuItem.target = '_blank'; + + icon = document.createElement('span'); + icon.className = 'icon-link'; + menuItem.appendChild(icon); + + text = document.createElement('span'); + text.innerText = t('core', 'View changelog'); + menuItem.appendChild(text); + + item.appendChild(menuItem); + list.appendChild(item); + } + + div.appendChild(list); + document.body.appendChild(div); }, - _onQueryError: function (o, t, e) { - console.debug(o); - console.debug('querying Whats New Data resulted in an error: ' + t +e); + _onQueryError: function (x, t, e) { + console.debug('querying Whats New Data resulted in an error: ' + t + e); + console.debug(x); }, _onDismissSuccess: function(data) { - console.debug('dismissing Whats New data was successful: ' + data); + //noop }, _onDismissError: function (data) { -- cgit v1.2.3