Browse Source

ClientScript register

pull/1/merge
Ruud 14 years ago
parent
commit
0672e120a0
  1. 4
      couchpotato/api/__init__.py
  2. 2
      couchpotato/core/loader.py
  3. 20
      couchpotato/core/plugins/base.py
  4. 6
      couchpotato/core/plugins/clientscript/__init__.py
  5. 56
      couchpotato/core/plugins/clientscript/main.py
  6. 6
      couchpotato/core/plugins/extension/__init__.py
  7. 7
      couchpotato/core/plugins/extension/main.py
  8. 389
      couchpotato/core/plugins/extension/static/couchpotato.user.js
  9. 5
      couchpotato/core/plugins/file/main.py
  10. 0
      couchpotato/core/plugins/file/static/file.js
  11. 4
      couchpotato/core/plugins/movie/main.py
  12. 0
      couchpotato/core/plugins/movie/static/search.css
  13. 0
      couchpotato/core/plugins/movie/static/search.js
  14. 11
      couchpotato/core/plugins/quality/main.py
  15. 0
      couchpotato/core/plugins/quality/static/quality.css
  16. 0
      couchpotato/core/plugins/quality/static/quality.js
  17. 9
      couchpotato/core/plugins/status/main.py
  18. 0
      couchpotato/core/plugins/status/static/status.js
  19. 10
      couchpotato/templates/_desktop.html

4
couchpotato/api/__init__.py

@ -3,8 +3,8 @@ from flask import Module
api = Module(__name__) api = Module(__name__)
def addApiView(route, func): def addApiView(route, func, static = False):
api.add_url_rule(route + '/', endpoint = route if route else 'index', view_func = func) api.add_url_rule(route + ('' if static else '/'), endpoint = route if route else 'index', view_func = func)
""" Api view """ """ Api view """
def index(): def index():

2
couchpotato/core/loader.py

@ -60,7 +60,7 @@ class Loader:
options = {} options = {}
for group in section['groups']: for group in section['groups']:
for option in group['options']: for option in group['options']:
options[option['name']] = option['default'] options[option['name']] = option.get('default', '')
fireEvent('settings.register', section_name = section['name'], options = options, save = save) fireEvent('settings.register', section_name = section['name'], options = options, save = save)
return True return True
except Exception, e: except Exception, e:

20
couchpotato/core/plugins/base.py

@ -1,7 +1,27 @@
from couchpotato.api import addApiView
from couchpotato.environment import Env from couchpotato.environment import Env
from flask.helpers import send_from_directory
import os.path
class Plugin(): class Plugin():
def conf(self, attr): def conf(self, attr):
return Env.setting(attr, self.__class__.__name__.lower()) return Env.setting(attr, self.__class__.__name__.lower())
def registerStatic(self, file_path):
class_name = self.__class__.__name__.lower()
self.plugin_file = file_path
path = class_name + '.static/'
addApiView(path + '<path:file>', self.showStatic, static = True)
return path
def showStatic(self, file = ''):
plugin_dir = os.path.dirname(self.plugin_file)
dir = os.path.join(plugin_dir, 'static')
return send_from_directory(dir, file)

6
couchpotato/core/plugins/clientscript/__init__.py

@ -0,0 +1,6 @@
from .main import ClientScript
def start():
return ClientScript()
config = []

56
couchpotato/core/plugins/clientscript/main.py

@ -0,0 +1,56 @@
from couchpotato.core.event import addEvent
from couchpotato.core.logger import CPLog
from couchpotato.core.plugins.base import Plugin
log = CPLog(__name__)
class ClientScript(Plugin):
urls = {
'style': {},
'script': {},
}
html = {
'style': '<link rel="stylesheet" href="%s" type="text/css">',
'script': '<script type="text/javascript" src="%s"></script>',
}
def __init__(self):
addEvent('register_style', self.registerStyle)
addEvent('register_script', self.registerScript)
addEvent('clientscript.get_styles', self.getStyles)
addEvent('clientscript.get_scripts', self.getScripts)
def getStyles(self, *args, **kwargs):
return self.get('style', *args, **kwargs)
def getScripts(self, *args, **kwargs):
return self.get('script', *args, **kwargs)
def get(self, type, as_html = False, location = 'head'):
data = '' if as_html else []
try:
return self.urls[type][location]
except Exception, e:
log.error(e)
return data
def registerStyle(self, path, position = 'head'):
self.register(path, 'style', position)
def registerScript(self, path, position = 'head'):
self.register(path, 'script', position)
def register(self, file, type, location):
if not self.urls[type].get(location):
self.urls[type][location] = []
filePath = file
self.urls[type][location].append(filePath)

