Split cleanly stacosys API usage and page rendering
Progress on new comment post method
This commit is contained in:
parent
a200fdfa88
commit
300727cdab
4 changed files with 78 additions and 126 deletions
|
|
@ -200,10 +200,10 @@ instance d'ici peu.</p>
|
|||
|
||||
<script type="text/javascript"><!--
|
||||
|
||||
STACOSYS_URL = 'http://127.0.0.1:8000';
|
||||
STACOSYS_TOKEN = '9fb3fc042c572cb831005fd16186126765140fa2bd9bb2d4a28e47a9457dc26c';
|
||||
var STACOSYS_URL = 'http://127.0.0.1:8000';
|
||||
var STACOSYS_TOKEN = '9fb3fc042c572cb831005fd16186126765140fa2bd9bb2d4a28e47a9457dc26c';
|
||||
//STACOSYS_PAGE = 'blogduyax.madyanne.fr/mes-applications-pour-blackberry.html'
|
||||
STACOSYS_PAGE = 'blogduyax.madyanne.fr/migration-du-blog-sous-pelican.html'
|
||||
var STACOSYS_PAGE = 'blogduyax.madyanne.fr/migration-du-blog-sous-pelican.html'
|
||||
|
||||
window.onload = initialize_comments();
|
||||
|
||||
|
|
|
|||
|
|
@ -16,23 +16,32 @@ function show_hide(panel_id, button_id){
|
|||
// --------------------------------------------------------------------------
|
||||
|
||||
function initialize_comments() {
|
||||
stacosys_count(comments_initialized);
|
||||
stacosys_get_count(init_success, init_failure);
|
||||
}
|
||||
|
||||
function comments_initialized(count) {
|
||||
function init_success(data) {
|
||||
var response = JSON.parse(data);
|
||||
var count = response.count;
|
||||
if (count > 0) {
|
||||
if (count > 1) {
|
||||
document.getElementById('show-comment-label').innerHTML = 'Voir les ' + count + ' commentaires';
|
||||
}
|
||||
document.getElementById('show-comments-button').style.display = '';
|
||||
}
|
||||
console.log('initialization success');
|
||||
}
|
||||
|
||||
function init_failure(error) {
|
||||
// NOP
|
||||
console.log('initialization failure');
|
||||
}
|
||||
|
||||
function show_comments() {
|
||||
stacosys_load(comments_loaded);
|
||||
stacosys_load_comments(loading_success, loading_failure);
|
||||
}
|
||||
|
||||
function comments_loaded(response) {
|
||||
function loading_success(data) {
|
||||
var response = JSON.parse(data);
|
||||
for (var i = 0, numTokens = response.data.length; i < numTokens; ++i) {
|
||||
response.data[i].mdcontent = markdown.toHTML(response.data[i].content);
|
||||
}
|
||||
|
|
@ -42,6 +51,11 @@ function comments_loaded(response) {
|
|||
document.getElementById('stacosys-comments').innerHTML = rendered;
|
||||
}
|
||||
|
||||
function loading_failure(error) {
|
||||
// NOP
|
||||
console.log('loading failure');
|
||||
}
|
||||
|
||||
// --------------------------------------------------------------------------
|
||||
// Submit a new comment
|
||||
// --------------------------------------------------------------------------
|
||||
|
|
@ -53,11 +67,17 @@ function new_comment() {
|
|||
var captcha = document.getElementById('captcha').value;
|
||||
//var subscribe = document.getElementById('subscribe').value;
|
||||
|
||||
stacosys_new(author, email, site, captcha, comment_submitted);
|
||||
stacosys_new_comment(author, email, site, captcha, submit_success, submit_failure);
|
||||
}
|
||||
|
||||
function comment_submitted(success) {
|
||||
console.log('SUBMITTED : ' + success);
|
||||
function submit_success(data) {
|
||||
console.log('submit ' + data);
|
||||
// TODO redirect to redirect page with page as argument
|
||||
}
|
||||
|
||||
function submit_failure(error) {
|
||||
console.log('submit failure');
|
||||
// TODO redirect to error page
|
||||
}
|
||||
|
||||
// --------------------------------------------------------------------------
|
||||
|
|
|
|||
|
|
@ -1,17 +1,16 @@
|
|||
// Copyright (c) 2015 Yannic ARNOUX
|
||||
|
||||
/**
|
||||
* Make a X-Domain request to url and callback.
|
||||
*
|
||||
* @param url {String}
|
||||
* @param method {String} HTTP verb ('GET', 'POST', 'DELETE', etc.)
|
||||
* @param data {String} request body
|
||||
* @param header {Dict} header options
|
||||
* @param callback {Function} to callback on completion
|
||||
* @param errback {Function} to callback on error
|
||||
*/
|
||||
function xdr(url, method, data, callback, errback) {
|
||||
function xdr(url, method, data, header, callback, errback) {
|
||||
var req;
|
||||
|
||||
|
||||
if(XMLHttpRequest) {
|
||||
req = new XMLHttpRequest();
|
||||
|
||||
|
|
@ -27,6 +26,9 @@ function xdr(url, method, data, callback, errback) {
|
|||
}
|
||||
}
|
||||
};
|
||||
for ( var h in header ) {
|
||||
req.setRequestHeader(h, header[h]);
|
||||
}
|
||||
req.send(data);
|
||||
}
|
||||
} else if(XDomainRequest) {
|
||||
|
|
@ -36,100 +38,38 @@ function xdr(url, method, data, callback, errback) {
|
|||
req.onload = function() {
|
||||
callback(req.responseText);
|
||||
};
|
||||
for ( var h in header ) {
|
||||
req.setRequestHeader(h, header[h]);
|
||||
}
|
||||
req.send(data);
|
||||
} else {
|
||||
errback(new Error('CORS not supported'));
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// Create the XHR object.
|
||||
function stacosys_get_cors_request(method, url) {
|
||||
var xhr = new XMLHttpRequest();
|
||||
if ("withCredentials" in xhr) {
|
||||
// XHR for Chrome/Firefox/Opera/Safari.
|
||||
xhr.open(method, url, true);
|
||||
} else if (typeof XDomainRequest != "undefined") {
|
||||
// XDomainRequest for IE.
|
||||
xhr = new XDomainRequest();
|
||||
xhr.open(method, url);
|
||||
} else {
|
||||
// CORS not supported.
|
||||
xhr = null;
|
||||
}
|
||||
return xhr;
|
||||
}
|
||||
|
||||
function stacosys_count(callback) {
|
||||
|
||||
function stacosys_get_count(callback, errback) {
|
||||
var url = STACOSYS_URL + '/comments/count?token=' + STACOSYS_TOKEN + '&url=' + STACOSYS_PAGE;
|
||||
var xhr = stacosys_get_cors_request('GET', url);
|
||||
if (!xhr) {
|
||||
console.log('CORS not supported');
|
||||
callback(0);
|
||||
return;
|
||||
}
|
||||
|
||||
// Response handlers.
|
||||
xhr.onload = function() {
|
||||
var jsonResponse = JSON.parse(xhr.responseText);
|
||||
var count = jsonResponse.count;
|
||||
callback(count);
|
||||
};
|
||||
|
||||
xhr.onerror = function() {
|
||||
console.log('Woops, there was an error making the request.');
|
||||
callback(0);
|
||||
};
|
||||
|
||||
xhr.send();
|
||||
xdr(url, 'GET', null, {}, callback, errback);
|
||||
}
|
||||
|
||||
function stacosys_load(callback) {
|
||||
|
||||
function stacosys_load_comments(callback, errback) {
|
||||
var url = STACOSYS_URL + '/comments?token=' + STACOSYS_TOKEN + '&url=' + STACOSYS_PAGE;
|
||||
var xhr = stacosys_get_cors_request('GET', url);
|
||||
if (!xhr) {
|
||||
console.log('CORS not supported');
|
||||
return;
|
||||
}
|
||||
|
||||
// Response handlers.
|
||||
xhr.onload = function() {
|
||||
var jsonResponse = JSON.parse(xhr.responseText);
|
||||
callback(jsonResponse);
|
||||
};
|
||||
|
||||
xhr.onerror = function() {
|
||||
console.log('Woops, there was an error making the request.');
|
||||
};
|
||||
|
||||
xhr.send();
|
||||
xdr(url, 'GET', null, {}, callback, errback);
|
||||
}
|
||||
|
||||
function stacosys_new(author, email, site, captcha, callback) {
|
||||
|
||||
var url = STACOSYS_URL + '/comments?token=' + STACOSYS_TOKEN
|
||||
+ '&url=' + STACOSYS_PAGE + '&author=' + author
|
||||
+ '&email=' + email + '&site=' + site
|
||||
+ '&captcha=' + captcha;
|
||||
var xhr = stacosys_get_cors_request('POST', url);
|
||||
if (!xhr) {
|
||||
console.log('CORS not supported');
|
||||
callback(false);
|
||||
return;
|
||||
}
|
||||
|
||||
// Response handlers.
|
||||
xhr.onload = function() {
|
||||
var jsonResponse = JSON.parse(xhr.responseText);
|
||||
callback(jsonResponse);
|
||||
function stacosys_new_comment(author, email, site, captcha, callback, errback) {
|
||||
var url = STACOSYS_URL + '/comments';
|
||||
var data = {
|
||||
'token': STACOSYS_TOKEN,
|
||||
'url': STACOSYS_PAGE,
|
||||
'author': author,
|
||||
'email': email,
|
||||
'site': site,
|
||||
'captcha': captcha
|
||||
};
|
||||
|
||||
xhr.onerror = function() {
|
||||
console.log('Woops, there was an error making the request.');
|
||||
callback(false);
|
||||
var header = {
|
||||
'Content-type': 'application/json'
|
||||
};
|
||||
|
||||
xhr.send();
|
||||
var j = JSON.stringify(data);
|
||||
xdr(url, 'POST', JSON.stringify(data), header, callback, errback);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue