override thread discovery with data-isso-id="...", close #27
This commit is contained in:
parent
a6f54f0191
commit
77df31d06f
@ -122,8 +122,8 @@ define(["q"], function(Q) {
|
|||||||
return rv.substring(0, rv.length - 1); // chop off trailing "&"
|
return rv.substring(0, rv.length - 1); // chop off trailing "&"
|
||||||
};
|
};
|
||||||
|
|
||||||
var create = function(data) {
|
var create = function(tid, data) {
|
||||||
return curl("POST", endpoint + "/new?" + qs({uri: location}), JSON.stringify(data)).then(
|
return curl("POST", endpoint + "/new?" + qs({uri: tid || location}), JSON.stringify(data)).then(
|
||||||
function (rv) { return JSON.parse(rv.body); });
|
function (rv) { return JSON.parse(rv.body); });
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -148,9 +148,9 @@ define(["q"], function(Q) {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
var fetch = function(plain) {
|
var fetch = function(tid) {
|
||||||
|
|
||||||
return curl("GET", endpoint + "/?" + qs({uri: location, plain: plain}), null).then(function (rv) {
|
return curl("GET", endpoint + "/?" + qs({uri: tid || location}), null).then(function (rv) {
|
||||||
if (rv.status === 200) {
|
if (rv.status === 200) {
|
||||||
return JSON.parse(rv.body);
|
return JSON.parse(rv.body);
|
||||||
} else {
|
} else {
|
||||||
@ -159,8 +159,8 @@ define(["q"], function(Q) {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
var count = function(uri) {
|
var count = function(tid) {
|
||||||
return curl("GET", endpoint + "/count?" + qs({uri: uri}), null).then(function(rv) {
|
return curl("GET", endpoint + "/count?" + qs({uri: tid || location}), null).then(function(rv) {
|
||||||
return JSON.parse(rv.body);
|
return JSON.parse(rv.body);
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
@ -5,11 +5,13 @@ define(["app/api", "app/dom", "app/markup"], function(api, $, Mark) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
var uri = el.href.match("^(.+)#isso-thread$")[1]
|
var tid = el.getAttribute("data-isso-id") ||
|
||||||
|
el.href.match("^(.+)#isso-thread$")[1]
|
||||||
.replace(/^.*\/\/[^\/]+/, '');
|
.replace(/^.*\/\/[^\/]+/, '');
|
||||||
api.count(uri).then(function(rv) {
|
|
||||||
|
api.count(tid).then(function(rv) {
|
||||||
el.textContent = Mark.up("{{ i18n-num-comments | pluralize : `n` }}", {n: rv});
|
el.textContent = Mark.up("{{ i18n-num-comments | pluralize : `n` }}", {n: rv});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
@ -59,7 +59,7 @@ define(["app/text/html", "app/dom", "app/utils", "app/config", "app/api", "app/m
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
api.create({
|
api.create($("#isso-thread").getAttribute("data-isso-id"), {
|
||||||
author: $("[name=author]", el).value || null,
|
author: $("[name=author]", el).value || null,
|
||||||
email: $("[name=email]", el).value || null,
|
email: $("[name=email]", el).value || null,
|
||||||
text: $("textarea", el).value,
|
text: $("textarea", el).value,
|
||||||
|
@ -26,7 +26,7 @@ require(["ready", "app/config", "app/api", "app/isso", "app/count", "app/dom", "
|
|||||||
$("#isso-thread").append(new isso.Postbox(null));
|
$("#isso-thread").append(new isso.Postbox(null));
|
||||||
$("#isso-thread").append('<div id="isso-root"></div>');
|
$("#isso-thread").append('<div id="isso-root"></div>');
|
||||||
|
|
||||||
api.fetch().then(function(rv) {
|
api.fetch($("#isso-thread").getAttribute("data-isso-id")).then(function(rv) {
|
||||||
|
|
||||||
if (! rv.length) {
|
if (! rv.length) {
|
||||||
$("#isso-thread > h4").textContent = Mark.up("{{ i18n-no-comments }}");
|
$("#isso-thread > h4").textContent = Mark.up("{{ i18n-no-comments }}");
|
||||||
|
@ -76,14 +76,14 @@ def host(name):
|
|||||||
return (rv.netloc.rsplit(':')[0], rv.port or 80, rv.scheme == 'https')
|
return (rv.netloc.rsplit(':')[0], rv.port or 80, rv.scheme == 'https')
|
||||||
|
|
||||||
|
|
||||||
def title(data, default=u"Untitled."):
|
def thread(data, default=u"Untitled.", id=None):
|
||||||
"""
|
"""
|
||||||
Extract <h1> title from web page. The title is *probably* the text node,
|
Extract <h1> title from web page. The title is *probably* the text node,
|
||||||
which is the nearest H1 node in context to an element with the `isso-thread` id.
|
which is the nearest H1 node in context to an element with the `isso-thread` id.
|
||||||
|
|
||||||
>>> title("asdf") # doctest: +IGNORE_UNICODE
|
>>> thread("asdf") # doctest: +IGNORE_UNICODE
|
||||||
'Untitled.'
|
(None, 'Untitled.')
|
||||||
>>> title('''
|
>>> thread('''
|
||||||
... <html>
|
... <html>
|
||||||
... <head>
|
... <head>
|
||||||
... <title>Foo!</title>
|
... <title>Foo!</title>
|
||||||
@ -102,14 +102,22 @@ def title(data, default=u"Untitled."):
|
|||||||
... </article>
|
... </article>
|
||||||
... </body>
|
... </body>
|
||||||
... </html>''') # doctest: +IGNORE_UNICODE
|
... </html>''') # doctest: +IGNORE_UNICODE
|
||||||
'Can you find me?'
|
(None, 'Can you find me?')
|
||||||
>>> title('''
|
>>> thread('''
|
||||||
... <html>
|
... <html>
|
||||||
... <body>
|
... <body>
|
||||||
... <h1>I'm the real title!1
|
... <h1>I'm the real title!1
|
||||||
... <section data-title="No way%21" id="isso-thread">
|
... <section data-title="No way%21" id="isso-thread">
|
||||||
... ''') # doctest: +IGNORE_UNICODE
|
... ''') # doctest: +IGNORE_UNICODE
|
||||||
'No way!'
|
(None, 'No way!')
|
||||||
|
>>> thread('''
|
||||||
|
... <section id="isso-thread" data-title="Test" data-isso-id="test">
|
||||||
|
... ''') # doctest: +IGNORE_UNICODE
|
||||||
|
('test', 'Test')
|
||||||
|
>>> thread('''
|
||||||
|
... <section id="isso-thread" data-isso-id="Fuu.">
|
||||||
|
... ''') # doctest: +IGNORE_UNICODE
|
||||||
|
('Fuu.', 'Untitled.')
|
||||||
"""
|
"""
|
||||||
|
|
||||||
html = html5lib.parse(data, treebuilder="dom")
|
html = html5lib.parse(data, treebuilder="dom")
|
||||||
@ -123,7 +131,7 @@ def title(data, default=u"Untitled."):
|
|||||||
chain(*map(html.getElementsByTagName, ("div", "section"))))))
|
chain(*map(html.getElementsByTagName, ("div", "section"))))))
|
||||||
|
|
||||||
if not el:
|
if not el:
|
||||||
return default
|
return id, default
|
||||||
|
|
||||||
el = el[0]
|
el = el[0]
|
||||||
visited = []
|
visited = []
|
||||||
@ -146,7 +154,12 @@ def title(data, default=u"Untitled."):
|
|||||||
yield item
|
yield item
|
||||||
|
|
||||||
try:
|
try:
|
||||||
return unquote(el.attributes["data-title"].value)
|
id = unquote(el.attributes["data-isso-id"].value)
|
||||||
|
except (KeyError, AttributeError):
|
||||||
|
pass
|
||||||
|
|
||||||
|
try:
|
||||||
|
return id, unquote(el.attributes["data-title"].value)
|
||||||
except (KeyError, AttributeError):
|
except (KeyError, AttributeError):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
@ -156,8 +169,8 @@ def title(data, default=u"Untitled."):
|
|||||||
rv = recurse(el)
|
rv = recurse(el)
|
||||||
|
|
||||||
if rv:
|
if rv:
|
||||||
return ''.join(gettext(rv)).strip()
|
return id, ''.join(gettext(rv)).strip()
|
||||||
|
|
||||||
el = el.parentNode
|
el = el.parentNode
|
||||||
|
|
||||||
return default
|
return id, default
|
||||||
|
@ -117,7 +117,7 @@ class API(object):
|
|||||||
if uri not in self.threads:
|
if uri not in self.threads:
|
||||||
with http.curl('GET', local("origin"), uri) as resp:
|
with http.curl('GET', local("origin"), uri) as resp:
|
||||||
if resp and resp.status == 200:
|
if resp and resp.status == 200:
|
||||||
title = parse.title(resp.read())
|
uri, title = parse.thread(resp.read(), id=uri)
|
||||||
else:
|
else:
|
||||||
return NotFound('URI does not exist')
|
return NotFound('URI does not exist')
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user