summaryrefslogtreecommitdiff
path: root/modules/server_add/helpers/server_add_menu.php
diff options
context:
space:
mode:
authorChad Kieffer <ckieffer@gmail.com>2009-06-02 22:55:23 -0600
committerChad Kieffer <ckieffer@gmail.com>2009-06-02 22:55:23 -0600
commit1df6db45dc569cc6f18a9d1622fce5ebe62f8d30 (patch)
treee4e8cac619bc2443c3e26d0f87a25c51f8a3b273 /modules/server_add/helpers/server_add_menu.php
parent2bd8051c28621f6c25a3f85b73da2f94d62440f2 (diff)
parentdde5fb96ee9db5a67b286ea4ac4f35190453a6ef (diff)
Merge branch 'master' of git@github.com:gallery/gallery3
Diffstat (limited to 'modules/server_add/helpers/server_add_menu.php')
-rw-r--r--modules/server_add/helpers/server_add_menu.php41
1 files changed, 33 insertions, 8 deletions
diff --git a/modules/server_add/helpers/server_add_menu.php b/modules/server_add/helpers/server_add_menu.php
index 04c94493..f02223f7 100644
--- a/modules/server_add/helpers/server_add_menu.php
+++ b/modules/server_add/helpers/server_add_menu.php
@@ -28,16 +28,41 @@ class server_add_menu_Core {
static function site($menu, $theme) {
$item = $theme->item();
-
$paths = unserialize(module::get_var("server_add", "authorized_paths"));
- if ($item && access::can("edit", $item) && access::can("server_add", $item) &&
- $item->is_album() && !empty($paths)) {
- $options_menu = $menu->get("options_menu")
- ->append(Menu::factory("dialog")
- ->id("server_add")
- ->label(t("Add from server"))
- ->url(url::site("server_add/index/$item->id")));
+ if (user::active()->admin && $item->is_album() && !empty($paths)) {
+ // This is a little tricky. Normally there's an "Add Photo" menu option, but we want to
+ // turn that into a dropdown if there are two different ways to add things. Do that in a
+ // portable way for now. If we find ourselves duplicating this pattern, we should make an
+ // API method for this.
+ $server_add = Menu::factory("dialog")
+ ->id("server_add")
+ ->label(t("Add from server"))
+ ->url(url::site("server_add/index/$item->id"));
+ $options_menu = $menu->get("options_menu");
+ $add_photos_item = $menu->get("add_photos_item");
+ $add_photos_menu = $menu->get("add_photos_menu");
+
+ if ($add_photos_item && !$add_photos_menu) {
+ // Assuming that $add_menu is unset, create add_menu and add our item
+ $menu->add_after(
+ "home",
+ Menu::factory("submenu")
+ ->id("add_photos_menu")
+ ->label(t("Add Photos"))
+ ->append(Menu::factory("dialog")
+ ->id("add_photos_submenu_item")
+ ->label(t("via Simple Uploader"))
+ ->url(url::site("simple_uploader/app/$item->id")))
+ ->append($server_add));
+ $menu->remove("add_photos_item");
+ } else if ($add_photos_menu) {
+ // Append to the existing sub-menu
+ $add_photos_menu->append($server_add);
+ } else {
+ // Else just add it in at the end of Options
+ $options_menu->append($server_add);
+ }
}
}
}