6
couchpotato/core/plugins/extension/__init__.py

@ -0,0 +1,6 @@
from .main import Extension
def start():
return Extension()
config = []

7
couchpotato/core/plugins/extension/main.py

@ -0,0 +1,7 @@
from couchpotato.core.plugins.base import Plugin
class Extension(Plugin):
def __init__(self):
self.registerStatic(__file__)

389
couchpotato/core/plugins/extension/static/couchpotato.user.js

@ -0,0 +1,389 @@
// ==UserScript==
// @name CouchPotato UserScript
// @description Add movies to your CouchPotato via external sites like IMDB
// @include http*://*.imdb.com/title/tt*
// @include http*://imdb.com/title/tt*
// @include ${host}*
// @include http://*.sharethe.tv/movies/*
// @include http://sharethe.tv/movies/*
// @include http://*.moviemeter.nl/film/*
// @include http://moviemeter.nl/film/*
// @include http://whiwa.net/stats/movie/*
// @include http://trailers.apple.com/trailers/*
// @include http://www.themoviedb.org/movie/*
// @include http://www.allocine.fr/film/*
// @include http://trakt.tv/movie/*
// @include http://*.trak.tv/movie/*
// @exclude http://trak.tv/movie/*/*
// @exclude http://*.trak.tv/movie/*/*
// ==/UserScript==
var version = 7;
function create() {
switch (arguments.length) {
case 1:
var A = document.createTextNode(arguments[0]);
break;
default:
var A = document.createElement(arguments[0]), B = arguments[1];
for ( var b in B) {
if (b.indexOf("on") == 0){
A.addEventListener(b.substring(2), B[b], false);
}
else if (",style,accesskey,id,name,src,href,which".indexOf(","
+ b.toLowerCase()) != -1){
A.setAttribute(b, B[b]);
}
else{
A[b] = B[b];
}
}
for ( var i = 2, len = arguments.length; i < len; ++i){
A.appendChild(arguments[i]);
}
}
return A;
}
if (typeof GM_addStyle == 'undefined'){
GM_addStyle = function(css) {
var head = document.getElementsByTagName('head')[0], style = document
.createElement('style');
if (!head) {
return
}
style.type = 'text/css';
style.textContent = css;
head.appendChild(style);
}
}
// Styles
GM_addStyle('\
#mmPopup { opacity: 0.5; width:200px; font-family: "Helvetica Neue", Helvetica, Arial, Geneva, sans-serif; -moz-border-radius-topleft: 6px; -moz-border-radius-topright: 6px; -webkit-border-top-left-radius: 6px; -webkit-border-top-right-radius: 6px; -moz-box-shadow: 0 0 20px rgba(0,0,0,0.5); -webkit-box-shadow: 0 0 20px rgba(0,0,0,0.5); position:fixed; z-index:9999; bottom:0; right:0; font-size:15px; margin: 0 20px; display: block; background:#f5f5f5; } \
#mmPopup:hover { opacity: 1; } \
#mmPopup a#addTo { cursor:pointer; text-align:center; text-decoration:none; color: #000; display:block; padding:15px 0 10px; } \
#mmPopup a#closeBtn { cursor:pointer; float: right; padding:10px; } \
#mmPopup a img { vertical-align: middle; } \
#mmPopup a:hover { color:#000; } \
#mmPopup iframe{ background:#f5f5f5; margin:6px; height:70px; width:188px; overflow:hidden; border:none; } \
');
var cpLocation = '${host}';
var movieImg = ''
var closeImg = ''
lib = (function(){
var _public = {}
_public.osd = function(id, year){
var navbar, newElement;
var iFrame = create('iframe', {
src : cpLocation + "movie/imdbAdd/?id=" + id + '&year=' + year,
frameborder : 0,
scrolling : 'no'
})
var addToText = '<a class="addTo" href="#"></a>'
var popupId = 'mmPopup'
var popup = create('div', {
id : popupId,
innerHTML : addToText
});
var addButton = create('a', {
innerHTML: '<img src="' + movieImg + '" />Add to CouchPotato',
id: 'addTo',
onclick: function(){
popup.innerHTML = '';
popup.appendChild(create('a', {
innerHTML: '<img src="' + closeImg + '" />',
id: 'closeBtn',
onclick: function(){
popup.innerHTML = '';
popup.appendChild(addButton);
}
}));
popup.appendChild(iFrame);
}
})
popup.appendChild(addButton);
document.body.parentNode.insertBefore(popup, document.body);
}
_public.search = function(name, year){
var imdb_id = 'tt1234567';
lib.osd(imdb_id, year);
return imdb_id;
}
return _public
})();
var CouchPotato = {}
CouchPotato['imdb.com'] = (function(){
function isMovie(){
var series = document.getElementsByTagName('h5')
for (var i = 0; i < series.length; i++) {
if (series[i].innerHTML == 'Seasons:') {
return false;
}
}
return true;
}
function getId(){
return 'tt' + location.href.replace(/[^\d+]+/g, '');
}
function getYear(){
try {
return document.getElementsByTagName('h1')[0].getElementsByTagName('a')[0].text;
} catch (e) {
var spans = document.getElementsByTagName('h1')[0].getElementsByTagName('span');
var pattern = /^\((TV|Video) ([0-9]+)\)$/;
for (var i = 0; i < spans.length; i++) {
if (spans[i].innerHTML.search(pattern)) {
return spans[i].innerHTML.match(pattern)[1];
}
}
}
}
var constructor = function(){
if(isMovie()){
lib.osd(getId(), getYear());
}
}
return constructor;
})();
CouchPotato['sharethe.tv'] = (function(){
function isMovie(){
var pattern = /movies\/[^/]+\/?$/;
matched = location.href.match(pattern);
return null != matched;
}
function getId(){
var pattern = /imdb\.com\/title\/tt(\d+)/;
var html = document.getElementsByTagName('html')[0].innerHTML;
var imdb_id = html.match(pattern)[1];
return imdb_id;
}
function getYear(){
var pattern = /(\d+)[^\d]*$/;
var html = document.getElementsByTagName('html')[0].innerHTML;
var year = html.match(pattern)[1];
return year;
}
function constructor(){
if(isMovie()){
lib.osd(getId(), getYear());
}
}
return constructor;
})();
CouchPotato['moviemeter.nl'] = (function(){
function isMovie(){
var pattern = /[^/]+\/?$/;
var html = document.getElementsByTagName('h1')[0].innerHTML
matched = location.href.match(pattern);
return null != matched;
}
function getId(){
var pattern = /imdb\.com\/title\/tt(\d+)/;
var html = document.getElementsByTagName('html')[0].innerHTML;
var imdb_id = html.match(pattern)[1];
return imdb_id;
}
function getYear(){
var pattern = /(\d+)[^\d]*$/;
var html = document.getElementsByTagName('h1')[0].innerHTML;
var year = html.match(pattern)[1];
return year;
}
function constructor(){
if(isMovie()){
lib.osd(getId(), getYear());
}
}
return constructor;
})();
CouchPotato['whiwa.net'] = (function(){
function isMovie(){
var pattern = /[^/]+\/?$/;
var html = document.getElementsByTagName('h3')[0].innerHTML
var matched = location.href.match(pattern);
return null != matched;
}
function getId(){
var pattern = /imdb\.com\/title\/tt(\d+)/;
var html = document.getElementsByTagName('html')[0].innerHTML;
var imdb_id = html.match(pattern)[1];
return imdb_id;
}
function getYear(){
var pattern = /(\d+)[^\d]*$/;
var html = document.getElementsByTagName('h3')[0].innerHTML;
var year = html.match(pattern)[1];
return year;
}
function constructor(){
if(isMovie()){
lib.osd(getId(), getYear());
}
}
return constructor;
})();
CouchPotato['trakt.tv'] = (function(){
var imdb_input = null;
var year_input = null;
function isMovie(){
imdb_input = document.getElementById("meta-imdb-id");
year_input = document.getElementById("meta-year");
return (null != imdb_input) && (null != year_input);
}
function getId(){
return imdb_input.value.substr(2);
}
function getYear(){
return year_input.value;
}
function constructor(){
if(isMovie()){
lib.osd(getId(), getYear());
}
}
return constructor;
})();
CouchPotato['trailers.apple.com'] = (function(){
function getId() {
var name = document.title.substr(0, document.title.indexOf(" -")).replace(/ /g, "+");
return lib.search(name, getYear())
}
function getYear(){
var release_date = document.getElementById("view-showtimes").parentNode.innerHTML;
var year = new RegExp("\\d{4}", release_date)
return year;
}
function constructor(){
getId();
}
return constructor;
})();
CouchPotato['themoviedb.org'] = (function(){
var obj = this;
function getId() {
name = document.title.substr(0, document.title.indexOf("TMDb")-3).replace(/ /g, "+");
lib.search(name, getYear())
}
function getYear(){
var year = document.getElementById("year").innerHTML;
year = year.substr(1, year.length-2);
return year;
}
function constructor(){
getId();
}
return constructor;
})();
CouchPotato['allocine.fr'] = (function(){
function isMovie(){
var pattern = /fichefilm_gen_cfilm=\d+?\.html$/;
matched = location.href.match(pattern);
return null != matched;
}
function getId() {
var name = document.title.substr(0, document.title.indexOf(" -")).replace(/ /g, "+");
lib.search(name, getYear())
}
function getYear(){
var year = new RegExp("\\d{4}", document.title)
return year;
}
function constructor(){
if(isMovie()){
lib.osd(getId(), getYear());
}
}
return constructor;
})();
// Start
(function(){
for (var i in CouchPotato){
GM_log(i);
if(location.href.indexOf(i) != -1){
new CouchPotato[i]();
break;
}
}
})();

