summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBharat Mediratta <bharat@menalto.com>2009-07-10 07:37:20 -0700
committerBharat Mediratta <bharat@menalto.com>2009-07-10 07:37:20 -0700
commitde39dcbce67f934085621ac7838980d42bfd1bb9 (patch)
tree78645b89ddb657f122f283f3bbf0924ad7258aa7
parentab5695ca575da4d5842d4c94924c3ee5c4a6faad (diff)
parenta059eff25d3e4975f39ad04181039d4544e47059 (diff)
Merge branch 'master' of git@github.com:gallery/gallery3
-rw-r--r--modules/dynamic/controllers/admin_dynamic.php81
-rw-r--r--modules/dynamic/controllers/dynamic.php64
-rw-r--r--modules/dynamic/helpers/dynamic_installer.php46
-rw-r--r--modules/dynamic/helpers/dynamic_menu.php27
-rw-r--r--modules/dynamic/helpers/dynamic_theme.php39
-rw-r--r--modules/dynamic/module.info3
-rw-r--r--modules/dynamic/views/admin_dynamic.html.php5
-rw-r--r--modules/dynamic/views/dynamic_block.html.php10
-rw-r--r--modules/g2_import/helpers/g2_import.php4
-rw-r--r--modules/tag/helpers/tag_event.php9
10 files changed, 284 insertions, 4 deletions
diff --git a/modules/dynamic/controllers/admin_dynamic.php b/modules/dynamic/controllers/admin_dynamic.php
new file mode 100644
index 00000000..50dac459
--- /dev/null
+++ b/modules/dynamic/controllers/admin_dynamic.php
@@ -0,0 +1,81 @@
+<?php defined("SYSPATH") or die("No direct script access.");/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2009 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 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
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+class Admin_Dynamic_Controller extends Admin_Controller {
+ public function index() {
+ print $this->_get_view();
+ }
+
+ public function handler() {
+ access::verify_csrf();
+
+ $form = $this->_get_form();
+ if ($form->validate()) {
+ foreach (array("updates", "popular") as $album) {
+ $album_defn = unserialize(module::get_var("dynamic", $album));
+ $group = $form->inputs[$album];
+ $album_defn->enabled = $group->inputs["{$album}_enabled"]->value;
+ $album_defn->description = $group->inputs["{$album}_description"]->value;
+ $album_defn->limit = $group->inputs["{$album}_limit"] === "" ? null :
+ $group->inputs["{$album}_limit"]->value;
+ module::set_var("dynamic", $album, serialize($album_defn));
+ }
+
+ message::success(t("Dynamic Albums Configured"));
+
+ url::redirect("admin/dynamic");
+ }
+
+ print $this->_get_view($form);
+ }
+
+ private function _get_view($form=null) {
+ $v = new Admin_View("admin.html");
+ $v->content = new View("admin_dynamic.html");
+ $v->content->form = empty($form) ? $this->_get_form() : $form;
+ return $v;
+ }
+
+ private function _get_form() {
+
+ $form = new Forge("admin/dynamic/handler", "", "post",
+ array("id" => "gAdminForm"));
+
+ foreach (array("updates", "popular") as $album) {
+ $album_defn = unserialize(module::get_var("dynamic", $album));
+
+ $group = $form->group($album)->label(t($album_defn->title));
+ $group->checkbox("{$album}_enabled")
+ ->label(t("Enable"))
+ ->value(1)
+ ->checked($album_defn->enabled);
+ $group->input("{$album}_limit")
+ ->label(t("Limit (leave empty for unlimited)"))
+ ->value(empty($album_defn->limit) ? "" : $album_defn->limit)
+ ->rules("valid_numeric");
+ $group->textarea("{$album}_description")
+ ->label(t("Description"))
+ ->rules("length[0,2048]")
+ ->value($album_defn->description);
+ }
+
+ $form->submit("submit")->value(t("Submit"));
+
+ return $form;
+ }
+} \ No newline at end of file
diff --git a/modules/dynamic/controllers/dynamic.php b/modules/dynamic/controllers/dynamic.php
new file mode 100644
index 00000000..6b5f2915
--- /dev/null
+++ b/modules/dynamic/controllers/dynamic.php
@@ -0,0 +1,64 @@
+<?php defined("SYSPATH") or die("No direct script access.");/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2009 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 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
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+class Dynamic_Controller extends Controller {
+ public function updates() {
+ print $this->_show("updates");
+ }
+
+ public function popular() {
+ print $this->_show("popular");
+ }
+
+ private function _show($album) {
+ $page_size = module::get_var("gallery", "page_size", 9);
+ $page = $this->input->get("page", "1");
+
+ $album_defn = unserialize(module::get_var("dynamic", $album));
+ $children_count = $album_defn->limit;
+ if (empty($children_count)) {
+ $children_count = ORM::factory("item")
+ ->viewable()
+ ->where("type !=", "album")
+ ->count_all();
+ }
+
+ $offset = ($page-1) * $page_size;
+
+ $max_pages = ceil($children_count / $page_size);
+
+ // Make sure that the page references a valid offset
+ if ($page < 1 || ($children_count && $page > ceil($children_count / $page_size))) {
+ Kohana::show_404();
+ }
+
+ $template = new Theme_View("page.html", "dynamic");
+ $template->set_global("page_size", $page_size);
+ $template->set_global("children", ORM::factory("item")
+ ->viewable()
+ ->where("type !=", "album")
+ ->orderby($album_defn->key_field, "DESC")
+ ->find_all($page_size, $offset));
+ $template->set_global("children_count", $children_count);
+ $template->content = new View("dynamic.html");
+ $template->content->title = t($album_defn->title);
+
+ print $template;
+ }
+
+} \ No newline at end of file
diff --git a/modules/dynamic/helpers/dynamic_installer.php b/modules/dynamic/helpers/dynamic_installer.php
new file mode 100644
index 00000000..66d6298d
--- /dev/null
+++ b/modules/dynamic/helpers/dynamic_installer.php
@@ -0,0 +1,46 @@
+<?php defined("SYSPATH") or die("No direct script access.");/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2009 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 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
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+class dynamic_installer {
+ static function install() {
+ $version = module::get_version("dynamic");
+ if ($version == 0) {
+ module::set_var("dynamic", "popular",
+ serialize((object)array("enabled" => false,
+ "limit" => null,
+ "description" => "",
+ "key_field" => "view_count",
+ "title" => t("Most Viewed"))));
+ module::set_var("dynamic", "updates",
+ serialize((object)array("enabled" => false,
+ "limit" => null,
+ "description" => "",
+ "key_field" => "created",
+ "title" => t("Recent Changes"))));
+ module::set_version("dynamic", 1);
+ }
+ }
+
+ static function upgrade($version) {
+ }
+
+ static function uninstall() {
+ /* @todo Put database table drops here */
+ module::delete("dynamic");
+ }
+}
diff --git a/modules/dynamic/helpers/dynamic_menu.php b/modules/dynamic/helpers/dynamic_menu.php
new file mode 100644
index 00000000..b2c73d6f
--- /dev/null
+++ b/modules/dynamic/helpers/dynamic_menu.php
@@ -0,0 +1,27 @@
+<?php defined("SYSPATH") or die("No direct script access.");/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2009 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 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
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+class dynamic_menu {
+ static function admin($menu, $theme) {
+ $menu->get("content_menu")
+ ->append(Menu::factory("link")
+ ->id("dynamic_menu")
+ ->label(t("Dynamic Albums"))
+ ->url(url::site("admin/dynamic")));
+ }
+}
diff --git a/modules/dynamic/helpers/dynamic_theme.php b/modules/dynamic/helpers/dynamic_theme.php
new file mode 100644
index 00000000..ba355098
--- /dev/null
+++ b/modules/dynamic/helpers/dynamic_theme.php
@@ -0,0 +1,39 @@
+<?php defined("SYSPATH") or die("No direct script access.");/**
+ * Gallery - a web based photo album viewer and editor
+ * Copyright (C) 2000-2009 Bharat Mediratta
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 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
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+class dynamic_theme {
+ static function sidebar_blocks($theme) {
+ $albums = array();
+ foreach (array("updates", "popular") as $album) {
+ $album_defn = unserialize(module::get_var("dynamic", $album));
+ if ($album_defn->enabled) {
+ $albums[$album] = $album_defn->title;
+ }
+ }
+ if (!empty($albums)) {
+ $block = new Block();
+ $block->css_id = "gDynamic";
+ $block->title = t("Dynamic Albums");
+ $block->content = new View("dynamic_block.html");
+ $block->content->albums = $albums;
+ return $block;
+ }
+ return "";
+ }
+
+}
diff --git a/modules/dynamic/module.info b/modules/dynamic/module.info
new file mode 100644
index 00000000..aa5e0432
--- /dev/null
+++ b/modules/dynamic/module.info
@@ -0,0 +1,3 @@
+name = Dynamic
+description = Adds the Recent Changes and Most Viewed dynamic albums
+version = 1
diff --git a/modules/dynamic/views/admin_dynamic.html.php b/modules/dynamic/views/admin_dynamic.html.php
new file mode 100644
index 00000000..cd7ccfea
--- /dev/null
+++ b/modules/dynamic/views/admin_dynamic.html.php
@@ -0,0 +1,5 @@
+<?php defined("SYSPATH") or die("No direct script access.") ?>
+<div id="gAdminDynamic">
+ <h2> <?= t("Dynamic Albums") ?> </h2>
+ <?= $form ?>
+</div>
diff --git a/modules/dynamic/views/dynamic_block.html.php b/modules/dynamic/views/dynamic_block.html.php
new file mode 100644
index 00000000..d14c2900
--- /dev/null
+++ b/modules/dynamic/views/dynamic_block.html.php
@@ -0,0 +1,10 @@
+<?php defined("SYSPATH") or die("No direct script access.") ?>
+<div class="gDynamicBlock">
+ <ul>
+ <? foreach ($albums as $album => $text): ?>
+ <li>
+ <a href="<?= url::site("dynamic/$album") ?>"><?= t($text) ?></a>
+ </li>
+ <? endforeach ?>
+ </ul>
+</div>
diff --git a/modules/g2_import/helpers/g2_import.php b/modules/g2_import/helpers/g2_import.php
index d67d4c04..7dd799c8 100644
--- a/modules/g2_import/helpers/g2_import.php
+++ b/modules/g2_import/helpers/g2_import.php
@@ -623,8 +623,10 @@ class g2_import_Core {
}
$tags = "";
+ // Multiword tags have the space changed to dots.s
foreach ($tag_names as $tag_name) {
- $tags .= (strlen($tags) ? ", " : "") . tag::add($g3_item, $tag_name);
+ $tags .= (strlen($tags) ? ", " : "") .
+ tag::add($g3_item, preg_replace('/\s+/', '.', $tag_name));
}
// Tag operations are idempotent so we don't need to map them. Which is good because we don't
diff --git a/modules/tag/helpers/tag_event.php b/modules/tag/helpers/tag_event.php
index 946326c0..7a170bf8 100644
--- a/modules/tag/helpers/tag_event.php
+++ b/modules/tag/helpers/tag_event.php
@@ -34,10 +34,13 @@ class tag_event_Core {
if (!empty($iptc["2#025"])) {
foreach($iptc["2#025"] as $tag) {
$tag = str_replace("\0", "", $tag);
- if (function_exists("mb_detect_encoding") && mb_detect_encoding($tag) != "UTF-8") {
- $tag = utf8_encode($tag);
+ foreach (preg_split("/[,;]/", $tag) as $word) {
+ $word = preg_replace('/\s+/', '.', trim($word));
+ if (function_exists("mb_detect_encoding") && mb_detect_encoding($word) != "UTF-8") {
+ $word = utf8_encode($word);
+ }
+ $tags[$word] = 1;
}
- $tags[$tag] = 1;
}
}
}