Fetch page titles
This commit is contained in:
parent
2a00fb1bb6
commit
3a28afe408
|
@ -574,7 +574,7 @@ button {
|
||||||
content: '* ';
|
content: '* ';
|
||||||
}
|
}
|
||||||
#chat .toggle-button {
|
#chat .toggle-button {
|
||||||
background: #eee;
|
background: #f5f5f5;
|
||||||
border-radius: 2px;
|
border-radius: 2px;
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
color: #666;
|
color: #666;
|
||||||
|
@ -588,16 +588,27 @@ button {
|
||||||
display: none;
|
display: none;
|
||||||
color: #222;
|
color: #222;
|
||||||
font: 12px Lato;
|
font: 12px Lato;
|
||||||
max-width: 220px;
|
max-width: 480px;
|
||||||
padding: 6px 8px;
|
padding: 6px 8px;
|
||||||
margin-top: 2px;
|
margin-top: 2px;
|
||||||
}
|
}
|
||||||
#chat .toggle-content.show {
|
#chat .toggle-content a {
|
||||||
display: inline-block !important;
|
color: inherit;
|
||||||
}
|
}
|
||||||
#chat .toggle-content img {
|
#chat .toggle-content img {
|
||||||
max-width: 100%;
|
max-width: 100%;
|
||||||
max-height: 100%;
|
max-height: 100%;
|
||||||
|
display: block;
|
||||||
|
margin: 2px 0;
|
||||||
|
}
|
||||||
|
#chat .toggle-content .head {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
#chat .toggle-content .body {
|
||||||
|
color: #999;
|
||||||
|
}
|
||||||
|
#chat .toggle-content.show {
|
||||||
|
display: inline-block !important;
|
||||||
}
|
}
|
||||||
#chat .count {
|
#chat .count {
|
||||||
background: #fafafa;
|
background: #fafafa;
|
||||||
|
|
|
@ -130,17 +130,19 @@ templates['network'] = template({"1":function(depth0,helpers,partials,data) {
|
||||||
templates['toggle'] = template({"1":function(depth0,helpers,partials,data) {
|
templates['toggle'] = template({"1":function(depth0,helpers,partials,data) {
|
||||||
var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression;
|
var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression;
|
||||||
return " <a href=\""
|
return " <a href=\""
|
||||||
+ escapeExpression(((helper = (helper = helpers.body || (depth0 != null ? depth0.body : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"body","hash":{},"data":data}) : helper)))
|
+ escapeExpression(((helper = (helper = helpers.link || (depth0 != null ? depth0.link : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"link","hash":{},"data":data}) : helper)))
|
||||||
+ "\" target=\"_blank\">\n <img src=\""
|
+ "\" target=\"_blank\">\n <img src=\""
|
||||||
+ escapeExpression(((helper = (helper = helpers.body || (depth0 != null ? depth0.body : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"body","hash":{},"data":data}) : helper)))
|
+ escapeExpression(((helper = (helper = helpers.link || (depth0 != null ? depth0.link : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"link","hash":{},"data":data}) : helper)))
|
||||||
+ "\">\n </a>\n";
|
+ "\">\n </a>\n";
|
||||||
},"3":function(depth0,helpers,partials,data) {
|
},"3":function(depth0,helpers,partials,data) {
|
||||||
var helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression;
|
var stack1, helper, functionType="function", helperMissing=helpers.helperMissing, escapeExpression=this.escapeExpression, buffer = " <a href=\""
|
||||||
return " <div class=\"head\">"
|
+ escapeExpression(((helper = (helper = helpers.link || (depth0 != null ? depth0.link : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"link","hash":{},"data":data}) : helper)))
|
||||||
+ escapeExpression(((helper = (helper = helpers.head || (depth0 != null ? depth0.head : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"head","hash":{},"data":data}) : helper)))
|
+ "\" target=\"_blank\">\n <div class=\"head\">";
|
||||||
+ "</div>\n <div class=\"body\">\n "
|
stack1 = ((helper = (helper = helpers.head || (depth0 != null ? depth0.head : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"head","hash":{},"data":data}) : helper));
|
||||||
|
if (stack1 != null) { buffer += stack1; }
|
||||||
|
return buffer + "</div>\n <div class=\"body\">\n "
|
||||||
+ escapeExpression(((helper = (helper = helpers.body || (depth0 != null ? depth0.body : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"body","hash":{},"data":data}) : helper)))
|
+ escapeExpression(((helper = (helper = helpers.body || (depth0 != null ? depth0.body : depth0)) != null ? helper : helperMissing),(typeof helper === functionType ? helper.call(depth0, {"name":"body","hash":{},"data":data}) : helper)))
|
||||||
+ "\n </div>\n";
|
+ "\n </div>\n </a>\n";
|
||||||
},"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) {
|
},"compiler":[6,">= 2.0.0-beta.1"],"main":function(depth0,helpers,partials,data) {
|
||||||
var stack1, helperMissing=helpers.helperMissing, buffer = "<div class=\"toggle-content\">\n";
|
var stack1, helperMissing=helpers.helperMissing, buffer = "<div class=\"toggle-content\">\n";
|
||||||
stack1 = ((helpers.equal || (depth0 && depth0.equal) || helperMissing).call(depth0, (depth0 != null ? depth0.type : depth0), "image", {"name":"equal","hash":{},"fn":this.program(1, data),"inverse":this.program(3, data),"data":data}));
|
stack1 = ((helpers.equal || (depth0 && depth0.equal) || helperMissing).call(depth0, (depth0 != null ? depth0.type : depth0), "image", {"name":"equal","hash":{},"fn":this.program(1, data),"inverse":this.program(3, data),"data":data}));
|
||||||
|
|
|
@ -1,13 +1,15 @@
|
||||||
<div class="toggle-content">
|
<div class="toggle-content">
|
||||||
{{#equal type "image"}}
|
{{#equal type "image"}}
|
||||||
<a href="{{body}}" target="_blank">
|
<a href="{{link}}" target="_blank">
|
||||||
<img src="{{body}}">
|
<img src="{{link}}">
|
||||||
</a>
|
</a>
|
||||||
{{else}}
|
{{else}}
|
||||||
<div class="head">{{head}}</div>
|
<a href="{{link}}" target="_blank">
|
||||||
<div class="body">
|
<div class="head">{{{head}}}</div>
|
||||||
{{body}}
|
<div class="body">
|
||||||
</div>
|
{{body}}
|
||||||
|
</div>
|
||||||
|
</a>
|
||||||
{{/equal}}
|
{{/equal}}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
var _ = require("lodash");
|
var _ = require("lodash");
|
||||||
|
var cheerio = require("cheerio");
|
||||||
var Msg = require("../../models/msg");
|
var Msg = require("../../models/msg");
|
||||||
var request = require("superagent");
|
var request = require("superagent");
|
||||||
|
|
||||||
|
@ -43,12 +44,16 @@ module.exports = function(irc, network) {
|
||||||
};
|
};
|
||||||
|
|
||||||
function parse(id, url, res, client) {
|
function parse(id, url, res, client) {
|
||||||
|
var type = "";
|
||||||
var head = "";
|
var head = "";
|
||||||
var body = "";
|
var body = "";
|
||||||
var type = "";
|
var link = url;
|
||||||
switch (res.type) {
|
switch (res.type) {
|
||||||
case "text/html":
|
case "text/html":
|
||||||
|
var $ = cheerio.load(res.res.text);
|
||||||
type = "link";
|
type = "link";
|
||||||
|
head = $("title").text();
|
||||||
|
body = "No description found.";
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case "image/png":
|
case "image/png":
|
||||||
|
@ -56,7 +61,6 @@ function parse(id, url, res, client) {
|
||||||
case "image/jpg":
|
case "image/jpg":
|
||||||
case "image/jpeg":
|
case "image/jpeg":
|
||||||
type = "image";
|
type = "image";
|
||||||
body = url;
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
@ -65,8 +69,9 @@ function parse(id, url, res, client) {
|
||||||
client.emit("toggle", {
|
client.emit("toggle", {
|
||||||
id: id,
|
id: id,
|
||||||
type: type,
|
type: type,
|
||||||
head: type,
|
head: head,
|
||||||
body: body
|
body: body,
|
||||||
|
link: link,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue