Browse Source
Support for "likes" and adding "settings" page
Support for "likes" and adding "settings" page
* Supports a bookmarklet to create "like" posts. * Beginning a "settings" page to connect silo profiles for POSSEing likes to twitter, facebook and instagrampull/5/head
Aaron Parecki
10 years ago
14 changed files with 419 additions and 44 deletions
-
3composer.json
-
67composer.lock
-
172controllers/controllers.php
-
7lib/config.template.php
-
20lib/helpers.php
-
17public/css/favorite.css
-
BINpublic/images/quill-logo-1024.png
-
8public/images/red-x.svg
-
8public/images/star.svg
-
23public/js/fav.js
-
8views/layout.php
-
22views/liked-js.php
-
20views/partials/fb-script.php
-
88views/settings.php
@ -0,0 +1,17 @@ |
|||||
|
|
||||
|
#quill-star { |
||||
|
position: absolute; |
||||
|
|
||||
|
top: 50%; |
||||
|
left: 50%; |
||||
|
margin-top: -100px; |
||||
|
margin-left: -100px; |
||||
|
|
||||
|
width: 200px; |
||||
|
height: 200px; |
||||
|
|
||||
|
} |
||||
|
|
||||
|
#quill-star.hidden { |
||||
|
display: none; |
||||
|
} |
After Width: 1024 | Height: 1024 | Size: 38 KiB |
@ -0,0 +1,8 @@ |
|||||
|
<?xml version="1.0" encoding="utf-8"?> |
||||
|
<!-- Generator: Adobe Illustrator 16.0.4, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> |
||||
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> |
||||
|
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" |
||||
|
width="108px" height="108px" viewBox="0 0 108 108" enable-background="new 0 0 108 108" xml:space="preserve"> |
||||
|
<line fill="none" stroke="#972D2C" stroke-width="20" stroke-miterlimit="10" x1="8.788" y1="8.308" x2="99.81" y2="99.329"/> |
||||
|
<line fill="none" stroke="#972D2C" stroke-width="20" stroke-miterlimit="10" x1="99.81" y1="8.308" x2="8.788" y2="99.329"/> |
||||
|
</svg> |
@ -0,0 +1,8 @@ |
|||||
|
<?xml version="1.0" encoding="utf-8"?> |
||||
|
<!-- Generator: Adobe Illustrator 16.0.4, SVG Export Plug-In . SVG Version: 6.00 Build 0) --> |
||||
|
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"> |
||||
|
<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" |
||||
|
width="108px" height="108px" viewBox="0 0 108 108" enable-background="new 0 0 108 108" xml:space="preserve"> |
||||
|
<polygon fill="#FCB117" points="54.306,4.549 70.476,37.312 106.633,42.566 80.47,68.069 86.646,104.079 54.306,87.077 |
||||
|
21.967,104.079 28.143,68.069 1.98,42.566 38.136,37.312 "/> |
||||
|
</svg> |
@ -0,0 +1,23 @@ |
|||||
|
console.log("Favoriting with token: " + quill_token); |
||||
|
|
||||
|
var http = new XMLHttpRequest(); |
||||
|
var params = "like-of=" + encodeURIComponent(window.location) + "&token=" + quill_token; |
||||
|
|
||||
|
http.open("POST", "http://quill.dev/favorite", true); |
||||
|
http.setRequestHeader("Content-Type", "application/x-www-form-urlencoded"); |
||||
|
|
||||
|
http.onreadystatechange = function() {//Call a function when the state changes.
|
||||
|
console.log(http); |
||||
|
if(http.readyState == 4 && http.status == 200) { |
||||
|
alert(http.responseText); |
||||
|
} |
||||
|
} |
||||
|
http.send(params); |
||||
|
|
||||
|
/* |
||||
|
|
||||
|
(function(){var el=document.createElement('input'); el.type="hidden"; el.id="quill_token"; el.value="eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoiMjciLCJtZSI6Imh0dHA6XC9cL2Fhcm9ucGFyZWNraS5jb20iLCJjcmVhdGVkX2F0IjoxNDEwMTE3NTM5fQ.ifp1VIgCTz9NPtMTlTLPBXAGSxHwpGS5tLPhXGxrjNk"; document.body.appendChild(el); document.body.appendChild(document.createElement('script')).src='http://quill.dev/js/fav.js';})(); |
||||
|
|
||||
|
(function(){document.body.appendChild(document.createElement('script')).src='http://quill.dev/favorite.js?url='+encodeURIComponent(window.location)+'&token=eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJ1c2VyX2lkIjoiMSIsIm1lIjoiaHR0cDpcL1wvcGsuZGV2XC8iLCJjcmVhdGVkX2F0IjoxNDE5MDM2NzAzfQ.AgJ5xyviiBzWOvQO0je0Bdi3BUpKJ4CLJnx8GIm-0OI';})(); |
||||
|
|
||||
|
*/ |
@ -0,0 +1,22 @@ |
|||||
|
<?= $this->facebook_id ? partial('partials/fb-script') : '' ?>
|
||||
|
|
||||
|
console.log("Favoriting URL: <?= $this->url ?>"); |
||||
|
|
||||
|
var star = document.createElement('img'); |
||||
|
star.id="quill-star"; |
||||
|
star.src="http://quill.dev/images/<?= $this->like_url ? 'star' : 'red-x' ?>.svg"; |
||||
|
document.body.appendChild(star); |
||||
|
|
||||
|
var css = document.createElement('link'); |
||||
|
css.rel="stylesheet"; |
||||
|
css.type="text/css"; |
||||
|
css.href="http://quill.dev/css/favorite.css"; |
||||
|
document.body.appendChild(css); |
||||
|
|
||||
|
setTimeout(function(){ |
||||
|
|
||||
|
document.getElementById('quill-star').classList.add('hidden'); |
||||
|
var el = document.getElementById('quill-star'); |
||||
|
el.parentNode.removeChild(el); |
||||
|
|
||||
|
}, 1200); |
@ -0,0 +1,20 @@ |
|||||
|
<script> |
||||
|
window.fbAsyncInit = function() { |
||||
|
FB.init({ |
||||
|
appId : '<?= Config::$fbClientID ?>', |
||||
|
xfbml : true, |
||||
|
version : 'v2.2' |
||||
|
}); |
||||
|
if(window.quillFbInit) { |
||||
|
window.quillFbInit(); |
||||
|
} |
||||
|
}; |
||||
|
|
||||
|
(function(d, s, id){ |
||||
|
var js, fjs = d.getElementsByTagName(s)[0]; |
||||
|
if (d.getElementById(id)) {return;} |
||||
|
js = d.createElement(s); js.id = id; |
||||
|
js.src = "//connect.facebook.net/en_US/sdk.js"; |
||||
|
fjs.parentNode.insertBefore(js, fjs); |
||||
|
}(document, 'script', 'facebook-jssdk')); |
||||
|
</script> |
@ -0,0 +1,88 @@ |
|||||
|
<div class="narrow"> |
||||
|
<?= partial('partials/header') ?>
|
||||
|
|
||||
|
<h2>Signed In As</h2> |
||||
|
<code><?= session('me') ?></code>
|
||||
|
|
||||
|
<h3>Facebook</h3> |
||||
|
<input type="button" id="facebook-button" value="Checking" class="btn"> |
||||
|
|
||||
|
<h3>Twitter</h3> |
||||
|
<input type="button" id="twitter-button" value="Checking" class="btn"> |
||||
|
|
||||
|
|
||||
|
<!-- |
||||
|
<h3>Instagram</h3> |
||||
|
|
||||
|
--> |
||||
|
|
||||
|
</div> |
||||
|
<script> |
||||
|
window.quillFbInit = function() { |
||||
|
FB.getLoginStatus(function(response) { |
||||
|
if (response.status === 'connected') { |
||||
|
// the user is logged in and has authenticated your
|
||||
|
// app, and response.authResponse supplies
|
||||
|
// the user's ID, a valid access token, a signed
|
||||
|
// request, and the time the access token
|
||||
|
// and signed request each expire
|
||||
|
var uid = response.authResponse.userID; |
||||
|
var accessToken = response.authResponse.accessToken; |
||||
|
|
||||
|
save_facebook_token(response.authResponse.accessToken); |
||||
|
|
||||
|
} else if (response.status === 'not_authorized') { |
||||
|
// the user is logged in to Facebook,
|
||||
|
// but has not authenticated your app
|
||||
|
console.log("Logged in but not authorized"); |
||||
|
|
||||
|
$("#facebook-button").val("Sign In").addClass("btn-warning"); |
||||
|
|
||||
|
} else { |
||||
|
// the user isn't logged in to Facebook.
|
||||
|
console.log("User isn't logged in"); |
||||
|
|
||||
|
$("#facebook-button").val("Sign In").addClass("btn-warning"); |
||||
|
} |
||||
|
}); |
||||
|
}; |
||||
|
window.quillHandleFbLogin = function(response) { |
||||
|
save_facebook_token(response.authResponse.accessToken); |
||||
|
}; |
||||
|
|
||||
|
function save_facebook_token(token) { |
||||
|
console.log("Authed with token: " + token); |
||||
|
$.post('/auth/facebook', { |
||||
|
fb_token: token |
||||
|
}, function(data){ |
||||
|
$("#facebook-button").val("Connected").addClass("btn-success"); |
||||
|
}); |
||||
|
} |
||||
|
|
||||
|
$(function(){ |
||||
|
$.getJSON("/auth/twitter", function(data){ |
||||
|
// Check if we're already authorized with twitter
|
||||
|
if(data && data.result == 'ok') { |
||||
|
$("#twitter-button").val("Connected").addClass("btn-success"); |
||||
|
} else if(data && data.url) { |
||||
|
$("#twitter-button").val("Sign In").data("url", data.url).addClass("btn-warning"); |
||||
|
} else { |
||||
|
$("#twitter-button").val("Error").addClass("btn-danger"); |
||||
|
} |
||||
|
}); |
||||
|
|
||||
|
$("#twitter-button").click(function(){ |
||||
|
if($(this).data('url')) { |
||||
|
window.location = $(this).data('url'); |
||||
|
} else { |
||||
|
$.getJSON("/auth/twitter", {login: 1}, function(data){ |
||||
|
window.location = data.url; |
||||
|
}); |
||||
|
} |
||||
|
}); |
||||
|
|
||||
|
$("#facebook-button").click(function(){ |
||||
|
FB.login(window.quillHandleFbLogin, {scope:'publish_actions'}); |
||||
|
}); |
||||
|
}); |
||||
|
</script> |
Write
Preview
Loading…
Cancel
Save
Reference in new issue