5
couchpotato/core/plugins/file/main.py

@ -1,6 +1,6 @@
from couchpotato import get_session from couchpotato import get_session
from couchpotato.api import addApiView from couchpotato.api import addApiView
from couchpotato.core.event import addEvent from couchpotato.core.event import addEvent, fireEvent
from couchpotato.core.helpers.variable import md5, getExt from couchpotato.core.helpers.variable import md5, getExt
from couchpotato.core.logger import CPLog from couchpotato.core.logger import CPLog
from couchpotato.core.plugins.base import Plugin from couchpotato.core.plugins.base import Plugin
@ -22,6 +22,9 @@ class FileManager(Plugin):
addApiView('file.cache/<path:file>', self.showImage) addApiView('file.cache/<path:file>', self.showImage)
path = self.registerStatic(__file__)
fireEvent('register_script', path + 'file.js')
def showImage(self, file = ''): def showImage(self, file = ''):
cache_dir = Env.get('cache_dir') cache_dir = Env.get('cache_dir')

0
couchpotato/static/scripts/file.js → couchpotato/core/plugins/file/static/file.js

4
couchpotato/core/plugins/movie/main.py

@ -19,6 +19,10 @@ class MoviePlugin(Plugin):
addApiView('movie.edit', self.edit) addApiView('movie.edit', self.edit)
addApiView('movie.delete', self.delete) addApiView('movie.delete', self.delete)
path = self.registerStatic(__file__)
fireEvent('register_script', path + 'search.js')
fireEvent('register_style', path + 'search.css')
def list(self): def list(self):
params = getParams() params = getParams()

