trac750 Use Facebook dialogs for success and error messages during initial setup / login

darcs-hash:20081208015412-7b5ce-c899a3b743621f7d003b93f383b78a2c8ba9fb52.gz
This commit is contained in:
Zach Copley 2008-12-07 20:54:12 -05:00
parent e35f40528b
commit 1a8869424b
2 changed files with 62 additions and 79 deletions

View File

@ -34,7 +34,6 @@ class FacebookhomeAction extends FacebookAction {
$user = null; $user = null;
$facebook = $this->get_facebook(); $facebook = $this->get_facebook();
$fbuid = $facebook->require_login(); $fbuid = $facebook->require_login();
# check to see whether there's already a Facebook link for this user # check to see whether there's already a Facebook link for this user
@ -42,21 +41,12 @@ class FacebookhomeAction extends FacebookAction {
if ($flink) { if ($flink) {
$this->display($facebook, $fbuid);
$user = $flink->getUser(); $user = $flink->getUser();
$this->show_home($facebook, $fbuid, $user);
$notice = $user->getCurrentNotice();
echo $this->show_notices($user);
$this->update_profile_box($facebook, $fbuid, $user);
} else { } else {
# Make the user put in her Laconica creds
$nickname = common_canonical_nickname($this->trimmed('nickname')); $nickname = common_canonical_nickname($this->trimmed('nickname'));
$password = $this->arg('password'); $password = $this->arg('password');
@ -64,12 +54,11 @@ class FacebookhomeAction extends FacebookAction {
if (common_check_user($nickname, $password)) { if (common_check_user($nickname, $password)) {
echo '<h2>Successful authentication!</h2>';
$user = User::staticGet('nickname', $nickname); $user = User::staticGet('nickname', $nickname);
if (!$user) { if (!$user) {
echo '<h2>Couldn\'t get user!</h2>'; echo '<fb:error message="Coudln\'t get user!" />';
$this->show_login_form(); $this->show_login_form();
} }
@ -84,16 +73,15 @@ class FacebookhomeAction extends FacebookAction {
$flink_id = $flink->insert(); $flink_id = $flink->insert();
if ($flink_id) { if ($flink_id) {
echo '<h2>Successfully made Identi.ca -> Facebook link</h2>'; echo '<fb:success message="You can now use the Identi.ca from Facebook!" />';
} }
$this->display($facebook, $fbuid); $this->show_home($facebook, $fbuid, $user);
return; return;
} else { } else {
echo '<h2>Fail!</h2>'; echo '<fb:error message="Incorrect username or password." />';
} }
} }
$this->show_login_form(); $this->show_login_form();
@ -101,17 +89,16 @@ class FacebookhomeAction extends FacebookAction {
} }
function display($facebook, $fbuid) { function show_home($facebook, $fbuid, $user) {
$this->show_header('Home'); $this->show_header('Home');
// Greet the currently logged-in user! echo $this->show_notices($user);
echo "<p>Hello, <fb:name uid=\"$fbuid\" useyou=\"false\" />!</p>"; $this->update_profile_box($facebook, $fbuid, $user);
$this->show_footer(); $this->show_footer();
} }
function show_notices($user) { function show_notices($user) {
$page = $this->trimmed('page'); $page = $this->trimmed('page');
@ -142,58 +129,4 @@ class FacebookhomeAction extends FacebookAction {
} }
function update_profile_box($facebook, $fbuid, $user) {
$notice = $user->getCurrentNotice();
# Need to include CSS for styling the Profile box
$style = '<style>
#notices {
clear: both;
margin: 0 auto;
padding: 0;
list-style-type: none;
width: 600px;
border-top: 1px solid #dec5b5;
}
#notices a:hover {
text-decoration: underline;
}
.notice_single {
clear: both;
display: block;
margin: 0;
padding: 5px 5px 5px 0;
min-height: 48px;
font-family: Georgia, "Times New Roman", Times, serif;
font-size: 13px;
line-height: 16px;
border-bottom: 1px solid #dec5b5;
background-color:#FCFFF5;
opacity:1;
}
.notice_single:hover {
background-color: #f7ebcc;
}
.notice_single p {
display: inline;
margin: 0;
padding: 0;
}
</style>';
$html = $this->render_notice($notice);
$fbml = "<fb:wide>$content $html</fb:wide>";
$fbml .= "<fb:narrow>$content $html</fb:narrow>";
$fbml_main = "<fb:narrow>$content $html</fb:narrow>";
$facebook->api_client->profile_setFBML(NULL, $fbuid, $fbml, NULL, NULL, $fbml_main);
}
} }

View File

@ -33,6 +33,56 @@ class FacebookAction extends Action {
return new Facebook($apikey, $secret); return new Facebook($apikey, $secret);
} }
function update_profile_box($facebook, $fbuid, $user) {
$notice = $user->getCurrentNotice();
# Need to include inline CSS for styling the Profile box
$style = '<style>
#notices {
clear: both;
margin: 0 auto;
padding: 0;
list-style-type: none;
width: 600px;
border-top: 1px solid #dec5b5;
}
#notices a:hover {
text-decoration: underline;
}
.notice_single {
clear: both;
display: block;
margin: 0;
padding: 5px 5px 5px 0;
min-height: 48px;
font-family: Georgia, "Times New Roman", Times, serif;
font-size: 13px;
line-height: 16px;
border-bottom: 1px solid #dec5b5;
background-color:#FCFFF5;
opacity:1;
}
.notice_single:hover {
background-color: #f7ebcc;
}
.notice_single p {
display: inline;
margin: 0;
padding: 0;
}
</style>';
$html = $this->render_notice($notice);
$fbml = "<fb:wide>$content $html</fb:wide>";
$fbml .= "<fb:narrow>$content $html</fb:narrow>";
$fbml_main = "<fb:narrow>$content $html</fb:narrow>";
$facebook->api_client->profile_setFBML(NULL, $fbuid, $fbml, NULL, NULL, $fbml_main);
}
# Display methods # Display methods