]> git.mxchange.org Git - friendica.git/commitdiff
contact "repair/relocate URL" tool
authorFriendika <info@friendika.com>
Thu, 14 Apr 2011 03:14:30 +0000 (20:14 -0700)
committerFriendika <info@friendika.com>
Thu, 14 Apr 2011 03:14:30 +0000 (20:14 -0700)
images/tools.png [new file with mode: 0644]
mod/contacts.php
mod/crepair.php [new file with mode: 0644]
view/contact_edit.tpl
view/crepair.tpl [new file with mode: 0644]
view/theme/duepuntozero/style.css

diff --git a/images/tools.png b/images/tools.png
new file mode 100644 (file)
index 0000000..c17094a
Binary files /dev/null and b/images/tools.png differ
index 834b1c63decf57fdce9ee0d946ae47431ea2c7af..ee7177d48eebb4225617786a66ffa9fa44a5202d 100644 (file)
@@ -272,6 +272,8 @@ function contacts_content(&$a) {
                        '$visit' => t('Visit $name\'s profile'),
                        '$blockunblock' => t('Block/Unblock contact'),
                        '$ignorecont' => t('Ignore contact'),
+                       '$altcrepair' => t('Repair contact URL settings'),
+                       '$lblcrepair' => t("Repair contact URL settings \x28WARNING: Advanced\x29"),
                        '$delete' => t('Delete contact'),
                        '$poll_interval' => contact_poll_interval($r[0]['priority']),
                        '$lastupdtext' => t('Last updated: '),
diff --git a/mod/crepair.php b/mod/crepair.php
new file mode 100644 (file)
index 0000000..617c381
--- /dev/null
@@ -0,0 +1,105 @@
+<?php
+
+function crepair_post(&$a) {
+       if(! local_user())
+               return;
+
+       $cid = (($a->argc > 1) ? intval($a->argv[1]) : 0);
+
+       if($cid) {
+               $r = q("SELECT * FROM `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1",
+                       intval($cid),
+                       intval(local_user())
+               );
+       }
+
+       if(! count($r))
+               return;
+
+       $contact = $r[0];
+
+       $nick    = ((x($_POST,'nick')) ? $_POST['nick'] : null);
+       $url     = ((x($_POST,'url')) ? $_POST['url'] : null);
+       $request = ((x($_POST,'request')) ? $_POST['request'] : null);
+       $confirm = ((x($_POST,'confirm')) ? $_POST['confirm'] : null);
+       $notify  = ((x($_POST,'notify')) ? $_POST['notify'] : null);
+       $poll    = ((x($_POST,'poll')) ? $_POST['poll'] : null);
+
+
+       $r = q("UPDATE `contact` SET `nick` = '%s', `url` = '%s', `request` = '%s', `confirm` = '%s', `notify` = '%s', `poll` = '%s'
+               WHERE `id` = %d AND `uid` = %d LIMIT 1",
+               dbesc($nick),
+               dbesc($url),
+               dbesc($request),
+               dbesc($confirm),
+               dbesc($notify),
+               dbesc($poll),
+               intval($contact['id']),
+               local_user()
+       );
+
+       if($r)
+               notice( t('Contact settings applied.') . EOL);
+       else
+               notice( t('Contact update failed.') . EOL);
+
+       return;
+}
+
+
+
+function crepair_content(&$a) {
+
+       if(! local_user()) {
+               notice( t('Permission denied.') . EOL);
+               return;
+       }
+
+       $cid = (($a->argc > 1) ? intval($a->argv[1]) : 0);
+
+       if($cid) {
+               $r = q("SELECT * FROM `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1",
+                       intval($cid),
+                       intval(local_user())
+               );
+       }
+
+       if(! count($r)) {
+               notice( t('Contact not found.') . EOL);
+               return;
+       }
+
+       $contact = $r[0];
+
+       $msg1 = t('Repair Contact Settings');
+
+       $msg2 = t('<strong>WARNING: This is highly advanced</strong> and if you enter incorrect information your communications with this contact will stop working.');
+       $msg3 = t('Please use your browser \'Back\' button <strong>now</strong> if you are uncertain what to do on this page.');
+
+       $o .= '<h2>' . $msg1 . '</h2>';
+
+       $o .= '<div class="error-message">' . $msg2 . EOL . EOL. $msg3 . '</div>';
+
+       $tpl = load_view_file('view/crepair.tpl');
+       $o .= replace_macros($tpl, array(
+               '$label_name' => t('Name'),
+               '$label_nick' => t('Account Nickname'),
+               '$label_url' => t('Account URL'),
+               '$label_request' => t('Friend Request URL'),
+               '$label_confirm' => t('Friend Confirm URL'),
+               '$label_notify' => t('Notification Endpoint URL'),
+               '$label_poll' => t('Poll/Feed URL'),
+               '$contact_name' => $contact['name'],
+               '$contact_nick' => $contact['nick'],
+               '$contact_id'   => $contact['id'],
+               '$contact_url'  => $contact['url'],
+               '$request'      => $contact['request'],
+               '$confirm'      => $contact['confirm'],
+               '$notify'       => $contact['notify'],
+               '$poll'         => $contact['poll'],
+               '$lbl_submit'   => t('Submit')
+       ));
+
+       return $o;
+
+}
\ No newline at end of file
index 4c2c6c6f813df4808e1ef4eadc2371905484f61f..5e4f0233507eb63be57128b734047f6d3884b5d1 100644 (file)
@@ -20,6 +20,8 @@
                <div id="contact-edit-links" >
                        <a href="contacts/$contact_id/block" id="contact-edit-block-link" ><img src="images/b_block.gif" alt="$blockunblock" title="$block_text"/></a>
                        <a href="contacts/$contact_id/ignore" id="contact-edit-ignore-link" ><img src="images/no.gif" alt="$ignorecont" title="$ignore_text"/></a>
+                       <a href="crepair/$contact_id" id="contact-edit-repair" ><img src="images/tools.png" alt="$altcrepair" title="$lblcrepair"/></a>
+
                </div>
                <div id="contact-drop-links" >
                        <a href="contacts/$contact_id/drop" id="contact-edit-drop-link" onclick="return confirmDelete();" ><img src="images/b_drophide.gif" alt="$delete" title="$delete" onmouseover="imgbright(this);" onmouseout="imgdull(this);" /></a>
diff --git a/view/crepair.tpl b/view/crepair.tpl
new file mode 100644 (file)
index 0000000..5870bac
--- /dev/null
@@ -0,0 +1,34 @@
+
+<form id="crepair-form" action="crepair/$contact_id" method="post" >
+
+<h4>$contact_name</h4>
+
+<label id="crepair-nick-label" for="crepair-nick">$label_nick</label>
+<input type="text" id="crepair-nick" name="nick" value="$contact_nick" />
+<div class="clear"></div>
+
+<label id="crepair-url-label" for="crepair-url">$label_url</label>
+<input type="text" id="crepair-url" name="url" value="$contact_url" />
+<div class="clear"></div>
+
+<label id="crepair-request-label" for="crepair-request">$label_request</label>
+<input type="text" id="crepair-request" name="request" value="$request" />
+<div class="clear"></div>
+<label id="crepair-confirm-label" for="crepair-confirm">$label_confirm</label>
+<input type="text" id="crepair-confirm" name="confirm" value="$confirm" />
+<div class="clear"></div>
+
+<label id="crepair-notify-label" for="crepair-notify">$label_notify</label>
+<input type="text" id="crepair-notify" name="notify" value="$notify" />
+<div class="clear"></div>
+
+<label id="crepair-poll-label" for="crepair-poll">$label_poll</label>
+<input type="text" id="crepair-poll" name="poll" value="$poll" />
+<div class="clear"></div>
+
+<input type="submit" name="submit" value="$lbl_submit" />
+
+</form>
+
+
index 51bdb716b36be6ec985d444890c3711623a4c1b6..6658cd94a36093a12659ff005e9c7745822b6c26 100644 (file)
@@ -2293,3 +2293,24 @@ a.mail-list-link {
 #prof-edit-desc {
        margin-top: 15px;
 }
+
+#crepair-nick-label,
+#crepair-url-label,
+#crepair-request-label,
+#crepair-confirm-label,
+#crepair-notify-label,
+#crepair-poll-label {
+       float: left;
+       width: 200px;
+       margin-bottom: 15px;
+}
+
+#crepair-nick,
+#crepair-url,
+#crepair-request,
+#crepair-confirm,
+#crepair-notify,
+#crepair-poll {
+       float: left;
+       width: 300px;
+}