2011-06-09 22:08:59 -04:00
|
|
|
NEWSBLUR.utils = {
|
|
|
|
|
2011-06-16 23:45:41 -04:00
|
|
|
compute_story_score: function(story) {
|
|
|
|
var score = 0;
|
|
|
|
var score_max = Math.max(story.intelligence['title'],
|
|
|
|
story.intelligence['author'],
|
|
|
|
story.intelligence['tags']);
|
|
|
|
var score_min = Math.min(story.intelligence['title'],
|
|
|
|
story.intelligence['author'],
|
|
|
|
story.intelligence['tags']);
|
|
|
|
if (score_max > 0) score = score_max;
|
|
|
|
else if (score_min < 0) score = score_min;
|
2011-06-09 22:08:59 -04:00
|
|
|
|
2011-06-16 23:45:41 -04:00
|
|
|
if (score == 0) score = story.intelligence['feed'];
|
2011-06-09 22:08:59 -04:00
|
|
|
|
2011-06-16 23:45:41 -04:00
|
|
|
return score;
|
|
|
|
},
|
|
|
|
|
|
|
|
generate_gradient: function(feed, type) {
|
|
|
|
if (!feed) return '';
|
|
|
|
var color = feed.favicon_color;
|
|
|
|
if (!color) return '';
|
|
|
|
|
|
|
|
var r = parseInt(color.substr(0, 2), 16);
|
|
|
|
var g = parseInt(color.substr(2, 2), 16);
|
|
|
|
var b = parseInt(color.substr(4, 2), 16);
|
|
|
|
|
|
|
|
if (type == 'border') {
|
|
|
|
return [
|
|
|
|
'1px solid rgb(',
|
|
|
|
[
|
|
|
|
parseInt(r*(6/8), 10),
|
|
|
|
parseInt(g*(6/8), 10),
|
|
|
|
parseInt(b*(6/8), 10)
|
|
|
|
].join(','),
|
|
|
|
')'
|
|
|
|
].join('');
|
|
|
|
} else if (type == 'webkit') {
|
|
|
|
return [
|
|
|
|
'-webkit-gradient(',
|
|
|
|
'linear,',
|
|
|
|
'left bottom,',
|
|
|
|
'left top,',
|
|
|
|
'color-stop(0, rgba(',
|
|
|
|
[
|
|
|
|
r,
|
|
|
|
g,
|
|
|
|
b,
|
|
|
|
255
|
|
|
|
].join(','),
|
|
|
|
')),',
|
|
|
|
'color-stop(1, rgba(',
|
|
|
|
[
|
|
|
|
r+35,
|
|
|
|
g+35,
|
|
|
|
b+35,
|
|
|
|
255
|
|
|
|
].join(','),
|
|
|
|
')))'
|
|
|
|
].join('');
|
|
|
|
} else if (type == 'moz') {
|
|
|
|
return [
|
|
|
|
'-moz-linear-gradient(',
|
|
|
|
'center bottom,',
|
|
|
|
'rgb(',
|
|
|
|
[
|
|
|
|
r,
|
|
|
|
g,
|
|
|
|
b
|
|
|
|
].join(','),
|
|
|
|
') 0%,',
|
|
|
|
'rgb(',
|
|
|
|
[
|
|
|
|
r+35,
|
|
|
|
g+35,
|
|
|
|
b+35
|
|
|
|
].join(','),
|
|
|
|
') 100%)'
|
|
|
|
].join('');
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
is_feed_floater_gradient_light: function(feed) {
|
|
|
|
if (!feed) return false;
|
|
|
|
var color = feed.favicon_color;
|
|
|
|
if (!color) return false;
|
|
|
|
|
|
|
|
var r = parseInt(color.substr(0, 2), 16) / 255.0;
|
|
|
|
var g = parseInt(color.substr(2, 2), 16) / 255.0;
|
|
|
|
var b = parseInt(color.substr(4, 2), 16) / 255.0;
|
|
|
|
|
|
|
|
return $.textColor({r: r, g: g, b: b}) != 'white';
|
2011-09-04 15:42:13 -07:00
|
|
|
},
|
|
|
|
|
|
|
|
make_folders: function(model) {
|
|
|
|
var folders = model.get_folders();
|
|
|
|
var $options = $.make('select', { className: 'NB-folders'});
|
|
|
|
|
|
|
|
var $option = $.make('option', { value: '' }, "Top Level");
|
|
|
|
$options.append($option);
|
|
|
|
|
2011-11-07 20:50:46 -08:00
|
|
|
$options = this.make_folder_options($options, folders, ' ');
|
2011-09-04 15:42:13 -07:00
|
|
|
|
|
|
|
return $options;
|
|
|
|
},
|
|
|
|
|
|
|
|
make_folder_options: function($options, items, depth) {
|
|
|
|
for (var i in items) {
|
|
|
|
var item = items[i];
|
|
|
|
if (typeof item == "object") {
|
|
|
|
for (var o in item) {
|
|
|
|
var folder = item[o];
|
|
|
|
var $option = $.make('option', { value: o }, depth + ' ' + o);
|
|
|
|
$options.append($option);
|
2011-11-07 20:50:46 -08:00
|
|
|
$options = this.make_folder_options($options, folder, depth+' ');
|
2011-09-04 15:42:13 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $options;
|
2011-06-16 23:45:41 -04:00
|
|
|
}
|
2011-06-09 22:08:59 -04:00
|
|
|
|
|
|
|
};
|