diff --git a/modules/photoannotation/controllers/admin_photoannotation.php b/modules/photoannotation/controllers/admin_photoannotation.php
index 80afecdf..535c004a 100644
--- a/modules/photoannotation/controllers/admin_photoannotation.php
+++ b/modules/photoannotation/controllers/admin_photoannotation.php
@@ -50,33 +50,7 @@ class Admin_Photoannotation_Controller extends Admin_Controller {
$tag_annotations = ORM::factory("items_face")->where("tag_id", "=", $sourcetag->id)->find_all();
foreach ($tag_annotations as $tag_annotation) {
- //Check if there are already user annotations of the target user on photo
- $user_annotations = ORM::factory("items_user")
- ->where("item_id", "=", $tag_annotation->item_id)
- ->where("user_id", "=", $targetuser->id)
- ->find_all();
- if (count($user_annotations) > 1) {
- //If there are more than one existing annotations, delete all and create a new one
- foreach ($user_annotations as $user_annotation) {
- $user_annotation->delete();
- }
- $target_annotation = ORM::factory("items_user");
- } elseif (count($user_annotations) == 1) {
- //If there is only one existing annotation, load it and update it
- $target_annotation = ORM::factory("items_user", $user_annotations[0]->id);
- } else {
- //If there are no existing annotations create one
- $target_annotation = ORM::factory("items_user");
- }
- //Save values from tag annotation to user annotation and save it
- $target_annotation->user_id = $targetuser->id;
- $target_annotation->item_id = $tag_annotation->item_id;
- $target_annotation->x1 = $tag_annotation->x1;
- $target_annotation->y1 = $tag_annotation->y1;
- $target_annotation->x2 = $tag_annotation->x2;
- $target_annotation->y2 = $tag_annotation->y2;
- $target_annotation->description = $tag_annotation->description;
- $target_annotation->save();
+ photoannotation::saveuser($targetuser->id, $tag_annotation->item_id, $tag_annotation->x1, $tag_annotation->y1, $tag_annotation->x2, $tag_annotation->y2, $tag_annotation->description);
//Delete the old annotation
$tag_annotation->delete();
}
@@ -115,6 +89,18 @@ class Admin_Photoannotation_Controller extends Admin_Controller {
"photoannotation", "nonotifications", $form->notifications->nonotifications->value, true);
module::set_var(
"photoannotation", "notificationoptout", $form->notifications->notificationoptout->value, true);
+ module::set_var(
+ "photoannotation", "newtagsubject", $form->newtagmail->newtagsubject->value);
+ module::set_var(
+ "photoannotation", "newtagbody", $form->newtagmail->newtagbody->value);
+ module::set_var(
+ "photoannotation", "newcommentsubject", $form->newcommentmail->newcommentsubject->value);
+ module::set_var(
+ "photoannotation", "newcommentbody", $form->newcommentmail->newcommentbody->value);
+ module::set_var(
+ "photoannotation", "updatedcommentsubject", $form->updatedcommentmail->updatedcommentsubject->value);
+ module::set_var(
+ "photoannotation", "updatedcommentbody", $form->updatedcommentmail->updatedcommentbody->value);
module::set_var(
"photoannotation", "onuserdelete", $form->onuserdelete->onuserdelete->value);
message::success(t("Your settings have been saved."));
@@ -240,6 +226,11 @@ class Admin_Photoannotation_Controller extends Admin_Controller {
}
private function _get_form() {
+ if (module::is_active("comment")) {
+ $comment_required = "";
+ } else {
+ $comment_required = " (comment module required)";
+ }
$form = new Forge("admin/photoannotation/handler", "", "post", array("id" => "g-admin-form"));
$group = $form->group("hoverphoto")->label(t("Hovering over the photo"));
$group->checkbox("noborder")->label(t("Don't show borders."))
@@ -273,6 +264,21 @@ class Admin_Photoannotation_Controller extends Admin_Controller {
->checked(module::get_var("photoannotation", "nonotifications", false));
$group->checkbox("notificationoptout")->label(t("Notify users by default (only applies to new users and user who have not saved their profile after installing this module)."))
->checked(module::get_var("photoannotation", "notificationoptout", false));
+ $group = $form->group("newtagmail")->label(t("Customize the mail sent to users when a user annotation is created"));
+ $group->input("newtagsubject")->label(t("Subject"))
+ ->value(module::get_var("photoannotation", "newtagsubject", "Someone tagged a photo of you"));
+ $group->textarea("newtagbody")->label(t("Body (allowed placeholders: %name = name of the recipient, %url = link to the item that was tagged)"))
+ ->value(module::get_var("photoannotation", "newtagbody", "Hello %name, please visit %url to view the photo."));
+ $group = $form->group("newcommentmail")->label(t("Customize the mail sent to users when a comment is added". $comment_required));
+ $group->input("newcommentsubject")->label(t("Subject"))
+ ->value(module::get_var("photoannotation", "newcommentsubject", "Someone added a comment to photo of you"));
+ $group->textarea("newcommentbody")->label(t("Body (allowed placeholders: %name = name of the recipient, %url = link to the item that was commented on)"))
+ ->value(module::get_var("photoannotation", "newcommentbody", "Hello %name, please visit %url to read the comment."));
+ $group = $form->group("updatedcommentmail")->label(t("Customize the mail sent to users when a comment is updated". $comment_required));
+ $group->input("updatedcommentsubject")->label(t("Subject"))
+ ->value(module::get_var("photoannotation", "updatedcommentsubject", "Someone updated a comment to photo of you"));
+ $group->textarea("updatedcommentbody")->label(t("Body (allowed placeholders: %name = name of the recipient, %url = link to the item that was commented on)"))
+ ->value(module::get_var("photoannotation", "updatedcommentbody", "Hello %name, please visit %url to read the comment."));
$group = $form->group("onuserdelete")->label(t("Auto conversion settings"));
$group->dropdown("onuserdelete")->label(t("When deleting a user do the following with all annotations associated with this user"))
->options(array("0" => t("Delete annotation"), "1" => t("Convert to tag annotation"), "2" => t("Convert to note annotation")))
diff --git a/modules/photoannotation/controllers/photoannotation.php b/modules/photoannotation/controllers/photoannotation.php
index ab8fbf20..0ba8a79c 100644
--- a/modules/photoannotation/controllers/photoannotation.php
+++ b/modules/photoannotation/controllers/photoannotation.php
@@ -51,11 +51,11 @@ class photoannotation_Controller extends Controller {
//Save annotation
if ($annotate_id == "new") { //This is a new annotation
if ($user_id > -1) { //Save user
- $this->_saveuser($user_id, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
+ photoannotation::saveuser($user_id, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
} elseif ($tag_data > -1) { //Conversion user -> face
- $this->_saveface($tag_data, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
+ photoannotation::saveface($tag_data, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
} elseif ($item_title != "") { //Conversion user -> note
- $this->_savenote($item_title, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
+ photoannotation::savenote($item_title, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
} else { //Somethings wrong
message::error(t("Please select a User or Tag or specify a Title."));
url::redirect($redir_uri);
@@ -68,12 +68,12 @@ class photoannotation_Controller extends Controller {
->where("id", "=", $annotate_id)
->find();
if ($user_id > -1) { //Conversion user -> user
- $this->_saveuser($user_id, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
+ photoannotation::saveuser($user_id, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
} elseif ($tag_data > -1) { //Conversion user -> face
- $this->_saveface($tag_data, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
+ photoannotation::saveface($tag_data, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
$updateduser->delete(); //delete old user
} elseif ($item_title != "") { //Conversion user -> note
- $this->_savenote($item_title, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
+ photoannotation::savenote($item_title, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
$updateduser->delete(); //delete old user
} else { //Somethings wrong
message::error(t("Please select a User or Tag or specify a Title."));
@@ -86,12 +86,12 @@ class photoannotation_Controller extends Controller {
->where("id", "=", $annotate_id)
->find();
if ($user_id > -1) { //Conversion face -> user
- $this->_saveuser($user_id, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
+ photoannotation::saveuser($user_id, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
$updatedface->delete(); //delete old face
} elseif ($tag_data > -1) { //Conversion face -> face
- $this->_saveface($tag_data, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description, $annotate_id);
+ photoannotation::saveface($tag_data, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description, $annotate_id);
} elseif ($item_title != "") { //Conversion face -> note
- $this->_savenote($item_title, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
+ photoannotation::savenote($item_title, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
$updatedface->delete(); //delete old face
} else { //Somethings wrong
message::error(t("Please select a User or Tag or specify a Title."));
@@ -104,13 +104,13 @@ class photoannotation_Controller extends Controller {
->where("id", "=", $annotate_id)
->find();
if ($user_id > -1) { //Conversion note -> user
- $this->_saveuser($user_id, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
+ photoannotation::saveuser($user_id, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
$updatednote->delete(); //delete old note
} elseif ($tag_data > -1) { //Conversion note -> face
- $this->_saveface($tag_data, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
+ photoannotation::saveface($tag_data, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description);
$updatednote->delete(); //delete old note
} elseif ($item_title != "") { //Conversion note -> note
- $this->_savenote($item_title, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description, $annotate_id);
+ photoannotation::savenote($item_title, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description, $annotate_id);
} else { //Somethings wrong
message::error(t("Please select a User or Tag or specify a Title."));
url::redirect($redir_uri);
@@ -161,106 +161,4 @@ class photoannotation_Controller extends Controller {
message::success(t("Annotation deleted."));
url::redirect($redir_uri);
}
-
- private function _saveuser($user_id, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description) {
- //Since we are associating a user we will remove any old annotation of this user on this photo
- $item_old_users = ORM::factory("items_user")
- ->where("user_id", "=", $user_id)
- ->where("item_id", "=", $item_id)
- ->find_all();
- if (count($item_old_users) > 1) {
- foreach ($item_old_users as $item_old_user) {
- $item_old_user->delete();
- }
- $item_user = ORM::factory("items_user");
- } elseif (count($item_old_users) == 1) {
- $item_user = ORM::factory("items_user", $item_old_users[0]->id);
- } else {
- $item_user = ORM::factory("items_user");
- if (!module::get_var("photoannotation", "nonotifications", false)) {
- $notification_settings = ORM::factory("photoannotation_notification")->where("user_id", "=", $user_id)->find();
- if (!$notification_settings->loaded()) {
- $notify = module::get_var("photoannotation", "notificationoptout", false);
- $notification_settings = ORM::factory("photoannotation_notification");
- $notification_settings->user_id = $user_id;
- $notification_settings->newtag = $notify;
- $notification_settings->comment = $notify;
- $notification_settings->save();
- }
- if ($notification_settings->newtag) {
- $user_recipient = ORM::factory("user")->where("id", "=", $user_id)->find();
- if ($user_recipient->email != "") {
- $recipient = $user_recipient->email;
- $subject = t("Somebody has tagged a photo of you");
- $item_notify = ORM::factory("item")->where("id", "=", $item_id)->find();
- $body = t("Please visit the gallery to view the photo.", array("url" => $item_notify->resize_url(true)));
- Sendmail::factory()
- ->to($recipient)
- ->subject($subject)
- ->header("Mime-Version", "1.0")
- ->header("Content-type", "text/html; charset=utf-8")
- ->message($body)
- ->send();
- }
- }
- }
- }
- $item_user->user_id = $user_id;
- $item_user->item_id = $item_id;
- $item_user->x1 = $str_x1;
- $item_user->y1 = $str_y1;
- $item_user->x2 = $str_x2;
- $item_user->y2 = $str_y2;
- $item_user->description = $description;
- $item_user->save();
- }
-
- private function _saveface($tag_id, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description, $annotate_id = "") {
- if ($annotate_id == "") {
- $item_face = ORM::factory("items_face");
- } else {
- $item_face = ORM::factory("items_face")
- ->where("id", "=", $annotate_id)
- ->find();
- }
- $item_face->tag_id = $tag_id;
- $item_face->item_id = $item_id;
- $item_face->x1 = $str_x1;
- $item_face->y1 = $str_y1;
- $item_face->x2 = $str_x2;
- $item_face->y2 = $str_y2;
- $item_face->description = $description;
- $item_face->save();
- }
-
- private function _savenote($item_title, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description, $annotate_id = "") {
- if ($annotate_id == "") {
- $item_note = ORM::factory("items_note");
- } else {
- $item_note = ORM::factory("items_note")
- ->where("id", "=", $annotate_id)
- ->find();
- }
- $item_note->item_id = $item_id;
- $item_note->x1 = $str_x1;
- $item_note->y1 = $str_y1;
- $item_note->x2 = $str_x2;
- $item_note->y2 = $str_y2;
- $item_note->title = $item_title;
- $item_note->description = $description;
- $item_note->save();
- }
-
- private function _send_tag_created($user_id, $item_id) {
- $recipient = ORM::factory("user", $user_id);
- if ($recipient->email) {
- Sendmail::factory()
- ->to($recipient->email)
- ->subject($t("Someone has tagged a photo with you on it"))
- ->header("Mime-Version", "1.0")
- ->header("Content-Type", "text/html; charset=UTF-8")
- ->message($text)
- ->send();
- }
- }
}
diff --git a/modules/photoannotation/helpers/photoannotation.php b/modules/photoannotation/helpers/photoannotation.php
new file mode 100644
index 00000000..3e45265f
--- /dev/null
+++ b/modules/photoannotation/helpers/photoannotation.php
@@ -0,0 +1,171 @@
+where("user_id", "=", $user_id)
+ ->where("item_id", "=", $item_id)
+ ->find_all();
+ if (count($item_old_users) > 1) {
+ foreach ($item_old_users as $item_old_user) {
+ $item_old_user->delete();
+ }
+ $item_user = ORM::factory("items_user");
+ } elseif (count($item_old_users) == 1) {
+ $item_user = ORM::factory("items_user", $item_old_users[0]->id);
+ } else {
+ $item_user = ORM::factory("items_user");
+ photoannotation::send_notifications($user_id, $item_id, "newtag");
+ }
+ $item_user->user_id = $user_id;
+ $item_user->item_id = $item_id;
+ $item_user->x1 = $str_x1;
+ $item_user->y1 = $str_y1;
+ $item_user->x2 = $str_x2;
+ $item_user->y2 = $str_y2;
+ $item_user->description = $description;
+ $item_user->save();
+ }
+
+ public static function saveface($tag_id, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description, $annotate_id = "") {
+ if ($annotate_id == "") {
+ $item_face = ORM::factory("items_face");
+ } else {
+ $item_face = ORM::factory("items_face")
+ ->where("id", "=", $annotate_id)
+ ->find();
+ }
+ $item_face->tag_id = $tag_id;
+ $item_face->item_id = $item_id;
+ $item_face->x1 = $str_x1;
+ $item_face->y1 = $str_y1;
+ $item_face->x2 = $str_x2;
+ $item_face->y2 = $str_y2;
+ $item_face->description = $description;
+ $item_face->save();
+ }
+
+ public static function savenote($item_title, $item_id, $str_x1, $str_y1, $str_x2, $str_y2, $description, $annotate_id = "") {
+ if ($annotate_id == "") {
+ $item_note = ORM::factory("items_note");
+ } else {
+ $item_note = ORM::factory("items_note")
+ ->where("id", "=", $annotate_id)
+ ->find();
+ }
+ $item_note->item_id = $item_id;
+ $item_note->x1 = $str_x1;
+ $item_note->y1 = $str_y1;
+ $item_note->x2 = $str_x2;
+ $item_note->y2 = $str_y2;
+ $item_note->title = $item_title;
+ $item_note->description = $description;
+ $item_note->save();
+ }
+
+ public static function send_notifications($recipient_id, $item_id, $mailtype) {
+ //Load the item
+ $item = ORM::factory("item")->where("id", "=", $item_id)->find();
+ if (!$item->loaded()) {
+ return false;
+ }
+ //Load the user
+ $recipient = ORM::factory("user")->where("id", "=", $recipient_id)->find();
+ if (!$recipient->loaded()) {
+ return false;
+ }
+ //Only send mail if the notifications are switched on globally
+ if (!module::get_var("photoannotation", "nonotifications", false)) {
+ //Get the users settings
+ $notification_settings = self::get_user_notification_settings($recipient);
+ //Check which type of mail to send
+ switch ($mailtype) {
+ case "newtag":
+ //Only send if user has this option enabled
+ if ($notification_settings->newtag) {
+ //Get subject and body and send the mail
+ $subject = module::get_var("photoannotation", "newtagsubject", "Someone tagged a photo of you");
+ $body = module::get_var("photoannotation", "newtagbody", "Hello %name, please visit %url to view the photo.");
+ $body = str_ireplace(array("%url", "%name"), array($item->abs_url(), $recipient->display_name()), $body);
+ return self::_send_mail($recipient->email, $subject, $body);
+ }
+ break;
+ case "newcomment":
+ //Only send if user has this option enabled
+ if ($notification_settings->comment) {
+ //Get subject and body and send the mail
+ $subject = module::get_var("photoannotation", "newcommentsubject", "Someone added a comment to photo of you");
+ $body = module::get_var("photoannotation", "newcommentbody", "Hello %name, please visit %url to read the comment.");
+ $body = str_ireplace(array("%url", "%name"), array($item->abs_url(), $recipient->display_name()), $body);
+ return self::_send_mail($recipient->email, $subject, $body);
+ }
+ break;
+ case "updatecomment":
+ //Only send if user has this option enabled
+ if ($notification_settings->comment) {
+ //Get subject and body and send the mail
+ $subject = module::get_var("photoannotation", "updatedcommentsubject", "Someone updated a comment to photo of you");
+ $body = module::get_var("photoannotation", "updatedcommentbody", "Hello %name, please visit %url to read the comment.");
+ $body = str_ireplace(array("%url", "%name"), array($item->abs_url(), $recipient->display_name()), $body);
+ return self::_send_mail($recipient->email, $subject, $body);
+ }
+ }
+ }
+ return false;
+ }
+
+ private static function _send_mail($mailto, $subject, $message) {
+ //Send the notification mail
+ return Sendmail::factory()
+ ->to($mailto)
+ ->subject($subject)
+ ->header("Mime-Version", "1.0")
+ ->header("Content-type", "text/html; charset=utf-8")
+ ->message($message)
+ ->send();
+ }
+
+ public static function get_user_notification_settings($user) {
+ //Try loading the notification settings of user
+ $notification_settings = ORM::factory("photoannotation_notification")->where("user_id", "=", $user->id)->find();
+ if (!$notification_settings->loaded()) {
+ //If the user did not save his settings use the website default
+ $notify = module::get_var("photoannotation", "notificationoptout", false);
+ $notification_settings = ORM::factory("photoannotation_notification");
+ $notification_settings->user_id = $user->id;
+ $notification_settings->newtag = $notify;
+ $notification_settings->comment = $notify;
+ $notification_settings->save();
+ }
+ return $notification_settings;
+ }
+
+ public static function get_user_cloud() {
+ $users = ORM::factory("user")->order_by("name", "ASC")->find_all();
+ foreach ($users as $user) {
+ $items_users_count = ORM::factory("items_user")->where("user_id", "=", $user->id)->count_all();
+ if ($items_users_count > 0) {
+ $user_array[] = $user->display_name();
+ }
+ }
+ return $user_array;
+ }
+}
\ No newline at end of file
diff --git a/modules/photoannotation/helpers/photoannotation_event.php b/modules/photoannotation/helpers/photoannotation_event.php
index a88a9ba9..cf841ac3 100644
--- a/modules/photoannotation/helpers/photoannotation_event.php
+++ b/modules/photoannotation/helpers/photoannotation_event.php
@@ -108,30 +108,13 @@ class photoannotation_event_Core {
$tag->add($item);
$tag->count++;
$tag->save();
- $new_items_tag = ORM::factory("items_face");
- $new_items_tag->item_id = $existingFace->item_id;
- $new_items_tag->tag_id = $tag->id;
- $new_items_tag->x1 = $existingFace->x1;
- $new_items_tag->y1 = $existingFace->y1;
- $new_items_tag->x2 = $existingFace->x2;
- $new_items_tag->y2 = $existingFace->y2;
- $new_items_tag->description = $existingFace->description;
- $new_items_tag->save();
+ photoannotation::saveface($tag->id, $existingFace->item_id, $existingFace->x1, $existingFace->y1, $existingFace->x2, $existingFace->y2, $existingFace->description);
}
break;
case "2":
//convert to note
foreach ($existingFaces as $existingFace) {
- $item = ORM::factory("item")->where("id", "=", $existingFace->item_id)->find();
- $new_items_tag = ORM::factory("items_note");
- $new_items_tag->item_id = $existingFace->item_id;
- $new_items_tag->title = $new_tag_name;
- $new_items_tag->x1 = $existingFace->x1;
- $new_items_tag->y1 = $existingFace->y1;
- $new_items_tag->x2 = $existingFace->x2;
- $new_items_tag->y2 = $existingFace->y2;
- $new_items_tag->description = $existingFace->description;
- $new_items_tag->save();
+ photoannotation::savenote($new_tag_name, $existingFace->item_id, $existingFace->x1, $existingFace->y1, $existingFace->x2, $existingFace->y2, $existingFace->description);
}
}
db::build()->delete("items_users")->where("user_id", "=", $old->id)->execute();
@@ -212,15 +195,7 @@ class photoannotation_event_Core {
static function user_edit_form($user, $form) {
// Allow users to modify notification settings.
if (!module::get_var("photoannotation", "nonotifications", false)) {
- $notification_settings = ORM::factory("photoannotation_notification")->where("user_id", "=", $user->id)->find();
- if (!$notification_settings->loaded()) {
- $notify = module::get_var("photoannotation", "notificationoptout", false);
- $notification_settings = ORM::factory("photoannotation_notification");
- $notification_settings->user_id = $user->id;
- $notification_settings->newtag = $notify;
- $notification_settings->comment = $notify;
- $notification_settings->save();
- }
+ $notification_settings = photoannotation::get_user_notification_settings($user);
$user_notification = $form->edit_user->group("edit_notification")->label("Tag notifications");
$user_notification->checkbox("photoannotation_newtag")->label(t("Notify me when a tag is added to a photo with me"))
->checked($notification_settings->newtag);
@@ -234,6 +209,7 @@ class photoannotation_event_Core {
if (!module::get_var("photoannotation", "nonotifications", false)) {
$notification_settings = ORM::factory("photoannotation_notification")->where("user_id", "=", $user->id)->find();
if (!$notification_settings->loaded()) {
+ $notification_settings = ORM::factory("photoannotation_notification");
$notification_settings->user_id = $user->id;
}
$notification_settings->newtag = $form->edit_user->edit_notification->photoannotation_newtag->value;
@@ -243,75 +219,21 @@ class photoannotation_event_Core {
}
static function comment_created($comment) {
- //@todo: clean this up
- $comment = ORM::factory("comment")->where("id", "=", "52")->find();
- if (!module::get_var("photoannotation", "nonotifications", false)) {
- $item_users = ORM::factory("items_user")->where("item_id", "=", $comment->item_id)->find_all();
- if (count($item_users) > 0) {
- foreach ($item_users as $item_user) {
- $notification_settings = ORM::factory("photoannotation_notification")->where("user_id", "=", $item_user-user_id)->find();
- if (!$notification_settings->loaded()) {
- $notify = module::get_var("photoannotation", "notificationoptout", false);
- $notification_settings = ORM::factory("photoannotation_notification");
- $notification_settings->user_id = $item_user-user_id;
- $notification_settings->newtag = $notify;
- $notification_settings->comment = $notify;
- $notification_settings->save();
- }
- if ($notification_settings->newtag) {
- $user_recipient = ORM::factory("user")->where("id", "=", $item_user-user_id)->find();
- if ($user_recipient->email != "") {
- $recipient = $user_recipient->email;
- $subject = t("Somebody has commented on a photo of you");
- $item_notify = ORM::factory("item")->where("id", "=", $comment->item_id)->find();
- $body = t("Please visit the gallery to view the photo.", array("url" => $item_notify->resize_url(true)));
- Sendmail::factory()
- ->to($recipient)
- ->subject($subject)
- ->header("Mime-Version", "1.0")
- ->header("Content-type", "text/html; charset=utf-8")
- ->message($body)
- ->send();
- }
- }
- }
+ //Check if there are any user annotations on the photo and send notification if applicable
+ $item_users = ORM::factory("items_user")->where("item_id", "=", $comment->item_id)->find_all();
+ if (count($item_users) > 0) {
+ foreach ($item_users as $item_user) {
+ photoannotation::send_notifications($item_user->user_id, $comment->item_id, "newcomment");
}
}
}
static function comment_updated($comment) {
- //@todo: clean this up
- $comment = ORM::factory("comment")->where("id", "=", "52")->find();
- if (!module::get_var("photoannotation", "nonotifications", false)) {
- $item_users = ORM::factory("items_user")->where("item_id", "=", $comment->item_id)->find_all();
- if (count($item_users) > 0) {
- foreach ($item_users as $item_user) {
- $notification_settings = ORM::factory("photoannotation_notification")->where("user_id", "=", $item_user-user_id)->find();
- if (!$notification_settings->loaded()) {
- $notify = module::get_var("photoannotation", "notificationoptout", false);
- $notification_settings = ORM::factory("photoannotation_notification");
- $notification_settings->user_id = $item_user-user_id;
- $notification_settings->newtag = $notify;
- $notification_settings->comment = $notify;
- $notification_settings->save();
- }
- if ($notification_settings->newtag) {
- $user_recipient = ORM::factory("user")->where("id", "=", $item_user-user_id)->find();
- if ($user_recipient->email != "") {
- $recipient = $user_recipient->email;
- $subject = t("Somebody has updated a commented on a photo of you");
- $item_notify = ORM::factory("item")->where("id", "=", $comment->item_id)->find();
- $body = t("Please visit the gallery to view the photo.", array("url" => $item_notify->resize_url(true)));
- Sendmail::factory()
- ->to($recipient)
- ->subject($subject)
- ->header("Mime-Version", "1.0")
- ->header("Content-type", "text/html; charset=utf-8")
- ->message($body)
- ->send();
- }
- }
- }
+ //Check if there are any user annotations on the photo and send notification if applicable
+ $item_users = ORM::factory("items_user")->where("item_id", "=", $comment->item_id)->find_all();
+ if (count($item_users) > 0) {
+ foreach ($item_users as $item_user) {
+ photoannotation::send_notifications($item_user->user_id, $comment->item_id, "updatecomment");
}
}
}
diff --git a/modules/photoannotation/views/admin_photoannotation.html.php b/modules/photoannotation/views/admin_photoannotation.html.php
index c9fad7d0..8c059194 100644
--- a/modules/photoannotation/views/admin_photoannotation.html.php
+++ b/modules/photoannotation/views/admin_photoannotation.html.php
@@ -22,4 +22,9 @@
.bind('keyup', function(){
$(this).ColorPickerSetColor(this.value);
});
+ if (!module::is_active("comment")): ?>
+ $(document).ready(function(){
+ $("input[name='newcommentsubject'], input[name='updatedcommentsubject'], textarea[name='newcommentbody'], textarea[name='updatedcommentbody']").attr("disabled", true);
+ });
+ endif ?>