0
couchpotato/static/style/plugin/movie_add.css → couchpotato/core/plugins/movie/static/search.css

0
couchpotato/static/scripts/block/search.js → couchpotato/core/plugins/movie/static/search.js

11
couchpotato/core/plugins/quality/main.py

@ -1,13 +1,14 @@
from couchpotato import get_session from couchpotato import get_session
from couchpotato.core.event import addEvent from couchpotato.core.event import addEvent, fireEvent
from couchpotato.core.helpers.encoding import toUnicode from couchpotato.core.helpers.encoding import toUnicode
from couchpotato.core.logger import CPLog from couchpotato.core.logger import CPLog
from couchpotato.core.plugins.base import Plugin
from couchpotato.core.settings.model import Quality, Profile, ProfileType from couchpotato.core.settings.model import Quality, Profile, ProfileType
log = CPLog(__name__) log = CPLog(__name__)
class QualityPlugin:
class QualityPlugin(Plugin):
qualities = [ qualities = [
{'identifier': 'bd50', 'size': (15000, 60000), 'label': 'BR-Disk', 'alternative': ['1080p', 'bd25'], 'allow': [], 'ext':[], 'tags': ['x264', 'h264', 'blu ray']}, {'identifier': 'bd50', 'size': (15000, 60000), 'label': 'BR-Disk', 'alternative': ['1080p', 'bd25'], 'allow': [], 'ext':[], 'tags': ['x264', 'h264', 'blu ray']},
@ -28,6 +29,10 @@ class QualityPlugin:
addEvent('quality.all', self.all) addEvent('quality.all', self.all)
addEvent('app.load', self.fill) addEvent('app.load', self.fill)
path = self.registerStatic(__file__)
fireEvent('register_script', path + 'quality.js')
fireEvent('register_style', path + 'quality.css')
def all(self): def all(self):
db = get_session() db = get_session()

0
couchpotato/static/style/plugin/quality.css → couchpotato/core/plugins/quality/static/quality.css

0
couchpotato/static/scripts/quality.js → couchpotato/core/plugins/quality/static/quality.js

9
couchpotato/core/plugins/status/main.py

@ -1,12 +1,14 @@
from couchpotato import get_session from couchpotato import get_session
from couchpotato.core.event import addEvent from couchpotato.core.event import addEvent, fireEvent
from couchpotato.core.helpers.encoding import toUnicode from couchpotato.core.helpers.encoding import toUnicode
from couchpotato.core.logger import CPLog from couchpotato.core.logger import CPLog
from couchpotato.core.plugins.base import Plugin
from couchpotato.core.settings.model import Status from couchpotato.core.settings.model import Status
log = CPLog(__name__) log = CPLog(__name__)
class StatusPlugin:
class StatusPlugin(Plugin):
statuses = { statuses = {
'active': 'Active', 'active': 'Active',
@ -21,6 +23,9 @@ class StatusPlugin:
addEvent('status.all', self.all) addEvent('status.all', self.all)
addEvent('app.load', self.fill) addEvent('app.load', self.fill)
path = self.registerStatic(__file__)
fireEvent('register_script', path + 'status.js')
def all(self): def all(self):
db = get_session() db = get_session()

0
couchpotato/static/scripts/status.js → couchpotato/core/plugins/status/static/status.js

10
couchpotato/templates/_desktop.html

@ -7,8 +7,6 @@
<link rel="stylesheet" href="{{ url_for('.static', filename='style/page/settings.css') }}" type="text/css"> <link rel="stylesheet" href="{{ url_for('.static', filename='style/page/settings.css') }}" type="text/css">
<link rel="stylesheet" href="{{ url_for('.static', filename='style/page/wanted.css') }}" type="text/css"> <link rel="stylesheet" href="{{ url_for('.static', filename='style/page/wanted.css') }}" type="text/css">
<link rel="stylesheet" href="{{ url_for('.static', filename='style/plugin/movie_add.css') }}" type="text/css">
<link rel="stylesheet" href="{{ url_for('.static', filename='style/plugin/quality.css') }}" type="text/css">
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/library/mootools.js') }}"></script> <script type="text/javascript" src="{{ url_for('.static', filename='scripts/library/mootools.js') }}"></script>
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/library/mootools_more.js') }}"></script> <script type="text/javascript" src="{{ url_for('.static', filename='scripts/library/mootools_more.js') }}"></script>
@ -20,7 +18,6 @@
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/block.js') }}"></script> <script type="text/javascript" src="{{ url_for('.static', filename='scripts/block.js') }}"></script>
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/block/navigation.js') }}"></script> <script type="text/javascript" src="{{ url_for('.static', filename='scripts/block/navigation.js') }}"></script>
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/block/footer.js') }}"></script> <script type="text/javascript" src="{{ url_for('.static', filename='scripts/block/footer.js') }}"></script>
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/block/search.js') }}"></script>
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/page.js') }}"></script> <script type="text/javascript" src="{{ url_for('.static', filename='scripts/page.js') }}"></script>
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/page/wanted.js') }}"></script> <script type="text/javascript" src="{{ url_for('.static', filename='scripts/page/wanted.js') }}"></script>
@ -29,9 +26,10 @@
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/page/soon.js') }}"></script> <script type="text/javascript" src="{{ url_for('.static', filename='scripts/page/soon.js') }}"></script>
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/page/manage.js') }}"></script> <script type="text/javascript" src="{{ url_for('.static', filename='scripts/page/manage.js') }}"></script>
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/quality.js') }}"></script> {% for url in fireEvent('clientscript.get_scripts', as_html = True, single = True) %}
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/status.js') }}"></script> <script type="text/javascript" src="{{ url_for('api.index') }}{{ url }}"></script>{% endfor %}
<script type="text/javascript" src="{{ url_for('.static', filename='scripts/file.js') }}"></script> {% for url in fireEvent('clientscript.get_styles', as_html = True, single = True) %}
<link rel="stylesheet" href="{{ url_for('api.index') }}{{ url }}" type="text/css">{% endfor %}
<link href="{{ url_for('.static', filename='images/favicon.ico') }}" rel="icon" type="image/x-icon" /> <link href="{{ url_for('.static', filename='images/favicon.ico') }}" rel="icon" type="image/x-icon" />
<link rel="apple-touch-icon" href="{{ url_for('.static', filename='images/homescreen.png') }}" /> <link rel="apple-touch-icon" href="{{ url_for('.static', filename='images/homescreen.png') }}" />

Loading…
Cancel
Save