diff options
author | Julius Härtl <jus@bitgrid.net> | 2020-05-27 09:07:17 +0200 |
---|---|---|
committer | Julius Härtl <jus@bitgrid.net> | 2020-07-15 09:24:50 +0200 |
commit | 673d70dfc5ac5cab63bda1c0d0d5d7a21bf420e9 (patch) | |
tree | 052e49a443b04c57b9e19d89000507e01466b275 /lib/public | |
parent | b327b4fbe6d732cca06bb200921439ac1eba3f15 (diff) | |
download | nextcloud-server-673d70dfc5ac5cab63bda1c0d0d5d7a21bf420e9.tar.gz nextcloud-server-673d70dfc5ac5cab63bda1c0d0d5d7a21bf420e9.zip |
Add new dashboard public API
Signed-off-by: Julius Härtl <jus@bitgrid.net>
Diffstat (limited to 'lib/public')
-rw-r--r-- | lib/public/Dashboard/IManager.php | 46 | ||||
-rw-r--r-- | lib/public/Dashboard/IPanel.php | 69 | ||||
-rw-r--r-- | lib/public/Dashboard/IRegisterPanelEvent.php | 50 |
3 files changed, 165 insertions, 0 deletions
diff --git a/lib/public/Dashboard/IManager.php b/lib/public/Dashboard/IManager.php new file mode 100644 index 00000000000..a5185ae22a7 --- /dev/null +++ b/lib/public/Dashboard/IManager.php @@ -0,0 +1,46 @@ +<?php +/** + * @copyright Copyright (c) 2020 Julius Härtl <jus@bitgrid.net> + * + * @author Julius Härtl <jus@bitgrid.net> + * + * @license GNU AGPL version 3 or any later version + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + * + */ + +namespace OCP\Dashboard; + +/** + * Interface IManager + * + * @package OCP\Dashboard + * @since 20.0.0 + */ +interface IManager { + + /** + * @param IPanel $panel + * @since 20.0.0 + */ + public function registerPanel(IPanel $panel): void; + + /** + * @since 20.0.0 + * + * @return IPanel[] + */ + public function getPanels(): array; +} diff --git a/lib/public/Dashboard/IPanel.php b/lib/public/Dashboard/IPanel.php new file mode 100644 index 00000000000..1b0e3c11d1a --- /dev/null +++ b/lib/public/Dashboard/IPanel.php @@ -0,0 +1,69 @@ +<?php +/** + * @copyright Copyright (c) 2020 Julius Härtl <jus@bitgrid.net> + * + * @author Julius Härtl <jus@bitgrid.net> + * + * @license GNU AGPL version 3 or any later version + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + * + */ + +namespace OCP\Dashboard; + +/** + * Interface IPanel + * + * @package OCP\Dashboard + * @since 20.0.0 + */ +interface IPanel { + + /** + * @return string + * @since 20.0.0 + */ + public function getId(): string; + + /** + * @return string + * @since 20.0.0 + */ + public function getTitle(): string; + + /** + * @return int + * @since 20.0.0 + */ + public function getOrder(): int; + + /** + * @return string + * @since 20.0.0 + */ + public function getIconClass(): string; + + /** + * @return string The absolute path to an icon in SVG + * @since 20.0.0 + */ + public function getIconUrl(): string; + + /** + * @return string The absolute url to the apps own view + * @since 20.0.0 + */ + public function getUrl(): string; +} diff --git a/lib/public/Dashboard/IRegisterPanelEvent.php b/lib/public/Dashboard/IRegisterPanelEvent.php new file mode 100644 index 00000000000..f322d87d82d --- /dev/null +++ b/lib/public/Dashboard/IRegisterPanelEvent.php @@ -0,0 +1,50 @@ +<?php +/** + * @copyright Copyright (c) 2020 Julius Härtl <jus@bitgrid.net> + * + * @author Julius Härtl <jus@bitgrid.net> + * + * @license GNU AGPL version 3 or any later version + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as + * published by the Free Software Foundation, either version 3 of the + * License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + * + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + * + */ + +namespace OCP\Dashboard; + +use OCP\EventDispatcher\Event; + +/** + * Class IRegisterPanelEvent + * + * @package OCP\Dashboard + * @since 20.0.0 + */ +class IRegisterPanelEvent extends Event { + private $manager; + + public function __construct(IManager $manager) { + parent::__construct(); + + $this->manager = $manager; + } + + /** + * @param IPanel $panel + * @since 20.0.0 + */ + public function registerPanel(IPanel $panel) { + $this->manager->registerPanel($panel); + } +} |